/* ============================================================
   Choosing Her — Pre-Sell Page styles  (v2 — premium art direction)
   Built strictly on the Choosing Her design system tokens.
   Gradients are confined to in-app screenshots only.
   ============================================================ */

@font-face{font-family:'Inter';font-weight:400;font-style:normal;font-display:swap;
  src:url('fonts/Inter_28pt-Regular.ttf') format('truetype');}
@font-face{font-family:'Inter';font-weight:500;font-style:normal;font-display:swap;
  src:url('fonts/Inter_28pt-Medium.ttf') format('truetype');}
@font-face{font-family:'Inter';font-weight:600;font-style:normal;font-display:swap;
  src:url('fonts/Inter_28pt-SemiBold.ttf') format('truetype');}
@font-face{font-family:'Inter';font-weight:700;font-style:normal;font-display:swap;
  src:url('fonts/Inter_28pt-Bold.ttf') format('truetype');}

:root{
  /* brand — exact design-system tokens */
  --ch-wisteria:#CFA0E5; --ch-rose:#FE769D; --ch-rose-deep:#DF6480; --ch-orange:#FF9191;
  --ch-gradient:linear-gradient(115deg,#CA95E2 4%,#FE769D 45%,#FF9191 86%);
  --ch-gradient-wash:linear-gradient(155deg,#D4A9E8 0%,#FEB4C9 46%,#FF9C9C 100%);
  --ch-gradient-soft:linear-gradient(115deg,#F1E2F7 0%,#FAE4EA 55%,#FFDEDE 100%);
  --ch-raisin:#2E2A2C; --ch-plum:#4E114F; --ch-off-white:#FDFBFA; --ch-crystal-mist:#FAEDE9;
  --ch-ink-button:#2E2A2C;
  --ch-gray-50:#F9F9F9; --ch-gray-100:#F2F0EF; --ch-gray-150:#F1F1F1; --ch-gray-200:#E6E5E4;
  --ch-gray-300:#DBDAD9; --ch-gray-400:#C0BFC0; --ch-gray-500:#909092; --ch-gray-600:#8C8A8B;

  /* page system — warm light, exact tokens only */
  --ink:#2E2A2C;           /* primary text — Raisin black            */
  --ink-soft:#6D6A6B;      /* body / secondary — Basic Black 200      */
  --ink-mute:#8C8A8B;      /* captions / tertiary — Basic Black 300   */
  --line:#E6E6E6;          /* hairline — Neutral 300                  */
  --line-strong:#DBDAD9;   /* border — Basic Gray 300                 */
  --paper:#FFFFFF;         /* surface                                 */
  --paper-warm:#FDFBFA;    /* off-white canvas                        */
  --blush:#FAEDE9;         /* Crystal Mist — the one soft tonal beat   */
  --raisin:#2E2A2C;        /* the single dark surface (footer)         */

  --accent-text:#DF6480;   /* deep rose — readable accent on light    */
  --accent-plum:#4E114F;   /* deep plum — contrast solid              */

  --radius-sm:12px; --radius-md:16px; --radius-lg:24px; --radius-pill:999px;
  /* tight, subtle neutral shadows — no colored glow / bloom */
  --shadow-tight:0 1px 2px rgba(46,42,44,.07), 0 1px 1px rgba(46,42,44,.04);
  --shadow-card:0 1px 3px rgba(46,42,44,.07), 0 8px 22px rgba(46,42,44,.05);
  --shadow-phone:0 12px 34px rgba(46,42,44,.15);

  --font-sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --tracking-tight:-0.02em; --tracking-head:-0.025em; --tracking-overline:0.02em;
  --maxw:640px;            /* text column cap */
  --maxw-wide:1180px;      /* full layout cap */
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{
  margin:0;font-family:var(--font-sans);font-weight:500;color:var(--ink);
  background:var(--paper-warm);letter-spacing:var(--tracking-tight);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;}
button{font-family:inherit;cursor:pointer;}
a{color:inherit;}

/* one unified warm grade across all real photography */
.graded{filter:saturate(.94) contrast(1.015) brightness(1.012);}

/* ---- shared layout ---- */
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding-left:24px;padding-right:24px;}
.section{padding:68px 0;}
.eyebrow{font-weight:600;font-size:11.5px;line-height:1.4;letter-spacing:var(--tracking-overline);
  text-transform:uppercase;color:var(--accent-text);}
h1,h2,h3,p{margin:0;}
.lede{font-weight:700;letter-spacing:var(--tracking-head);color:var(--ink);text-wrap:balance;}

/* ---------- Primary CTA — brand gradient pill, white label, identical everywhere ---------- */
.cta{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  width:100%;min-height:56px;padding:0 28px;border:none;border-radius:var(--radius-pill);
  background:var(--ch-gradient);color:#fff;font-weight:600;font-size:17px;letter-spacing:-0.01em;
  box-shadow:var(--shadow-tight);
  transition:filter .18s ease,transform .16s ease;text-decoration:none;
}
.cta:hover{filter:brightness(1.04);}
.cta:active{transform:scale(.985);filter:brightness(.97);}
.cta--auto{width:auto;min-height:46px;font-size:15px;padding:0 22px;}
.risk{margin-top:12px;text-align:center;font-weight:500;font-size:13px;line-height:1.5;color:var(--ink-mute);}
.cta-block{max-width:392px;margin-left:auto;margin-right:auto;}

/* star rating inline anchor */
.stars{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:13.5px;color:var(--ink);}
.stars .pips{color:var(--ch-rose-deep);letter-spacing:2px;font-size:14px;}
.stars .count{font-weight:500;color:var(--ink-mute);}

/* ============================================================
   STICKY HEADER — transparent over hero, solid on scroll
   ============================================================ */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:60;
  transition:background .3s ease,box-shadow .3s ease,border-color .3s ease;
  background:transparent;border-bottom:1px solid transparent;
}
.topbar__in{display:flex;align-items:center;justify-content:space-between;gap:16px;
  height:60px;max-width:var(--maxw-wide);margin:0 auto;padding:0 22px;}
.topbar__logo{height:17px;width:auto;display:block;}
.topbar__logo--white{display:block;filter:drop-shadow(0 1px 6px rgba(0,0,0,.35));}
.topbar__logo--dark{display:none;}
.topbar .cta{display:none;}                    /* no second CTA above the fold on mobile */
.topbar.solid{background:rgba(251,248,246,.9);backdrop-filter:saturate(150%) blur(18px);
  -webkit-backdrop-filter:saturate(150%) blur(18px);border-bottom-color:var(--line);}
.topbar.solid .topbar__logo--white{display:none;}
.topbar.solid .topbar__logo--dark{display:block;}

/* ============================================================
   HERO — full-bleed founder photo + lower-third panel
   ============================================================ */
.hero{position:relative;width:100%;
  min-height:clamp(580px,94svh,820px);
  display:flex;align-items:flex-end;overflow:hidden;background:#2E2A2C;}
.hero__media{position:absolute;inset:0;z-index:0;
  background:#2E2A2C 50% 18%/cover no-repeat;
  background-image:url('img/hero-portrait.png');
  filter:saturate(.96) contrast(1.01) brightness(1.02);}
/* directional protection: warm raisin, transparent up top, present toward the text. Not a global wash, not near-black. */
.hero__scrim{position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(to top,rgba(46,42,44,.9) 0%,rgba(46,42,44,.8) 28%,rgba(46,42,44,.56) 48%,rgba(46,42,44,.18) 64%,rgba(46,42,44,0) 78%),
    linear-gradient(to bottom,rgba(46,42,44,.24) 0%,rgba(46,42,44,0) 22%);}
.hero__panel{position:relative;z-index:2;width:100%;max-width:var(--maxw-wide);
  margin:0 auto;padding:0 20px 40px;}
.hero__inner{max-width:560px;}
.hero__accent{display:block;width:46px;height:4px;border-radius:999px;
  background:var(--ch-gradient);margin-bottom:20px;
  box-shadow:0 2px 10px rgba(254,118,157,.45);}
.hero h1{color:#fff;font-weight:700;letter-spacing:-0.035em;line-height:1.06;
  font-size:clamp(33px,8.8vw,56px);
  text-shadow:0 1px 18px rgba(0,0,0,.3);}
.hero h1 .l1,.hero h1 .l2{display:block;}
.hero__sub{margin-top:14px;color:rgba(255,255,255,.92);font-weight:500;
  font-size:clamp(15px,4vw,19px);line-height:1.45;max-width:34ch;
  text-shadow:0 1px 12px rgba(0,0,0,.3);}
.hero__cta{margin-top:24px;max-width:392px;}
.hero .cta{box-shadow:0 6px 20px rgba(0,0,0,.28);}
.hero .risk{text-align:left;color:rgba(255,255,255,.84);}
.hero__anchor{margin-top:16px;}
.hero__anchor .stars{color:#fff;}
.hero__anchor .stars .pips{color:#fff;}

/* ============================================================
   MICRO-PROOF BAR — clean near-white, large confident numerals
   ============================================================ */
.proofbar{background:var(--paper);border-bottom:1px solid var(--line);}
.proofbar .wrap{max-width:var(--maxw-wide);}
.proofbar__head{text-align:center;font-weight:600;font-size:clamp(16px,4.4vw,20px);
  line-height:1.35;color:var(--ink);max-width:22ch;margin:0 auto 40px;letter-spacing:-0.015em;}
.proofbar__grid{display:flex;flex-direction:column;gap:0;max-width:380px;margin:0 auto;}
.proofstat{text-align:center;padding:26px 0;border-bottom:1px solid var(--line);}
.proofstat:last-child{border-bottom:none;}
.proofstat__big{font-weight:700;font-size:46px;letter-spacing:-0.03em;line-height:1;color:var(--ink);}
.proofstat__big.pips{color:var(--ch-rose-deep);font-size:34px;letter-spacing:3px;}
.proofstat__lab{margin-top:12px;font-weight:500;font-size:13.5px;line-height:1.4;color:var(--ink-mute);
  letter-spacing:0;}

/* ============================================================
   PROBLEM / EMPATHY — warm blush beat (the one soft tonal beat)
   ============================================================ */
.problem{background:var(--blush);color:var(--ink);}
.problem .lede{color:var(--ink);font-size:clamp(26px,6.6vw,38px);line-height:1.16;}
.problem__body{margin-top:24px;display:flex;flex-direction:column;gap:18px;
  font-weight:500;font-size:clamp(16px,4.2vw,19px);line-height:1.62;color:var(--ink-soft);
  max-width:62ch;}
.problem__body .last{color:var(--ink);font-weight:600;}

/* ============================================================
   HOW IT WORKS — restrained single-tone icons
   ============================================================ */
.how{background:var(--paper-warm);}
.how__intro{text-align:center;margin-bottom:48px;}
.how__intro .lede{font-size:clamp(25px,6.2vw,34px);line-height:1.16;margin-top:16px;}
.steps{display:flex;flex-direction:column;gap:16px;max-width:var(--maxw);margin:0 auto;}
.step{display:flex;gap:20px;align-items:flex-start;padding:28px;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-md);
  box-shadow:var(--shadow-tight);}
.step__ico{flex:none;width:50px;height:50px;border-radius:var(--radius-pill);
  display:flex;align-items:center;justify-content:center;
  color:var(--ch-rose-deep);background:var(--ch-crystal-mist);}
.step__ico svg{width:23px;height:23px;}
.step__n{font-weight:600;font-size:12px;letter-spacing:var(--tracking-overline);
  text-transform:uppercase;color:var(--ch-rose-deep);display:block;margin-bottom:6px;}
.step h3{font-weight:700;font-size:19px;letter-spacing:-0.02em;color:var(--ink);line-height:1.2;}
.step p{margin-top:9px;font-weight:500;font-size:15px;line-height:1.55;color:var(--ink-soft);}

/* ============================================================
   IN-APP PREVIEW (carousel)
   ============================================================ */
.preview{background:var(--paper);overflow:hidden;border-top:1px solid var(--line);}
.preview__head{text-align:center;margin-bottom:6px;}
.preview__head .lede{font-size:clamp(25px,6.2vw,34px);line-height:1.16;margin-top:16px;}

.carousel{position:relative;margin-top:38px;}
.carousel__track{display:flex;gap:22px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:8px 24px 26px;scrollbar-width:none;-webkit-overflow-scrolling:touch;}
.carousel__track::-webkit-scrollbar{display:none;}
.slide{flex:none;width:248px;scroll-snap-align:center;display:flex;flex-direction:column;align-items:center;}
.slide__cap{margin-top:22px;text-align:center;font-weight:600;font-size:15.5px;line-height:1.4;
  color:var(--ink);max-width:230px;letter-spacing:-0.01em;}
.carousel__dots{display:flex;justify-content:center;gap:2px;margin-top:8px;}
.dot{width:7px;height:7px;padding:19px 8px;box-sizing:content-box;background-clip:content-box;
  border-radius:999px;background:var(--ch-gray-300);border:none;transition:background .2s,width .2s;}
.dot[aria-selected="true"]{width:22px;background-clip:content-box;background:var(--ch-rose-deep);}

/* ============================================================
   PHONE FRAME + APP SCREENS  (gradients allowed here — in-product)
   ============================================================ */
.phone{position:relative;width:248px;border-radius:42px;background:#111;
  padding:9px;box-shadow:var(--shadow-phone);}
.phone--sm{width:166px;border-radius:30px;padding:6px;}
.phone__screen{position:relative;border-radius:34px;overflow:hidden;background:#fff;
  aspect-ratio:248/512;display:flex;flex-direction:column;}
.phone--sm .phone__screen{border-radius:25px;}
.phone__notch{position:absolute;top:8px;left:50%;transform:translateX(-50%);
  width:84px;height:20px;border-radius:999px;background:#111;z-index:20;}
.phone--sm .phone__notch{width:58px;height:14px;top:6px;}
.statusbar{display:flex;align-items:center;justify-content:space-between;
  padding:11px 20px 2px;font-weight:600;font-size:11px;color:var(--ch-raisin);flex:none;z-index:10;}
.statusbar .sb-r{display:flex;gap:5px;align-items:center;}
.phone--sm .statusbar{font-size:8px;padding:8px 14px 2px;}
.scr{flex:1;overflow:hidden;display:flex;flex-direction:column;}

/* app top bar */
.app-top{display:flex;align-items:center;justify-content:space-between;padding:6px 18px 12px;flex:none;}
.app-top img{height:15px;width:auto;}
.app-bell{width:30px;height:30px;display:flex;align-items:center;justify-content:center;color:var(--ch-raisin);}
.app-bell svg{width:18px;height:18px;}

/* day-streak card */
.daycard{margin:0 14px;border-radius:var(--radius-md);overflow:hidden;box-shadow:0 3px 10px rgba(0,0,0,.06);}
.daycard__top{position:relative;padding:20px 18px 22px;background:var(--ch-gradient-wash);overflow:hidden;}
.daycard__top::after{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 90% at 80% -10%,rgba(255,255,255,.5),transparent 55%);}
.daycard__row{position:relative;display:flex;justify-content:space-between;align-items:flex-start;}
.daycard__day{font-weight:700;font-size:26px;letter-spacing:-0.02em;color:#fff;line-height:1;}
.daycard__sub{font-weight:500;font-size:12px;color:rgba(255,255,255,.94);margin-top:7px;}
.daycard__plus{width:30px;height:30px;border-radius:999px;background:var(--ch-ink-button);
  color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;line-height:1;flex:none;}
.daycard__btm{background:#fff;padding:16px 12px 14px;}
.arc{display:flex;justify-content:space-between;align-items:flex-start;padding:0 4px;}
.arc__d{display:flex;flex-direction:column;align-items:center;gap:6px;}
.arc__n{font-weight:500;font-size:10px;color:var(--ch-gray-400);}
.arc__n.today{color:var(--ch-rose-deep);}
.arc__dot{width:24px;height:24px;border-radius:999px;display:flex;align-items:center;justify-content:center;
  font-size:11px;background:#fff;}
.arc__dot.done{border:1.5px solid var(--ch-rose);color:var(--ch-rose);}
.arc__dot.miss{border:1.5px dashed #E2E0DF;}
.arc__dot.today{background:var(--ch-gradient);color:#fff;box-shadow:0 4px 10px rgba(254,118,157,.4);}
.arc__dot.bloom{background:#FFE9EE;color:var(--ch-rose);}
.daynote{text-align:center;font-weight:500;font-size:11px;line-height:1.45;color:var(--ch-gray-500);margin-top:13px;}

/* overline pill centered */
.app-overline{display:flex;justify-content:center;margin:20px 0 12px;}
.app-overline span{font-weight:600;font-size:9.5px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ch-rose-deep);}

/* program / photo card */
.progcard{margin:0 14px;background:#fff;border-radius:var(--radius-md);overflow:hidden;box-shadow:0 3px 10px rgba(0,0,0,.06);}
.photo{position:relative;overflow:hidden;}
.photo img{width:100%;height:100%;object-fit:cover;}
.photo__scrim{position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.6) 0%,rgba(0,0,0,.08) 46%,transparent 70%);}
.photo__heart{position:absolute;top:11px;right:11px;width:30px;height:30px;border-radius:999px;
  background:rgba(255,255,255,.2);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;color:#fff;}
.photo__heart svg{width:16px;height:16px;}
.photo__cap{position:absolute;left:16px;bottom:13px;right:16px;color:#fff;}
.photo__title{font-weight:700;letter-spacing:-0.02em;}
.photo__meta{font-weight:500;opacity:.95;margin-top:6px;display:flex;align-items:center;gap:6px;}
.spark{color:#fff;letter-spacing:1px;}

.progcard__foot{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;}
.progcard__foot span{font-weight:600;font-size:13px;color:var(--ch-raisin);}
.mini-arrow{width:30px;height:30px;border-radius:999px;border:2px solid var(--ch-rose);
  display:flex;align-items:center;justify-content:center;color:var(--ch-rose-deep);}
.mini-arrow svg{width:15px;height:15px;}

/* time chips (frame 2) */
.scr-pad{padding:0 16px;}
.q-title{font-weight:700;font-size:18px;letter-spacing:-0.02em;color:var(--ch-raisin);margin:2px 0 4px;}
.q-sub{font-weight:500;font-size:12px;color:var(--ch-gray-500);margin-bottom:16px;}
.chips{display:flex;gap:8px;margin-bottom:18px;flex-wrap:wrap;}
.chip{padding:8px 15px;border-radius:999px;background:var(--ch-gray-100);color:var(--ch-gray-600);
  font-weight:600;font-size:12px;border:1.5px solid transparent;}
.chip.on{background:var(--ch-gradient-soft);color:var(--ch-rose-deep);border-color:rgba(254,118,157,.4);}

/* exercise list (frame 3) */
.exlist{display:flex;flex-direction:column;}
.exrow{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid #F1F1F1;}
.exrow:last-child{border-bottom:none;}
.exrow__img{width:46px;height:46px;border-radius:12px;flex:none;background:#eee center/cover;}
.exrow__t{flex:1;}
.exrow__n{font-weight:600;font-size:13.5px;color:var(--ch-raisin);}
.exrow__d{font-weight:500;font-size:11px;color:var(--ch-gray-500);margin-top:4px;}
.exrow__swap{display:inline-flex;align-items:center;gap:5px;padding:6px 10px;border-radius:999px;
  background:var(--ch-gray-100);color:var(--ch-rose-deep);font-weight:600;font-size:10.5px;border:none;}
.exrow__swap svg{width:13px;height:13px;}
.exrow__chev{color:var(--ch-gray-400);display:flex;}
.exrow__chev svg{width:16px;height:16px;}

/* completion screen (frame 4 / hero phone) */
.complete{flex:1;position:relative;background:var(--ch-gradient-wash);
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:0 26px;}
.complete::before{content:"";position:absolute;inset:0;
  background:radial-gradient(90% 60% at 50% 24%,rgba(255,255,255,.45),transparent 60%);}
.hexbadge{position:relative;width:84px;height:94px;margin:0 auto 22px;
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
  background:linear-gradient(150deg,#FFB8CB,#FE5E86);display:flex;align-items:center;justify-content:center;
  box-shadow:0 16px 40px rgba(223,100,128,.45);}
.hexbadge svg{width:36px;height:36px;color:#fff;}
.complete__over{position:relative;font-weight:500;font-size:10.5px;letter-spacing:.08em;
  text-transform:uppercase;color:rgba(255,255,255,.95);margin-bottom:12px;}
.complete__h{position:relative;font-weight:700;font-size:24px;letter-spacing:-0.02em;color:#fff;line-height:1.15;}
.complete__p{position:relative;margin:13px auto 0;max-width:215px;font-weight:500;font-size:13px;line-height:1.5;color:rgba(255,255,255,.94);}
.complete__chips{position:relative;display:flex;gap:8px;margin-top:22px;}
.complete__chips .cc{padding:7px 13px;border-radius:999px;background:rgba(255,255,255,.22);
  color:#fff;font-weight:600;font-size:11px;backdrop-filter:blur(4px);}

/* phone bottom CTA bar */
.scr-cta{flex:none;padding:11px 16px 16px;background:#fff;border-top:1px solid #F1F1F1;}
.scr-cta .pill{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;height:44px;
  border-radius:999px;background:var(--ch-gradient);color:#fff;font-weight:600;font-size:14px;border:none;}
.scr-cta .pill svg{width:16px;height:16px;}
.home-ind{flex:none;height:22px;display:flex;align-items:center;justify-content:center;background:inherit;}
.home-ind::after{content:"";width:106px;height:4px;border-radius:999px;background:var(--ch-raisin);opacity:.85;}

/* ============================================================
   TESTIMONIALS — editorial cards with avatars
   ============================================================ */
.proof{overflow-x:clip;background:var(--paper-warm);}
.proof__head{text-align:center;margin-bottom:36px;}
.proof__head .lede{font-size:clamp(25px,6.2vw,34px);line-height:1.16;margin-top:16px;}
.tcards{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:4px 24px 12px;margin:0 -24px;scrollbar-width:none;}
.tcards::-webkit-scrollbar{display:none;}
.tcard{flex:none;width:min(85vw,340px);scroll-snap-align:center;background:var(--paper);
  border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:var(--shadow-card);
  padding:30px 28px;display:flex;flex-direction:column;}
.tcard__pips{color:var(--ch-rose-deep);font-size:13px;letter-spacing:3px;margin-bottom:18px;}
.tcard__q{font-weight:500;font-size:18px;line-height:1.5;color:var(--ink);letter-spacing:-0.015em;
  text-wrap:pretty;}
.tcard__by{margin-top:24px;display:flex;align-items:center;gap:12px;}
.tcard__av{flex:none;width:42px;height:42px;border-radius:999px;background:var(--ch-crystal-mist);
  display:flex;align-items:center;justify-content:center;
  font-weight:600;font-size:16px;color:var(--ch-rose-deep);letter-spacing:0;
  border:1px solid rgba(196,71,101,.16);}
.tcard__name{display:block;font-weight:600;font-size:14.5px;color:var(--ink);}
.tcard__meta{display:block;font-weight:500;font-size:12.5px;color:var(--ink-mute);margin-top:2px;}
.proof__foot{margin-top:32px;display:flex;justify-content:center;}

/* ============================================================
   YOU WON'T FALL BEHIND
   ============================================================ */
.forgive{background:var(--paper);border-top:1px solid var(--line);}
.forgive__card{max-width:var(--maxw);margin:0 auto;}
.forgive .lede{font-size:clamp(24px,6vw,34px);line-height:1.16;}
.forgive__body{margin-top:20px;font-weight:500;font-size:clamp(16px,4.2vw,18px);
  line-height:1.6;color:var(--ink-soft);max-width:60ch;}
.forgive__quotes{margin-top:36px;display:flex;flex-direction:column;gap:24px;}
.fq{padding-left:20px;border-left:2px solid var(--ch-rose-deep);}
.fq__q{font-weight:600;font-size:16.5px;line-height:1.5;color:var(--ink);letter-spacing:-0.01em;}
.fq__by{margin-top:9px;font-weight:500;font-size:13.5px;color:var(--ink-mute);}

/* ============================================================
   TRIAL CALLOUT
   ============================================================ */
.trial{background:var(--paper-warm);}
.trial__head{text-align:center;margin-bottom:34px;}
.trial__head .lede{font-size:clamp(25px,6.2vw,34px);line-height:1.16;margin-top:16px;}
.trial__list{max-width:var(--maxw);margin:0 auto;background:var(--paper);
  border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);overflow:hidden;}
.trow{display:flex;gap:16px;align-items:flex-start;padding:22px 26px;border-bottom:1px solid var(--line);}
.trow:last-child{border-bottom:none;}
.trow__ic{flex:none;width:36px;height:36px;border-radius:999px;background:var(--ch-crystal-mist);
  display:flex;align-items:center;justify-content:center;color:var(--ch-rose-deep);}
.trow__ic svg{width:18px;height:18px;}
.trow__t{font-weight:500;font-size:15.5px;line-height:1.5;color:var(--ink);padding-top:7px;}
.trow__t b{font-weight:700;}
.trial__quote{max-width:var(--maxw);margin:28px auto 0;text-align:center;}
.trial__quote .q{font-weight:600;font-size:18px;color:var(--ink);letter-spacing:-0.01em;}
.trial__quote .by{margin-top:10px;font-weight:500;font-size:13.5px;color:var(--ink-mute);}

/* ============================================================
   FAQ
   ============================================================ */
.faq{background:var(--paper);border-top:1px solid var(--line);}
.faq__list{display:flex;flex-direction:column;gap:12px;max-width:var(--maxw);margin:0 auto;}
.faq-item{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-md);overflow:hidden;
  transition:border-color .2s ease;}
.faq-item.open{border-color:var(--line-strong);}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:20px 22px;background:none;border:none;text-align:left;
  font-weight:600;font-size:16px;color:var(--ink);letter-spacing:-0.01em;min-height:44px;}
.faq-q .pm{flex:none;width:26px;height:26px;border-radius:999px;background:var(--ch-crystal-mist);
  display:flex;align-items:center;justify-content:center;color:var(--ch-rose-deep);transition:transform .25s;}
.faq-q .pm svg{width:14px;height:14px;}
.faq-item.open .faq-q .pm{transform:rotate(45deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;}
.faq-a__in{padding:0 22px 20px;font-weight:500;font-size:15px;line-height:1.6;color:var(--ink-soft);}

/* ============================================================
   FINAL CTA — full brand gradient block (the signature)
   ============================================================ */
.final{position:relative;overflow:hidden;color:#fff;text-align:center;background:var(--ch-gradient);}
.final::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(120% 80% at 50% -10%,rgba(255,255,255,.34),transparent 56%);}
.final__in{position:relative;max-width:640px;margin:0 auto;}
.final h2{font-weight:700;letter-spacing:-0.03em;color:#fff;
  font-size:clamp(28px,7vw,42px);line-height:1.1;text-wrap:balance;
  text-shadow:0 1px 16px rgba(78,17,79,.18);}
.final__sub{margin:18px auto 0;max-width:30ch;font-weight:500;font-size:clamp(16px,4.2vw,18px);
  line-height:1.5;color:rgba(255,255,255,.94);}
.final__cta{margin:32px auto 0;max-width:392px;}
/* gradient pill would vanish on a gradient block — sanctioned plum contrast solid, white label */
.final .cta{background:var(--accent-plum);box-shadow:0 8px 24px rgba(78,17,79,.3);}
.final .cta:hover{background:var(--accent-plum);filter:brightness(1.12);}
.final .cta:active{filter:brightness(.96);}
.final__anchor{margin-top:22px;display:flex;justify-content:center;}
.final .stars{color:#fff;}
.final .stars .pips{color:#fff;}
.final__risk{margin-top:14px;color:rgba(255,255,255,.92);font-size:13.5px;line-height:1.5;}

/* store badges */
.badges{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:28px;}
.badge{display:inline-flex;align-items:center;gap:10px;height:52px;padding:0 18px;
  border-radius:12px;background:#000;color:#fff;text-decoration:none;border:1px solid rgba(255,255,255,.16);
  transition:transform .15s,filter .15s;}
.badge:hover{filter:brightness(1.14);}
.badge:active{transform:scale(.97);}
.badge svg{flex:none;}
.badge__txt{display:flex;flex-direction:column;line-height:1;text-align:left;}
.badge__txt small{font-weight:500;font-size:9.5px;opacity:.82;letter-spacing:.01em;}
.badge__txt b{font-weight:600;font-size:16px;letter-spacing:-0.01em;margin-top:2px;}
.final .badge{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.4);}
.final .badge:hover{background:rgba(255,255,255,.26);filter:none;}

/* ============================================================
   FOOTER — the single dark surface (Raisin black)
   ============================================================ */
.foot{background:var(--raisin);color:#fff;text-align:center;padding:52px 0 46px;}
.foot__logo{height:18px;width:auto;margin:0 auto 18px;opacity:.95;}
.foot__priv{font-weight:600;font-size:14px;color:#fff;}
.foot__priv span{color:rgba(255,255,255,.56);font-weight:500;}
.foot__links{margin-top:18px;display:flex;flex-wrap:wrap;gap:10px 18px;align-items:center;justify-content:center;}
.foot__links a{font-weight:500;font-size:13px;color:rgba(255,255,255,.74);text-decoration:none;
  min-height:44px;display:inline-flex;align-items:center;}
.foot__links a:hover{color:#fff;}
.foot__badges{margin-top:18px;display:flex;gap:10px;justify-content:center;flex-wrap:wrap;}
.foot__badges .badge{height:46px;background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.2);}
.foot__fine{margin-top:28px;font-weight:500;font-size:11.5px;color:rgba(255,255,255,.4);}

/* ============================================================
   STICKY BOTTOM CTA (mobile)
   ============================================================ */
.sticky-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:70;
  padding:12px 18px calc(12px + env(safe-area-inset-bottom));
  background:rgba(251,248,246,.94);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-top:1px solid var(--line);box-shadow:0 -4px 20px rgba(33,29,31,.07);
  transform:translateY(130%);transition:transform .32s cubic-bezier(.4,0,.2,1);
}
.sticky-cta.show{transform:translateY(0);}
.sticky-cta__in{max-width:520px;margin:0 auto;}
.sticky-cta .cta{min-height:52px;font-size:16px;}
.sticky-cta .risk{margin-top:7px;font-size:11.5px;}

/* ============================================================
   RESPONSIVE — desktop is intentional, not stretched
   ============================================================ */
@media (min-width:880px){
  .section{padding:112px 0;}
  .wrap{padding-left:32px;padding-right:32px;}

  .topbar__in{height:72px;padding:0 36px;}
  .topbar__logo{height:19px;}
  .topbar .cta{display:inline-flex;}                 /* persistent CTA on desktop */
  .topbar:not(.solid) .cta{background:rgba(255,255,255,.16);
    border:1px solid rgba(255,255,255,.34);box-shadow:none;backdrop-filter:blur(6px);}
  .topbar:not(.solid) .cta:hover{background:rgba(255,255,255,.26);}

  /* hero: text contained lower-left over the photo */
  .hero{min-height:clamp(620px,90svh,860px);}
  .hero__media{background-image:url('img/hero-landscape.png');background-position:64% 22%;}
  .hero__scrim{background:
    linear-gradient(to top,rgba(46,42,44,.84) 0%,rgba(46,42,44,.5) 30%,rgba(46,42,44,.12) 52%,rgba(46,42,44,0) 64%),
    linear-gradient(105deg,rgba(46,42,44,.66) 0%,rgba(46,42,44,.3) 38%,rgba(46,42,44,0) 64%);}
  .hero__panel{padding-bottom:64px;}
  .hero__inner{max-width:680px;}
  .hero h1{font-size:clamp(44px,5vw,54px);}
  .hero .risk{text-align:left;}

  .proofbar__grid{flex-direction:row;max-width:920px;gap:0;}
  .proofstat{flex:1;padding:8px 24px;border-bottom:none;border-right:1px solid var(--line);}
  .proofstat:last-child{border-right:none;}
  .proofstat__big{font-size:56px;}
  .proofstat__big.pips{font-size:40px;}

  .problem .wrap{max-width:920px;}
  .problem .lede{font-size:44px;max-width:17ch;}

  .steps{flex-direction:row;gap:20px;max-width:var(--maxw-wide);align-items:stretch;}
  .step{flex:1;flex-direction:column;text-align:left;padding:34px 30px;}

  .carousel__track{justify-content:center;flex-wrap:wrap;overflow:visible;gap:34px;}
  .carousel__dots{display:none;}
  .slide{width:236px;}

  .tcards{flex-wrap:nowrap;justify-content:center;overflow:visible;margin:0;padding:4px 0;max-width:var(--maxw-wide);}
  .tcard{width:360px;}

  .forgive__quotes{flex-direction:row;gap:32px;}
  .fq{flex:1;}

  .trial__list{display:flex;flex-wrap:wrap;}
  .trow{flex:1 1 100%;}
}

@media (min-width:880px){
  .sticky-cta{display:none;}
}

@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto !important;}
  .sticky-cta,.topbar{transition:none;}
}

/* ============================================================
   CRAFT + MOTION SYSTEM (v4)
   End-state is the base style; motion is added only under
   prefers-reduced-motion: no-preference, so reduced-motion
   and no-JS users always see full, static content.
   ============================================================ */

/* visible focus for keyboard users */
a:focus-visible,button:focus-visible,.faq-q:focus-visible{
  outline:2.5px solid var(--accent-plum);outline-offset:3px;border-radius:6px;}
.cta:focus-visible,.badge:focus-visible{outline-offset:4px;}
.final .cta:focus-visible{outline-color:#fff;}
.hero .cta:focus-visible,.hero__anchor a:focus-visible{outline-color:#fff;}

/* refined overline — blossom mark + confident tracking */
.eyebrow{display:inline-flex;align-items:center;gap:7px;letter-spacing:0.16em;}
.eyebrow::before{content:"";width:13px;height:13px;flex:none;
  background:no-repeat center/contain url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHZpZXdCb3g9JzAgMCAxMDAgMTAwJz48ZGVmcz48bGluZWFyR3JhZGllbnQgaWQ9J2UnIHgxPScwJyB5MT0nMCcgeDI9JzEnIHkyPScxJz48c3RvcCBvZmZzZXQ9JzAnIHN0b3AtY29sb3I9JyNDQTk1RTInLz48c3RvcCBvZmZzZXQ9JzAuNDUnIHN0b3AtY29sb3I9JyNGRTc2OUQnLz48c3RvcCBvZmZzZXQ9JzAuODYnIHN0b3AtY29sb3I9JyNGRjkxOTEnLz48L2xpbmVhckdyYWRpZW50PjwvZGVmcz48ZyBmaWxsPSd1cmwoI2UpJyB0cmFuc2Zvcm09J3RyYW5zbGF0ZSg1MCA1MCknPjxnIGlkPSdwJz48cGF0aCBkPSdNMCwtMzggQzEzLC0zOCAyMCwtMjMgMTUsLTExIEMxMSwtMiA1LDEgMCwxIEMtNSwxIC0xMSwtMiAtMTUsLTExIEMtMjAsLTIzIC0xMywtMzggMCwtMzggWicvPjwvZz48dXNlIGhyZWY9JyNwJyB0cmFuc2Zvcm09J3JvdGF0ZSg3MiknLz48dXNlIGhyZWY9JyNwJyB0cmFuc2Zvcm09J3JvdGF0ZSgxNDQpJy8+PHVzZSBocmVmPScjcCcgdHJhbnNmb3JtPSdyb3RhdGUoMjE2KScvPjx1c2UgaHJlZj0nI3AnIHRyYW5zZm9ybT0ncm90YXRlKDI4OCknLz48Y2lyY2xlIHI9JzgnIGZpbGw9JyNGREZCRkEnLz48L2c+PC9zdmc+");}

/* gradient-ring avatars (refined from flat monogram) */
.tcard__av{background-image:linear-gradient(var(--blush),var(--blush)),var(--ch-gradient);
  background-origin:border-box;background-clip:padding-box,border-box;
  border:2px solid transparent;box-shadow:none;}

/* ---- signature bloom ---- */
.bloom{position:relative;display:flex;justify-content:center;align-items:center;
  height:132px;margin-bottom:4px;}
.bloom__glow{position:absolute;top:50%;left:50%;width:300px;height:300px;
  transform:translate(-50%,-50%);border-radius:50%;
  background:radial-gradient(circle,rgba(254,118,157,.26),rgba(207,160,229,.12) 40%,transparent 64%);}
.bloom__flower{position:relative;width:124px;height:124px;
  filter:drop-shadow(0 12px 26px rgba(223,100,128,.26));transform-origin:center;}

/* spacing rhythm — the two emotional beats breathe more */
.problem{padding-top:80px;padding-bottom:80px;}
.forgive{padding-top:88px;padding-bottom:88px;}
.proofbar{padding-top:52px;padding-bottom:52px;}
.forgive__card{text-align:center;}
.forgive .forgive__body{margin-left:auto;margin-right:auto;}
.forgive__quotes{margin-top:40px;text-align:left;}

@media (prefers-reduced-motion:no-preference){
  /* scroll reveal — only hidden when JS is present (html.js), so no-JS shows all */
  html.js .reveal{opacity:0;transform:translateY(20px);
    transition:opacity .6s ease-out,transform .65s cubic-bezier(.2,.7,.2,1);}
  html.js .reveal.is-visible{opacity:1;transform:none;}
  .reveal[data-d="1"]{transition-delay:.09s;}
  .reveal[data-d="2"]{transition-delay:.18s;}

  /* staggered groups: container toggles, children cascade */
  html.js .stagger>*{opacity:0;transform:translateY(20px);
    transition:opacity .6s ease-out,transform .65s cubic-bezier(.2,.7,.2,1);}
  html.js .stagger.is-visible>*{opacity:1;transform:none;}
  html.js .stagger.is-visible>*:nth-child(1){transition-delay:.04s;}
  html.js .stagger.is-visible>*:nth-child(2){transition-delay:.12s;}
  html.js .stagger.is-visible>*:nth-child(3){transition-delay:.20s;}
  html.js .stagger.is-visible>*:nth-child(4){transition-delay:.28s;}
  html.js .stagger.is-visible>*:nth-child(5){transition-delay:.36s;}

  /* signature bloom: petals draw in, glow swells (hidden only with JS) */
  html.js .bloom__flower{transform:scale(.42) rotate(-26deg);opacity:0;
    transition:transform 1.05s cubic-bezier(.18,.74,.22,1),opacity .7s ease;}
  html.js .bloom__glow{opacity:0;transform:translate(-50%,-50%) scale(.6);
    transition:opacity .9s ease,transform 1.1s cubic-bezier(.18,.74,.22,1);}
  html.js .forgive.bloomed .bloom__flower{transform:scale(1) rotate(0);opacity:1;}
  html.js .forgive.bloomed .bloom__glow{opacity:1;transform:translate(-50%,-50%) scale(1);}

  /* hero parallax hook (JS sets --py) */
  .hero__media{will-change:transform;transform:translate3d(0,var(--py,0),0) scale(1.06);}
}
