/* ============================================================
   BASELINE — metabolic assessment funnel
   Built on the Vishak Moopar — Metabolic Science design system.
   Territory: clinical authority, warmed by humanity.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Spectral:ital,wght@0,300;0,400;0,500;0,600;1,400&family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

:root {
  /* Brand color */
  --ink:#16201E; --ink-soft:#2A332F;
  --teal-900:#0A3437; --teal-700:#0E4A4E; --teal-500:#14686C;
  --teal-200:#BBD3D2; --teal-050:#E7F0EE;
  --green-600:#2F8A63; --green-500:#3A9C72; --green-050:#E7F1EA;
  /* Warm neutrals */
  --sand:#F4EFE5; --bone:#FCFAF4; --white:#FFFFFF;
  --line:#E5DECF; --line-strong:#D8CFBC;
  --muted:#5C635F; --faint:#8B908A;
  /* Semantic — calm, no alarm red */
  --watch:#C28A1F; --watch-050:#F6ECD6;
  --high:#BB5E3C; --high-050:#F4E3DB;
  --focus:#14686C;
  /* Type */
  --font-display:'Spectral', Georgia, 'Times New Roman', serif;
  --font-sans:'IBM Plex Sans', system-ui, sans-serif;
  --font-mono:'IBM Plex Mono', ui-monospace, 'SFMono-Regular', monospace;
  /* Spacing */
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px;
  --s-6:32px; --s-7:48px; --s-8:64px; --s-9:96px; --s-10:128px;
  /* Radii */
  --r-sm:6px; --r-md:10px; --r-lg:16px; --r-xl:24px; --r-pill:999px;
  /* Elevation */
  --e-1:0 1px 2px rgba(20,40,38,.06), 0 1px 1px rgba(0,0,0,.03);
  --e-2:0 4px 16px -6px rgba(14,74,78,.16), 0 1px 3px rgba(20,40,38,.06);
  --e-3:0 18px 48px -16px rgba(14,74,78,.22), 0 2px 6px rgba(20,40,38,.07);
  /* Motion */
  --ease:cubic-bezier(.2,.6,.2,1); --dur:220ms;
}

@media (prefers-reduced-motion: reduce){
  * { animation-duration:.001ms !important; transition-duration:.001ms !important; }
  html { scroll-behavior:auto; }
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0; background:var(--sand); color:var(--ink);
  font-family:var(--font-sans); font-size:17px; line-height:1.62;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
.wrap{max-width:1120px; margin:0 auto; padding:0 32px;}
.wrap-narrow{max-width:680px; margin:0 auto; padding:0 24px;}
.serif{font-family:var(--font-display);}
.metric{font-family:var(--font-mono); font-variant-numeric:tabular-nums; letter-spacing:-.01em;}

/* ---------- View routing ---------- */
.view{display:none; animation:fadeUp var(--dur) var(--ease);}
.view.active{display:block;}
@keyframes fadeUp{from{opacity:0; transform:translateY(8px);} to{opacity:1; transform:none;}}

/* ---------- Eyebrow ---------- */
.eyebrow{
  font-family:var(--font-mono); font-weight:500; font-size:13px;
  letter-spacing:.14em; text-transform:uppercase; color:var(--teal-500);
  display:inline-block;
}

/* ---------- Buttons ---------- */
.btn{
  font-family:var(--font-sans); font-weight:600; font-size:16px;
  border-radius:var(--r-pill); padding:15px 28px; border:1.5px solid transparent;
  cursor:pointer; line-height:1; display:inline-flex; align-items:center; gap:9px;
  text-decoration:none; transition:background var(--dur) var(--ease),
  transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.btn-primary{background:var(--teal-700); color:#FCFAF4;}
.btn-primary:hover{background:var(--teal-500); box-shadow:var(--e-2);}
.btn-primary:active{background:var(--teal-900); transform:translateY(1px);}
.btn-secondary{background:transparent; color:var(--teal-700); border-color:var(--line-strong);}
.btn-secondary:hover{border-color:var(--teal-500); color:var(--teal-500);}
.btn-ghost{background:transparent; color:var(--teal-700); padding:10px 6px;}
.btn-ghost:hover{color:var(--teal-500);}
.btn-lg{font-size:17px; padding:17px 34px;}
.btn:disabled{opacity:.45; cursor:not-allowed;}
.lucide{width:1em; height:1em; stroke-width:1.75; vertical-align:-2px;}
*:focus-visible{outline:2px solid var(--focus); outline-offset:2px; border-radius:3px;}

/* ---------- Nav ---------- */
.nav{position:sticky; top:0; z-index:50; background:rgba(244,239,229,.82);
  backdrop-filter:blur(12px); border-bottom:1px solid var(--line);}
.nav-in{display:flex; align-items:center; justify-content:space-between; height:70px;}
.brand{display:flex; align-items:center; gap:11px; text-decoration:none;}
.brand .brand-logo{height:46px; width:auto; display:block;}
.brand .wm{font-family:var(--font-display); font-weight:500; font-size:26px;
  letter-spacing:-.02em; color:var(--ink); line-height:1;}
.nav-right{display:flex; flex-direction:column; align-items:flex-end; gap:3px;}
.nav-right .tag{font-family:var(--font-mono); font-size:11px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--teal-500); line-height:1;}
.nav .secure{font-family:var(--font-mono); font-size:12px; color:var(--muted);
  display:inline-flex; align-items:center; gap:7px;}
.nav .secure .lucide{color:var(--green-600); width:15px; height:15px;}

/* ============================================================
   LANDING  (stage: RELIEF · one fear-acknowledgment line)
   ============================================================ */
.hero{padding:64px 0 40px;}
.hero-grid{display:grid; grid-template-columns:1.04fr .96fr; column-gap:56px; row-gap:0;
  align-items:center;
  grid-template-areas:
    "eyebrow video"
    "head    video"
    "sub     video"
    "ack     video"
    "cta     video";}
.ga-eyebrow{grid-area:eyebrow; align-self:end;}
.ga-head{grid-area:head;}
.ga-sub{grid-area:sub;}
.ga-video{grid-area:video; align-self:center;}
.ga-ack{grid-area:ack;}
.ga-cta{grid-area:cta; align-self:start;}
.hero h1{font-family:var(--font-display); font-weight:400;
  font-size:clamp(2.4rem,1.4rem+2.8vw,3.5rem); line-height:1.08;
  letter-spacing:-.018em; margin:16px 0 0; color:var(--ink); text-wrap:balance;}
.hero .sub{font-size:21px; line-height:1.5; color:var(--ink-soft); margin:18px 0 0; max-width:42ch;}
.hero .ack{font-size:16px; color:var(--muted); margin:22px 0 0; max-width:46ch;
  padding-left:16px; border-left:2px solid var(--line-strong); font-style:italic;}
.hero-cta{display:flex; gap:14px; margin-top:30px; align-items:center; flex-wrap:wrap;}
.hero-cta .micro{font-size:14px; color:var(--muted);}
.reassure{display:flex; gap:22px; margin-top:26px; flex-wrap:wrap;}
.reassure span{display:inline-flex; align-items:center; gap:8px; font-size:14.5px; color:var(--muted);}
.reassure .lucide{color:var(--green-600);}

/* landing Wistia frame */
.hero-video-frame{position:relative; border-radius:var(--r-xl); overflow:hidden;
  border:1px solid var(--line); box-shadow:var(--e-2); background:#0A3437;
  aspect-ratio:16/9;}

/* video slot */
.video{position:relative; border-radius:var(--r-xl); overflow:hidden;
  border:1px solid var(--line); background:linear-gradient(150deg,#0E4A4E,#0A3437 72%);
  box-shadow:var(--e-2); aspect-ratio:16/10; display:flex; align-items:center; justify-content:center;}
.video video, .video iframe{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; border:0;}
.video .play{position:relative; z-index:2; display:flex; flex-direction:column; align-items:center;
  gap:14px; color:#EAF2F0; text-align:center; padding:24px;}
.video .play-btn{width:74px; height:74px; border-radius:999px; background:rgba(252,250,244,.95);
  color:var(--teal-700); display:flex; align-items:center; justify-content:center; box-shadow:var(--e-3);
  transition:transform var(--dur) var(--ease);}
.video:hover .play-btn{transform:scale(1.06);}
.video .play-btn .lucide{width:30px; height:30px; margin-left:3px;}
.video .cap{font-size:13.5px; color:var(--teal-200); font-family:var(--font-mono); letter-spacing:.02em;}

/* trust strip */
.trust{border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--bone);}
.trust-in{display:grid; grid-template-columns:repeat(4,1fr); gap:16px 12px; padding:20px 0;}
.stat{text-align:center;}
.stat .n{font-family:var(--font-mono); font-weight:500; font-size:22px;
  font-variant-numeric:tabular-nums; color:var(--teal-700); letter-spacing:-.01em; line-height:1.1;}
.stat .l{font-size:12.5px; color:var(--muted); margin-top:3px;}

/* ============================================================
   QUESTIONNAIRE  (stage: CONTROL · agency-building)
   ============================================================ */
.assess{min-height:calc(100vh - 70px); display:flex; flex-direction:column;}
.progress{background:var(--bone); border-bottom:1px solid var(--line); position:sticky; top:70px; z-index:40;}
.progress-in{padding:18px 0 16px;}
.progress-row{display:flex; align-items:center; justify-content:space-between; margin-bottom:11px;}
.progress-step{font-family:var(--font-mono); font-size:12px; letter-spacing:.08em;
  text-transform:uppercase; color:var(--muted);}
.progress-back{background:none; border:0; color:var(--teal-700); cursor:pointer;
  font-family:var(--font-sans); font-size:14px; font-weight:500; display:inline-flex;
  align-items:center; gap:6px; padding:4px 2px;}
.progress-back:hover{color:var(--teal-500);}
.progress-track{height:6px; background:var(--line); border-radius:999px; overflow:hidden;}
.progress-fill{height:100%; background:var(--teal-700); border-radius:999px; width:0;
  transition:width 360ms var(--ease);}

.q-stage{flex:1; display:flex; align-items:center; padding:48px 0;}
.q-card{max-width:640px; margin:0 auto; width:100%;}
.q-screen{display:none;}
.q-screen.active{display:block; animation:fadeUp 260ms var(--ease);}
.q-eyebrow{font-family:var(--font-mono); font-size:12px; letter-spacing:.12em;
  text-transform:uppercase; color:var(--teal-500); display:block; margin-bottom:12px;}
.q-title{font-family:var(--font-display); font-weight:500; font-size:clamp(1.7rem,1.2rem+1.6vw,2.35rem);
  line-height:1.18; letter-spacing:-.01em; margin:0; color:var(--ink); text-wrap:balance;}
.q-help{font-size:16px; color:var(--muted); margin:14px 0 0; max-width:54ch;}

.opts{display:flex; flex-direction:column; gap:12px; margin-top:32px;}
.opt{display:flex; align-items:center; gap:14px; padding:18px 20px; background:var(--bone);
  border:1.5px solid var(--line); border-radius:var(--r-lg); cursor:pointer;
  transition:border-color var(--dur) var(--ease), background var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  font-size:18px; color:var(--ink); text-align:left; width:100%; font-family:var(--font-sans);}
.opt:hover{border-color:var(--teal-500); box-shadow:var(--e-1);}
.opt .mark{width:24px; height:24px; border-radius:999px; border:2px solid var(--line-strong);
  flex:0 0 24px; display:flex; align-items:center; justify-content:center; transition:all var(--dur) var(--ease);}
.opt.check .mark{border-radius:7px;}
.opt .mark .lucide{width:15px; height:15px; color:#fff; opacity:0;}
.opt.selected{border-color:var(--teal-700); background:var(--teal-050);}
.opt.selected .mark{border-color:var(--teal-700); background:var(--teal-700);}
.opt.selected .mark .lucide{opacity:1;}
.opt .sub{display:block; font-size:13.5px; color:var(--muted); margin-top:3px; font-family:var(--font-mono);}

/* precision (optional numbers) */
.precision{margin-top:26px; background:var(--bone); border:1px solid var(--line);
  border-radius:var(--r-lg); padding:22px 24px;}
.precision .badge{font-family:var(--font-mono); font-size:11px; letter-spacing:.1em;
  text-transform:uppercase; color:var(--green-600); background:var(--green-050);
  padding:4px 10px; border-radius:var(--r-pill); display:inline-block;}
.fields{display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:18px;}
.field label{display:block; font-size:14px; color:var(--ink-soft); margin-bottom:6px; font-weight:500;}
.field .unit{color:var(--muted); font-family:var(--font-mono); font-size:12px;}
.field input{width:100%; font-family:var(--font-mono); font-size:17px; color:var(--ink);
  background:var(--white); border:1.5px solid var(--line); border-radius:var(--r-md);
  padding:12px 14px; transition:border-color var(--dur) var(--ease);}
.field input:focus{border-color:var(--teal-500); outline:none;}
.field input::placeholder{color:var(--faint);}

.q-actions{display:flex; align-items:center; gap:14px; margin-top:32px;}
.q-actions .skip{background:none; border:0; color:var(--muted); cursor:pointer;
  font-family:var(--font-sans); font-size:15px; text-decoration:underline; text-underline-offset:3px;}
.q-actions .skip:hover{color:var(--teal-700);}

/* contact capture (peak curiosity) */
.capture{max-width:560px; margin:0 auto; text-align:center;}
.capture .lock{width:54px; height:54px; border-radius:var(--r-md); background:var(--teal-050);
  color:var(--teal-700); display:inline-flex; align-items:center; justify-content:center; margin-bottom:20px;}
.capture .lock .lucide{width:26px; height:26px;}
.capture h2{font-family:var(--font-display); font-weight:500; font-size:clamp(1.7rem,1.2rem+1.5vw,2.3rem);
  line-height:1.18; margin:0; color:var(--ink); text-wrap:balance;}
.capture p{font-size:17px; color:var(--ink-soft); margin:14px auto 0; max-width:46ch;}
.capture .form{margin-top:28px; text-align:left;}
.capture .form label{display:block; font-size:14px; color:var(--ink-soft); margin-bottom:7px; font-weight:500;}
.capture .form .field-row{margin-bottom:16px;}
.capture .form input.text{width:100%; font-family:var(--font-sans); font-size:17px; color:var(--ink);
  background:var(--white); border:1.5px solid var(--line); border-radius:var(--r-md);
  padding:14px 16px; transition:border-color var(--dur) var(--ease);}
.capture .form input.text:focus{border-color:var(--teal-500); outline:none;}
.capture .form input.text::placeholder{color:var(--faint);}
.phone{display:flex; gap:10px;}
.phone .cc{font-family:var(--font-mono); font-size:17px; background:var(--white);
  border:1.5px solid var(--line); border-radius:var(--r-md); padding:14px 14px; color:var(--ink-soft);
  display:flex; align-items:center;}
.phone .cc-select{font-family:var(--font-mono); font-size:16px; background:var(--white);
  border:1.5px solid var(--line); border-radius:var(--r-md); padding:14px 10px; color:var(--ink-soft);
  max-width:138px; cursor:pointer; appearance:menulist;}
.phone .cc-select:focus{border-color:var(--teal-500); outline:none;}
.phone input{flex:1; font-family:var(--font-mono); font-size:17px; letter-spacing:.02em;
  background:var(--white); border:1.5px solid var(--line); border-radius:var(--r-md); padding:14px 16px; color:var(--ink);}
.phone input:focus{border-color:var(--teal-500); outline:none;}
.capture .consent{display:flex; gap:10px; align-items:flex-start; margin-top:16px;
  font-size:13px; color:var(--muted); line-height:1.5;}
.capture .consent input{margin-top:3px; accent-color:var(--teal-700);}
.capture .err{color:var(--high); font-size:14px; margin-top:10px; min-height:20px;}
.capture .btn{width:100%; justify-content:center; margin-top:22px;}
.capture .whatsapp-note{display:inline-flex; align-items:center; gap:7px; margin-top:18px;
  font-size:13.5px; color:var(--muted); font-family:var(--font-mono);}
.capture .whatsapp-note .lucide{color:var(--green-600);}

/* ============================================================
   RESULT  (stage: HOPE → CERTAINTY)
   ============================================================ */
.result{padding:56px 0 80px;}
.verdict{max-width:720px; margin:0 auto; text-align:center;}
.verdict .badge{display:inline-flex; align-items:center; gap:9px; font-family:var(--font-mono);
  font-size:12px; letter-spacing:.12em; text-transform:uppercase; padding:7px 16px;
  border-radius:var(--r-pill); margin-bottom:22px;}
.verdict .badge.green{color:var(--green-600); background:var(--green-050);}
.verdict .badge.amber{color:var(--watch); background:var(--watch-050);}
.verdict .badge .dot{width:8px; height:8px; border-radius:999px; background:currentColor;}
.verdict h1{font-family:var(--font-display); font-weight:400;
  font-size:clamp(2rem,1.3rem+2.2vw,2.9rem); line-height:1.14; letter-spacing:-.015em;
  margin:0; color:var(--ink); text-wrap:balance;}
.verdict-support{font-size:18px; line-height:1.55; color:var(--ink-soft);
  margin:18px auto 0; max-width:54ch; text-wrap:pretty;}

/* ---- 2 · THE 90-DAY PATH (centerpiece) ---- */
.path{max-width:920px; margin:52px auto 0;}
.path-eyebrow{display:block; text-align:center; margin-bottom:8px;}
.path-title{font-family:var(--font-display); font-weight:500; text-align:center;
  font-size:clamp(1.5rem,1.2rem+1vw,2rem); line-height:1.2; letter-spacing:-.01em;
  margin:0 0 40px; color:var(--ink); text-wrap:balance;}
.path-track{list-style:none; margin:0; padding:0;
  display:grid; grid-template-columns:repeat(5,1fr);}
.path-node{position:relative;}
.node-rail{position:relative; height:30px; display:flex; align-items:center; justify-content:center;}
.node-rail::before, .node-rail::after{content:""; position:absolute; top:50%;
  transform:translateY(-50%); height:2px; width:calc(50% + 1px); background:var(--line-strong);}
.node-rail::before{left:0;}
.node-rail::after{right:0;}
.path-node:first-child .node-rail::before{display:none;}
.path-node:last-child .node-rail::after{display:none;}
/* line up to / from "here" reads as progress */
.path-node.is-here .node-rail::after{background:var(--teal-500);}
.node-dot{position:relative; z-index:2; width:18px; height:18px; border-radius:999px;
  background:var(--bone); border:2.5px solid var(--line-strong);
  display:flex; align-items:center; justify-content:center; transition:none;}
.path-node.is-here .node-dot{border-color:var(--teal-700); background:var(--teal-700);
  box-shadow:0 0 0 5px var(--teal-050);}
.path-node.is-end .node-dot{width:28px; height:28px; border-color:var(--green-600); background:var(--green-050);}
.path-node.is-end .node-dot .lucide{width:15px; height:15px; color:var(--green-600);}
.node-body{display:flex; flex-direction:column; align-items:center; gap:3px;
  text-align:center; margin-top:14px; padding:0 8px;}
.node-label{font-family:var(--font-mono); font-weight:500; font-size:12.5px;
  letter-spacing:.02em; color:var(--ink);}
.node-sub{font-size:12.5px; line-height:1.35; color:var(--muted); max-width:17ch;}
.here-tag{margin-top:9px; display:inline-flex; align-items:center; gap:6px;
  font-family:var(--font-mono); font-size:10.5px; letter-spacing:.02em; color:var(--teal-700);
  background:var(--teal-050); border:1px solid var(--teal-200); border-radius:var(--r-pill); padding:5px 10px;}
.here-tag .lucide{width:12px; height:12px;}

/* ---- 3 · PROOF (one) ---- */
.proof-one{max-width:600px; margin:48px auto 0;}
.proof-one-eyebrow{display:block; text-align:center; margin-bottom:16px;}
.proof-one-card{background:var(--white); border:1px solid var(--line); border-radius:var(--r-xl);
  padding:30px 32px; box-shadow:var(--e-2);}
.ba{display:flex; align-items:center; justify-content:center; gap:26px;}
.ba-col{display:flex; flex-direction:column; align-items:center; gap:6px;}
.ba-lbl{font-family:var(--font-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted);}
.ba-val{font-size:42px; line-height:1; color:var(--ink);}
.ba-col.is-after .ba-val{color:var(--green-600);}
.ba-arrow{color:var(--line-strong); display:flex;}
.ba-arrow .lucide{width:28px; height:28px;}
.proof-lab{margin-top:24px; border:1px dashed var(--line-strong); border-radius:var(--r-lg);
  min-height:150px; display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:10px; color:var(--faint); background:var(--sand); text-align:center; padding:22px; font-size:13px;}
.proof-lab .lucide{width:26px; height:26px;}
.proof-lab-img{width:100%; display:block; border-radius:var(--r-lg); margin-top:24px;
  border:1px solid var(--line);}
.proof-quote{font-family:var(--font-display); font-weight:400; font-size:19px; line-height:1.45;
  color:var(--ink); margin:24px 0 0; letter-spacing:-.005em; text-wrap:pretty;}
.proof-who{font-family:var(--font-mono); font-size:13px; color:var(--muted); margin-top:12px;}

/* ---- secondary CTA (mid) ---- */
.cta-mid{max-width:600px; margin:36px auto 0; text-align:center;}
.cta-mid-sub{font-size:13.5px; color:var(--muted); margin:14px 0 0;}

/* ---- 4 · video caption ---- */
.video-cap{text-align:center; font-size:14px; color:var(--muted); margin:14px 0 0;}

/* path → vertical on smaller screens */
@media(max-width:720px){
  .path-track{grid-template-columns:1fr;}
  .path-node{display:grid; grid-template-columns:30px 1fr; gap:16px; align-items:start;}
  .node-rail{height:auto; width:30px; align-self:stretch; justify-content:flex-start;}
  .node-rail::after{display:none;}
  .node-rail::before{top:0; bottom:0; left:50%; transform:translateX(-50%);
    height:auto; width:2px; background:var(--line-strong);}
  .path-node:first-child .node-rail::before{display:block; top:13px;}
  .path-node:last-child .node-rail::before{display:block; bottom:auto; height:13px;}
  .path-node.is-here .node-rail::after{display:none;}
  .node-dot{position:absolute; top:5px; left:50%; transform:translateX(-50%);}
  .node-body{text-align:left; align-items:flex-start; margin-top:0; padding:0 0 26px;}
  .node-sub{max-width:none;}
}

/* mechanism (belief-shift) */
.mechanism{max-width:680px; margin:48px auto 0; background:var(--bone);
  border:1px solid var(--line); border-radius:var(--r-xl); padding:36px 40px; box-shadow:var(--e-1);}
.mechanism .eyebrow{margin-bottom:14px;}
.mechanism h2{font-family:var(--font-display); font-weight:500; font-size:24px; line-height:1.3;
  margin:0 0 14px; color:var(--ink);}
.mechanism p{font-size:18px; line-height:1.6; color:var(--ink-soft); margin:0 0 14px;}
.mechanism p:last-child{margin-bottom:0;}
.mechanism .keyline{color:var(--teal-700); font-weight:600;}

/* proof — Bonnie's testimonial */
.proof{max-width:680px; margin:32px auto 0;}
.proof-card{background:var(--white); border:1px solid var(--line); border-radius:var(--r-xl);
  overflow:hidden; box-shadow:var(--e-2);}
.proof-img{width:100%; display:block; border-bottom:1px solid var(--line);}
.result-video-wrap{max-width:680px; margin:32px auto 0;}
.result-video{aspect-ratio:16/9;}
.proof-video{position:relative; aspect-ratio:16/9; background:linear-gradient(150deg,#0E4A4E,#0A3437 72%);
  display:flex; align-items:center; justify-content:center; cursor:pointer;}
.proof-video video, .proof-video iframe{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; border:0;}
.proof-video .play-btn{position:relative; z-index:2; width:66px; height:66px; border-radius:999px;
  background:rgba(252,250,244,.95); color:var(--teal-700); display:flex; align-items:center;
  justify-content:center; box-shadow:var(--e-3); transition:transform var(--dur) var(--ease);}
.proof-video:hover .play-btn{transform:scale(1.06);}
.proof-video .play-btn .lucide{width:26px; height:26px; margin-left:3px;}
.proof-body{padding:24px 28px;}
.proof-body .who{display:flex; align-items:center; gap:14px;}
.proof-body .avatar{width:48px; height:48px; border-radius:999px;
  background:linear-gradient(150deg,#E9E2D2,#DCEAE4); border:1px solid var(--line); flex:0 0 48px;}
.proof-body .nm{font-weight:600; font-size:16px; color:var(--ink);}
.proof-body .meta{font-size:13.5px; color:var(--muted); font-family:var(--font-mono);}
.proof-body blockquote{font-family:var(--font-display); font-weight:400; font-size:19px;
  line-height:1.45; color:var(--ink); margin:18px 0 0; letter-spacing:-.005em;}

/* payment → booking */
.pay-section{max-width:680px; margin:40px auto 0; scroll-margin-top:90px;}
.pay-card{background:var(--bone); border:1px solid var(--line); border-radius:var(--r-xl);
  padding:36px 40px; box-shadow:var(--e-2);}
.pay-card .eyebrow{margin-bottom:12px;}
.pay-title{font-family:var(--font-display); font-weight:500; font-size:26px; line-height:1.2;
  margin:0 0 10px; color:var(--ink);}
.pay-sub{font-size:17px; line-height:1.55; color:var(--ink-soft); margin:0;}
.pay-form{margin-top:24px;}
.pay-form .field-row{margin-bottom:16px;}
.pay-form label{display:block; font-size:14px; color:var(--ink-soft); margin-bottom:7px; font-weight:500;}
.pay-form .text{width:100%; font-family:var(--font-sans); font-size:17px; color:var(--ink);
  background:var(--white); border:1.5px solid var(--line); border-radius:var(--r-md);
  padding:14px 16px; transition:border-color var(--dur) var(--ease);}
.pay-form .phone{display:flex; gap:10px;}
.pay-form .phone .cc{font-family:var(--font-mono); font-size:17px; background:var(--white);
  border:1.5px solid var(--line); border-radius:var(--r-md); padding:14px; color:var(--ink-soft);
  display:flex; align-items:center;}
.pay-form .phone input{flex:1; font-family:var(--font-mono); font-size:17px; letter-spacing:.02em;
  background:var(--white); border:1.5px solid var(--line); border-radius:var(--r-md);
  padding:14px 16px; color:var(--ink); transition:border-color var(--dur) var(--ease);}
.pay-form .text:focus, .pay-form .phone input:focus{border-color:var(--teal-500); outline:none;}
.pay-form .text::placeholder, .pay-form .phone input::placeholder{color:var(--faint);}
.pay-form #pay-btn{width:100%; justify-content:center; margin-top:6px;}
.pay-fine{font-size:13.5px; color:var(--muted); text-align:center; margin:14px 0 0;}
.pay-err{color:var(--high); font-size:14px; margin:2px 0 0; min-height:20px;}
.pay-retry{color:var(--high); font-size:14.5px; line-height:1.5; text-align:center; margin-top:14px;}
/* reward beat — gold confirmation + calendar */
.success-line{display:flex; align-items:center; gap:11px; font-family:var(--font-display);
  font-size:20px; line-height:1.4; color:#8F6210; background:#FBF0D6;
  border:1px solid #E6CB8C; border-radius:var(--r-lg); padding:18px 20px;}
.success-line .lucide{color:#C28A1F; flex:0 0 auto; width:22px; height:22px;}
.cal-embed{margin-top:22px; min-height:560px; border:1px solid var(--line);
  border-radius:var(--r-lg); overflow:hidden; background:var(--white);}

/* CTA band */
.cta-band{max-width:680px; margin:40px auto 0; background:var(--teal-700); color:#FCFAF4;
  border-radius:var(--r-xl); padding:46px 44px; text-align:center; box-shadow:var(--e-3);}
.cta-band .eyebrow{color:var(--teal-200);}
.cta-band h2{font-family:var(--font-display); font-weight:500;
  font-size:clamp(1.7rem,1.2rem+1.5vw,2.3rem); margin:12px 0 0; color:#FCFAF4; letter-spacing:-.01em;}
.cta-band p{color:var(--teal-200); font-size:17px; margin:14px auto 26px; max-width:46ch;}
.cta-band .btn-primary{background:#FCFAF4; color:var(--teal-900);}
.cta-band .btn-primary:hover{background:#fff;}
.cta-band .fine{margin-top:18px; font-size:13px; color:var(--teal-200); font-family:var(--font-mono);
  display:inline-flex; align-items:center; gap:8px;}
.cta-band .fine .lucide{width:15px; height:15px;}

/* sent confirmation */
.sent-toast{max-width:680px; margin:20px auto 0; background:var(--green-050);
  border:1px solid var(--green-500); border-radius:var(--r-lg); padding:16px 22px;
  display:flex; align-items:center; gap:12px; font-size:15px; color:var(--ink-soft);}
.sent-toast .lucide{color:var(--green-600); flex:0 0 auto;}

/* ---------- Footer ---------- */
.footer{background:var(--ink); color:#C9CFC9; padding:48px 0 40px; margin-top:64px;}
.footer-col{display:flex; flex-direction:column; align-items:center; text-align:center; gap:10px;}
.footer-logo{height:84px; width:auto; display:block;}
.footer .wm{font-family:var(--font-display); font-weight:500; font-size:26px; color:#FCFAF4; line-height:1;}
.footer .ftag{font-family:var(--font-mono); font-size:11px; letter-spacing:.14em;
  text-transform:uppercase; color:#7E867E;}
.footer .fine{font-size:12.5px; color:#7E867E; line-height:1.6; max-width:58ch; margin:8px auto 0;}
.footer .copy{font-size:13px; color:#9AA29A; margin-top:4px;}
.footer a{color:#C9CFC9; text-decoration:none;}
.footer a:hover{color:#fff;}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr; column-gap:0;
    grid-template-areas:"eyebrow" "head" "sub" "video" "ack" "cta";}
  .ga-eyebrow{align-self:auto;}
  .ga-video{margin-top:22px;}
  .hero{padding:36px 0 24px;}
  .fields{grid-template-columns:1fr;}
}
@media(max-width:560px){
  .wrap, .wrap-narrow{padding:0 20px;}
  .btn{width:100%; justify-content:center;}
  .hero-cta .micro{width:100%; text-align:center;}
  .nav .secure span{display:none;}
  .pay-card{padding:26px 22px;}
  .mechanism{padding:28px 24px;}
  .cta-band{padding:38px 26px;}
  .trust-in{grid-template-columns:repeat(2,1fr); gap:18px 12px;}
  .stat .n{font-size:21px;}
}
