/* ============================================================
   FrontDesk — editorial / paper system
   Warm cream paper, true-black punctuation sections, monochrome,
   black-and-white photography. Hanken Grotesk + Newsreader italic.
   Quiet, spacious, premium. No gradients, no glass, no glow.
   ============================================================ */

:root{
  /* paper + ink */
  --paper:#F4F1EA;
  --paper-2:#EEEAE0;
  --card:#FFFFFF;
  --ink:#17150F;
  --ink-2:#3C3930;
  --muted:#78736A;
  --muted-2:#9A958A;
  --line:#E3DDD0;
  --line-2:#D6CFBF;

  /* dark sections */
  --black:#0C0B08;
  --black-2:#161410;
  --on-black:#EFEBE1;
  --on-black-muted:#9D988B;
  --on-black-line:rgba(255,255,255,.12);

  /* accent — monochrome by default (tweakable, kept subtle) */
  --accent:#17150F;
  --accent-ink:#FFFFFF;     /* text on accent buttons */

  --maxw:1200px;
  --pad:clamp(20px,5vw,48px);

  --r-card:16px;
  --r-btn:9px;

  --font:'Hanken Grotesk',system-ui,-apple-system,Segoe UI,sans-serif;
  --serif:'Newsreader',Georgia,'Times New Roman',serif;

  --ease:cubic-bezier(.22,.7,.2,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font);
  background:var(--paper);
  color:var(--ink-2);
  font-size:17px;
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
p{margin:0}
h1,h2,h3,h4{margin:0;color:var(--ink);font-weight:500;line-height:1.06;letter-spacing:-.022em}
::selection{background:var(--ink);color:var(--paper)}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.wrap-wide{max-width:1360px;margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
section{padding:clamp(72px,11vw,148px) 0;position:relative}
.section-tight{padding:clamp(56px,8vw,104px) 0}

/* type scale */
.display{font-size:clamp(40px,6.6vw,82px);letter-spacing:-.035em;line-height:.98}
.h1{font-size:clamp(32px,4.6vw,60px);letter-spacing:-.03em;line-height:1.02}
.h2{font-size:clamp(27px,3.4vw,44px);letter-spacing:-.026em;line-height:1.06}
.h3{font-size:clamp(20px,2vw,25px);letter-spacing:-.02em;line-height:1.15}
.serif-it{font-family:var(--serif);font-style:italic;font-weight:400;letter-spacing:-.01em}
.lede{font-size:clamp(17px,1.5vw,20px);color:var(--muted);line-height:1.55;font-weight:400}
.eyebrow{font-size:12.5px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);display:inline-block}
.measure{max-width:34ch}
.measure-wide{max-width:52ch}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:inherit;font-weight:600;font-size:14.5px;letter-spacing:-.01em;cursor:pointer;
  padding:11px 19px;border-radius:var(--r-btn);border:1px solid transparent;line-height:1;
  transition:transform .18s var(--ease),background .18s var(--ease),color .18s var(--ease),border-color .18s var(--ease);
  white-space:nowrap;
}
.btn-dark{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.btn-dark:hover{transform:translateY(-1px);background:#000}
.btn-line{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn-line:hover{border-color:var(--ink);background:rgba(0,0,0,.02)}
.btn-lg{padding:14px 24px;font-size:15.5px;border-radius:11px}
.btn .arr{font-size:1.05em;transition:transform .18s var(--ease)}
.btn:hover .arr{transform:translateX(3px)}
/* on-dark */
.on-dark .btn-dark{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.on-dark .btn-dark:hover{background:#fff}
.on-dark .btn-line{color:var(--on-black);border-color:rgba(255,255,255,.24)}
.on-dark .btn-line:hover{border-color:rgba(255,255,255,.7);background:rgba(255,255,255,.04)}

/* link with underline reveal */
.tlink{display:inline-flex;align-items:center;gap:7px;font-weight:600;font-size:14.5px;color:var(--ink);
  border-bottom:1px solid var(--line-2);padding-bottom:2px;transition:border-color .2s}
.tlink:hover{border-color:var(--ink)}
.tlink .arr{transition:transform .18s var(--ease)}
.tlink:hover .arr{transform:translateX(3px)}

/* ---------- Section heads ---------- */
.shead{display:flex;flex-direction:column;gap:18px;max-width:60ch}
.shead .eyebrow{margin-bottom:2px}
.shead-row{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;flex-wrap:wrap}

/* ---------- Dark section base ---------- */
.dark{background:var(--black);color:var(--on-black)}
.dark h1,.dark h2,.dark h3,.dark h4{color:#fff}
.dark .eyebrow{color:var(--on-black-muted)}
.dark .lede{color:var(--on-black-muted)}
.paper-2{background:var(--paper-2)}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .3s var(--ease),border-color .3s,backdrop-filter .3s}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:66px;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(244,241,234,.82);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}
.nav.scrolled .nav-in{border-color:var(--line)}
.brand{display:flex;align-items:center;gap:9px;font-weight:600;font-size:18px;color:var(--ink);letter-spacing:-.02em}
.brand-mark{width:24px;height:24px;border-radius:6px;background:var(--ink);display:grid;place-items:center}
.brand-mark span{width:9px;height:9px;border:1.7px solid var(--paper);border-radius:2px}
.nav-mid{display:flex;align-items:center;gap:30px}
.nav-mid a{font-size:14.5px;font-weight:500;color:var(--ink-2);transition:color .2s}
.nav-mid a:hover{color:var(--ink)}
.nav-right{display:flex;align-items:center;gap:14px}
.nav-cta{padding:9px 16px;font-size:14px}
@media(max-width:840px){.nav-mid{display:none}.nav-right .ghost-link{display:none}}

/* ============================================================
   HERO
   ============================================================ */
.hero{padding-top:118px;padding-bottom:0}
.hero-top{display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:end;padding-bottom:clamp(34px,5vw,60px)}
@media(max-width:860px){.hero-top{grid-template-columns:1fr;gap:24px;align-items:start}}
.hero h1{color:var(--ink)}
.hero-sub{margin-top:4px}
.hero-sub p{font-size:clamp(16px,1.45vw,19px);color:var(--muted);line-height:1.5;max-width:42ch}
.hero-actions{margin-top:26px;display:flex;gap:12px;flex-wrap:wrap}

/* product window on a soft backdrop */
.hero-stage{position:relative;padding:clamp(20px,4vw,46px) clamp(16px,3vw,40px) 0;
  background:linear-gradient(180deg,var(--paper-2),var(--paper));
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden}
.hero-stage .backdrop{position:absolute;inset:0;z-index:0}
.hero-window{position:relative;z-index:2;max-width:1080px;margin:0 auto;transform:translateY(0)}

/* generic browser frame */
.frame{background:#fff;border:1px solid var(--line);border-radius:14px 14px 0 0;overflow:hidden;
  box-shadow:0 -1px 0 rgba(0,0,0,.02),0 40px 80px -40px rgba(20,16,8,.45),0 16px 40px -28px rgba(20,16,8,.3)}
.frame.full{border-radius:14px}
.frame-bar{display:flex;align-items:center;gap:14px;padding:11px 15px;border-bottom:1px solid var(--line);background:#fbfaf7}
.frame-dots{display:flex;gap:6px}
.frame-dots i{width:11px;height:11px;border-radius:50%;background:#E0DACD}
.frame-url{flex:1;display:flex;align-items:center;justify-content:center}
.frame-url span{font-size:12px;color:var(--muted-2);background:#fff;border:1px solid var(--line);
  border-radius:7px;padding:5px 14px;font-weight:500}
.frame-tag{font-size:10.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);
  border:1px solid var(--line);border-radius:20px;padding:4px 10px;white-space:nowrap;background:#fff}
.frame-body{position:relative}

/* ---- carousel of example businesses ---- */
.car-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;
  max-width:1080px;margin:0 auto 14px;padding:0 2px}
.car-bar-lab{font-size:11.5px;font-weight:600;letter-spacing:.04em;color:var(--muted);text-transform:uppercase}
.car-bar-ctrl{display:flex;align-items:center;gap:13px}
.car-dots{display:flex;align-items:center;gap:7px}
.car-dots button{width:8px;height:8px;border-radius:50%;border:0;padding:0;cursor:pointer;
  background:#D7D0C2;transition:transform .2s var(--ease),background .2s}
.car-dots button:hover{background:#B9B0A0}
.car-dots button.on{background:var(--ink);transform:scale(1.3)}
.car-arrow{width:32px;height:32px;border-radius:50%;border:1px solid var(--line-2);background:#fff;
  cursor:pointer;color:var(--ink);font-size:17px;line-height:1;display:flex;align-items:center;
  justify-content:center;transition:background .15s,border-color .15s,color .15s}
.car-arrow:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.car-viewport{overflow:hidden}
.car-track{display:flex;will-change:transform;transition:transform .55s var(--ease)}
.car-slide{flex:0 0 100%;min-width:100%;position:relative}
@media(max-width:720px){.car-bar-lab{display:none}.car-bar{justify-content:center}}

/* ============================================================
   MOCK CLIENT SITE (inside hero frame) — fashion atelier
   ============================================================ */
.mock{display:grid;grid-template-columns:1.25fr .75fr;min-height:380px}
@media(max-width:720px){.mock{grid-template-columns:1fr;min-height:0}}
.mock-left{padding:0}
.mock-hero{position:relative;height:100%;min-height:300px;background:#E7E2D7;overflow:hidden;display:flex;align-items:flex-end}
.mock-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.mock-hero .grad{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.66));z-index:1}
.mock-hero .cap{position:relative;z-index:2;padding:26px 28px;color:#fff}
.mock-hero .cap .ek{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.7);font-weight:600}
.mock-hero .cap h4{color:#fff;font-size:25px;font-weight:500;letter-spacing:-.02em;margin-top:9px;line-height:1.08}
.mock-hero .cap p{color:rgba(255,255,255,.78);font-size:13px;margin-top:8px;max-width:30ch}
.mock-right{border-left:1px solid var(--line);padding:24px 24px;display:flex;flex-direction:column;background:#fff}
.mock-right .mr-k{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600}
.mock-right h5{font-size:18px;font-weight:600;color:var(--ink);margin-top:8px;letter-spacing:-.02em}
.mock-right .mr-sub{font-size:13px;color:var(--muted);margin-top:6px;line-height:1.5}
.mform{margin-top:18px;display:flex;flex-direction:column;gap:9px}
.mform label{font-size:11px;font-weight:600;color:var(--ink-2)}
.mform input{font-family:inherit;font-size:13.5px;padding:11px 12px;border:1px solid var(--line-2);border-radius:9px;
  outline:none;color:var(--ink);background:#fff;transition:border-color .18s}
.mform input:focus{border-color:var(--ink)}
.mform button{margin-top:4px;font-family:inherit;font-weight:600;font-size:14px;color:#fff;background:var(--ink);
  border:0;border-radius:9px;padding:12px;cursor:pointer;transition:background .18s}
.mform button:hover{background:#000}
.mform button:disabled{opacity:.55;cursor:default}
.mform .fineprint{font-size:11px;color:var(--muted-2);margin-top:2px;text-align:center}

/* ============================================================
   ALERT — drops in from the desk side (interactive demo)
   ============================================================ */
.alert{position:absolute;right:18px;top:18px;z-index:30;width:268px;
  background:#fff;border:1px solid var(--line);border-radius:13px;padding:14px 15px;
  box-shadow:0 24px 50px -18px rgba(20,16,8,.4);
  transform:translateY(-12px) scale(.98);opacity:0;pointer-events:none;
  transition:transform .42s var(--ease),opacity .3s}
.alert.show{transform:none;opacity:1}
.alert .a-top{display:flex;align-items:center;gap:9px}
.alert .a-dot{width:8px;height:8px;border-radius:50%;background:#17150F;flex:none}
.alert .a-k{font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);font-weight:700}
.alert .a-time{margin-left:auto;font-size:11px;color:var(--muted-2);font-weight:500}
.alert .a-name{font-size:16px;font-weight:600;color:var(--ink);margin-top:9px;letter-spacing:-.01em}
.alert .a-meta{font-size:12.5px;color:var(--muted);margin-top:3px}
.alert .a-cta{margin-top:12px;display:flex;gap:7px}
.alert .a-cta .mini{font-size:12px;font-weight:600;padding:7px 11px;border-radius:7px;border:1px solid var(--line-2);color:var(--ink)}
.alert .a-cta .mini.solid{background:var(--ink);color:#fff;border-color:var(--ink)}
@media(max-width:720px){.alert{right:12px;top:12px;width:240px}}

/* ============================================================
   LOGO / TRUST STRIP
   ============================================================ */
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.strip-in{display:flex;align-items:center;gap:clamp(20px,4vw,52px);justify-content:space-between;flex-wrap:wrap;
  padding:26px 0}
.strip-lab{font-size:13px;color:var(--muted);font-weight:500;white-space:nowrap}
.strip-logos{display:flex;align-items:center;gap:clamp(18px,3.4vw,44px);flex-wrap:wrap}
.strip-logos span{font-size:15px;font-weight:600;color:var(--muted-2);letter-spacing:-.01em}

/* ============================================================
   TWO-UP PHOTO CARDS
   ============================================================ */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:clamp(34px,5vw,56px)}
@media(max-width:760px){.duo{grid-template-columns:1fr}}
.pcard{position:relative;border-radius:var(--r-card);overflow:hidden;min-height:clamp(320px,40vw,440px);
  display:flex;align-items:flex-end;background:#E7E2D7;isolation:isolate}
.pcard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.pcard .grad{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.0) 30%,rgba(0,0,0,.72))}
.pcard .pc-in{position:relative;z-index:2;padding:clamp(24px,3vw,34px);color:#fff}
.pcard .pc-k{font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.72);font-weight:600}
.pcard h3{color:#fff;font-size:clamp(22px,2.4vw,29px);font-weight:500;margin-top:12px;letter-spacing:-.02em}
.pcard p{color:rgba(255,255,255,.8);font-size:15px;margin-top:10px;max-width:34ch;line-height:1.5}

/* ============================================================
   PRODUCT UI GRID
   ============================================================ */
.ugrid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;margin-top:clamp(34px,5vw,56px)}
@media(max-width:900px){.ugrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.ugrid{grid-template-columns:1fr}}
.ucard{background:var(--card);border:1px solid var(--line);border-radius:var(--r-card);padding:22px 22px 0;
  display:flex;flex-direction:column;overflow:hidden;transition:border-color .2s,transform .2s var(--ease)}
.ucard:hover{transform:translateY(-3px);border-color:var(--line-2)}
.ucard .uc-k{font-size:11.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);font-weight:600}
.ucard h3{font-size:19px;font-weight:600;color:var(--ink);margin-top:11px;letter-spacing:-.02em}
.ucard p{font-size:14px;color:var(--muted);margin-top:8px;line-height:1.5}
.ucard .uc-viz{margin-top:20px;margin-left:-22px;margin-right:-22px;border-top:1px solid var(--line);
  background:#FBFAF7;padding:18px 22px;min-height:118px}
/* spans */
.ucard.col4{grid-column:span 4}
.ucard.col3{grid-column:span 3}
.ucard.col2{grid-column:span 2}
@media(max-width:900px){.ucard.col4,.ucard.col3,.ucard.col2{grid-column:span 2}}
@media(max-width:560px){.ucard.col4,.ucard.col3,.ucard.col2{grid-column:span 1}}

/* mini UI bits inside ucards */
.inbox-row{display:flex;align-items:center;gap:11px;padding:9px 0;border-bottom:1px solid var(--line)}
.inbox-row:last-child{border-bottom:0}
.inbox-row .av{width:28px;height:28px;border-radius:50%;background:#ECE7DC;color:var(--ink-2);
  display:grid;place-items:center;font-size:11px;font-weight:700;flex:none}
.inbox-row .nm{font-size:13px;font-weight:600;color:var(--ink)}
.inbox-row .mt{font-size:11.5px;color:var(--muted-2)}
.inbox-row .tg{margin-left:auto;font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  color:var(--ink);background:#ECE7DC;border-radius:20px;padding:3px 8px}
.stat-big{font-size:42px;font-weight:500;color:var(--ink);letter-spacing:-.03em;line-height:1;font-variant-numeric:tabular-nums}
.stat-sub{font-size:12.5px;color:var(--muted);margin-top:6px}
.bars{display:flex;align-items:flex-end;gap:7px;height:62px;margin-top:6px}
.bars i{flex:1;background:#E0DACD;border-radius:3px 3px 0 0}
.bars i.on{background:var(--ink)}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chips span{font-size:12px;font-weight:600;color:var(--ink-2);border:1px solid var(--line);border-radius:20px;padding:5px 11px;background:#fff}
.thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}
.thumbs i{aspect-ratio:1;border-radius:7px;background:#ECE7DC;border:1px solid var(--line)}
.thumbs img{aspect-ratio:1;border-radius:7px;object-fit:cover;width:100%;border:1px solid var(--line)}
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--line)}
.toggle-row:last-child{border-bottom:0}
.toggle-row .tl{font-size:13px;font-weight:600;color:var(--ink)}
.toggle-row .tw{width:34px;height:20px;border-radius:20px;background:var(--ink);position:relative;flex:none}
.toggle-row .tw::after{content:"";position:absolute;top:2px;right:2px;width:16px;height:16px;border-radius:50%;background:#fff}

/* ============================================================
   QUOTE
   ============================================================ */
.quote{text-align:center}
.quote blockquote{margin:0 auto;max-width:18ch;font-size:clamp(26px,3.8vw,46px);font-weight:500;
  color:var(--ink);letter-spacing:-.028em;line-height:1.08}
.quote blockquote .serif-it{color:var(--ink)}
.quote .qmax{max-width:24ch;margin:0 auto}
.quote-by{margin-top:28px;display:flex;flex-direction:column;gap:3px;align-items:center}
.quote-by .qn{font-weight:600;color:var(--ink);font-size:15px}
.quote-by .qr{font-size:13.5px;color:var(--muted)}

/* ============================================================
   SPLIT — product moment (phone)
   ============================================================ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);align-items:center}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:36px}}
.split-media{display:flex;justify-content:center}
.phone{width:248px;border-radius:34px;background:#0C0B08;padding:9px;border:1px solid #26231c;
  box-shadow:0 50px 90px -40px rgba(20,16,8,.55)}
.phone-scr{background:var(--paper);border-radius:27px;overflow:hidden;height:512px;position:relative}
.phone-nz{position:absolute;top:9px;left:50%;transform:translateX(-50%);width:84px;height:21px;border-radius:14px;background:#0C0B08;z-index:5}
.pa{padding:40px 14px 14px}
.pa-bar{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--muted);font-weight:600;padding:0 4px 12px}
.pa-h{font-size:13px;font-weight:600;color:var(--ink);letter-spacing:-.01em;margin-bottom:10px;padding:0 2px}
.pa-card{background:#fff;border:1px solid var(--line);border-radius:13px;padding:13px 13px;margin-bottom:9px}
.pa-card .pk{font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);font-weight:700}
.pa-card .pn{font-size:15px;font-weight:600;color:var(--ink);margin-top:6px}
.pa-card .pm{font-size:12px;color:var(--muted);margin-top:2px}
.pa-card .pbadge{display:inline-block;margin-top:9px;font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  color:#fff;background:var(--ink);border-radius:20px;padding:3px 9px}
.pa-stat{display:flex;gap:9px;margin-bottom:9px}
.pa-stat .s{flex:1;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px}
.pa-stat .s .v{font-size:26px;font-weight:500;color:var(--ink);letter-spacing:-.02em;line-height:1}
.pa-stat .s .l{font-size:10.5px;color:var(--muted);margin-top:5px;letter-spacing:.02em}

/* ============================================================
   DARK FEATURE (how it works)
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:clamp(40px,5vw,60px)}
@media(max-width:840px){.steps{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}
.stepc{background:var(--black-2);border:1px solid var(--on-black-line);border-radius:var(--r-card);padding:24px 22px;
  display:flex;flex-direction:column;min-height:210px}
.stepc .sn{font-size:12px;font-weight:600;color:var(--on-black-muted);letter-spacing:.04em}
.stepc h3{color:#fff;font-size:20px;font-weight:600;margin-top:auto;letter-spacing:-.02em}
.stepc p{color:var(--on-black-muted);font-size:14px;margin-top:9px;line-height:1.5}

/* ============================================================
   FULL-BLEED PHOTO BAND
   ============================================================ */
.band{position:relative;min-height:clamp(440px,56vw,600px);display:flex;align-items:center;overflow:hidden;isolation:isolate;background:#E7E2D7}
.band img.band-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.band .veil{position:absolute;inset:0;z-index:1;background:linear-gradient(105deg,rgba(8,7,5,.82) 0%,rgba(8,7,5,.5) 48%,rgba(8,7,5,.22) 100%)}
.band-in{position:relative;z-index:2;width:100%}
.band h2{color:#fff;max-width:18ch}
.band-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:38px;max-width:920px}
@media(max-width:760px){.band-cols{grid-template-columns:1fr;gap:20px}}
.band-cols .bc .bk{font-family:var(--serif);font-style:italic;font-size:22px;color:#fff;letter-spacing:-.01em}
.band-cols .bc p{color:rgba(255,255,255,.78);font-size:14.5px;margin-top:9px;line-height:1.55}

/* ============================================================
   WHO FOR
   ============================================================ */
.who{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:clamp(36px,4vw,52px)}
@media(max-width:780px){.who{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.who{grid-template-columns:1fr}}
.whoc{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:20px 20px;
  display:flex;align-items:center;gap:13px;transition:border-color .2s,transform .2s var(--ease)}
.whoc:hover{transform:translateY(-2px);border-color:var(--line-2)}
.whoc .wn{font-size:15.5px;font-weight:600;color:var(--ink);letter-spacing:-.01em}
.whoc .wd{font-size:12.5px;color:var(--muted);margin-top:2px}
.whoc .wi{width:34px;height:34px;border-radius:9px;border:1px solid var(--line);display:grid;place-items:center;flex:none;background:#FBFAF7}
.whoc .wi svg{width:17px;height:17px;stroke:var(--ink);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.whoc.feat{background:var(--ink);border-color:var(--ink)}
.whoc.feat .wn{color:#fff}
.whoc.feat .wd{color:rgba(255,255,255,.62)}
.whoc.feat .wi{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.16)}
.whoc.feat .wi svg{stroke:#fff}

/* ============================================================
   PRICING
   ============================================================ */
.price{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(32px,5vw,64px);align-items:center;
  border:1px solid var(--line);border-radius:22px;background:var(--card);overflow:hidden;margin-top:clamp(34px,4vw,52px)}
@media(max-width:820px){.price{grid-template-columns:1fr}}
.price-left{padding:clamp(32px,4vw,52px)}
.price-left .eyebrow{color:var(--muted)}
.price-amt{font-size:clamp(44px,6vw,68px);font-weight:500;color:var(--ink);letter-spacing:-.035em;line-height:1;margin-top:18px}
.price-amt small{font-size:18px;color:var(--muted);font-weight:500;letter-spacing:0}
.price-meta{margin-top:16px;display:flex;flex-direction:column;gap:7px}
.price-meta .pm{display:flex;align-items:baseline;gap:8px;font-size:15px;color:var(--ink-2)}
.price-meta .pm b{color:var(--ink);font-weight:600}
.price-meta .save{font-size:13px;color:var(--muted);font-family:var(--serif);font-style:italic}
.price-left .btn{margin-top:26px}
.price-note{margin-top:14px;font-size:12.5px;color:var(--muted-2)}
.price-right{padding:clamp(28px,3.6vw,44px);background:#FBFAF7;border-left:1px solid var(--line);align-self:stretch}
@media(max-width:820px){.price-right{border-left:0;border-top:1px solid var(--line)}}
.price-right .pk{font-size:12px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:18px}
.incl{list-style:none;margin:0;padding:0;columns:1;display:grid;grid-template-columns:1fr 1fr;gap:11px 22px}
@media(max-width:520px){.incl{grid-template-columns:1fr}}
.incl li{display:flex;gap:10px;align-items:flex-start;font-size:14px;color:var(--ink-2);line-height:1.4}
.incl li svg{width:15px;height:15px;flex:none;margin-top:2px;stroke:var(--ink);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ---- growth add-on ---- */
.addon-connect{display:flex;align-items:center;gap:16px;margin:30px 0 16px;justify-content:center}
.addon-connect .ac-line{height:1px;background:var(--line-2);flex:1;max-width:110px}
.addon-connect .ac-lab{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--muted);white-space:nowrap}
.addon{display:grid;grid-template-columns:1.2fr .8fr;border:1px solid var(--ink);border-radius:22px;
  background:var(--card);overflow:hidden;box-shadow:0 24px 60px -42px rgba(20,16,8,.5)}
@media(max-width:820px){.addon{grid-template-columns:1fr}}
.addon-main{padding:clamp(28px,3.6vw,44px)}
.addon-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.addon-head .eyebrow{color:var(--muted);white-space:nowrap}
.rec-tag{font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff;
  background:var(--ink);border-radius:20px;padding:5px 10px;line-height:1}
.rec-tag.sm{font-size:9px;padding:3px 7px;margin-left:9px;position:relative;top:-1px}
.addon-main h3{font-size:clamp(22px,2.6vw,31px);font-weight:500;letter-spacing:-.025em;line-height:1.08;color:var(--ink)}
.addon-main .asub{margin-top:12px;color:var(--muted);font-size:15.5px;line-height:1.55;max-width:48ch}
.addon-incl{list-style:none;margin:24px 0 0;padding:0;display:flex;flex-direction:column;gap:14px}
.addon-incl li{display:flex;gap:12px;align-items:flex-start;font-size:14.5px;color:var(--ink-2);line-height:1.5}
.addon-incl li svg{width:17px;height:17px;flex:none;margin-top:2px;stroke:var(--ink);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.addon-incl li b{color:var(--ink);font-weight:600}
.addon-side{background:var(--black);color:var(--on-black);padding:clamp(28px,3.4vw,40px);
  display:flex;flex-direction:column;align-items:flex-start}
.addon-side .ak{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--on-black-muted);font-weight:600}
.addon-amt{font-size:clamp(34px,4vw,46px);font-weight:500;color:#fff;letter-spacing:-.03em;line-height:1;margin-top:14px;white-space:nowrap}
.addon-amt small{font-size:15px;color:var(--on-black-muted);font-weight:500;letter-spacing:0}
.addon-side .awith{font-size:13px;color:var(--on-black-muted);margin-top:9px}
.addon-side .apos{font-family:var(--serif);font-style:italic;font-size:16.5px;color:#fff;margin-top:20px;line-height:1.42;max-width:30ch}
.addon-side .btn{margin-top:24px;width:100%}

/* ---- combined summary ---- */
.combined{margin-top:16px;border:1px solid var(--line);border-radius:22px;background:#FBFAF7;padding:clamp(24px,3vw,36px)}
.combined .ck{font-size:12px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:4px}
.combined-row{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center;padding:18px 0;border-top:1px solid var(--line)}
.combined-row:first-of-type{border-top:0}
.combined-row .cname{font-weight:600;color:var(--ink);font-size:16px;letter-spacing:-.01em}
.combined-row .cdesc{font-size:13.5px;color:var(--muted);margin-top:4px;max-width:56ch;line-height:1.5}
.combined-row .cprice{font-size:24px;font-weight:600;color:var(--ink);letter-spacing:-.02em;white-space:nowrap}
.combined-row .cprice small{font-size:14px;color:var(--muted);font-weight:500}
.combined-row.best .cprice{font-size:28px}
.combined-foot{border-top:1px solid var(--line);padding-top:18px;font-size:14.5px;color:var(--ink-2)}
.combined-foot b{color:var(--ink);font-weight:600}
.combined-foot .cf-save{font-family:var(--serif);font-style:italic;color:var(--muted)}
@media(max-width:560px){
  .combined-row{grid-template-columns:1fr;gap:6px}
  .combined-row .cprice{justify-self:start}
}

/* ============================================================
   FAQ
   ============================================================ */
.faq{display:grid;grid-template-columns:.7fr 1.3fr;gap:clamp(28px,4vw,56px);align-items:start}
@media(max-width:780px){.faq{grid-template-columns:1fr;gap:24px}}
.faq-list{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{display:flex;align-items:center;gap:18px;width:100%;text-align:left;background:none;border:0;
  font-family:inherit;cursor:pointer;padding:22px 2px;font-size:18px;font-weight:600;color:var(--ink);letter-spacing:-.015em}
.faq-q .qx{margin-left:auto;flex:none;width:18px;height:18px;position:relative}
.faq-q .qx::before,.faq-q .qx::after{content:"";position:absolute;background:var(--ink);border-radius:2px;
  transition:transform .3s var(--ease),opacity .3s}
.faq-q .qx::before{top:8px;left:0;width:18px;height:2px}
.faq-q .qx::after{left:8px;top:0;width:2px;height:18px}
.faq-item.open .qx::after{transform:scaleY(0);opacity:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .34s var(--ease)}
.faq-a-in{padding:0 2px 24px;color:var(--muted);font-size:15.5px;line-height:1.6;max-width:60ch}

/* ============================================================
   ITALIC-SERIF CTA MOMENT
   ============================================================ */
.serif-cta{text-align:center}
.serif-cta h2{font-size:clamp(30px,4.4vw,56px);font-weight:500;letter-spacing:-.03em;line-height:1.04;max-width:20ch;margin:0 auto}
.serif-cta .sub{margin-top:20px;max-width:46ch;margin-left:auto;margin-right:auto}
.serif-cta .covers{display:flex;justify-content:center;gap:12px;margin-top:42px;flex-wrap:wrap}
.serif-cta .covers img{width:104px;height:128px;object-fit:cover;border-radius:10px}

/* ============================================================
   FINAL CTA (dark)
   ============================================================ */
.final{text-align:center}
.final h2{color:#fff;font-size:clamp(36px,6vw,86px);letter-spacing:-.035em;line-height:.98;max-width:14ch;margin:0 auto}
.final .sub{margin:24px auto 0;max-width:42ch}
.final-actions{margin-top:34px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.final-wa{margin-top:20px;font-size:13.5px;color:var(--on-black-muted)}
.final-wa a{color:#fff;border-bottom:1px solid rgba(255,255,255,.3);padding-bottom:1px}

/* ============================================================
   FOOTER (dark)
   ============================================================ */
.footer{background:var(--black);color:var(--on-black-muted);padding:clamp(56px,7vw,88px) 0 40px;border-top:1px solid var(--on-black-line)}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:32px}
@media(max-width:780px){.foot-top{grid-template-columns:1fr 1fr;gap:30px}}
@media(max-width:460px){.foot-top{grid-template-columns:1fr}}
.footer .brand{color:#fff;margin-bottom:14px}
.footer .brand .brand-mark{background:var(--paper)}
.footer .brand .brand-mark span{border-color:var(--ink)}
.foot-blurb{font-size:14.5px;color:var(--on-black-muted);max-width:30ch;line-height:1.55;font-family:var(--serif);font-style:italic}
.foot-col h4{color:#fff;font-size:12px;letter-spacing:.13em;text-transform:uppercase;font-weight:600;margin-bottom:15px}
.foot-col a{display:block;font-size:14.5px;color:var(--on-black-muted);margin-bottom:10px;transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  border-top:1px solid var(--on-black-line);margin-top:clamp(40px,5vw,64px);padding-top:24px;font-size:13px;color:var(--on-black-muted)}

/* ============================================================
   REVEAL (timeline-proof: JS hard-locks the visible end state)
   ============================================================ */
.reveal.d1{--rd:.06s}
.reveal.d2{--rd:.12s}
.reveal.d3{--rd:.18s}
.reveal.d4{--rd:.24s}
.reveal.d5{--rd:.30s}
@media(prefers-reduced-motion:no-preference){
  html.js .reveal{opacity:0}
  html.js .reveal.in{animation:revUp .7s var(--ease) both;animation-delay:var(--rd,0s)}
}
@keyframes revUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){html *{scroll-behavior:auto}}

/* ============================================================
   LEGAL PAGES (privacy / terms)
   ============================================================ */
.legal-hero{padding-top:clamp(118px,15vh,168px);padding-bottom:clamp(34px,5vw,54px);
  border-bottom:1px solid var(--line);background:var(--paper-2)}
.legal-hero .eyebrow{color:var(--muted);margin-bottom:18px}
.legal-hero h1{font-size:clamp(38px,6vw,62px);letter-spacing:-.03em;line-height:1.02}
.legal-hero .legal-sub{margin-top:18px;max-width:62ch;font-size:clamp(16px,1.4vw,19px);
  color:var(--muted);line-height:1.55}
.legal-updated{margin-top:24px;font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted-2);font-weight:700}

.legal-body{padding:clamp(44px,6vw,76px) 0 clamp(60px,9vw,108px)}
.legal-grid{display:grid;grid-template-columns:230px 1fr;gap:clamp(36px,6vw,84px);align-items:start}
@media(max-width:880px){.legal-grid{grid-template-columns:1fr;gap:6px}}

.legal-toc{position:sticky;top:92px}
.legal-toc .toc-k{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted-2);font-weight:700;margin-bottom:14px}
.legal-toc a{display:block;font-size:14px;color:var(--muted);line-height:1.4;
  padding:6px 0 6px 14px;margin-left:-16px;border-left:2px solid transparent;transition:color .18s,border-color .18s}
.legal-toc a:hover{color:var(--ink);border-color:var(--line-2)}
@media(max-width:880px){.legal-toc{display:none}}

.legal-content{max-width:72ch}
.legal-content > section{padding:0;scroll-margin-top:88px}
.legal-content > section + section{margin-top:clamp(34px,4vw,50px)}
.legal-content h2{font-size:clamp(21px,2.4vw,27px);letter-spacing:-.02em;display:flex;align-items:baseline;gap:13px}
.legal-content h2 .num{font-family:var(--serif);font-style:italic;font-weight:400;font-size:.78em;
  color:var(--muted-2);letter-spacing:0}
.legal-content h3{font-size:16.5px;font-weight:600;color:var(--ink);margin-top:24px;letter-spacing:-.01em}
.legal-content p{margin-top:14px;color:var(--ink-2);line-height:1.62}
.legal-content ul{margin:14px 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:10px}
.legal-content li{position:relative;padding-left:22px;color:var(--ink-2);line-height:1.6}
.legal-content li::before{content:"";position:absolute;left:2px;top:11px;width:6px;height:6px;
  border-radius:50%;background:var(--line-2)}
.legal-content li b,.legal-content p b{color:var(--ink);font-weight:600}
.legal-content a.tl{color:var(--ink);text-decoration:underline;text-underline-offset:2px;
  text-decoration-color:var(--line-2)}
.legal-content a.tl:hover{text-decoration-color:currentColor}
.legal-note{margin-top:34px;padding:22px 24px;background:var(--paper-2);border:1px solid var(--line);
  border-radius:14px;font-size:14px;color:var(--muted);line-height:1.62}
.legal-note b{color:var(--ink)}
