/* Report styles — used inline on the public page AND inside the PDF. */

.gyla-report {
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	color: #1d2327;
	line-height: 1.5;
	max-width: 900px;
	margin: 0 auto;
	padding: 24px;
}

.gyla-report__head {
	border-bottom: 1px solid #e5e7eb;
	padding-bottom: 24px;
	margin-bottom: 32px;
	text-align: center;
}

.gyla-report__brand {
	font-size: 20px;
	font-weight: 700;
	color: #111;
	margin-bottom: 12px;
}

.gyla-report__logo {
	max-height: 60px;
	margin-bottom: 12px;
}

.gyla-report h1 {
	font-size: 32px;
	margin: 0 0 8px;
}

.gyla-report__meta {
	color: #6b7280;
	font-size: 14px;
	margin: 0;
}

.gyla-overall {
	display: flex;
	gap: 16px;
	justify-content: center;
	margin-bottom: 32px;
	flex-wrap: wrap;
}

.gyla-overall__box {
	border: 1px solid #e5e7eb;
	border-radius: 12px;
	padding: 24px;
	text-align: center;
	min-width: 200px;
	background: #f9fafb;
}

.gyla-overall__box--a { border-color: #16a34a; background: #ecfdf5; }
.gyla-overall__box--b { border-color: #65a30d; background: #f7fee7; }
.gyla-overall__box--c { border-color: #ca8a04; background: #fefce8; }
.gyla-overall__box--d { border-color: #ea580c; background: #fff7ed; }
.gyla-overall__box--f { border-color: #dc2626; background: #fef2f2; }

.gyla-overall__score {
	font-size: 48px;
	font-weight: 800;
	line-height: 1;
}

.gyla-overall__grade {
	font-size: 24px;
	font-weight: 700;
	margin-top: 4px;
}

.gyla-overall__label {
	color: #6b7280;
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	margin-top: 6px;
}

.gyla-section {
	margin-bottom: 40px;
}

.gyla-section h2 {
	font-size: 22px;
	margin: 0 0 16px;
	border-bottom: 1px solid #e5e7eb;
	padding-bottom: 8px;
}

.gyla-section h3 {
	font-size: 16px;
	margin: 24px 0 8px;
}

.gyla-url {
	font-size: 14px;
	color: #6b7280;
	font-weight: 400;
	margin-left: 8px;
}

.gyla-findings {
	list-style: none;
	margin: 0;
	padding: 0;
}

.gyla-finding {
	border-left: 4px solid #d1d5db;
	background: #f9fafb;
	padding: 12px 16px;
	margin-bottom: 10px;
	border-radius: 0 6px 6px 0;
}

.gyla-finding--high   { border-left-color: #dc2626; background: #fef2f2; }
.gyla-finding--medium { border-left-color: #f59e0b; background: #fffbeb; }
.gyla-finding--low    { border-left-color: #2563eb; background: #eff6ff; }

.gyla-finding__tag {
	display: inline-block;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	padding: 2px 8px;
	border-radius: 4px;
	margin-right: 8px;
	background: #fff;
	border: 1px solid #d1d5db;
}

.gyla-finding__source {
	display: inline-block;
	font-size: 11px;
	color: #6b7280;
	margin-right: 8px;
}

.gyla-finding strong {
	display: inline;
}

.gyla-finding p {
	margin: 6px 0 0;
	color: #374151;
	font-size: 14px;
}

.gyla-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: 12px;
	margin-bottom: 16px;
}

.gyla-card {
	border: 1px solid #e5e7eb;
	border-radius: 8px;
	padding: 14px;
	background: #fff;
}

.gyla-card--a { border-color: #16a34a; }
.gyla-card--b { border-color: #65a30d; }
.gyla-card--c { border-color: #ca8a04; }
.gyla-card--d { border-color: #ea580c; }
.gyla-card--f { border-color: #dc2626; }

.gyla-card__head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 6px;
}

.gyla-card__label {
	font-size: 13px;
	color: #374151;
	font-weight: 600;
}

.gyla-card__grade {
	font-size: 18px;
	font-weight: 800;
}

.gyla-card__score {
	font-size: 20px;
	font-weight: 700;
}

.gyla-card__note {
	font-size: 12px;
	color: #9ca3af;
	margin-top: 4px;
}

.gyla-tags { display: flex; flex-wrap: wrap; gap: 6px; }

.gyla-tag {
	display: inline-block;
	padding: 4px 10px;
	border-radius: 16px;
	font-size: 12px;
	font-weight: 600;
	background: #f3f4f6;
	color: #6b7280;
}

.gyla-tag--yes { background: #dcfce7; color: #166534; }
.gyla-tag--no  { background: #fee2e2; color: #991b1b; }

.gyla-table {
	width: 100%;
	border-collapse: collapse;
	margin-top: 8px;
}

.gyla-table th, .gyla-table td {
	border: 1px solid #e5e7eb;
	padding: 8px 12px;
	text-align: left;
	font-size: 14px;
}

.gyla-table th {
	background: #f9fafb;
	width: 40%;
	font-weight: 600;
}

.gyla-themes { display: flex; flex-wrap: wrap; gap: 6px; }

.gyla-theme {
	display: inline-block;
	padding: 4px 10px;
	border-radius: 16px;
	font-size: 12px;
	background: #f3f4f6;
	color: #6b7280;
}

.gyla-theme--yes { background: #dbeafe; color: #1e40af; }

.gyla-psi {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
}

.gyla-psi__item {
	background: #f9fafb;
	border: 1px solid #e5e7eb;
	border-radius: 6px;
	padding: 10px 16px;
	min-width: 100px;
	text-align: center;
}

.gyla-psi__item span {
	display: block;
	color: #6b7280;
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.gyla-psi__item strong {
	font-size: 22px;
}

.gyla-fixplan__intro {
	color: #4b5563;
	font-size: 14px;
	margin-bottom: 18px;
}

.gyla-fixplan__week {
	border: 1px solid #e5e7eb;
	border-radius: 8px;
	padding: 16px 20px;
	margin-bottom: 14px;
	background: #fff;
}

.gyla-fixplan__week h3 {
	margin: 0 0 10px;
	font-size: 16px;
	color: #111;
	text-transform: none;
	letter-spacing: 0;
}

.gyla-fixplan__week ol {
	margin: 0;
	padding-left: 22px;
}

.gyla-fixplan__task {
	margin-bottom: 12px;
	padding-left: 4px;
}

.gyla-fixplan__task--high   { color: #991b1b; }
.gyla-fixplan__task--medium { color: #92400e; }
.gyla-fixplan__task--low    { color: #1e40af; }

.gyla-fixplan__task strong { color: #111; }
.gyla-fixplan__task p { color: #4b5563; font-size: 13px; margin: 4px 0 0; }

.gyla-fixplan__est {
	display: inline-block;
	font-size: 11px;
	font-weight: 700;
	background: #f3f4f6;
	color: #6b7280;
	padding: 2px 8px;
	border-radius: 999px;
	margin-right: 8px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.gyla-fixplan__ongoing {
	background: #f9fafb;
	border-left: 4px solid #f59e0b;
	border-radius: 0 8px 8px 0;
	padding: 16px 20px;
	margin-top: 14px;
}

.gyla-fixplan__ongoing h3 {
	margin: 0 0 8px;
	font-size: 15px;
}

.gyla-fixplan__ongoing ul { margin: 0; padding-left: 18px; }

.gyla-compare {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
	margin-bottom: 12px;
}

.gyla-compare th,
.gyla-compare td {
	border: 1px solid #e5e7eb;
	padding: 10px 12px;
	text-align: left;
}

.gyla-compare th { background: #f9fafb; font-weight: 600; }

.gyla-compare__row--target { background: #fef3c7; }
.gyla-compare__row--target td { font-weight: 700; }

.gyla-compare__you {
	display: inline-block;
	background: #f59e0b;
	color: #111827;
	font-size: 11px;
	font-weight: 700;
	padding: 1px 8px;
	border-radius: 999px;
	margin-left: 6px;
	letter-spacing: 0.05em;
}

.gyla-compare__gaps {
	background: #fef2f2;
	border-left: 4px solid #dc2626;
	padding: 12px 18px;
	margin: 0;
	border-radius: 0 6px 6px 0;
	color: #991b1b;
}

.gyla-compare__gaps li { margin: 4px 0; }

.gyla-progress {
	border-radius: 12px;
	padding: 18px 22px;
	margin-bottom: 28px;
}

.gyla-progress--up   { background: #ecfdf5; border: 1px solid #a7f3d0; color: #065f46; }
.gyla-progress--down { background: #fef2f2; border: 1px solid #fecaca; color: #7f1d1d; }
.gyla-progress--flat { background: #f9fafb; border: 1px solid #e5e7eb; color: #374151; }

.gyla-progress__head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 4px;
}

.gyla-progress__label {
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	opacity: 0.8;
}

.gyla-progress__delta { font-size: 24px; font-weight: 800; }
.gyla-progress__line   { font-weight: 600; margin: 4px 0; }
.gyla-progress__detail { font-size: 13px; opacity: 0.85; margin: 0; }

.gyla-cta {
	background: #111827;
	color: #fff;
	padding: 32px;
	border-radius: 12px;
	text-align: center;
	margin: 40px 0;
}

.gyla-cta h2 {
	color: #fff;
	border: none;
	margin-bottom: 12px;
}

.gyla-cta p {
	color: #d1d5db;
	margin-bottom: 20px;
}

.gyla-cta__btn {
	display: inline-block;
	background: #f59e0b;
	color: #111827;
	font-weight: 700;
	padding: 12px 28px;
	border-radius: 8px;
	text-decoration: none;
}

.gyla-report__foot {
	border-top: 1px solid #e5e7eb;
	margin-top: 40px;
	padding-top: 16px;
	text-align: center;
	color: #9ca3af;
	font-size: 12px;
}

/* PDF-specific tweaks. Dompdf has limited support — keep these conservative. */
.gyla-report--pdf .gyla-grid { display: block; }
.gyla-report--pdf .gyla-card { display: inline-block; width: 30%; vertical-align: top; }
.gyla-report--pdf .gyla-overall { display: block; text-align: center; }
.gyla-report--pdf .gyla-overall__box { display: inline-block; vertical-align: top; }
