/* ===== Base / layout / components — built on tokens.css =====
   Mobile-first, semantic, accessible. Animate only transform/opacity.
   ONE warm system: cream surfaces, espresso ink, terracotta as the single accent. */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);font-size:var(--step-0);line-height:1.65;color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
h1,h2,h3{font-family:var(--font-head);color:var(--brand-ink);line-height:1.08;margin:0 0 .4em;font-weight:600}
/* Fraunces' display ampersand is an ornate swash that reads as a broken glyph — set ampersands in italic Inter instead (clean, still characterful) */
.amp{font-family:var(--font-body);font-style:italic;font-weight:600;font-size:.92em;letter-spacing:0}
p{margin:0 0 1em;max-width:var(--measure)}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
:focus-visible{outline:3px solid var(--brand);outline-offset:2px;border-radius:4px}
.wrap{width:min(1120px,90vw);margin-inline:auto}
.skip{position:absolute;left:-999px;top:0;background:var(--brand);color:#fff;padding:.6rem 1rem;z-index:100}
.skip:focus{left:0}

/* eyebrow label — the editorial signpost above each section head */
/* eyebrows appear ~7×; keep them quiet warm-ink so rust stays reserved for actions + the one hero accent */
.eyebrow{display:inline-block;font-family:var(--font-body);font-weight:600;font-size:var(--step--1);
  letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);margin:0 0 .9rem;position:relative;padding-left:1.5rem}
.eyebrow::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:1rem;height:2px;background:var(--brand);opacity:.7}

/* ===== Buttons — ONE dominant primary, isolated, thumb-sized (L31) ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font:600 var(--step-0)/1 var(--font-body);padding:.9em 1.6em;border-radius:999px;
  border:1px solid transparent;cursor:pointer;transition:transform .15s var(--ease),box-shadow .15s var(--ease),background .15s var(--ease);min-height:48px;text-decoration:none}
.btn:hover{transform:translateY(-1px);text-decoration:none}
.btn--primary{background:var(--brand);color:#fff;box-shadow:var(--shadow-cta)}
.btn--primary:hover{background:var(--brand-deep)}
.btn--lg{padding:1.05em 2.1em;font-size:var(--step-1)}

/* ===== Nav ===== */
.nav{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--paper) 90%,transparent);backdrop-filter:saturate(1.1) blur(10px);border-bottom:1px solid var(--line)}
.nav__inner{display:flex;align-items:center;gap:var(--s3);min-height:66px}
.nav__brand{display:flex;align-items:center}
.nav__links{display:none;gap:var(--s4);margin-left:auto}
.nav__links a{color:var(--ink);font-weight:500}
.nav__links a:hover{color:var(--brand);text-decoration:none}
.nav__cta{margin-left:auto;padding:.6em 1.2em;min-height:42px}
@media(min-width:780px){ .nav__links{display:flex} .nav__cta{margin-left:0} }

/* ===== Sections — fluid vertical rhythm, generous + consistent ===== */
section{padding:clamp(3rem,2rem+4vw,5.5rem) 0}
/* section heads pulled DOWN a step so the hero (6.6rem) + guarantee (4rem) own the top of the modular scale and these read as true sub-heads, not competing display (gate: flat hierarchy) */
.section__h2{font-size:var(--step-2);margin:0 0 clamp(1.5rem,1rem+1.8vw,2.5rem);max-width:20ch;text-wrap:balance;letter-spacing:-.01em;font-weight:600}

/* ===== Hero — light editorial split: copy on cream, photo in a card (Tracy-style) ===== */
.hero--split{background:var(--paper);overflow:hidden}
.hero--split .hero__inner{display:grid;grid-template-columns:1fr;gap:clamp(2rem,1.4rem+3vw,3.5rem);align-items:stretch;
  padding-top:clamp(2.5rem,1.6rem+3.5vw,5rem);padding-bottom:clamp(2.5rem,1.6rem+3.5vw,5rem)}
.hero--split .hero__copy{max-width:56ch;display:flex;flex-direction:column;justify-content:center}
/* hero headline must be THE image — let the serif physically dominate the upper-left (ref bar: Tonic/Tracy) */
.hero--split .hero__h1{color:var(--brand-ink);font-size:clamp(2.9rem,1.6rem+6vw,6.6rem);line-height:.96;letter-spacing:-.035em;text-wrap:balance;margin:0;font-weight:600}
.hero--split .hero__h1 em{font-style:italic;color:var(--brand)}
.hero--split .hero__sub{color:var(--ink-2);font-size:var(--step-1);max-width:46ch;margin-top:var(--s3);line-height:1.6}
.hero__fig{margin:0;position:relative;border-radius:calc(var(--radius) * 1.1);overflow:hidden;
  box-shadow:0 26px 60px -18px rgba(42,37,32,.32);aspect-ratio:4/3}
.hero__fig .hero__bg{display:block;width:100%;height:100%;object-fit:cover;object-position:64% 50%}
/* borderless rust-ruled label (NOT a pill) — matches the .eyebrow signpost used site-wide; kills the SaaS chip tell */
.hero__badge{display:inline-flex;align-items:center;gap:.7em;color:var(--brand-ink);
  font-weight:600;font-size:var(--step--1);margin-bottom:var(--s3);letter-spacing:.01em;line-height:1.3}
.hero__badge::before{content:"";flex:0 0 auto;width:1.6rem;height:2px;background:var(--brand)}
.hero__badge b{color:var(--brand);font-weight:600}
.hero__cta{display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;gap:.9rem;margin-top:var(--s4)}
/* anchor the bottom-left so the hero column fills its height (kills the L-shaped void next to the tall photo) */
.hero__trust{font-size:var(--step--1);color:var(--ink-2);margin:var(--s4) 0 0;padding-top:var(--s3);border-top:1px solid var(--line)}
.btn--ghost{background:transparent;color:var(--brand-ink);border:1px solid var(--line)}
.btn--ghost:hover{background:var(--paper-2);border-color:var(--ink-2)}
@media(min-width:920px){
  .hero--split .hero__inner{grid-template-columns:1.05fr 1fr}
  .hero__fig{aspect-ratio:5/4}
}

/* ===== Guarantee — the ONE dramatic display moment (quiet cream, big serif, no loud band) ===== */
/* a DELIBERATE centred display moment, not a squeeze — generous air above/below so the axis-switch reads as intentional */
.guarantee{background:var(--paper);text-align:center;border-bottom:1px solid var(--line);padding-block:clamp(4.5rem,3rem+6vw,8.5rem)}
.guarantee .wrap{max-width:none;margin-inline:auto}
.guarantee p{font-family:var(--font-head);font-weight:600;font-size:clamp(2.1rem,1.3rem+3.4vw,4rem);line-height:1.06;letter-spacing:-.02em;
  color:var(--brand-ink);max-width:17ch;margin:0 auto;text-wrap:balance}
.guarantee p .hl{color:var(--brand);font-style:italic}
.guarantee small{display:block;margin-top:var(--s3);font-family:var(--font-body);font-size:var(--step-0);color:var(--ink-2);max-width:40ch;margin-inline:auto}

/* ===== Trust strip — quiet inline row on cream (no navy bar) ===== */
.trust{background:var(--paper-2);padding:clamp(2.25rem,1.6rem+2.2vw,3.5rem) 0;border-bottom:1px solid var(--line)}
/* real 2→4 col grid so every item sits on its own cell — no orphaned centred line */
.trust__row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s3) var(--s4);align-items:center;
  font-size:var(--step-0);font-weight:500;color:var(--brand-ink);letter-spacing:.005em}
.trust__row span{position:relative;padding-left:1.5rem;line-height:1.35}
.trust__row span::before{content:"";position:absolute;left:0;top:.5em;width:8px;height:8px;border-radius:999px;background:var(--brand)}
@media(min-width:760px){ .trust__row{grid-template-columns:repeat(4,1fr)} }

/* ===== Cards — borderless, generous padding, subtle lift (no Bootstrap boxes) ===== */
.cards{display:grid;gap:var(--s4);grid-template-columns:1fr;margin-top:clamp(1.5rem,1rem+1.8vw,2.5rem)}
/* designed objects, not Bootstrap boxes: a hairline accent rule + tight internal hierarchy + even padding */
.card{background:var(--paper-2);border-radius:var(--radius);padding:var(--s5) var(--s4);position:relative;overflow:hidden;
  transition:transform .18s var(--ease),box-shadow .18s var(--ease)}
.card::before{content:"";position:absolute;left:var(--s4);right:var(--s4);top:0;height:3px;background:var(--brand);opacity:.85;border-radius:0 0 3px 3px}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.card h3{font-size:var(--step-1);color:var(--brand-ink);margin-bottom:.45em;line-height:1.15;letter-spacing:-.01em}
.card p{color:var(--ink-2);margin:0;font-size:var(--step-0)}
@media(min-width:760px){ .cards{grid-template-columns:repeat(3,1fr)} }

.services{background:var(--paper)}

/* ===== About — asymmetric, warm ===== */
.about{background:var(--paper-2)}
.about__inner{display:grid;gap:var(--s5);align-items:center}
/* warm-grade Adam's REAL photo (do NOT fabricate a likeness) so it sits with the golden hero, not as a cool snapshot */
.about__fig{margin:0;position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:0 18px 44px rgba(42,37,32,.18)}
/* photo is already shot golden-hour on-grade; only a whisper of warmth to seat it with the hero, not crush it */
.about__fig::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(255,178,108,.10),rgba(150,78,32,.08));mix-blend-mode:multiply;pointer-events:none}
.about__img{display:block;width:100%;object-fit:cover;aspect-ratio:1/1;filter:saturate(1.04) contrast(1.02)}
/* the AEO answer object — visually a lead paragraph, semantically the extractable answer */
.answer{font-size:var(--step-1);color:var(--ink);font-weight:500;line-height:1.5;border-left:3px solid var(--brand);padding-left:var(--s3)}
@media(min-width:860px){ .about__inner{grid-template-columns:.92fr 1.08fr} }

/* ===== How it works — oversized editorial numerals, left-aligned ===== */
.how{background:var(--paper)}
.how__grid{display:grid;gap:var(--s5) var(--s4);margin-top:clamp(1.5rem,1rem+1.8vw,2.5rem)}
@media(min-width:780px){ .how__grid{grid-template-columns:repeat(3,1fr)} }
.how__step{padding:0}
.how__num{display:block;font-family:var(--font-head);font-weight:600;font-size:var(--step-4);line-height:1;
  color:var(--brand);margin-bottom:.3rem;letter-spacing:-.02em}
.how__step h3{font-size:var(--step-1);margin-bottom:.4em}
.how__step p{color:var(--ink-2);margin:0}
.how__step::before{content:"";display:block;height:2px;width:48px;background:var(--brand);opacity:.35;margin-bottom:var(--s2)}

/* ===== SIGNATURE WOW — before→after hydrobath drag-reveal (left-aligned, editorial) ===== */
@property --pos{syntax:"<percentage>";inherits:false;initial-value:55%}
.reveal-wow{background:var(--brand-tint)}
.reveal-wow .section__h2{margin-bottom:.6rem}
.reveal-wow__lede{max-width:54ch;margin:0 0 clamp(1.5rem,1rem+2vw,2.5rem);color:var(--ink-2);font-size:var(--step-1)}
.ba{--pos:55%;position:relative;max-width:980px;aspect-ratio:3/2;border-radius:var(--radius);overflow:hidden;
  box-shadow:0 18px 50px rgba(42,37,32,.2);user-select:none;touch-action:pan-y;isolation:isolate}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.ba__before{clip-path:inset(0 calc(100% - var(--pos)) 0 0);z-index:1}
.ba__after{z-index:0}
.ba__range{position:absolute;inset:0;width:100%;height:100%;margin:0;padding:0;opacity:0;cursor:ew-resize;z-index:4;-webkit-appearance:none;appearance:none;background:transparent}
.ba__range::-webkit-slider-thumb{-webkit-appearance:none;width:64px;height:100%;cursor:ew-resize}
.ba__range::-moz-range-thumb{width:64px;height:100%;border:0;background:transparent;cursor:ew-resize}
.ba__line{position:absolute;top:0;bottom:0;left:var(--pos);width:3px;background:#fff;transform:translateX(-50%);z-index:2;pointer-events:none;box-shadow:0 0 0 1px rgba(42,37,32,.12)}
.ba__grip{position:absolute;top:50%;left:var(--pos);transform:translate(-50%,-50%);width:48px;height:48px;border-radius:999px;
  background:#fff;box-shadow:0 4px 14px rgba(42,37,32,.32);display:grid;place-items:center;z-index:3;pointer-events:none;
  color:var(--brand);font-size:1.1rem;font-weight:700;line-height:1;font-family:var(--font-body)}
.ba__grip::before{content:"\2039  \203A"}
.ba__tag{position:absolute;bottom:.9rem;padding:.34em .85em;border-radius:999px;font-size:var(--step--1);font-weight:600;
  color:#fff;background:rgba(42,37,32,.68);backdrop-filter:blur(3px);z-index:2;pointer-events:none;letter-spacing:.02em}
.ba__tag--before{left:.9rem}
.ba__tag--after{right:.9rem}
.reveal-wow__hint{margin:1.25rem 0 0;font-size:var(--step--1);color:var(--ink-2)}
@media(prefers-reduced-motion:no-preference){ .ba.nudge{animation:baNudge 2.2s var(--ease) .4s 1} }
@keyframes baNudge{0%,100%{--pos:55%}30%{--pos:68%}60%{--pos:46%}}

/* ===== FAQ ===== */
.faq{background:var(--paper-2)}
.faq details{border-bottom:1px solid var(--line);padding:var(--s3) 0}
.faq summary{font-weight:600;font-size:var(--step-1);font-family:var(--font-head);cursor:pointer;list-style:none;color:var(--brand-ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--brand);font-family:var(--font-body)}
.faq details[open] summary::after{content:"–"}
.faq p{margin:.8rem 0 0;color:var(--ink-2)}

/* ===== Final CTA + footer ===== */
/* THE dark anchor band — the one confident contrast moment the page was missing (gate's #1 fix). Deep espresso closer, à la Tonic's black / Tracy's green. */
.cta-final{background:var(--brand-ink);text-align:center;color:#F4ECE3;padding-block:clamp(4rem,2.6rem+5vw,7rem)}
.cta-final h2{font-size:var(--step-2);margin-bottom:var(--s3);color:#FBF7F1;letter-spacing:-.01em}
.cta-final p{color:#D8CDBE !important}
.cta-final .btn--ghost{color:#FBF7F1 !important;border-color:rgba(255,255,255,.34) !important}
.cta-final .btn--ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.55) !important}
/* footer sits directly under the dark band — drop its top hairline so the two darks read as one anchored base, not a seam */
.cta-final + .footer{border-top:0}
.footer{background:var(--brand-ink);color:#E6DED2;padding:var(--s5) 0;font-size:var(--step--1);border-top:1px solid rgba(255,255,255,.08)}
.footer__inner{display:flex;flex-wrap:wrap;gap:var(--s2) var(--s4);justify-content:space-between}
.footer p{max-width:none;margin:0}
.footer a{color:#fff;text-decoration:underline}

/* scroll reveal — transform/opacity only (playbook L44/L35) */
[data-reveal]{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){[data-reveal]{opacity:1;transform:none}}

/* button press + sheen (intent-fired, single pass) */
.btn:active{transform:translateY(1px) scale(.98)}
.btn--primary{position:relative;overflow:hidden}
.btn--primary::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.35),transparent);transform:skewX(-18deg)}
.btn--primary:hover::after{animation:sheen .7s var(--ease) 1}
@keyframes sheen{to{left:130%}}
@media(prefers-reduced-motion:reduce){.btn--primary:hover::after{animation:none}}

/* keep CTA labels on one line; trim nav CTA on small screens */
.btn{white-space:nowrap}
.hero__cta .btn{flex:0 0 auto}
@media(max-width:560px){ .cta-num{display:none} .nav__cta{padding:.55em .9em} }
@media(max-width:560px){ .hero__cta{flex-direction:column;align-items:stretch} .hero__cta .btn{width:100%} }
