/* ==========================================================================
   Huw Williams Golf — Design System v2
   Creative Direction: "CLARITY" — calm, editorial, morning-links light.
   Layout: editorial / indexed.  Type: Fraunces + Hanken Grotesk.
   Colour: warm chalk, ink, fairway green, sand.  Motion: editorial reveal.
   Signature: "The Line" — a drawn swing-path arc.  Density: expansive.
   Deliberately NOT the v1 dark/electric-green/Inter house style.
   ========================================================================== */

:root {
	/* --- Colour: "morning links" --- */
	--paper: #F7F4EE;          /* warm chalk canvas */
	--paper-2: #F1ECE2;        /* recessed warm tone */
	--raised: #FCFBF7;         /* lifted surface */
	--ink: #1C211C;            /* near-black, faintly green-warm */
	--ink-soft: #565D54;       /* muted body / secondary */
	--ink-faint: #8B9085;      /* labels, meta */
	--green: #41543B;          /* deep fairway green */
	--green-mid: #6E7E63;      /* mid sage */
	--sand: #C2A06B;           /* warm brass/sand accent */
	--sand-deep: #A07E3E;
	--line: rgba(28, 33, 28, 0.12);
	--line-soft: rgba(28, 33, 28, 0.07);
	--line-strong: rgba(28, 33, 28, 0.22);

	/* --- Type --- */
	--font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
	--font-sans: 'Hanken Grotesk', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;

	--fs-eyebrow: 0.74rem;
	--fs-body: 1.06rem;
	--fs-lede: clamp(1.2rem, 1.8vw, 1.45rem);
	--fs-h5: 1.2rem;
	--fs-h4: clamp(1.35rem, 2.2vw, 1.7rem);
	--fs-h3: clamp(1.7rem, 3vw, 2.3rem);
	--fs-h2: clamp(2.1rem, 4.4vw, 3.5rem);
	--fs-h1: clamp(2.6rem, 6.4vw, 5.4rem);
	--fs-display: clamp(3rem, 9vw, 7.5rem);

	--lh-tight: 1.02;
	--lh-snug: 1.12;
	--lh-body: 1.62;
	--ls-tight: -0.02em;
	--ls-display: -0.03em;
	--ls-eyebrow: 0.2em;
	--measure: 64ch;

	/* --- Layout --- */
	--container: 1280px;
	--container-wide: 1480px;
	--reading: 720px;
	--gutter: clamp(1.4rem, 5vw, 4rem);
	--section-y: clamp(5.5rem, 12vw, 11rem);
	--radius: 4px;
	--radius-lg: 10px;
	--radius-img: 6px;

	/* --- Motion --- */
	--ease: cubic-bezier(0.22, 1, 0.36, 1);
	--ease-soft: cubic-bezier(0.4, 0, 0.2, 1);
	--dur: 460ms;
	--dur-slow: 900ms;

	--header-h: 84px;
	--header-h-min: 64px;
}

/* ==========================================================================
   Reset
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
	margin: 0;
	background: var(--paper);
	color: var(--ink);
	font-family: var(--font-sans);
	font-size: var(--fs-body);
	line-height: var(--lh-body);
	font-weight: 400;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
	overflow-x: hidden;
}
img, picture, video, svg { max-width: 100%; display: block; }
h1, h2, h3, h4, h5, h6 {
	margin: 0;
	font-family: var(--font-display);
	font-weight: 500;
	line-height: var(--lh-snug);
	letter-spacing: var(--ls-tight);
	font-optical-sizing: auto;
}
p { margin: 0 0 1em; }
p:last-child { margin-bottom: 0; }
a { color: inherit; text-decoration: none; transition: color var(--dur) var(--ease); }
button { font: inherit; cursor: pointer; background: none; border: 0; color: inherit; }
ul { list-style: none; padding: 0; margin: 0; }
strong { font-weight: 600; }
::selection { background: var(--sand); color: var(--ink); }

.screen-reader-text {
	position: absolute !important;
	clip: rect(1px,1px,1px,1px);
	width: 1px; height: 1px; overflow: hidden;
}
.skip-link {
	position: fixed; top: 10px; left: 10px;
	background: var(--ink); color: var(--paper);
	padding: 10px 16px; border-radius: var(--radius);
	z-index: 999; transform: translateY(-200%);
	transition: transform var(--dur) var(--ease);
	font-size: 0.85rem;
}
.skip-link:focus { transform: translateY(0); }

/* ==========================================================================
   Layout primitives
   ========================================================================== */
.container {
	width: 100%;
	max-width: var(--container);
	margin: 0 auto;
	padding-left: var(--gutter);
	padding-right: var(--gutter);
}
.container--wide { max-width: var(--container-wide); }
.container--reading { max-width: calc(var(--reading) + var(--gutter) * 2); }
.center { text-align: center; }
.measure { max-width: var(--measure); }

/* Eyebrow / index label — editorial small-caps with optional index number */
.eyebrow {
	display: flex;
	align-items: baseline;
	gap: 0.9rem;
	font-family: var(--font-sans);
	font-size: var(--fs-eyebrow);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: var(--ls-eyebrow);
	color: var(--ink-faint);
	margin: 0 0 1.6rem;
}
.eyebrow__index {
	font-family: var(--font-display);
	font-size: 0.9rem;
	font-weight: 500;
	color: var(--green);
	letter-spacing: 0;
}
.eyebrow--green { color: var(--green); }

.display { font-size: var(--fs-display); line-height: var(--lh-tight); letter-spacing: var(--ls-display); }
.lede {
	font-size: var(--fs-lede);
	color: var(--ink-soft);
	line-height: 1.5;
	max-width: 52ch;
	font-weight: 400;
}

/* Italic emphasis in display type — Fraunces italic reads as warmth */
.em-italic { font-style: italic; font-weight: 400; }
.text-green { color: var(--green); }
.text-sand { color: var(--sand-deep); }

/* ==========================================================================
   Buttons — editorial, restrained
   ========================================================================== */
.btn {
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
	padding: 0.95rem 1.6rem;
	font-family: var(--font-sans);
	font-size: 0.92rem;
	font-weight: 600;
	letter-spacing: 0.01em;
	line-height: 1;
	border-radius: var(--radius);
	border: 1px solid transparent;
	transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease), transform var(--dur) var(--ease);
	cursor: pointer;
	white-space: nowrap;
}
.btn:focus-visible { outline: 2px solid var(--green); outline-offset: 3px; }

.btn--primary { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.btn--primary:hover { background: var(--green); border-color: var(--green); }

.btn--line { background: transparent; color: var(--ink); border-color: var(--line-strong); }
.btn--line:hover { background: var(--ink); color: var(--paper); border-color: var(--ink); }

/* Legacy alias so any .btn--ghost in markup still looks right */
.btn--ghost { background: transparent; color: var(--ink); border-color: var(--line-strong); }
.btn--ghost:hover { background: var(--ink); color: var(--paper); border-color: var(--ink); }

.btn--block { width: 100%; justify-content: center; }
.btn__arrow { display: inline-block; transition: transform var(--dur) var(--ease); }
.btn:hover .btn__arrow { transform: translateX(4px); }

/* Text link CTA — the soft / tertiary action */
.link-cta {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-weight: 600;
	font-size: 0.95rem;
	color: var(--ink);
	padding-bottom: 3px;
	border-bottom: 1px solid var(--line-strong);
	transition: border-color var(--dur) var(--ease), gap var(--dur) var(--ease);
}
.link-cta:hover { border-color: var(--green); color: var(--green); gap: 0.75rem; }
.link-cta__arrow { color: var(--sand-deep); transition: transform var(--dur) var(--ease); }
.link-cta:hover .link-cta__arrow { transform: translateX(3px); }

.cta-row { display: flex; flex-wrap: wrap; gap: 1rem 1.5rem; align-items: center; margin-top: 2.25rem; }

/* ==========================================================================
   Header — light, editorial
   ========================================================================== */
.site-header {
	position: fixed;
	top: 0; left: 0; right: 0;
	z-index: 80;
	height: var(--header-h);
	transition: height var(--dur) var(--ease), background var(--dur) var(--ease), border-color var(--dur) var(--ease);
	border-bottom: 1px solid transparent;
}
.site-header.is-scrolled {
	height: var(--header-h-min);
	background: rgba(247, 244, 238, 0.86);
	backdrop-filter: saturate(120%) blur(14px);
	-webkit-backdrop-filter: saturate(120%) blur(14px);
	border-bottom-color: var(--line);
}
.site-header__inner {
	height: 100%;
	max-width: var(--container-wide);
	margin: 0 auto;
	padding: 0 var(--gutter);
	display: grid;
	grid-template-columns: auto 1fr auto auto;
	align-items: center;
	gap: 1.5rem;
}
.site-header__brand {
	display: inline-flex;
	align-items: baseline;
	gap: 0.55rem;
	font-family: var(--font-display);
	font-weight: 500;
	font-size: 1.15rem;
	letter-spacing: var(--ls-tight);
	color: var(--ink);
}
.site-header__brand .brand-initials {
	color: var(--green);
	font-weight: 600;
}
.brand-word { font-size: 1.15rem; }

.site-nav { justify-self: center; }
.site-nav__list { display: flex; gap: 2.2rem; align-items: center; }
.site-nav__list a {
	font-size: 0.92rem;
	font-weight: 500;
	color: var(--ink-soft);
	position: relative;
	padding: 6px 0;
}
.site-nav__list a::after {
	content: "";
	position: absolute; left: 0; right: 0; bottom: 0;
	height: 1px; background: var(--green);
	transform: scaleX(0); transform-origin: left;
	transition: transform var(--dur) var(--ease);
}
.site-nav__list a:hover { color: var(--ink); }
.site-nav__list a:hover::after,
.site-nav__list a[aria-current="page"]::after,
.site-nav__list .current-menu-item > a::after { transform: scaleX(1); }

.site-header__cta { display: flex; align-items: center; gap: 0.65rem; }
.site-header__cta .btn--line { display: none; }
@media (min-width: 1100px) { .site-header__cta .btn--line { display: inline-flex; } }

.site-header__toggle {
	display: none;
	width: 44px; height: 44px;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 5px;
}
.site-header__toggle .bar {
	display: block; width: 24px; height: 1.5px; background: var(--ink);
	transition: transform var(--dur) var(--ease), opacity var(--dur) var(--ease);
}
.site-header__toggle[aria-expanded="true"] .bar:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.site-header__toggle[aria-expanded="true"] .bar:nth-child(2) { opacity: 0; }
.site-header__toggle[aria-expanded="true"] .bar:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

@media (max-width: 1024px) {
	.site-nav { display: none; }
	.site-header__cta .btn--line { display: none; }
	.site-header__toggle { display: inline-flex; }
}
@media (max-width: 560px) {
	.site-header__cta .btn--primary { display: none; }
}

/* ==========================================================================
   Mobile menu
   ========================================================================== */
.mobile-menu {
	position: fixed; inset: 0;
	background: var(--paper);
	z-index: 70;
	padding: calc(var(--header-h) + 1.5rem) var(--gutter) 2rem;
	display: flex; flex-direction: column;
	overflow-y: auto;
	opacity: 0; transform: translateY(-10px);
	transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.mobile-menu[hidden] { display: none !important; }
.mobile-menu.is-open { opacity: 1; transform: translateY(0); }
.mobile-menu__inner { display: flex; flex-direction: column; gap: 2.5rem; max-width: 600px; margin: 0 auto; width: 100%; }
.mobile-menu__list { display: flex; flex-direction: column; }
.mobile-menu__list a {
	display: flex; align-items: baseline; gap: 1rem;
	padding: 1rem 0;
	font-family: var(--font-display);
	font-size: clamp(1.8rem, 7vw, 2.6rem);
	font-weight: 500;
	letter-spacing: var(--ls-tight);
	border-bottom: 1px solid var(--line);
	counter-increment: mm;
}
.mobile-menu__list a::before {
	content: counter(mm, decimal-leading-zero);
	font-family: var(--font-sans);
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--ink-faint);
	letter-spacing: 0.1em;
}
.mobile-menu__list { counter-reset: mm; }
.mobile-menu__cta { display: grid; gap: 0.75rem; }
.mobile-menu__social {
	display: flex; gap: 1.5rem;
	padding-top: 1.5rem; border-top: 1px solid var(--line);
	color: var(--ink-faint); font-size: 0.9rem;
}
body.menu-open { overflow: hidden; }

/* Sticky mobile book */
.sticky-book {
	display: none;
	position: fixed; bottom: 16px; left: 16px; right: 16px;
	z-index: 60;
	padding: 1.05rem 1.4rem;
	background: var(--ink); color: var(--paper);
	border-radius: var(--radius);
	font-weight: 600; font-size: 0.95rem;
	align-items: center; justify-content: space-between;
	box-shadow: 0 14px 34px rgba(28, 33, 28, 0.22);
	transform: translateY(150%);
	transition: transform var(--dur-slow) var(--ease);
}
.sticky-book.is-visible { transform: translateY(0); }
@media (max-width: 720px) { .sticky-book { display: flex; } }

.site-main { padding-top: var(--header-h); }

/* ==========================================================================
   Section scaffolding — editorial, indexed
   ========================================================================== */
.section { padding: var(--section-y) 0; position: relative; }
.section--tight { padding: clamp(3.5rem, 7vw, 6rem) 0; }
.section--paper-2 { background: var(--paper-2); }
.section--rule { border-top: 1px solid var(--line); }

/* Section heading block */
.s-head { max-width: 760px; margin-bottom: clamp(2.5rem, 5vw, 4.5rem); }
.s-head--wide { max-width: 920px; }
.s-head__title { font-size: var(--fs-h2); line-height: var(--lh-snug); letter-spacing: var(--ls-tight); }
.s-head__lede { font-size: var(--fs-lede); color: var(--ink-soft); margin-top: 1.25rem; line-height: 1.5; max-width: 56ch; }

/* ==========================================================================
   HERO — type-led editorial split (light)
   ========================================================================== */
.hero {
	position: relative;
	padding-top: clamp(3rem, 8vw, 6rem);
	padding-bottom: clamp(3rem, 7vw, 5.5rem);
	overflow: hidden;
}
.hero__grid {
	display: grid;
	grid-template-columns: 1.05fr 0.95fr;
	gap: clamp(2rem, 5vw, 5rem);
	align-items: center;
	min-height: calc(82vh - var(--header-h));
	min-height: calc(82dvh - var(--header-h));
}
.hero__eyebrow {
	display: inline-flex; align-items: center; gap: 0.75rem;
	font-size: var(--fs-eyebrow); font-weight: 600;
	text-transform: uppercase; letter-spacing: var(--ls-eyebrow);
	color: var(--ink-faint); margin-bottom: 1.75rem;
}
.hero__eyebrow::before { content: ""; width: 30px; height: 1px; background: var(--sand); }
.hero__title {
	font-size: var(--fs-h1);
	line-height: var(--lh-tight);
	letter-spacing: var(--ls-display);
	font-weight: 400;
	max-width: 14ch;
}
.hero__title .em-italic { color: var(--green); }
.hero__sub { font-size: var(--fs-lede); color: var(--ink-soft); max-width: 44ch; margin-top: 1.75rem; line-height: 1.5; }
.hero__cta { display: flex; flex-wrap: wrap; gap: 1rem 1.5rem; align-items: center; margin-top: 2.5rem; }
.hero__proof {
	display: flex; flex-wrap: wrap; gap: 0.5rem 1.5rem;
	margin-top: 3rem; padding-top: 1.75rem;
	border-top: 1px solid var(--line);
	font-size: 0.82rem; color: var(--ink-soft); letter-spacing: 0.01em;
}
.hero__proof li { position: relative; padding-left: 16px; }
.hero__proof li::before {
	content: ""; position: absolute; left: 0; top: 0.5em;
	width: 6px; height: 6px; border-radius: 50%; background: var(--green-mid);
}
.hero__media {
	position: relative;
	border-radius: var(--radius-img);
	overflow: hidden;
	aspect-ratio: 4/5;
	background: var(--paper-2);
}
.hero__media .hwg-image, .hero__media picture, .hero__media img { width: 100%; height: 100%; object-fit: cover; }
/* Hero ball-flight arc accent */
.hero__arc { position: absolute; right: -4%; top: -6%; width: 46%; height: auto; pointer-events: none; z-index: -1; color: var(--sand); opacity: 0.5; }

@media (max-width: 880px) {
	.hero__grid { grid-template-columns: 1fr; min-height: 0; gap: 2.5rem; }
	.hero__media { aspect-ratio: 16/11; order: -1; }
	.hero__title { max-width: 18ch; }
}

/* ==========================================================================
   "The Line" — signature swing-path SVG
   ========================================================================== */
.the-line { position: relative; }
/* The signature swing-path threads down the left number column as a fine,
   quiet sand hairline. non-scaling-stroke keeps it 1.5px despite the
   non-uniform viewBox stretch. */
.the-line__svg {
	position: absolute;
	left: 0; top: 0;
	width: clamp(3.5rem, 6vw, 6rem);
	height: 100%;
	pointer-events: none;
	overflow: visible;
	z-index: 0;
}
.the-line__path {
	fill: none;
	stroke: var(--sand);
	stroke-width: 1.5;
	stroke-linecap: round;
	vector-effect: non-scaling-stroke;
	stroke-dasharray: var(--len, 1200);
	stroke-dashoffset: var(--len, 1200);
	transition: stroke-dashoffset 1.8s var(--ease-soft);
	opacity: 0.6;
}
.the-line.is-drawn .the-line__path { stroke-dashoffset: 0; }
/* Keep content above the line, but DON'T clobber the SVG's absolute position. */
.the-line > :not(.the-line__svg) { position: relative; z-index: 1; }
@media (max-width: 640px) { .the-line__svg { display: none; } }

/* ==========================================================================
   THE HW METHOD — numbered editorial sequence
   ========================================================================== */
.method { counter-reset: method; display: grid; gap: clamp(2.5rem, 5vw, 4rem); }
.method__step {
	display: grid;
	grid-template-columns: minmax(0, 6rem) 1fr;
	gap: clamp(1.5rem, 4vw, 3.5rem);
	align-items: start;
	padding-bottom: clamp(2.5rem, 5vw, 4rem);
	border-bottom: 1px solid var(--line);
}
.method__step:last-child { border-bottom: 0; padding-bottom: 0; }
.method__num {
	counter-increment: method;
	font-family: var(--font-display);
	font-size: clamp(2.5rem, 5vw, 4rem);
	font-weight: 400;
	line-height: 1;
	color: var(--green);
	font-style: italic;
}
.method__num::before { content: counter(method, decimal-leading-zero); }
.method__body { max-width: 60ch; }
.method__title { font-size: var(--fs-h3); margin-bottom: 0.75rem; }
.method__text { color: var(--ink-soft); font-size: 1.1rem; }
.method__tag {
	display: inline-block; margin-top: 1.25rem;
	font-size: 0.78rem; letter-spacing: 0.06em; text-transform: uppercase;
	color: var(--ink-faint);
}
@media (max-width: 640px) {
	.method__step { grid-template-columns: 1fr; gap: 0.75rem; }
}

/* ==========================================================================
   EDITORIAL ROWS — coaching paths (alternating image/text)
   ========================================================================== */
.rows { display: grid; gap: clamp(3rem, 6vw, 6rem); }
.row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(2rem, 5vw, 5rem);
	align-items: center;
}
.row:nth-child(even) .row__media { order: 2; }
.row__media {
	position: relative;
	border-radius: var(--radius-img);
	overflow: hidden;
	aspect-ratio: 5/4;
	background: var(--paper-2);
}
.row__media .hwg-image, .row__media picture, .row__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 1s var(--ease); }
.row:hover .row__media img { transform: scale(1.03); }
.row__index {
	font-family: var(--font-display);
	font-style: italic;
	font-size: 1.1rem;
	color: var(--sand-deep);
	margin-bottom: 1rem;
}
.row__title { font-size: var(--fs-h3); margin-bottom: 1rem; }
.row__text { color: var(--ink-soft); font-size: 1.08rem; max-width: 46ch; margin-bottom: 1.75rem; }
@media (max-width: 760px) {
	.row { grid-template-columns: 1fr; gap: 1.75rem; }
	.row:nth-child(even) .row__media { order: -1; }
	.row__media { aspect-ratio: 16/11; }
}

/* ==========================================================================
   CREDENTIALS — typeset masthead (not a card grid)
   ========================================================================== */
.masthead { border-top: 1px solid var(--ink); border-bottom: 1px solid var(--ink); }
.masthead__list {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
}
.masthead__item {
	padding: 1.75rem 1.5rem 1.75rem 0;
	border-bottom: 1px solid var(--line);
	border-right: 1px solid var(--line);
}
.masthead__item:nth-child(3n) { border-right: 0; }
.masthead__label {
	font-size: 0.72rem; text-transform: uppercase; letter-spacing: var(--ls-eyebrow);
	color: var(--ink-faint); margin-bottom: 0.5rem;
}
.masthead__name { font-family: var(--font-display); font-size: 1.2rem; font-weight: 500; }
@media (max-width: 720px) {
	.masthead__list { grid-template-columns: repeat(2, 1fr); }
	.masthead__item:nth-child(3n) { border-right: 1px solid var(--line); }
	.masthead__item:nth-child(2n) { border-right: 0; }
}
@media (max-width: 440px) {
	.masthead__list { grid-template-columns: 1fr; }
	.masthead__item { border-right: 0 !important; }
}

/* Quiet stat figures */
.figures { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1.5rem, 4vw, 3rem); margin-top: 4rem; }
.figure__num {
	font-family: var(--font-display); font-weight: 400;
	font-size: clamp(2.4rem, 5vw, 3.4rem); line-height: 1;
	color: var(--ink); letter-spacing: var(--ls-tight); margin-bottom: 0.6rem;
}
.figure__num .unit { color: var(--sand-deep); }
.figure__label { color: var(--ink-soft); font-size: 0.92rem; }
@media (max-width: 640px) { .figures { grid-template-columns: 1fr 1fr; gap: 2rem; } }

/* ==========================================================================
   PULL-QUOTES / testimonials — woven, not boxed
   ========================================================================== */
.pullquote { max-width: 22ch; }
.pullquote__mark { font-family: var(--font-display); font-size: 3rem; line-height: 0; color: var(--sand); display: block; height: 1.4rem; }
.pullquote__text { font-family: var(--font-display); font-weight: 400; font-size: clamp(1.6rem, 3.5vw, 2.6rem); line-height: 1.22; letter-spacing: var(--ls-tight); }

.quotes { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.5rem, 4vw, 3rem); }
.quote { display: flex; flex-direction: column; gap: 1.25rem; }
.quote__text { font-family: var(--font-display); font-size: 1.3rem; line-height: 1.35; font-weight: 400; }
.quote__text::before { content: "“"; color: var(--sand); }
.quote__text::after { content: "”"; color: var(--sand); }
.quote__by { margin-top: auto; padding-top: 1.25rem; border-top: 1px solid var(--line); }
.quote__name { font-weight: 600; font-size: 0.95rem; }
.quote__meta { color: var(--ink-faint); font-size: 0.82rem; margin-top: 2px; }
@media (max-width: 860px) { .quotes { grid-template-columns: 1fr; gap: 2.5rem; } }

/* ==========================================================================
   PROCESS STEPS — calm numbered (Skillest)
   ========================================================================== */
.steps { counter-reset: step; display: grid; gap: 0; }
.step {
	counter-increment: step;
	display: grid;
	grid-template-columns: 4rem 1fr;
	gap: 1.5rem;
	padding: 1.6rem 0;
	border-top: 1px solid var(--line);
	align-items: baseline;
}
.step:last-child { border-bottom: 1px solid var(--line); }
.step__num { font-family: var(--font-display); font-style: italic; font-size: 1.5rem; color: var(--green); }
.step__num::before { content: counter(step, decimal-leading-zero); }
.step__title { font-size: 1.15rem; font-weight: 600; margin-bottom: 0.3rem; font-family: var(--font-sans); }
.step__text { color: var(--ink-soft); font-size: 1rem; }
@media (max-width: 540px) { .step { grid-template-columns: 2.5rem 1fr; gap: 1rem; } }

/* Two-column editorial split content (e.g. Skillest copy + steps) */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2.5rem, 6vw, 6rem); align-items: center; }
.split--portrait { grid-template-columns: 0.9fr 1.1fr; align-items: stretch; }
@media (max-width: 860px) { .split, .split--portrait { grid-template-columns: 1fr; gap: 2.5rem; } }

/* ==========================================================================
   ABOUT — portrait + serif story
   ========================================================================== */
.about__portrait { position: relative; border-radius: var(--radius-img); overflow: hidden; aspect-ratio: 4/5; background: var(--paper-2); }
.about__portrait .hwg-image, .about__portrait picture, .about__portrait img { width: 100%; height: 100%; object-fit: cover; }
.about__body h2 { font-size: var(--fs-h2); margin-bottom: 1.5rem; }
.about__body p { color: var(--ink-soft); margin-bottom: 1.1rem; font-size: 1.08rem; }
.about__sig { margin-top: 1.75rem; font-family: var(--font-display); font-style: italic; font-size: 1.6rem; color: var(--green); }

/* ==========================================================================
   PAGE HERO (interior pages) — editorial
   ========================================================================== */
.page-hero { padding: clamp(8rem, 15vw, 12rem) 0 clamp(2.5rem, 5vw, 4rem); }
.page-hero__title { font-size: var(--fs-h1); line-height: var(--lh-tight); letter-spacing: var(--ls-display); font-weight: 400; max-width: 16ch; }
.page-hero__title .em-italic { color: var(--green); }
.page-hero__lede { font-size: var(--fs-lede); color: var(--ink-soft); margin-top: 1.5rem; max-width: 56ch; line-height: 1.5; }
.page-hero__cta { margin-top: 2.25rem; display: flex; flex-wrap: wrap; gap: 1rem 1.5rem; align-items: center; }

/* ==========================================================================
   FINAL CTA — calm invitation
   ========================================================================== */
.invite { padding: var(--section-y) 0; text-align: center; }
.invite__inner { max-width: 760px; margin: 0 auto; }
.invite__title { font-size: var(--fs-h1); line-height: var(--lh-tight); letter-spacing: var(--ls-display); font-weight: 400; }
.invite__title .em-italic { color: var(--green); }
.invite__copy { font-size: var(--fs-lede); color: var(--ink-soft); margin: 1.5rem auto 0; max-width: 48ch; }
.invite__cta { display: flex; justify-content: center; flex-wrap: wrap; gap: 1rem 1.5rem; align-items: center; margin-top: 2.5rem; }

/* ==========================================================================
   FORMS
   ========================================================================== */
.form { display: grid; gap: 1.25rem; max-width: 640px; }
.form__field { display: flex; flex-direction: column; gap: 0.45rem; }
.form__label { font-size: 0.82rem; font-weight: 600; color: var(--ink-soft); letter-spacing: 0.01em; }
.form__input, .form__select, .form__textarea {
	background: var(--raised);
	border: 1px solid var(--line-strong);
	color: var(--ink);
	padding: 0.9rem 1rem;
	border-radius: var(--radius);
	font-family: inherit; font-size: 1rem;
	transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.form__input:focus, .form__select:focus, .form__textarea:focus { outline: none; border-color: var(--green); background: #fff; }
.form__textarea { min-height: 150px; resize: vertical; }
.form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
@media (max-width: 600px) { .form__row { grid-template-columns: 1fr; } }
.form__notice { padding: 1rem 1.25rem; border-radius: var(--radius); border: 1px solid var(--green-mid); background: rgba(110, 126, 99, 0.08); color: var(--ink-soft); }
.form__notice--error { border-color: #c0654a; background: rgba(192, 101, 74, 0.08); }

/* ==========================================================================
   IMAGE + placeholder
   ========================================================================== */
.hwg-image { display: block; width: 100%; overflow: hidden; border-radius: inherit; background: var(--paper-2); }
.hwg-image--placeholder {
	display: grid; place-items: center;
	color: var(--ink-faint);
	border: 1px dashed var(--line-strong);
	background:
		repeating-linear-gradient(45deg, var(--paper-2) 0, var(--paper-2) 10px, var(--paper) 10px, var(--paper) 20px);
	text-align: center; padding: 1rem;
}
.hwg-image__slot { font-family: var(--font-sans); font-size: 0.85rem; font-weight: 600; color: var(--ink-soft); }
.hwg-image__hint { display: block; font-size: 0.7rem; margin-top: 6px; color: var(--ink-faint); letter-spacing: var(--ls-eyebrow); text-transform: uppercase; }

/* ==========================================================================
   FAQ — editorial accordion
   ========================================================================== */
.faqs { display: grid; }
.faq { border-top: 1px solid var(--line); }
.faq:last-child { border-bottom: 1px solid var(--line); }
.faq__q {
	width: 100%; text-align: left;
	padding: 1.5rem 0;
	display: flex; align-items: baseline; justify-content: space-between; gap: 1.5rem;
	font-family: var(--font-display); font-size: clamp(1.15rem, 2.2vw, 1.4rem); font-weight: 500;
	color: var(--ink);
}
.faq__q::after { content: "+"; font-family: var(--font-sans); font-size: 1.5rem; color: var(--green); transition: transform var(--dur) var(--ease); font-weight: 300; }
.faq[open] .faq__q::after { transform: rotate(45deg); }
.faq__a { padding: 0 0 1.5rem; color: var(--ink-soft); max-width: var(--measure); font-size: 1.05rem; }
details.faq summary { list-style: none; cursor: pointer; }
details.faq summary::-webkit-details-marker { display: none; }

/* ==========================================================================
   AUDIENCE / value cards — editorial (no icon-card cliché)
   ========================================================================== */
.notes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--line); }
.note { padding: 2rem 1.75rem 2rem 0; border-bottom: 1px solid var(--line); border-right: 1px solid var(--line); }
.note:nth-child(3n) { border-right: 0; padding-right: 0; }
.note__index { font-family: var(--font-display); font-style: italic; color: var(--sand-deep); font-size: 1rem; margin-bottom: 0.85rem; }
.note__title { font-size: 1.2rem; font-weight: 500; margin-bottom: 0.5rem; font-family: var(--font-display); }
.note__text { color: var(--ink-soft); font-size: 0.98rem; }
@media (max-width: 820px) { .notes { grid-template-columns: 1fr 1fr; } .note:nth-child(3n) { border-right: 1px solid var(--line); padding-right: 1.75rem; } .note:nth-child(2n) { border-right: 0; padding-right: 0; } }
@media (max-width: 520px) { .notes { grid-template-columns: 1fr; } .note { border-right: 0 !important; padding-right: 0 !important; } }

/* ==========================================================================
   VIDEO grid (tips) — editorial
   ========================================================================== */
.videos { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.25rem, 3vw, 2rem); }
.video-card { display: block; }
.video-card__media { position: relative; aspect-ratio: 16/9; border-radius: var(--radius-img); overflow: hidden; background: var(--paper-2); }
.video-card__media .hwg-image, .video-card__media picture, .video-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.9s var(--ease); }
.video-card:hover .video-card__media img { transform: scale(1.04); }
.video-card__play {
	position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
	width: 56px; height: 56px; border-radius: 50%;
	background: rgba(247, 244, 238, 0.92); color: var(--ink);
	display: grid; place-items: center;
	transition: transform var(--dur) var(--ease), background var(--dur) var(--ease);
}
.video-card:hover .video-card__play { transform: translate(-50%, -50%) scale(1.08); background: var(--sand); }
.video-card__title { margin-top: 1rem; font-family: var(--font-display); font-size: 1.1rem; font-weight: 500; }
.video-card__meta { color: var(--ink-faint); font-size: 0.82rem; margin-top: 0.25rem; }
@media (max-width: 860px) { .videos { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .videos { grid-template-columns: 1fr; } }

/* Tip cards (IG vertical) */
.tips-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.25rem, 3vw, 2rem); }
.tip-card { display: block; }
.tip-card__media { aspect-ratio: 4/5; border-radius: var(--radius-img); overflow: hidden; background: var(--paper-2); }
.tip-card__media .hwg-image, .tip-card__media picture, .tip-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.9s var(--ease); }
.tip-card:hover .tip-card__media img { transform: scale(1.04); }
.tip-card__cat { margin-top: 1rem; font-size: 0.72rem; text-transform: uppercase; letter-spacing: var(--ls-eyebrow); color: var(--sand-deep); }
.tip-card__title { font-family: var(--font-display); font-size: 1.1rem; font-weight: 500; margin-top: 0.4rem; }
@media (max-width: 860px) { .tips-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .tips-grid { grid-template-columns: 1fr; } }

/* ==========================================================================
   LEAD MAGNET
   ========================================================================== */
.lead-magnet { display: grid; grid-template-columns: 1.3fr 0.7fr; gap: clamp(2rem, 5vw, 4rem); align-items: center; padding: clamp(2rem, 5vw, 3.5rem); background: var(--paper-2); border-radius: var(--radius-lg); }
.lead-magnet h2 { font-size: var(--fs-h3); margin-bottom: 1rem; }
.lead-magnet p { color: var(--ink-soft); margin-bottom: 1.75rem; max-width: 44ch; }
.lead-magnet__form { display: flex; gap: 0.6rem; max-width: 460px; flex-wrap: wrap; }
.lead-magnet__form input { flex: 1; min-width: 200px; background: var(--raised); border: 1px solid var(--line-strong); color: var(--ink); padding: 0.9rem 1rem; border-radius: var(--radius); font-family: inherit; font-size: 0.95rem; }
.lead-magnet__form input:focus { outline: none; border-color: var(--green); }
.lead-magnet__visual { aspect-ratio: 3/4; border-radius: var(--radius-img); overflow: hidden; }
@media (max-width: 760px) { .lead-magnet { grid-template-columns: 1fr; } .lead-magnet__visual { max-width: 240px; } }

/* ==========================================================================
   Contact
   ========================================================================== */
.contact-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: clamp(2.5rem, 6vw, 5rem); }
.contact-info { display: grid; gap: 1.75rem; align-content: start; }
.contact-info__item h3 { font-family: var(--font-sans); font-size: 0.74rem; text-transform: uppercase; letter-spacing: var(--ls-eyebrow); color: var(--ink-faint); margin-bottom: 0.5rem; font-weight: 600; }
.contact-info__item p, .contact-info__item a { font-size: 1.1rem; color: var(--ink); }
.contact-info__item a:hover { color: var(--green); }
@media (max-width: 860px) { .contact-grid { grid-template-columns: 1fr; } }

/* ==========================================================================
   WP content (page-body, single)
   ========================================================================== */
.page-body { padding: clamp(2rem, 5vw, 3.5rem) 0 var(--section-y); }
.page-body h2 { font-size: var(--fs-h3); margin: 2.5rem 0 1rem; }
.page-body h3 { font-size: var(--fs-h4); margin: 2rem 0 0.75rem; }
.page-body p { color: var(--ink-soft); font-size: 1.1rem; line-height: 1.7; margin-bottom: 1.25rem; }
.page-body a { color: var(--green); text-decoration: underline; text-underline-offset: 3px; }
.page-body ul { padding-left: 1.25rem; list-style: disc; color: var(--ink-soft); margin-bottom: 1.25rem; }
.page-body li { margin-bottom: 0.45rem; }
.page-body blockquote { border-left: 2px solid var(--sand); padding-left: 1.5rem; margin: 2rem 0; font-family: var(--font-display); font-size: 1.4rem; color: var(--ink); }
.single__thumb { margin-top: 2rem; border-radius: var(--radius-img); overflow: hidden; aspect-ratio: 16/9; }
.single__thumb img { width: 100%; height: 100%; object-fit: cover; }

/* ==========================================================================
   Footer — light editorial
   ========================================================================== */
.site-footer { background: var(--paper-2); border-top: 1px solid var(--line); padding: clamp(4rem, 8vw, 6rem) 0 2.5rem; }
.site-footer__inner { max-width: var(--container-wide); margin: 0 auto; padding: 0 var(--gutter); }
.site-footer__grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 2.5rem; padding-bottom: 3rem; border-bottom: 1px solid var(--line); }
.site-footer__brand { display: inline-flex; align-items: baseline; gap: 0.5rem; font-family: var(--font-display); font-size: 1.3rem; font-weight: 500; margin-bottom: 1rem; }
.site-footer__brand .brand-initials { color: var(--green); font-weight: 600; }
.site-footer__col--brand p { color: var(--ink-soft); max-width: 34ch; font-size: 0.98rem; }
.site-footer__col h3 { font-family: var(--font-sans); font-size: 0.72rem; text-transform: uppercase; letter-spacing: var(--ls-eyebrow); color: var(--ink-faint); margin-bottom: 1.1rem; font-weight: 600; }
.site-footer__col ul { display: grid; gap: 0.7rem; }
.site-footer__col a { color: var(--ink-soft); font-size: 0.96rem; }
.site-footer__col a:hover { color: var(--ink); }
.site-footer__base { margin-top: 2.5rem; display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; color: var(--ink-faint); font-size: 0.84rem; }
@media (max-width: 880px) { .site-footer__grid { grid-template-columns: 1fr 1fr; gap: 2rem; } }
@media (max-width: 520px) { .site-footer__grid { grid-template-columns: 1fr; } }

/* ==========================================================================
   Reveal animations — editorial (clip + rise)
   ========================================================================== */
[data-reveal] { opacity: 0; transform: translateY(20px); transition: opacity var(--dur-slow) var(--ease), transform var(--dur-slow) var(--ease); will-change: opacity, transform; }
[data-reveal].is-revealed { opacity: 1; transform: none; }
[data-reveal-delay="1"] { transition-delay: 90ms; }
[data-reveal-delay="2"] { transition-delay: 180ms; }
[data-reveal-delay="3"] { transition-delay: 270ms; }
[data-reveal-delay="4"] { transition-delay: 360ms; }

/* Image clip reveal */
[data-reveal-img] { clip-path: inset(0 0 100% 0); transition: clip-path 1.1s var(--ease); }
[data-reveal-img].is-revealed { clip-path: inset(0 0 0 0); }

@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; }
	[data-reveal], [data-reveal-img] { opacity: 1; transform: none; clip-path: none; }
	.the-line__path { stroke-dashoffset: 0 !important; }
}

/* ==========================================================================
   404
   ========================================================================== */
.section--404 { min-height: 70vh; display: grid; place-items: center; text-align: center; }
.section--404 .display { margin: 1rem 0; }

/* Utilities */
.divider { height: 1px; background: var(--line); border: 0; margin: 0; }
.mt-lg { margin-top: clamp(2.5rem, 5vw, 4rem); }
