/* ==========================================================================
   Huw Williams Golf · FLIGHTPATH
   Emotional target: forward motion. The page is one ball flight.
   Provenance: A1 the measured flight (trajectory line, readout, easing),
   A2 Dubai first light (twilight indigo into the hot sun band),
   A3 Welsh morning (slate, sea-silver, cool green-grey),
   A4 the itinerary (the journey the page takes), A5 the lens (the funnel).
   Type: Saira variable display (athletic, DIN-rooted) over Figtree body.
   Forbidden here: flat neutral black, monospace label systems, numbered
   section motifs, stat tickers beyond the single hero readout, sand/linen
   heritage calm. Dark passages are atmospheric indigo, never neutral.
   ========================================================================== */

@view-transition { navigation: auto; }

:root {
	/* THE DAWN SYSTEM · all oklch
	   Act one: Dubai first light */
	--twilight-deep: oklch(20% 0.055 282);
	--twilight: oklch(26% 0.06 278);
	--twilight-soft: oklch(33% 0.055 274);
	--sun: oklch(71% 0.19 48);          /* the signal: one hot accent */
	--sun-hot: oklch(79% 0.165 62);
	--sun-deep: oklch(60% 0.19 38);
	/* Act two: daylight */
	--day: oklch(96.5% 0.011 95);
	--day-dim: oklch(92% 0.016 95);
	--ink: oklch(24% 0.035 275);        /* indigo-slate ink, never black */
	--ink-soft: oklch(40% 0.03 270);
	--ink-faint: oklch(51% 0.025 265);
	/* Act three: Welsh morning */
	--slate-deep: oklch(29% 0.035 245);
	--slate: oklch(37% 0.035 240);
	--sea-silver: oklch(88% 0.015 235);
	--sea-green: oklch(54% 0.045 200);
	/* Shared */
	--bone: oklch(96.5% 0.01 250);
	--line-on-dark: color-mix(in oklch, var(--bone) 18%, transparent);
	--line-on-light: color-mix(in oklch, var(--ink) 16%, transparent);

	/* Type */
	--display: 'Saira', 'Avenir Next Condensed', 'Arial Narrow', sans-serif;
	--body: 'Figtree', 'Helvetica Neue', Arial, sans-serif;
	--fs-hero: clamp(3.4rem, 13vw, 10rem);
	--fs-h2: clamp(2.1rem, 5.4vw, 3.9rem);
	--fs-h3: clamp(1.25rem, 2.2vw, 1.7rem);
	--fs-lede: clamp(1.1rem, 1.6vw, 1.3rem);
	--fs-body: 1.04rem;
	--track-tight: -0.025em;
	--track-caps: 0.16em;

	/* Layout: compressed rhythm */
	--wrap: 1180px;
	--gutter: clamp(1.15rem, 4vw, 3rem);
	--panel-y: clamp(3.25rem, 6.5vw, 5.5rem);
	--radius: 4px;
	--header-h: 68px;
	--dock-h: 72px;

	/* Motion: the strike curve. Fast off the face, weightless, soft landing */
	--launch: cubic-bezier(0.3, 0, 0.1, 1);
	--dur: 400ms;
	--dur-slow: 800ms;
}

/* ==========================================================================
   Reset and base
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
	margin: 0;
	background: var(--twilight-deep);
	color: var(--bone);
	font-family: var(--body);
	font-size: var(--fs-body);
	line-height: 1.62;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	overflow-x: hidden;
}
img, svg, picture, video { max-width: 100%; display: block; }
h1, h2, h3 {
	margin: 0;
	font-family: var(--display);
	font-weight: 800;
	font-stretch: 92%;
	line-height: 0.98;
	letter-spacing: var(--track-tight);
	text-transform: uppercase;
}
p { margin: 0 0 1em; }
p:last-child { margin-bottom: 0; }
a { color: inherit; transition: color var(--dur) var(--launch); }
button { font: inherit; border: 0; background: none; color: inherit; cursor: pointer; }
ul, ol, dl, dd { margin: 0; padding: 0; list-style: none; }
::selection { background: var(--sun); color: var(--twilight-deep); }

.skip-link {
	position: fixed; top: 10px; left: 10px; z-index: 300;
	background: var(--sun); color: var(--twilight-deep);
	padding: 10px 16px; border-radius: var(--radius);
	font-family: var(--display); font-weight: 700; font-size: 0.85rem;
	text-decoration: none; text-transform: uppercase; letter-spacing: 0.04em;
	transform: translateY(-200%);
	transition: transform var(--dur) var(--launch);
}
.skip-link:focus { transform: none; }
:focus-visible { outline: 2px solid var(--sun-hot); outline-offset: 3px; }
.panel--day :focus-visible { outline-color: var(--sun-deep); }

.wrap { max-width: var(--wrap); margin-inline: auto; padding-inline: var(--gutter); }

/* Wide-tracked caps label */
.label {
	display: inline-flex; align-items: center; gap: 0.6rem;
	font-family: var(--display);
	font-weight: 600; font-stretch: 88%;
	font-size: 0.74rem; letter-spacing: var(--track-caps);
	text-transform: uppercase;
	opacity: 0.85;
}
.label::before { content: ""; width: 18px; height: 2px; background: var(--sun); }
.label--bare::before { display: none; }

.lede { font-size: var(--fs-lede); line-height: 1.55; max-width: 56ch; opacity: 0.92; }

/* ==========================================================================
   Header, sheet, dock (conversion chrome: one primary CTA)
   ========================================================================== */
.bar {
	position: fixed; inset-inline: 0; top: 0; z-index: 100;
	height: var(--header-h);
	display: flex; align-items: center; justify-content: space-between;
	gap: 1.25rem;
	padding-inline: var(--gutter);
	background: color-mix(in oklch, var(--twilight-deep) 72%, transparent);
	backdrop-filter: blur(14px);
	border-bottom: 1px solid var(--line-on-dark);
}
.wordmark {
	font-family: var(--display); font-weight: 800; font-stretch: 95%;
	font-size: 1.12rem; letter-spacing: 0.01em; text-transform: uppercase;
	color: var(--bone); text-decoration: none; white-space: nowrap;
}
.wordmark b { color: var(--sun-hot); }
.bar nav { display: flex; gap: 1.4rem; }
.bar nav a {
	font-family: var(--display); font-weight: 600; font-stretch: 90%;
	font-size: 0.8rem; letter-spacing: 0.1em; text-transform: uppercase;
	color: color-mix(in oklch, var(--bone) 78%, transparent);
	text-decoration: none; padding: 6px 0; position: relative; white-space: nowrap;
}
.bar nav a::after {
	content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 2px;
	background: var(--sun); transform: scaleX(0); transform-origin: left;
	transition: transform var(--dur) var(--launch);
}
.bar nav a:hover { color: var(--bone); }
.bar nav a:hover::after, .bar nav a[aria-current="page"]::after { transform: none; }
@media (max-width: 1100px) { .bar nav { display: none; } }

.menu-toggle { display: none; flex-direction: column; gap: 5px; padding: 10px; }
.menu-toggle .tick { width: 24px; height: 2px; background: var(--bone); transition: transform var(--dur) var(--launch), opacity var(--dur) var(--launch); }
.menu-toggle[aria-expanded="true"] .tick:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.menu-toggle[aria-expanded="true"] .tick:nth-child(2) { opacity: 0; }
.menu-toggle[aria-expanded="true"] .tick:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
@media (max-width: 1100px) { .menu-toggle { display: inline-flex; } }

.sheet {
	position: fixed; inset: 0; z-index: 90;
	background: linear-gradient(185deg, var(--twilight-deep) 0%, var(--twilight) 70%, var(--sun-deep) 160%);
	padding: calc(var(--header-h) + 1.5rem) var(--gutter) 2rem;
	display: flex; flex-direction: column; gap: 2rem; overflow-y: auto;
	opacity: 0; transform: translateY(-8px);
	transition: opacity var(--dur) var(--launch), transform var(--dur) var(--launch);
}
.sheet[hidden] { display: none !important; }
.sheet.open { opacity: 1; transform: none; }
.sheet nav a {
	display: block; padding: 0.85rem 0;
	font-family: var(--display); font-weight: 800; font-stretch: 90%;
	font-size: clamp(1.9rem, 8vw, 2.8rem); letter-spacing: var(--track-tight);
	text-transform: uppercase; color: var(--bone); text-decoration: none;
	border-bottom: 1px solid var(--line-on-dark);
}
body.menu-open { overflow: hidden; }

.dock {
	display: none;
	position: fixed; inset-inline: 0; bottom: 0; z-index: 85;
	padding: 0.7rem var(--gutter) calc(0.7rem + env(safe-area-inset-bottom));
	background: color-mix(in oklch, var(--twilight-deep) 80%, transparent);
	backdrop-filter: blur(14px);
	border-top: 1px solid var(--line-on-dark);
}
@media (max-width: 1100px) {
	.dock { display: block; }
	main { padding-bottom: var(--dock-h); }
}

/* ==========================================================================
   Buttons · magnetic primaries
   ========================================================================== */
.btn {
	display: inline-flex; align-items: center; justify-content: center; gap: 0.55rem;
	padding: 1rem 1.7rem;
	font-family: var(--display); font-weight: 700; font-stretch: 92%;
	font-size: 0.92rem; letter-spacing: 0.07em; text-transform: uppercase;
	border-radius: var(--radius); text-decoration: none; white-space: nowrap;
	background: var(--sun); color: var(--twilight-deep);
	transition: background var(--dur) var(--launch), transform var(--dur) var(--launch), box-shadow var(--dur) var(--launch);
	will-change: transform;
}
.btn:hover { background: var(--sun-hot); box-shadow: 0 10px 36px color-mix(in oklch, var(--sun) 45%, transparent); }
.btn--night { background: var(--twilight-deep); color: var(--sun-hot); }
.btn--night:hover { background: var(--twilight); box-shadow: 0 10px 36px color-mix(in oklch, var(--twilight-deep) 60%, transparent); }
.btn--full { width: 100%; }

.link-cta {
	display: inline-flex; align-items: baseline; gap: 0.5rem;
	font-family: var(--display); font-weight: 700; font-stretch: 90%;
	font-size: 0.8rem; letter-spacing: var(--track-caps); text-transform: uppercase;
	text-decoration: none; padding-bottom: 3px;
	border-bottom: 2px solid var(--sun);
	transition: gap var(--dur) var(--launch), color var(--dur) var(--launch);
}
.link-cta:hover { gap: 0.85rem; }
.link-cta .arrow { color: var(--sun-deep); }
.panel--act1 .link-cta:hover, .panel--act3 .link-cta:hover { color: var(--sun-hot); }
.panel--day .link-cta:hover { color: var(--sun-deep); }

.cta-row { display: flex; flex-wrap: wrap; align-items: center; gap: 1rem 1.75rem; margin-top: 2rem; }
.context-cta .btn { transition: background var(--dur) var(--launch), opacity 180ms var(--launch), transform var(--dur) var(--launch); }
.context-cta.swapping .btn { opacity: 0; }

/* ==========================================================================
   Panels · the three acts and their bridges
   No text ever sits inside a bridge: AA is provable on every ground.
   ========================================================================== */
.panel { position: relative; padding-block: var(--panel-y); }
.panel--act1 { background: linear-gradient(180deg, var(--twilight) 0%, var(--twilight-soft) 100%); color: var(--bone); }
.panel--day { background: linear-gradient(180deg, var(--day) 0%, var(--day-dim) 100%); color: var(--ink); }
.panel--day .label { color: var(--ink-soft); }
.panel--day .lede { color: var(--ink-soft); opacity: 1; }
.panel--act3 { background: linear-gradient(180deg, var(--slate) 0%, var(--slate-deep) 100%); color: var(--bone); }
.panel--finale {
	background:
		radial-gradient(120% 90% at 50% 118%, var(--sun) 0%, var(--sun-deep) 34%, transparent 62%),
		linear-gradient(180deg, var(--twilight-deep) 0%, var(--twilight) 100%);
	color: var(--bone);
}

/* Interior page hero: clears the fixed bar, compressed and confident */
.panel--hero { padding-top: calc(var(--header-h) + clamp(3rem, 8vh, 5rem)); }
.panel--hero h1 { font-size: clamp(2.7rem, 8vw, 6rem); font-stretch: 102%; max-width: 14ch; }
.panel--hero .lede { margin-top: 1.1rem; }

.bridge { height: clamp(4.5rem, 9vh, 7.5rem); pointer-events: none; }
.bridge--dawn-day { background: linear-gradient(180deg, var(--twilight-soft) 0%, var(--day) 100%); }
.bridge--day-sea { background: linear-gradient(180deg, var(--day-dim) 0%, var(--slate) 100%); }
.bridge--sea-night { background: linear-gradient(180deg, var(--slate-deep) 0%, var(--twilight-deep) 100%); }

/* Film grain on atmospheric panels */
.grain { position: relative; isolation: isolate; }
.grain::after {
	content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
	opacity: 0.05; mix-blend-mode: overlay;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)'/%3E%3C/svg%3E");
}
.grain > * { position: relative; z-index: 2; }

.panel-head { max-width: 780px; margin-bottom: clamp(1.75rem, 3.5vw, 3rem); }
.panel-head .label { margin-bottom: 1rem; }
.panel-head h2 { font-size: var(--fs-h2); }
.panel-head .lede { margin-top: 1rem; }

/* ==========================================================================
   HERO · the dawn sky, the self-drawing arc, the readout
   ========================================================================== */
.hero {
	position: relative;
	min-height: 100svh;
	display: flex; flex-direction: column; justify-content: flex-end;
	padding: calc(var(--header-h) + 4vh) 0 clamp(3rem, 7vh, 5rem);
	overflow: clip;
	color: var(--bone);
	background:
		linear-gradient(180deg,
			var(--twilight-deep) 0%,
			var(--twilight) 38%,
			var(--twilight-soft) 56%,
			var(--sun-deep) 72%,
			var(--sun) 80%,
			var(--sun-hot) 85%,
			var(--sun-deep) 92%,
			var(--twilight) 100%); /* meets the next panel's start exactly */
}
.hero__inner { position: relative; z-index: 3; }
.hero .label { margin-bottom: 1.1rem; }
.hero h1 {
	font-size: var(--fs-hero);
	font-stretch: 104%;
	max-width: 9ch;
	text-wrap: balance;
}
/* Variable width settles as the hero scrolls away, where supported */
@supports (animation-timeline: view()) {
	.hero h1 { animation: settleWidth both linear; animation-timeline: view(); animation-range: exit 0% exit 90%; }
	@keyframes settleWidth { to { font-stretch: 86%; letter-spacing: -0.01em; } }
}
.hero__lede { margin-top: 1.4rem; max-width: 52ch; font-size: var(--fs-lede); line-height: 1.5; opacity: 0.94; }
.hero__cta { margin-top: 2.2rem; display: flex; flex-wrap: wrap; align-items: center; gap: 1rem 1.75rem; }

/* The arc: pathLength normalised, pure CSS self-draw on load */
.hero__flight { position: absolute; inset: 0; z-index: 1; pointer-events: none; }
.hero__flight svg { width: 100%; height: 100%; overflow: visible; }
.hero__arc {
	fill: none;
	stroke: var(--sun-hot);
	stroke-width: 2.5;
	stroke-linecap: round;
	vector-effect: non-scaling-stroke;
	stroke-dasharray: 100;
	stroke-dashoffset: 100;
	filter: drop-shadow(0 0 10px color-mix(in oklch, var(--sun-hot) 60%, transparent));
	animation: arcDraw 2.1s var(--launch) 0.35s forwards;
}
@keyframes arcDraw { to { stroke-dashoffset: 0; } }

/* The single data readout, by design the only one on the site */
.readout {
	position: absolute; z-index: 3;
	right: var(--gutter); top: clamp(6.5rem, 16vh, 9.5rem);
	display: grid; gap: 0.55rem;
	text-align: right;
}
.readout > div { display: grid; gap: 0.1rem; }
.readout dt {
	font-family: var(--display); font-weight: 600; font-stretch: 88%;
	font-size: 0.62rem; letter-spacing: var(--track-caps); text-transform: uppercase;
	opacity: 0.72;
}
.readout dd {
	font-family: var(--display); font-weight: 800; font-stretch: 100%;
	font-size: clamp(1.3rem, 2.6vw, 1.9rem); line-height: 1;
	color: var(--sun-hot);
}
.readout dd .unit { font-size: 0.55em; font-weight: 600; opacity: 0.85; margin-left: 2px; }
.readout__tbc {
	font-family: var(--display); font-size: 0.58rem; font-stretch: 90%;
	letter-spacing: 0.12em; text-transform: uppercase;
	opacity: 0.6; border-bottom: 1px dashed currentColor; cursor: help;
	justify-self: end;
}
@media (max-width: 720px) {
	/* The dock owns the primary CTA on small screens; the bar stays clean */
	.bar .context-cta { display: none; }
	/* Readout joins the flow as a strip above the headline block */
	.readout {
		position: static; order: -1;
		display: flex; flex-wrap: wrap; align-items: baseline;
		gap: 0.4rem 1.4rem;
		text-align: left;
		padding-inline: var(--gutter);
		margin-bottom: 1.1rem;
	}
	.readout dd { font-size: 1.3rem; }
	.readout__tbc { align-self: center; }
	/* The arc whispers behind portrait copy instead of cutting through it */
	.hero__arc { opacity: 0.55; }
	.hero__scrollcue { display: none; }
}

.hero__scrollcue {
	position: absolute; z-index: 3; left: 50%; bottom: 0.9rem; transform: translateX(-50%);
	font-family: var(--display); font-size: 0.62rem; font-stretch: 90%;
	letter-spacing: var(--track-caps); text-transform: uppercase; opacity: 0.6;
}

/* ==========================================================================
   THE TRAJECTORY · one line through the whole page
   ========================================================================== */
.flightline {
	position: absolute; inset: 0; z-index: 5; pointer-events: none;
}
.flightline svg { width: 100%; height: 100%; }
.flightline path {
	fill: none;
	stroke: var(--sun);
	stroke-width: 2;
	stroke-linecap: round;
	vector-effect: non-scaling-stroke;
	/* Quiet enough to pass behind copy, present enough to lead the eye */
	opacity: 0.5;
	filter: drop-shadow(0 0 6px color-mix(in oklch, var(--sun) 30%, transparent));
	stroke-dasharray: 100;
	stroke-dashoffset: 100;
}
@supports (animation-timeline: scroll()) {
	.flightline path { animation: lineDraw linear both; animation-timeline: scroll(); animation-range: 2% 96%; }
	@keyframes lineDraw { to { stroke-dashoffset: 0; } }
}
main { position: relative; }

/* ==========================================================================
   Triage · where are you starting?
   ========================================================================== */
.trio { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.1rem, 2.5vw, 2rem); }
.trio > a {
	display: grid; grid-template-rows: subgrid; grid-row: span 3; gap: 0.55rem;
	padding: 1.2rem 1.25rem 1.35rem;
	border: 1px solid var(--line-on-dark);
	border-radius: var(--radius);
	background: color-mix(in oklch, var(--bone) 5%, transparent);
	text-decoration: none; color: inherit;
	transition: transform var(--dur) var(--launch), border-color var(--dur) var(--launch), background var(--dur) var(--launch);
}
.trio > a:hover { transform: translateY(-4px); border-color: var(--sun); background: color-mix(in oklch, var(--bone) 9%, transparent); }
.trio h3 { font-size: var(--fs-h3); }
.trio p { font-size: 0.95rem; opacity: 0.85; }
.trio .link-cta { align-self: end; justify-self: start; }
@media (max-width: 760px) { .trio { grid-template-columns: 1fr; } }

/* ==========================================================================
   Method · three strikes
   ========================================================================== */
.method { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.25rem, 3vw, 2.5rem); }
.method > div { border-top: 3px solid var(--sun); padding-top: 1.1rem; }
.method h3 { font-size: var(--fs-h3); margin-bottom: 0.45rem; }
.method p { color: var(--ink-soft); font-size: 0.97rem; }
@media (max-width: 760px) { .method { grid-template-columns: 1fr; } }

/* ==========================================================================
   Forms · carried conversion architecture, rethemed
   ========================================================================== */
.form { display: grid; gap: 1.05rem; max-width: 600px; }
.field { display: grid; gap: 0.35rem; }
.field label {
	font-family: var(--display); font-weight: 600; font-stretch: 90%;
	font-size: 0.72rem; letter-spacing: 0.1em; text-transform: uppercase;
	color: var(--ink-soft);
}
.field input, .field select, .field textarea {
	font-family: var(--body); font-size: 1rem; color: var(--ink);
	background: oklch(99% 0.004 95);
	border: 1px solid var(--line-on-light); border-radius: var(--radius);
	padding: 0.85rem 0.95rem;
	transition: border-color var(--dur) var(--launch), box-shadow var(--dur) var(--launch);
}
.field input:focus, .field select:focus, .field textarea:focus {
	outline: none; border-color: var(--sun-deep);
	box-shadow: 0 0 0 3px color-mix(in oklch, var(--sun) 25%, transparent);
}
.field textarea { min-height: 130px; resize: vertical; }
.field .error { display: none; font-family: var(--display); font-stretch: 92%; font-size: 0.8rem; color: oklch(48% 0.16 28); }
.field.invalid input, .field.invalid select, .field.invalid textarea { border-color: oklch(55% 0.17 28); }
.field.invalid .error { display: block; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.05rem; }
@media (max-width: 600px) { .form-row { grid-template-columns: 1fr; } }
.form-success {
	display: none;
	padding: 1.4rem 1.5rem;
	border: 2px solid var(--sun-deep); border-radius: var(--radius);
	background: color-mix(in oklch, var(--sun) 12%, oklch(99% 0.004 95));
	color: var(--ink);
}
.form-success h3 { font-size: 1.1rem; margin-bottom: 0.3rem; }
.form-success p { margin: 0; color: var(--ink-soft); }
form.sent { display: none; }
form.sent + .form-success { display: block; }

.split { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(1.75rem, 4.5vw, 4rem); align-items: center; }
@media (max-width: 860px) { .split { grid-template-columns: 1fr; } }

/* ==========================================================================
   The two landscapes · Dubai and Surrey, opposing atmospheres
   ========================================================================== */
.landscapes { display: grid; grid-template-columns: 1fr 1fr; }
.landscape {
	position: relative; overflow: clip;
	min-height: clamp(420px, 58vh, 560px);
	display: flex; flex-direction: column; justify-content: flex-end;
	padding: clamp(1.75rem, 4vw, 3rem);
	color: var(--bone);
}
.landscape--dubai { --scrim: color-mix(in oklch, var(--twilight-deep) 72%, transparent); background: linear-gradient(195deg, var(--twilight) 0%, var(--twilight-soft) 42%, var(--sun-deep) 88%, var(--sun) 100%); }
.landscape--surrey { --scrim: color-mix(in oklch, var(--slate-deep) 72%, transparent); background: linear-gradient(165deg, var(--sea-silver) -25%, var(--slate) 48%, var(--slate-deep) 100%); }
.landscape__sky {
	position: absolute; inset: -12% 0; z-index: 0; pointer-events: none;
}
@supports (animation-timeline: view()) {
	.landscape__sky { animation: skyDrift linear both; animation-timeline: view(); animation-range: cover 0% cover 100%; }
	@keyframes skyDrift { from { transform: translateY(-4%); } to { transform: translateY(4%); } }
}
.landscape__sky--dubai { background: radial-gradient(85% 50% at 28% 82%, color-mix(in oklch, var(--sun-hot) 55%, transparent) 0%, transparent 65%); }
.landscape__sky--surrey {
	background:
		radial-gradient(90% 55% at 70% 14%, color-mix(in oklch, var(--sea-silver) 36%, transparent) 0%, transparent 60%),
		radial-gradient(80% 45% at 25% 96%, color-mix(in oklch, var(--sea-green) 42%, transparent) 0%, transparent 62%);
}
/* Copy always sits on a guaranteed-dark field, whatever the glows do */
.landscape::before {
	content: ""; position: absolute; inset: 40% 0 0 0; z-index: 1; pointer-events: none;
	background: linear-gradient(180deg, transparent 0%, var(--scrim) 60%);
}
.landscape > * { position: relative; z-index: 2; }
.landscape h3 { font-size: clamp(1.7rem, 3.6vw, 2.6rem); }
.landscape p { max-width: 38ch; font-size: 0.98rem; opacity: 0.92; }
.landscape .label { margin-bottom: 0.6rem; }
@media (max-width: 760px) { .landscapes { grid-template-columns: 1fr; } }

/* ==========================================================================
   Quotes · verbatim, verifiable
   ========================================================================== */
.quotes { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.1rem, 2.5vw, 2rem); }
.quote {
	display: flex; flex-direction: column; gap: 1rem;
	padding: 1.3rem 1.3rem 1.4rem;
	border: 1px solid var(--line-on-dark); border-left: 3px solid var(--sun);
	border-radius: var(--radius);
	background: color-mix(in oklch, var(--bone) 5%, transparent);
}
.quote blockquote { margin: 0; font-size: 1.04rem; line-height: 1.5; }
.quote figcaption { margin-top: auto; }
.quote .who { font-family: var(--display); font-weight: 700; font-stretch: 92%; font-size: 0.92rem; text-transform: uppercase; letter-spacing: 0.04em; }
.quote .context { display: block; font-size: 0.82rem; opacity: 0.7; margin-top: 2px; }
@media (max-width: 820px) { .quotes { grid-template-columns: 1fr; } }
.proof-links { margin-top: 1.9rem; display: flex; flex-wrap: wrap; gap: 1rem 2.25rem; align-items: baseline; }

.tbc { border-bottom: 2px dashed currentColor; opacity: 0.85; cursor: help; }

/* ==========================================================================
   Finale · the landing
   ========================================================================== */
.finale { text-align: center; padding-block: clamp(5rem, 12vh, 8.5rem); }
.finale h2 { font-size: clamp(2.6rem, 8vw, 6rem); font-stretch: 102%; max-width: 14ch; margin-inline: auto; }
.finale .lede { margin: 1.2rem auto 0; }
.finale .cta-row { justify-content: center; }

/* ==========================================================================
   Footer
   ========================================================================== */
.foot { background: var(--twilight-deep); border-top: 1px solid var(--line-on-dark); padding: 2.25rem 0 5rem; color: var(--bone); }
.foot .wrap { display: flex; flex-wrap: wrap; gap: 1rem 3rem; justify-content: space-between; align-items: baseline; }
.foot p, .foot a { font-family: var(--display); font-stretch: 92%; font-size: 0.78rem; letter-spacing: 0.06em; text-transform: uppercase; opacity: 0.75; text-decoration: none; }
.foot a:hover { opacity: 1; color: var(--sun-hot); }
.foot ul { display: flex; flex-wrap: wrap; gap: 1.2rem; }

/* ==========================================================================
   Reveals · panels arrive with pace
   ========================================================================== */
.rise { opacity: 0; transform: translateY(22px); transition: opacity var(--dur-slow) var(--launch), transform var(--dur-slow) var(--launch); }
.rise.in { opacity: 1; transform: none; }
@supports (animation-timeline: view()) {
	.rise { opacity: 1; transform: none; transition: none; animation: rise both; animation-timeline: view(); animation-range: entry 0% entry 32%; }
	@keyframes rise { from { opacity: 0; transform: translateY(22px); } }
}

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; }
	.rise { opacity: 1 !important; transform: none !important; animation: none !important; }
	.hero__arc, .flightline path { stroke-dashoffset: 0 !important; animation: none !important; }
	.hero h1 { animation: none !important; }
	.landscape__sky { animation: none !important; transform: none !important; }
}

/* ==========================================================================
   Phase two components
   ========================================================================== */

/* Numbered loop (online coaching) */
.steps { display: grid; gap: 0; counter-reset: step; max-width: 640px; }
.step {
	counter-increment: step;
	display: grid; grid-template-columns: 2.6rem 1fr; gap: 1rem; align-items: baseline;
	padding: 1.05rem 0; border-top: 1px solid var(--line-on-light);
}
.step:last-child { border-bottom: 1px solid var(--line-on-light); }
.step::before {
	content: counter(step);
	font-family: var(--display); font-weight: 800; font-stretch: 100%;
	font-size: 1.3rem; color: var(--sun-deep); line-height: 1;
}
.step h3 { font-size: 1.05rem; margin-bottom: 0.2rem; }
.step p { color: var(--ink-soft); font-size: 0.96rem; margin: 0; }

/* Note grid (audiences, philosophy, certifications, topics) */
.notes { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 2.5vw, 1.75rem); }
.note { border-top: 3px solid var(--sun); padding-top: 0.95rem; }
.note h3 { font-size: 1.05rem; margin-bottom: 0.35rem; }
.note p { font-size: 0.95rem; margin: 0; }
.panel--day .note p { color: var(--ink-soft); }
.panel--act1 .note p, .panel--act3 .note p { opacity: 0.85; }
@media (max-width: 820px) { .notes { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .notes { grid-template-columns: 1fr; } }

/* Packages with TBC price anchors */
.packs { display: grid; gap: 0; }
.pack {
	display: grid; grid-template-columns: 1fr auto; gap: 0.25rem 2rem; align-items: baseline;
	padding: 1.3rem 0; border-top: 1px solid var(--line-on-light);
}
.pack:last-child { border-bottom: 1px solid var(--line-on-light); }
.pack h3 { font-size: 1.3rem; }
.pack p { grid-column: 1; color: var(--ink-soft); margin: 0; max-width: 52ch; }
.pack__price { font-family: var(--display); font-weight: 700; font-stretch: 95%; font-size: 1rem; letter-spacing: 0.04em; text-transform: uppercase; white-space: nowrap; color: var(--sun-deep); }
@media (max-width: 560px) { .pack { grid-template-columns: 1fr; } }

/* Venue rows */
.venues { display: grid; gap: 0; }
.venue {
	display: grid; grid-template-columns: 1fr auto; gap: 0.3rem 1.5rem; align-items: baseline;
	padding: 1.1rem 0; border-top: 1px solid var(--line-on-light);
}
.venue:last-of-type { border-bottom: 1px solid var(--line-on-light); }
.venue h3 { font-size: 1.2rem; }
.venue p { grid-column: 1 / -1; color: var(--ink-soft); font-size: 0.95rem; margin: 0; }
.venue .label { color: var(--sun-deep); }
.venues-note { margin-top: 0.9rem; font-size: 0.9rem; color: var(--ink-faint); font-style: italic; }
@media (max-width: 540px) { .venue { grid-template-columns: 1fr; } }

/* FAQ accordion (day grounds) */
.faqs details { border-top: 1px solid var(--line-on-light); }
.faqs details:last-child { border-bottom: 1px solid var(--line-on-light); }
.faqs summary {
	list-style: none; cursor: pointer;
	display: flex; justify-content: space-between; align-items: baseline; gap: 1.5rem;
	padding: 1.15rem 0;
	font-family: var(--display); font-weight: 700; font-stretch: 94%;
	font-size: 1.02rem; letter-spacing: 0.02em; text-transform: uppercase;
}
.faqs summary::-webkit-details-marker { display: none; }
.faqs summary::after { content: "+"; color: var(--sun-deep); font-size: 1.25rem; transition: transform var(--dur) var(--launch); }
.faqs details[open] summary::after { transform: rotate(45deg); }
.faqs details > div { padding: 0 0 1.15rem; color: var(--ink-soft); max-width: 62ch; }

/* Placeholder slot (photography to follow) */
.slot {
	display: grid; place-items: center; text-align: center;
	border: 1px dashed color-mix(in oklch, currentColor 40%, transparent);
	border-radius: var(--radius);
	background: color-mix(in oklch, currentColor 6%, transparent);
	padding: 1rem; opacity: 0.85;
}
.slot span { font-family: var(--display); font-weight: 600; font-stretch: 90%; font-size: 0.72rem; letter-spacing: var(--track-caps); text-transform: uppercase; }

/* ==========================================================================
   THE ATLAS · the trajectory becomes the flight route (Trips page)
   Hand-built SVG: graticule, great-circle arcs, destination stops.
   ========================================================================== */
.atlas { position: relative; }
.atlas svg { width: 100%; height: auto; display: block; }
.atlas .graticule { stroke: var(--line-on-dark); stroke-width: 1; fill: none; vector-effect: non-scaling-stroke; }
.atlas .route {
	fill: none; stroke: var(--sun); stroke-width: 2.25; stroke-linecap: round;
	vector-effect: non-scaling-stroke;
	filter: drop-shadow(0 0 8px color-mix(in oklch, var(--sun) 40%, transparent));
	stroke-dasharray: 100; stroke-dashoffset: 100;
}
.atlas .stop circle { fill: var(--sun-hot); }
.atlas .stop .halo {
	fill: none; stroke: var(--sun-hot); stroke-width: 1.5; opacity: 0.55;
	transform-box: fill-box; transform-origin: center;
	animation: halo 2.6s var(--launch) infinite;
}
@keyframes halo { 0% { transform: scale(0.5); opacity: 0.7; } 100% { transform: scale(1.9); opacity: 0; } }
.atlas .stop text {
	font-family: var(--display); font-weight: 700;
	font-size: 17px; letter-spacing: 0.1em; text-transform: uppercase;
	fill: var(--bone);
}
.atlas .stop .when { font-weight: 500; font-size: 12.5px; fill: color-mix(in oklch, var(--bone) 70%, transparent); }
@supports (animation-timeline: view()) {
	.atlas .route { animation: routeDraw linear both; animation-timeline: view(); animation-range: entry 10% cover 65%; }
	@keyframes routeDraw { to { stroke-dashoffset: 0; } }
	.atlas .stop { animation: stopPop both var(--launch); animation-timeline: view(); }
	@keyframes stopPop { from { opacity: 0; } }
	.atlas .stop:nth-of-type(1) { animation-range: entry 12% entry 28%; }
	.atlas .stop:nth-of-type(2) { animation-range: entry 28% cover 38%; }
	.atlas .stop:nth-of-type(3) { animation-range: cover 38% cover 50%; }
	.atlas .stop:nth-of-type(4) { animation-range: cover 48% cover 60%; }
}

/* Trip cards, revealing in route order beneath the atlas */
.tripcards { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(1rem, 2.5vw, 1.75rem); }
.tripcard {
	border: 1px solid var(--line-on-dark); border-left: 3px solid var(--sun);
	border-radius: var(--radius);
	background: color-mix(in oklch, var(--bone) 5%, transparent);
	padding: 1.3rem 1.4rem 1.4rem;
}
.tripcard h3 { font-size: clamp(1.3rem, 2.4vw, 1.7rem); margin-bottom: 0.35rem; }
.tripcard .label { margin-bottom: 0.5rem; color: var(--sun-hot); }
.tripcard p { font-size: 0.96rem; opacity: 0.88; margin: 0; }
@media (max-width: 700px) { .tripcards { grid-template-columns: 1fr; } }

@media (prefers-reduced-motion: reduce) {
	.atlas .route { stroke-dashoffset: 0 !important; animation: none !important; }
	.atlas .stop { opacity: 1 !important; animation: none !important; }
	.atlas .stop .halo { animation: none !important; opacity: 0.4; }
}

/* ==========================================================================
   Styleguide page
   ========================================================================== */
.sg { padding-block: calc(var(--header-h) + 2rem) 4rem; }
.sg section { margin-bottom: 3.5rem; }
.sg h2 { font-size: clamp(1.6rem, 3vw, 2.3rem); margin-bottom: 1.25rem; }
.sg .swatches { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 0.8rem; }
.sg .swatch { border-radius: var(--radius); overflow: hidden; border: 1px solid var(--line-on-dark); }
.sg .swatch > div { height: 74px; }
.sg .swatch p { font-family: var(--display); font-stretch: 90%; font-size: 0.68rem; letter-spacing: 0.08em; text-transform: uppercase; padding: 0.55rem 0.7rem; margin: 0; background: var(--twilight); }
.sg .typerow { border-top: 1px solid var(--line-on-dark); padding-block: 1rem; }
.sg .note { font-size: 0.92rem; opacity: 0.8; max-width: 68ch; }
