/* Komodo National Park — Main CSS (deferred, non-critical).
   Covers below-the-fold: footer, inline CTA, FAQ accordion, archive, 404, components. */

/* Inline CTA */
.inline-cta {
	background: var(--c-primary);
	color: #fff;
	border-radius: var(--radius-lg);
	padding: var(--space-8) var(--space-5);
	text-align: center;
	margin: var(--space-10) auto;
	max-width: var(--max-w-reading);
}
.inline-cta h2 { color: #fff; margin-top: 0; }
.inline-cta p { color: rgba(255,255,255,0.92); }
.inline-cta__buttons {
	display: flex; gap: var(--space-3); justify-content: center; flex-wrap: wrap;
	margin: var(--space-5) 0 var(--space-3);
}
.inline-cta__buttons .btn--primary { background: #fff; color: var(--c-primary) !important; }
.inline-cta__buttons .btn--primary:hover { background: var(--c-surface-alt); }
.inline-cta__buttons .btn--secondary { color: #fff; border-color: rgba(255,255,255,0.4); }
.inline-cta__buttons .btn--secondary:hover { background: rgba(255,255,255,0.1); }
.inline-cta__hours { color: rgba(255,255,255,0.75); font-size: 0.85rem; margin: 0; }

/* FAQ accordion (uses native <details>) */
.faq details {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: var(--radius-sm);
	padding: var(--space-4);
	margin-bottom: var(--space-3);
}
.faq summary {
	font-weight: var(--fw-bold);
	font-size: var(--fs-lead);
	cursor: pointer;
	padding-right: var(--space-6);
	position: relative;
	list-style: none;
	color: var(--c-text);
}
.faq details p {
	font-size: var(--fs-body);
	line-height: var(--lh-relaxed);
	color: var(--c-text);
	margin: 0;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
	content: "+";
	position: absolute; right: 0; top: 50%; transform: translateY(-50%);
	font-size: 1.5rem; color: var(--c-primary);
}
.faq details[open] summary::after { content: "−"; }
.faq details > *:not(summary) { margin-top: var(--space-3); }

/* Footer */
.site-footer {
	background: var(--c-text);
	color: rgba(255,255,255,0.85);
	margin-top: var(--space-12);
	padding: var(--space-10) 0 var(--space-6);
}
.site-footer a { color: #fff; text-decoration: none; }
.site-footer a:hover { color: var(--c-sand); text-decoration: underline; }
/* Force underline on legal paragraph links (a11y: link-in-text-block) */
.site-footer p.footer-col__legal a,
.site-footer p.footer-col__desc a {
	text-decoration: underline !important;
	text-underline-offset: 2px;
}
.footer-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-8);
}
@media (min-width: 720px)  { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .footer-grid { grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--space-6); } }
@media (min-width: 1024px) { .footer-grid--5col { grid-template-columns: 1.6fr 1fr 1fr 1fr 1.2fr; gap: var(--space-5); } }
.footer-col__title {
	color: #fff; font-size: 1rem; font-weight: 700;
	margin: 0 0 var(--space-3); letter-spacing: 0.01em;
}
.footer-col__desc { font-size: 0.9rem; color: rgba(255,255,255,0.7); }
.footer-col__legal {
	font-size: 0.85rem;
	color: rgba(255,255,255,0.78); /* improved contrast for surrounding text */
	margin-top: var(--space-3);
}
.footer-col__list { list-style: none; padding: 0; margin: 0; }
.footer-col__list li { margin-bottom: var(--space-2); font-size: 0.9rem; }
.footer-bottom {
	margin-top: var(--space-8); padding-top: var(--space-5);
	border-top: 1px solid rgba(255,255,255,0.1);
	display: flex; flex-direction: column; gap: var(--space-2);
	font-size: 0.8rem; color: rgba(255,255,255,0.55);
}

/* Page content typography */
.page-content,
.post-content {
	font-size: var(--fs-lead);
	line-height: var(--lh-loose);
}
.page-content > p,
.post-content > p { margin-bottom: var(--space-5); }
.page-content blockquote,
.post-content blockquote {
	border-left: 4px solid var(--c-primary);
	padding: var(--space-3) var(--space-5);
	background: var(--c-surface-alt);
	margin: var(--space-5) 0;
	font-style: italic;
}
.page-content table th,
.post-content table th { background: var(--c-primary); color: #fff; }
.page-content table tbody tr:nth-child(even) td,
.post-content table tbody tr:nth-child(even) td { background: var(--c-surface-alt); }

/* Card grid (used in homepage) */
.card-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-4);
	margin: var(--space-5) 0;
}
@media (min-width: 600px)  { .card-grid--2 { grid-template-columns: 1fr 1fr; } }
@media (min-width: 720px)  { .card-grid--3 { grid-template-columns: 1fr 1fr 1fr; } }
@media (min-width: 960px)  { .card-grid--4 { grid-template-columns: repeat(4, 1fr); } }

.card {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: var(--radius-md);
	padding: var(--space-5);
	transition: transform 0.15s, box-shadow 0.15s;
}
.card:hover { transform: translateY(-2px); box-shadow: 0 4px 16px rgba(0,0,0,0.06); }
.card h3 { margin-top: 0; }
.card a.card__link { color: var(--c-primary); font-weight: 600; text-decoration: none; }
.card a.card__link:hover { text-decoration: underline; }

/* Archive */
.archive__title { margin-bottom: var(--space-6); }
.archive__list { list-style: none; padding: 0; }
.archive__item { border-bottom: 1px solid var(--c-border); padding: var(--space-5) 0; }
.archive__link { display: block; text-decoration: none; color: var(--c-text); }
.archive__post-title { color: var(--c-primary); margin: 0 0 var(--space-2); }
.archive__excerpt { color: var(--c-text); margin: 0 0 var(--space-2); }
.archive__date { color: var(--c-text-muted); }

/* 404 */
.error-404 { padding: var(--space-12) 0; text-align: center; }
.error-404 h1 { color: var(--c-primary); }
.error-404__links { display: flex; gap: var(--space-3); justify-content: center; flex-wrap: wrap; margin-top: var(--space-5); }

/* Pagination */
.pagination, .nav-links { display: flex; gap: var(--space-2); justify-content: center; margin: var(--space-6) 0; }
.pagination a, .pagination .current,
.nav-links a, .nav-links .current {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 40px; height: 40px; padding: 0 var(--space-3);
	border: 1px solid var(--c-border); border-radius: var(--radius-sm);
	text-decoration: none;
}
.pagination .current, .nav-links .current { background: var(--c-primary); color: #fff; border-color: var(--c-primary); }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { animation: none !important; transition: none !important; }
	html { scroll-behavior: auto; }
}

/* =====================================================
   HOMEPAGE — NatGeo-style Magazine Components
   ===================================================== */

/* Section header (shared) */
.section-header {
	max-width: 760px;
	margin: 0 auto var(--space-6);
	text-align: center;
}
.section-header__eyebrow {
	font-size: var(--fs-caption);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--c-primary-dark);
	font-weight: var(--fw-bold);
	margin: 0 0 var(--space-3);
}
.section-header__title {
	font-size: clamp(var(--fs-h2), 4vw, 2.25rem);
	margin: 0 0 var(--space-3);
	line-height: var(--lh-snug);
	letter-spacing: -0.02em;
	font-weight: var(--fw-bold);
}
.section-header__title--center { text-align: center; }
.section-header__sub {
	color: var(--c-text-muted);
	font-size: var(--fs-lead);
	line-height: var(--lh-relaxed);
	margin: 0;
}

/* ===== HERO ===== */
.hero {
	position: relative;
	color: #fff;
	padding: var(--space-12) 0 var(--space-10);
	overflow: hidden;
	isolation: isolate;
}
.hero__bg {
	position: absolute; inset: 0; z-index: -1;
}
.hero__bg-gradient {
	position: absolute; inset: 0;
	background:
		radial-gradient(1200px 600px at 20% 10%, rgba(230, 184, 0, 0.18), transparent 60%),
		radial-gradient(900px 600px at 85% 0%, rgba(230, 57, 70, 0.16), transparent 60%),
		linear-gradient(135deg, #0a5a59 0%, #0E7C7B 40%, #143F5E 100%);
}
.hero__bg-waves {
	position: absolute; left: 0; right: 0; bottom: 0; width: 100%; height: 220px;
}
.hero__inner {
	max-width: 900px;
}
.hero__eyebrow {
	display: inline-block;
	font-size: var(--fs-caption);
	letter-spacing: 0.18em;
	text-transform: uppercase;
	font-weight: var(--fw-bold);
	padding: var(--space-2) var(--space-3);
	background: rgba(255,255,255,0.12);
	border: 1px solid rgba(255,255,255,0.24);
	border-radius: 999px;
	margin: 0 0 var(--space-5);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}
.hero__title {
	font-size: clamp(var(--fs-display), 8vw, 3.75rem);
	line-height: var(--lh-tight);
	letter-spacing: -0.024em;
	font-weight: var(--fw-black);
	margin: 0 0 var(--space-5);
	color: #fff;
}
.hero__title-accent {
	display: block;
	font-size: clamp(var(--fs-h3), 3vw, 1.625rem);
	font-weight: var(--fw-regular);
	letter-spacing: -0.005em;
	color: #FFE08C;
	margin-top: var(--space-3);
	line-height: var(--lh-snug);
}
.hero__sub {
	font-size: var(--fs-lead);
	line-height: var(--lh-relaxed);
	color: rgba(255,255,255,0.92);
	max-width: 720px;
	margin: 0 0 var(--space-6);
}
.hero__sub strong { color: #fff; }
.hero__ctas {
	display: flex; flex-wrap: wrap; gap: var(--space-3);
	margin-bottom: var(--space-6);
}
.btn--hero-primary {
	background: #fff;
	color: #0a5a59 !important;
	padding: 0 var(--space-6);
	font-size: 1.0625rem;
	font-weight: 700;
	box-shadow: 0 6px 20px rgba(0,0,0,0.18);
	gap: var(--space-2);
	border: 0;
}

/* CLS guards — reserve space to prevent shift as content loads */
.hero { min-height: 540px; contain: layout style; }
@media (min-width: 768px) { .hero { min-height: 580px; } }

.product-card { min-height: 420px; contain: layout style; }
@media (min-width: 720px) { .product-card { min-height: 440px; } }

.journey, .carousel-section, .stats, .featured, .news, .faq, .final-cta {
	contain: layout style;
}

.news__link { min-height: 200px; }
.featured__card { min-height: 220px; }
.stats__item { min-height: 180px; }
.journey__step { min-height: 240px; }
.btn--hero-primary:hover { background: #FFE08C; transform: translateY(-1px); }
.btn--hero-wa {
	background: #075E54; /* WhatsApp dark — 6.36:1 on white, passes WCAG AAA */
	color: #fff !important;
	padding: 0 var(--space-5);
	font-size: 1rem;
	font-weight: 700;
	gap: var(--space-2);
	box-shadow: 0 6px 20px rgba(7, 94, 84, 0.4);
}
.btn--hero-wa:hover { background: #054a42; transform: translateY(-1px); }
.btn--ghost {
	background: transparent;
	color: #fff !important;
	border: 1.5px solid rgba(255,255,255,0.7);
}
.btn--ghost:hover { background: rgba(255,255,255,0.12); }
.btn--lg { min-height: 56px; padding: 0 var(--space-6); font-size: 1.0625rem; }

.hero__trust {
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-wrap: wrap; gap: var(--space-2) var(--space-5);
	font-size: var(--fs-meta);
	color: rgba(255,255,255,0.9);
}
.hero__trust li {
	display: flex; align-items: center; gap: var(--space-2);
	margin-bottom: 0;
	padding-right: var(--space-4);
	border-right: 1px solid rgba(255,255,255,0.18);
}
.hero__trust li:last-child { border-right: 0; padding-right: 0; }
.hero__trust strong { color: #FFE08C; font-weight: 800; }

.hero__disclosure {
	background: rgba(0, 0, 0, 0.55);
	color: rgba(255,255,255,0.92);
	font-size: var(--fs-meta);
	padding: var(--space-3) 0;
	margin-top: var(--space-8);
	border-top: 1px solid rgba(255,255,255,0.1);
	border-bottom: 1px solid rgba(255,255,255,0.1);
	text-align: center;
}
.hero__disclosure a { color: #FFE08C; }
@media (min-width: 768px) {
	.hero__disclosure { font-size: 0.9rem; padding: var(--space-3) var(--space-6); }
}

/* ===== TEAM AUTHORITY — E-E-A-T signal block ===== */
.team-authority {
	padding: var(--space-12) 0;
	background: var(--c-surface);
	border-top: 1px solid var(--c-border);
}
.team-authority__grid {
	list-style: none; padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-4);
	margin: var(--space-6) 0;
}
@media (min-width: 720px) { .team-authority__grid { grid-template-columns: 1fr 1fr 1fr; } }
.team-authority__person {
	display: flex;
	gap: var(--space-4);
	align-items: flex-start;
	background: var(--c-surface-alt);
	padding: var(--space-4);
	border-radius: var(--radius-md);
	margin: 0;
}
.team-authority__avatar {
	width: 56px; height: 56px;
	flex-shrink: 0;
	border-radius: 50%;
	display: flex;
	align-items: center; justify-content: center;
	color: #fff;
	font-weight: var(--fw-black);
	font-size: var(--fs-h3);
	font-family: var(--font-serif);
}
.team-authority__meta { flex: 1; min-width: 0; }
.team-authority__name {
	margin: 0 0 2px;
	font-size: var(--fs-h4);
	color: var(--c-text);
	font-weight: var(--fw-bold);
}
.team-authority__role {
	margin: 0 0 var(--space-2);
	font-size: var(--fs-meta);
	color: var(--c-primary-dark);
	font-weight: var(--fw-bold);
}
.team-authority__years {
	margin: 0 0 var(--space-2);
	font-size: var(--fs-caption);
	color: var(--c-text-muted);
	font-weight: var(--fw-bold);
	letter-spacing: 0.04em;
	text-transform: uppercase;
}
.team-authority__detail {
	margin: 0;
	font-size: var(--fs-meta);
	color: var(--c-text);
	line-height: var(--lh-relaxed);
}
.team-authority__credentials {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-2) var(--space-4);
	margin: var(--space-6) 0 0;
	padding: var(--space-5);
	background: var(--c-primary-tint);
	border-radius: var(--radius-md);
	border-left: 4px solid var(--c-primary);
}
@media (min-width: 768px) {
	.team-authority__credentials { grid-template-columns: repeat(3, 1fr); gap: var(--space-3) var(--space-5); }
}
.team-authority__credentials > div { margin: 0; padding: 0; display: flex; flex-direction: column; gap: 2px; }
.team-authority__credentials dt {
	font-size: var(--fs-caption);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--c-text-muted);
	font-weight: var(--fw-bold);
	margin: 0;
}
.team-authority__credentials dd {
	font-size: var(--fs-meta);
	color: var(--c-text);
	font-weight: var(--fw-bold);
	margin: 0;
}

/* ===== CUSTOMER JOURNEY ===== */
.journey {
	padding: var(--space-12) 0;
	background: var(--c-surface-alt);
}
.journey__steps {
	list-style: none; padding: 0; margin: 0;
	display: grid;
	gap: var(--space-5);
	grid-template-columns: 1fr;
}
@media (min-width: 900px) {
	.journey__steps { grid-template-columns: 1fr 1fr 1fr; gap: var(--space-4); }
}
.journey__step {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: var(--radius-lg);
	padding: var(--space-6);
	position: relative;
	transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
	margin-bottom: 0;
}
.journey__step:hover {
	transform: translateY(-4px);
	box-shadow: 0 10px 30px rgba(0,0,0,0.08);
	border-color: var(--c-primary);
}
.journey__step--final {
	background: linear-gradient(135deg, #0E7C7B 0%, #143F5E 100%);
	border-color: #0a5a59;
	color: #fff;
}
.journey__step--final .journey__step-title { color: #fff; }
.journey__step--final p { color: rgba(255,255,255,0.92); }
.journey__step--final .journey__link { color: #FFE08C; }
.journey__step--final .journey__num { background: #FFE08C; color: #0a5a59; }
.journey__num {
	width: 52px; height: 52px;
	border-radius: 50%;
	background: var(--c-primary);
	color: #fff;
	display: inline-flex; align-items: center; justify-content: center;
	font-weight: var(--fw-black); font-size: 1.4rem;
	margin-bottom: var(--space-3);
	font-family: var(--font-serif);
}
.journey__step-title {
	margin: 0 0 var(--space-3);
	font-size: var(--fs-h3);
	line-height: var(--lh-snug);
	font-weight: var(--fw-bold);
}
.journey__step p {
	color: var(--c-text-muted);
	margin: 0 0 var(--space-3);
	font-size: var(--fs-body);
	line-height: var(--lh-relaxed);
}
.journey__step em { color: var(--c-primary); font-style: normal; font-weight: 600; }
.journey__step--final em { color: #FFE08C; font-style: normal; font-weight: 600; }
.journey__link {
	color: var(--c-primary);
	font-weight: var(--fw-bold);
	text-decoration: underline;
	text-underline-offset: 4px;
	font-size: var(--fs-meta);
}
.journey__link--primary {
	display: inline-block;
	padding: var(--space-3) var(--space-4);
	background: #FFE08C;
	color: #0a5a59 !important;
	border-radius: var(--radius-sm);
	text-decoration: none;
	font-weight: 700;
	margin-top: var(--space-2);
}
.journey__link--primary:hover { background: #fff; }

/* ===== PRODUCT CAROUSEL ===== */
.carousel-section {
	padding: var(--space-12) 0;
	background: var(--c-surface-alt);
}
.carousel {
	position: relative;
}
.carousel__track {
	display: flex;
	gap: var(--space-4);
	overflow-x: auto;
	overflow-y: hidden;
	scroll-snap-type: x mandatory;
	scrollbar-width: thin;
	scrollbar-color: var(--c-primary) transparent;
	padding: var(--space-3) 0 var(--space-5);
	-webkit-overflow-scrolling: touch;
	scroll-behavior: smooth;
}
.carousel__track::-webkit-scrollbar { height: 8px; }
.carousel__track::-webkit-scrollbar-track { background: rgba(0,0,0,0.05); border-radius: 4px; }
.carousel__track::-webkit-scrollbar-thumb { background: var(--c-primary); border-radius: 4px; }

.product-card {
	flex: 0 0 280px;
	max-width: 280px;
	min-height: 380px;
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: var(--radius-lg);
	overflow: hidden;
	scroll-snap-align: start;
	transition: transform 0.2s, box-shadow 0.2s;
	display: flex;
	flex-direction: column;
}
@media (min-width: 720px) {
	.product-card { flex: 0 0 320px; max-width: 320px; }
}
.product-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 14px 36px rgba(0,0,0,0.12);
}
.product-card__link {
	display: flex; flex-direction: column;
	color: var(--c-text);
	text-decoration: none;
	height: 100%;
}
.product-card__media {
	height: 140px;
	background: var(--card-gradient, linear-gradient(135deg,#0E7C7B,#143F5E));
	display: flex; align-items: center; justify-content: center;
	position: relative;
	color: rgba(255,255,255,0.96);
}
.product-card__icon {
	width: 64px; height: 64px;
}
.product-card__icon svg { width: 100%; height: 100%; }
.product-card__badge {
	position: absolute;
	top: var(--space-3); right: var(--space-3);
	background: rgba(255,255,255,0.96);
	color: var(--c-primary-dark);
	font-size: var(--fs-caption);
	font-weight: var(--fw-black);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	padding: var(--space-2) var(--space-3);
	border-radius: 999px;
}
.product-card__body {
	padding: var(--space-4);
	display: flex; flex-direction: column;
	flex: 1;
}
.product-card__title {
	font-size: var(--fs-h4);
	margin: 0 0 var(--space-2);
	color: var(--c-text);
	line-height: var(--lh-snug);
	font-weight: var(--fw-bold);
}
.product-card__hook {
	color: var(--c-text-muted);
	font-size: var(--fs-meta);
	line-height: var(--lh-relaxed);
	margin: 0 0 var(--space-3);
	flex: 1;
}
.product-card__meta {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-2);
	margin: 0 0 var(--space-3);
	padding: var(--space-3) 0;
	border-top: 1px solid var(--c-border);
	border-bottom: 1px solid var(--c-border);
}
.product-card__meta div { display: flex; flex-direction: column; gap: 2px; }
.product-card__meta dt {
	font-size: var(--fs-caption);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--c-text-muted);
	font-weight: var(--fw-bold);
	margin: 0;
}
.product-card__meta dd {
	margin: 0;
	font-size: var(--fs-meta);
	color: var(--c-text);
	font-weight: var(--fw-bold);
}
.product-card__cta {
	color: var(--c-primary);
	font-weight: var(--fw-bold);
	font-size: var(--fs-meta);
	margin-top: auto;
}

.carousel__controls {
	display: flex; gap: var(--space-2);
	justify-content: center;
	margin-top: var(--space-2);
}
.carousel__btn {
	width: 44px; height: 44px;
	border-radius: 50%;
	background: var(--c-primary);
	color: #fff;
	border: 0;
	display: inline-flex; align-items: center; justify-content: center;
	transition: background 0.15s, transform 0.05s;
}
.carousel__btn:hover { background: var(--c-primary-dark); }
.carousel__btn:active { transform: scale(0.95); }
.carousel__btn:disabled { background: var(--c-border); cursor: not-allowed; opacity: 0.5; }

@media (min-width: 1024px) {
	.carousel__controls { justify-content: flex-end; }
}

.carousel-section__footer {
	text-align: center;
	margin-top: var(--space-5);
	color: var(--c-text-muted);
	font-size: var(--fs-body);
}
.carousel-section__footer a {
	font-weight: var(--fw-bold);
	color: var(--c-primary-dark);
}

/* ===== STATS STRIP ===== */
.stats {
	padding: var(--space-12) 0;
	background: var(--c-surface);
	border-top: 1px solid var(--c-border);
	border-bottom: 1px solid var(--c-border);
}
.stats__grid {
	margin: var(--space-6) 0 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr 1fr; /* 2x2 on mobile for compact scroll */
	gap: var(--space-3);
}
@media (min-width: 600px)  { .stats__grid { gap: var(--space-4); } }
@media (min-width: 960px)  { .stats__grid { grid-template-columns: repeat(4, 1fr); gap: var(--space-4); } }
.stats__item {
	text-align: center;
	padding: var(--space-4) var(--space-3);
	background: var(--c-surface-alt);
	border-radius: var(--radius-lg);
	min-height: 0;
}
@media (min-width: 600px)  { .stats__item { padding: var(--space-5) var(--space-4); } }
.stats__label {
	display: block;
	font-size: var(--fs-caption);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--c-text-muted);
	font-weight: var(--fw-bold);
	margin: 0 0 var(--space-2);
}
.stats__value {
	display: block;
	font-size: clamp(var(--fs-stat), 5vw, 2.5rem);
	font-weight: var(--fw-black);
	color: var(--c-primary-dark);
	margin: 0 0 var(--space-2);
	font-family: var(--font-serif);
	letter-spacing: -0.02em;
	line-height: var(--lh-tight);
}
.stats__unit {
	display: block;
	font-size: var(--fs-meta);
	color: var(--c-text-muted);
	font-weight: var(--fw-regular);
	font-family: var(--font-sans);
	letter-spacing: 0;
	margin-top: 4px;
}
.stats__note {
	font-size: var(--fs-meta);
	color: var(--c-text-muted);
	margin: 0;
	line-height: var(--lh-relaxed);
}

/* ===== FEATURED ARTICLES ===== */
.featured {
	padding: var(--space-12) 0;
	background: var(--c-surface-alt);
}
/* Mobile: horizontal swipe scroll; Desktop: grid */
.featured__grid {
	display: flex;
	gap: var(--space-3);
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	padding-bottom: var(--space-3);
	scrollbar-width: thin;
	scrollbar-color: var(--c-primary) transparent;
}
.featured__grid::-webkit-scrollbar { height: 6px; }
.featured__grid::-webkit-scrollbar-thumb { background: var(--c-primary); border-radius: 3px; }
@media (min-width: 600px) {
	.featured__grid {
		display: grid;
		grid-template-columns: 1fr 1fr;
		overflow: visible;
		gap: var(--space-4);
		padding-bottom: 0;
	}
}
@media (min-width: 1024px) { .featured__grid { grid-template-columns: repeat(5, 1fr); gap: var(--space-3); } }
.featured__card {
	display: flex; flex-direction: column;
	padding: var(--space-5);
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: var(--radius-md);
	color: var(--c-text);
	text-decoration: none;
	transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
	flex: 0 0 78%;
	scroll-snap-align: start;
	min-height: 0;
}
@media (min-width: 600px) {
	.featured__card { flex: 1 1 auto; }
}
.featured__card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 28px rgba(0,0,0,0.08);
	border-color: var(--c-primary);
	color: var(--c-text);
}
.featured__icon {
	width: 40px; height: 40px;
	color: var(--c-primary);
	margin-bottom: var(--space-3);
}
.featured__icon svg { width: 100%; height: 100%; }
.featured__title {
	font-size: var(--fs-h4);
	margin: 0 0 var(--space-2);
	color: var(--c-text);
	line-height: var(--lh-snug);
	font-weight: var(--fw-bold);
}
.featured__desc {
	font-size: var(--fs-meta);
	color: var(--c-text-muted);
	margin: 0 0 var(--space-3);
	flex: 1;
	line-height: var(--lh-relaxed);
}
.featured__meta {
	font-size: var(--fs-meta);
	font-weight: var(--fw-bold);
	color: var(--c-primary-dark);
}

/* ===== NEWS GRID ===== */
.news {
	padding: var(--space-12) 0;
	background: var(--c-surface);
}
.news__grid {
	list-style: none; padding: 0; margin: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-4);
}
@media (min-width: 720px) { .news__grid { grid-template-columns: 1fr 1fr 1fr; } }
.news__item { margin-bottom: 0; }
.news__link {
	display: block;
	padding: var(--space-5);
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: var(--radius-md);
	color: var(--c-text);
	text-decoration: none;
	height: 100%;
	transition: transform 0.2s, box-shadow 0.2s;
}
.news__link:hover {
	transform: translateY(-3px);
	box-shadow: 0 10px 24px rgba(0,0,0,0.06);
	color: var(--c-text);
}
.news__date {
	font-size: var(--fs-caption);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--c-text-muted);
	font-weight: var(--fw-bold);
}
.news__title {
	font-size: var(--fs-h4);
	line-height: var(--lh-snug);
	margin: var(--space-2) 0 var(--space-2);
	color: var(--c-text);
	font-weight: var(--fw-bold);
}
.news__excerpt {
	font-size: var(--fs-meta);
	color: var(--c-text-muted);
	line-height: var(--lh-relaxed);
	margin: 0 0 var(--space-3);
}
.news__cta {
	color: var(--c-primary-dark);
	font-weight: var(--fw-bold);
	font-size: var(--fs-meta);
}
.news__viewall {
	text-align: center;
	margin-top: var(--space-6);
}

/* ===== HOMEPAGE FAQ ===== */
.faq {
	padding: var(--space-12) 0;
	background: var(--c-surface-alt);
}
.faq__list { margin: var(--space-5) 0; }
.faq details { background: var(--c-surface); border-radius: var(--radius-md); }
.faq details[open] { box-shadow: 0 4px 14px rgba(0,0,0,0.06); }
.faq__more { text-align: center; margin-top: var(--space-5); }

/* ===== FINAL CTA ===== */
.final-cta {
	padding: var(--space-12) 0;
	background: linear-gradient(135deg, #143F5E 0%, #0a5a59 50%, #0E7C7B 100%);
	color: #fff;
	text-align: center;
}
.final-cta__inner { max-width: 760px; margin: 0 auto; }
.final-cta h2 {
	color: #fff;
	font-size: clamp(var(--fs-h2), 4vw, 2.25rem);
	margin: 0 0 var(--space-4);
	line-height: var(--lh-snug);
	letter-spacing: -0.02em;
}
.final-cta p {
	color: rgba(255,255,255,0.92);
	font-size: var(--fs-lead);
	line-height: var(--lh-relaxed);
}
.final-cta__buttons {
	display: flex; gap: var(--space-3); justify-content: center; flex-wrap: wrap;
	margin: var(--space-6) 0 var(--space-4);
}
.final-cta__small {
	font-size: var(--fs-meta);
	color: rgba(255,255,255,0.7);
	margin: 0;
}

/* ===== COMPARE TABLE — DIY vs Operator ===== */
.compare {
	padding: var(--space-12) 0;
	background: var(--c-surface);
}
/* Mobile tabs */
.compare__tabs {
	display: flex;
	gap: var(--space-2);
	margin: var(--space-5) auto 0;
	max-width: 480px;
	background: var(--c-surface-alt);
	padding: var(--space-1);
	border-radius: var(--radius-md);
	border: 1px solid var(--c-border);
}
.compare__tab {
	flex: 1;
	min-height: 44px;
	padding: var(--space-2) var(--space-3);
	background: transparent;
	border: 0;
	border-radius: var(--radius-sm);
	font-size: var(--fs-meta);
	font-weight: var(--fw-bold);
	color: var(--c-text-muted);
	cursor: pointer;
	transition: background 0.15s, color 0.15s;
}
.compare__tab.is-active {
	background: var(--c-primary);
	color: #fff;
}
.compare__tab:hover:not(.is-active) {
	background: rgba(0,0,0,0.04);
}
@media (min-width: 900px) {
	.compare__tabs { display: none; }
}

.compare__grid {
	display: block;
	margin-top: var(--space-4);
}
@media (min-width: 900px) {
	.compare__grid {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: var(--space-5);
		margin-top: var(--space-6);
	}
}

/* Mobile: only show active pane */
.compare__col[data-compare-pane] { display: none; }
.compare__col[data-compare-pane].is-active { display: flex; }
@media (min-width: 900px) {
	.compare__col[data-compare-pane] { display: flex; }
}
.compare__col {
	background: var(--c-surface-alt);
	border: 1px solid var(--c-border);
	border-radius: var(--radius-lg);
	padding: var(--space-5);
	flex-direction: column;
}
@media (min-width: 900px) {
	.compare__col { padding: var(--space-6); }
}
.compare__col--operator {
	background: linear-gradient(180deg, var(--c-primary-tint) 0%, var(--c-surface) 100%);
	border-color: var(--c-primary);
	box-shadow: 0 12px 32px rgba(14, 124, 123, 0.12);
	position: relative;
}
.compare__col--operator::before {
	content: "Recommended for most foreign tourists";
	position: absolute;
	top: -14px; left: 50%; transform: translateX(-50%);
	background: var(--c-primary-dark);
	color: #fff;
	padding: 4px 14px;
	border-radius: 999px;
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	white-space: nowrap;
	box-shadow: 0 4px 12px rgba(10, 90, 89, 0.3);
}
.compare__col-head { margin-bottom: var(--space-4); }
.compare__col-tag {
	display: inline-block;
	font-size: var(--fs-caption);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--c-text-muted);
	font-weight: var(--fw-bold);
	margin-bottom: var(--space-2);
}
.compare__col-tag--recommended { display: none; }
.compare__col-title {
	font-size: var(--fs-h3);
	margin: 0 0 var(--space-2);
	color: var(--c-text);
	line-height: var(--lh-snug);
	font-weight: var(--fw-bold);
}
.compare__col-sub {
	color: var(--c-text-muted);
	margin: 0;
	font-size: var(--fs-body);
	line-height: var(--lh-relaxed);
}
.compare__rows {
	margin: 0; padding: 0;
	border-top: 1px solid var(--c-border);
	flex: 1;
}
.compare__row {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2px;
	padding: var(--space-3) 0;
	border-bottom: 1px solid var(--c-border);
}
@media (min-width: 480px) {
	.compare__row { grid-template-columns: 1fr 1.6fr; gap: var(--space-3); }
}
.compare__row dt {
	font-size: var(--fs-caption);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--c-text-muted);
	font-weight: var(--fw-bold);
	margin: 0;
}
.compare__row dd {
	margin: 0;
	color: var(--c-text);
	font-size: var(--fs-meta);
	line-height: var(--lh-relaxed);
}
.compare__good, .compare__bad, .compare__warn {
	display: inline-flex;
	align-items: center; justify-content: center;
	width: 18px; height: 18px;
	border-radius: 50%;
	font-size: 0.8rem;
	font-weight: 700;
	margin-right: 6px;
	vertical-align: middle;
}
.compare__good { background: var(--c-good); color: #fff; }
.compare__bad  { background: var(--c-bad);  color: #fff; }
.compare__warn { background: var(--c-warn); color: #fff; }
.compare__col-foot {
	margin-top: var(--space-4);
	padding-top: var(--space-4);
	border-top: 1px solid var(--c-border);
}
.compare__verdict {
	font-size: var(--fs-meta);
	color: var(--c-text-muted);
	margin: 0 0 var(--space-4);
	line-height: var(--lh-relaxed);
	font-style: italic;
}
.btn--block {
	display: flex;
	width: 100%;
	text-align: center;
}

/* ===== TESTIMONIALS ===== */
.testimonials {
	padding: var(--space-12) 0;
	background: var(--c-surface-cool);
}
/* Mobile: horizontal swipe scroll; Desktop: grid */
.testimonials__grid {
	list-style: none; padding: 0 0 var(--space-3); margin: var(--space-6) 0 var(--space-5);
	display: flex;
	gap: var(--space-3);
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
	scrollbar-color: var(--c-primary) transparent;
}
.testimonials__grid::-webkit-scrollbar { height: 6px; }
.testimonials__grid::-webkit-scrollbar-thumb { background: var(--c-primary); border-radius: 3px; }
@media (min-width: 768px)  {
	.testimonials__grid {
		display: grid;
		grid-template-columns: 1fr 1fr;
		overflow: visible; padding-bottom: 0;
	}
}
@media (min-width: 1024px) { .testimonials__grid { grid-template-columns: 1fr 1fr 1fr; gap: var(--space-5); } }
.testimonial {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: var(--radius-lg);
	padding: var(--space-5);
	display: flex; flex-direction: column;
	margin-bottom: 0;
	transition: transform 0.2s, box-shadow 0.2s;
	min-height: 0;
	flex: 0 0 82%;
	scroll-snap-align: start;
}
@media (min-width: 768px) { .testimonial { flex: 1 1 auto; min-height: 260px; } }
.testimonial:hover { transform: translateY(-3px); box-shadow: 0 10px 28px rgba(0,0,0,0.08); }
.testimonial__rating {
	display: flex; gap: 2px;
	margin-bottom: var(--space-3);
}
.testimonial__quote {
	margin: 0 0 var(--space-4);
	flex: 1;
	font-size: var(--fs-body);
	line-height: var(--lh-relaxed);
	color: var(--c-text);
}
.testimonial__quote p { margin: 0; font-style: italic; }
.testimonial__author {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	padding-top: var(--space-3);
	border-top: 1px solid var(--c-border);
}
.testimonial__avatar {
	width: 48px; height: 48px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center; justify-content: center;
	color: #fff;
	font-weight: 800;
	font-size: 1.2rem;
	flex-shrink: 0;
}
.testimonial__meta { flex: 1; }
.testimonial__name {
	font-weight: var(--fw-bold);
	color: var(--c-text);
	margin: 0;
	font-size: var(--fs-meta);
	line-height: var(--lh-snug);
}
.testimonial__trip {
	color: var(--c-text-muted);
	margin: 0;
	font-size: var(--fs-caption);
}
.testimonials__note {
	text-align: center;
	color: var(--c-text-muted);
	font-size: var(--fs-meta);
	margin: var(--space-4) 0 0;
	font-style: italic;
}

/* ===== SEASONAL BANNER ===== */
.seasonal {
	background: linear-gradient(135deg, #FFE08C 0%, #E6B800 100%);
	padding: var(--space-4) 0;
	color: #1A1A1A;
}
.seasonal__inner {
	display: flex; flex-wrap: wrap; align-items: center;
	gap: var(--space-3);
}
.seasonal__icon {
	font-size: 2rem;
	flex-shrink: 0;
}
.seasonal__text { flex: 1; min-width: 220px; }
.seasonal__tag {
	display: inline-block;
	font-size: var(--fs-caption);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	font-weight: var(--fw-black);
	background: #1A1A1A;
	color: #FFE08C;
	padding: 2px 8px;
	border-radius: 4px;
	margin-bottom: 4px;
}
.seasonal__title {
	margin: 0;
	font-size: var(--fs-h4);
	font-weight: var(--fw-bold);
	color: #1A1A1A;
	line-height: var(--lh-snug);
}
.seasonal__body {
	margin: 4px 0 0;
	font-size: var(--fs-meta);
	color: #1A1A1A;
	line-height: var(--lh-relaxed);
}
.seasonal__cta {
	background: #1A1A1A;
	color: #FFE08C !important;
	padding: var(--space-3) var(--space-4);
	border-radius: var(--radius-md);
	font-weight: var(--fw-bold);
	text-decoration: none;
	font-size: var(--fs-meta);
	white-space: nowrap;
}
.seasonal__cta:hover { background: #0a0a0a; color: #fff !important; }

/* ===== QUICK-START WIZARD ===== */
.quickstart {
	padding: var(--space-12) 0;
	background: var(--c-surface-cool);
}
.quickstart__head {
	text-align: center;
	margin-bottom: var(--space-6);
}
.quickstart__eyebrow {
	font-size: var(--fs-caption);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--c-primary-dark);
	font-weight: var(--fw-bold);
	margin: 0 0 var(--space-2);
}
.quickstart__title {
	font-size: clamp(var(--fs-h2), 4vw, 2.25rem);
	margin: 0 0 var(--space-2);
	color: var(--c-text);
}
.quickstart__sub {
	color: var(--c-text-muted);
	font-size: var(--fs-lead);
	margin: 0;
}
.quickstart__form {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: var(--radius-lg);
	padding: var(--space-5);
	box-shadow: 0 12px 28px rgba(0,0,0,0.05);
}
.quickstart__field {
	border: 0; padding: 0; margin: 0 0 var(--space-5);
}
.quickstart__field:last-of-type { margin-bottom: var(--space-3); }
.quickstart__field legend {
	font-size: var(--fs-meta);
	font-weight: var(--fw-bold);
	color: var(--c-text);
	margin-bottom: var(--space-3);
	letter-spacing: 0.02em;
}
.quickstart__chips {
	display: flex; flex-wrap: wrap;
	gap: var(--space-2);
}
.quickstart__chip {
	cursor: pointer;
	margin-bottom: 0;
}
.quickstart__chip input { position: absolute; opacity: 0; pointer-events: none; }
.quickstart__chip span {
	display: inline-block;
	padding: 10px 14px;
	background: var(--c-surface);
	border: 2px solid var(--c-border);
	border-radius: 999px;
	font-size: var(--fs-meta);
	font-weight: var(--fw-bold);
	color: var(--c-text);
	transition: border-color 0.15s, background 0.15s, color 0.15s;
}
.quickstart__chip:hover span {
	border-color: var(--c-primary);
}
.quickstart__chip input:checked + span {
	background: var(--c-primary-dark);
	color: #fff;
	border-color: var(--c-primary-dark);
}
.quickstart__result {
	margin-top: var(--space-5);
	padding: var(--space-5);
	background: linear-gradient(135deg, var(--c-primary-tint) 0%, var(--c-surface) 100%);
	border-left: 4px solid var(--c-primary-dark);
	border-radius: var(--radius-md);
}
.quickstart__verdict-label {
	font-size: var(--fs-caption);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-weight: var(--fw-bold);
	color: var(--c-primary-dark);
	margin: 0 0 var(--space-2);
}
.quickstart__verdict {
	font-size: var(--fs-h3);
	color: var(--c-text);
	margin: 0 0 var(--space-2);
	line-height: var(--lh-snug);
}
.quickstart__verdict-detail {
	color: var(--c-text-muted);
	margin: 0 0 var(--space-4);
	font-size: var(--fs-meta);
	line-height: var(--lh-relaxed);
}
.quickstart__actions { margin-top: var(--space-4); }

/* ===== BOOKING TIMELINE ===== */
.timeline {
	padding: var(--space-12) 0;
	background: var(--c-surface);
}
.timeline__list {
	list-style: none; padding: 0; margin: var(--space-5) 0 0;
}
.timeline__row {
	display: grid;
	grid-template-columns: 80px 1fr;
	gap: var(--space-2) var(--space-3);
	padding: var(--space-3) var(--space-4);
	border-radius: var(--radius-md);
	margin-bottom: var(--space-2);
	background: var(--c-surface-alt);
	align-items: center;
}
@media (min-width: 600px) {
	.timeline__row { grid-template-columns: 80px 1.4fr 1fr; }
}
.timeline__row--ok { border-left: 4px solid var(--c-good, #15803d); }
.timeline__row--warn { border-left: 4px solid var(--c-warn, #B45309); }
.timeline__row--bad { border-left: 4px solid var(--c-bad, #B91C1C); }
.timeline__lead {
	font-family: var(--font-serif);
	font-weight: var(--fw-black);
	font-size: var(--fs-h3);
	color: var(--c-primary-dark);
	letter-spacing: -0.02em;
}
.timeline__when {
	font-weight: var(--fw-bold);
	color: var(--c-text);
	font-size: var(--fs-body);
	grid-column: 2;
}
@media (min-width: 600px) { .timeline__when { grid-column: 2 / 3; } }
.timeline__risk {
	font-size: var(--fs-meta);
	color: var(--c-text-muted);
	grid-column: 2;
}
@media (min-width: 600px) { .timeline__risk { grid-column: 3; text-align: right; } }
.timeline__note {
	margin: var(--space-5) 0 0;
	padding: var(--space-4);
	background: var(--c-primary-tint);
	border-radius: var(--radius-md);
	font-size: var(--fs-meta);
	color: var(--c-text);
	text-align: center;
}

/* ===== RELATED GUIDES (inner pages) ===== */
.related-guides {
	margin: var(--space-10) 0 var(--space-6);
	padding: var(--space-5);
	background: var(--c-surface-cool);
	border-radius: var(--radius-lg);
	border-left: 4px solid var(--c-primary);
}
.related-guides__title {
	font-size: var(--fs-h4);
	color: var(--c-text);
	margin: 0 0 var(--space-4);
	font-weight: var(--fw-bold);
}
.related-guides__list {
	list-style: none; padding: 0; margin: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-3);
}
@media (min-width: 600px) { .related-guides__list { grid-template-columns: 1fr 1fr; } }
.related-guides__item { margin: 0; }
.related-guides__link {
	display: block;
	padding: var(--space-3) var(--space-4);
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: var(--radius-md);
	color: var(--c-text);
	text-decoration: none;
	transition: border-color 0.15s, transform 0.05s, box-shadow 0.15s;
}
.related-guides__link:hover {
	border-color: var(--c-primary);
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(0,0,0,0.06);
	color: var(--c-text);
}
.related-guides__t {
	display: block;
	font-weight: var(--fw-bold);
	color: var(--c-text);
	font-size: var(--fs-body);
	margin-bottom: 4px;
	line-height: var(--lh-snug);
}
.related-guides__d {
	display: block;
	font-size: var(--fs-meta);
	color: var(--c-text-muted);
	line-height: var(--lh-relaxed);
	margin-bottom: var(--space-2);
}
.related-guides__cta {
	display: inline-block;
	font-size: var(--fs-meta);
	font-weight: var(--fw-bold);
	color: var(--c-primary-dark);
}

/* ===== TRUST STRIP — payment + security ===== */
.trust-strip {
	background: var(--c-surface-alt);
	padding: var(--space-5) 0;
	border-bottom: 1px solid var(--c-border);
}
.trust-strip__inner {
	display: flex; flex-direction: column;
	gap: var(--space-4);
	align-items: stretch;
}
@media (min-width: 768px) {
	.trust-strip__inner { flex-direction: row; align-items: center; gap: var(--space-6); justify-content: center; }
}
.trust-strip__group {
	display: flex; flex-direction: column;
	gap: var(--space-2);
	text-align: center;
}
@media (min-width: 768px) {
	.trust-strip__group { text-align: left; }
}
.trust-strip__label {
	font-size: var(--fs-caption);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--c-text-muted);
	font-weight: var(--fw-bold);
}
.trust-strip__icons {
	display: flex; flex-wrap: wrap; gap: var(--space-2);
	justify-content: center;
}
@media (min-width: 768px) {
	.trust-strip__icons { justify-content: flex-start; }
}
.trust-pill {
	display: inline-block;
	padding: 4px 10px;
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: 999px;
	font-size: var(--fs-caption);
	font-weight: var(--fw-bold);
	color: var(--c-text);
	letter-spacing: 0.02em;
}
.trust-pill--badge {
	background: var(--c-primary-dark);
	color: #fff;
	border-color: var(--c-primary-dark);
}
.trust-strip__divider {
	display: none;
}
@media (min-width: 768px) {
	.trust-strip__divider {
		display: block;
		width: 1px; height: 40px;
		background: var(--c-border);
	}
}

/* ===== HOW MANY DAYS QUIZ ===== */
.quiz {
	background: var(--c-surface-cool);
	padding: var(--space-12) 0;
}
.quiz__cards {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-3);
	margin-top: var(--space-5);
}
@media (min-width: 768px) { .quiz__cards { grid-template-columns: 1fr 1fr; } }
.quiz__option {
	cursor: pointer;
	background: var(--c-surface);
	border: 2px solid var(--c-border);
	border-radius: var(--radius-md);
	padding: var(--space-4);
	display: flex; flex-direction: column;
	gap: var(--space-3);
	margin-bottom: 0;
	transition: border-color 0.15s, box-shadow 0.15s, transform 0.05s;
}
.quiz__option:hover {
	border-color: var(--c-primary);
	box-shadow: 0 4px 14px rgba(14, 124, 123, 0.1);
	transform: translateY(-2px);
}
.quiz__option input {
	position: absolute; opacity: 0; pointer-events: none;
}
.quiz__option:has(input:checked) {
	border-color: var(--c-primary);
	background: linear-gradient(135deg, var(--c-primary-tint) 0%, var(--c-surface) 100%);
}
.quiz__option-head {
	display: flex; flex-direction: column;
	gap: 2px;
}
.quiz__hours {
	font-size: var(--fs-h3);
	font-weight: var(--fw-black);
	color: var(--c-primary-dark);
	font-family: var(--font-serif);
	letter-spacing: -0.02em;
}
.quiz__sub {
	font-size: var(--fs-meta);
	color: var(--c-text-muted);
}
.quiz__answer {
	font-size: var(--fs-meta);
	color: var(--c-text);
	line-height: var(--lh-relaxed);
	padding-top: var(--space-3);
	border-top: 1px dashed var(--c-border);
}
.quiz__answer strong { color: var(--c-primary-dark); }
.quiz__link {
	display: block;
	margin-top: var(--space-2);
	color: var(--c-primary-dark);
	font-weight: var(--fw-bold);
	text-decoration: underline;
	text-underline-offset: 3px;
}

/* ===== CONCIERGE FORM ===== */
.concierge {
	background: linear-gradient(135deg, #FFFCF7 0%, #F2F7F7 100%);
	padding: var(--space-12) 0;
	border-top: 1px solid var(--c-border);
}
.concierge-form {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: var(--radius-lg);
	padding: var(--space-5);
	box-shadow: 0 10px 28px rgba(0,0,0,0.04);
}
@media (min-width: 768px) { .concierge-form { padding: var(--space-6) var(--space-8); } }
.concierge-form__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-4);
}
@media (min-width: 600px) { .concierge-form__grid { grid-template-columns: 1fr 1fr; } }
.concierge-form__field { display: flex; flex-direction: column; gap: 6px; }
.concierge-form__field--full { grid-column: 1 / -1; }
.concierge-form label {
	font-size: var(--fs-meta);
	font-weight: var(--fw-bold);
	color: var(--c-text);
}
.concierge-form input,
.concierge-form select,
.concierge-form textarea {
	width: 100%;
	min-height: 48px;
	padding: var(--space-2) var(--space-3);
	background: var(--c-surface);
	border: 2px solid var(--c-border);
	border-radius: var(--radius-md);
	font-size: var(--fs-body);
	color: var(--c-text);
	font-family: inherit;
	transition: border-color 0.15s, box-shadow 0.15s;
}
.concierge-form input:focus,
.concierge-form select:focus,
.concierge-form textarea:focus {
	border-color: var(--c-primary);
	outline: 0;
	box-shadow: 0 0 0 3px var(--c-primary-tint);
}
.concierge-form textarea { min-height: 96px; line-height: var(--lh-relaxed); }
.concierge-form__actions {
	display: flex; flex-wrap: wrap; gap: var(--space-3);
	margin-top: var(--space-5);
}
.concierge-form__actions .btn { flex: 1; min-width: 200px; }
.concierge-form__legal {
	margin: var(--space-4) 0 0;
	font-size: var(--fs-caption);
	color: var(--c-text-muted);
	text-align: center;
	font-style: italic;
}

/* ===== Page--front cleanup ===== */
.page--front section { margin: 0; }

/* Print */
@media print {
	.site-header, .site-footer, .sticky-cta, .inline-cta,
	.hero, .journey, .carousel-section, .stats, .featured, .news, .faq, .final-cta { display: none !important; }
	a { color: #000; text-decoration: underline; }
	body { background: #fff; color: #000; }
}
