/* ═══════════════════════════════════════════════════════════════════════════
   Family Command Center — marketing site shared design system
   Mirrors the FCC app: garden green, warm cream, Figtree, calm + premium.
   Canonical tokens & components are defined in design-guide.md (design-guide.html = rendered reference).
   ═══════════════════════════════════════════════════════════════════════════ */
/* ── Self-hosted fonts — no third-party requests (privacy by default) ──────── */
@font-face{
  font-family:'Figtree'; font-style:normal; font-weight:300 900; font-display:swap;
  src:url('assets/fonts/figtree-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Figtree'; font-style:normal; font-weight:300 900; font-display:swap;
  src:url('assets/fonts/figtree-latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  /* Fraunces variable — drive opsz via font-optical-sizing, wght via font-weight,
     SOFT/WONK via font-variation-settings on each display selector. */
  font-family:'Fraunces'; font-style:normal; font-weight:100 900; font-display:swap;
  src:url('assets/fonts/fraunces-variable.woff2') format('woff2');
}

:root{
  --font:'Figtree', system-ui, -apple-system, sans-serif;
  --font-display:'Fraunces', Georgia, 'Times New Roman', Cambria, serif;

  --garden:#3C7A5B;
  --garden-deep:#2F6149;
  --garden-soft:#E7EFE9;
  --garden-line:#C7DDCF;

  --bg:#F4F2EC;
  --bg-2:#ECEDEA;
  --surf:#FFFFFF;
  --surf-2:#F7F7F4;
  --surf-3:#EFEFEB;

  --ink:#21232A;
  --ink-2:#5C5F69;
  --ink-3:#6F737D;
  --line:#E4E4DF;
  --line-2:#D8D8D2;

  /* Category tints — accents only; -bg fills track the tint via color-mix */
  --task:#5B6CF0;    --task-bg:color-mix(in srgb, var(--task) 14%, #fff);
  --chore:#1E9E90;   --chore-bg:color-mix(in srgb, var(--chore) 14%, #fff);
  --shop:#C88A3A;    --shop-bg:color-mix(in srgb, var(--shop) 14%, #fff);
  --routine:#8C79D6; --routine-bg:color-mix(in srgb, var(--routine) 14%, #fff);
  --event:#DD6396;   --event-bg:color-mix(in srgb, var(--event) 14%, #fff);

  --warn-bg:#F6EAD6; --warn-ink:#9A6418;
  --good-bg:#DCEFEB; --good-ink:#157567;
  --danger:#B4543C;  --danger-bg:#F3E2DC;

  --r:20px; --r-lg:28px; --r-sm:13px; --r-pill:999px;
  --sh-1:0 1px 2px rgba(33,35,42,.04), 0 4px 14px rgba(33,35,42,.05);
  --sh-2:0 1px 2px rgba(33,35,42,.04), 0 10px 30px rgba(33,35,42,.07);
  --sh-3:0 2px 6px rgba(33,35,42,.05), 0 26px 60px rgba(33,35,42,.12);
  --maxw:1140px;

  /* design-guide.html token aliases — so snippets copied from the guide work as-is */
  --green:var(--garden); --green-deep:var(--garden-deep); --green-soft:var(--garden-soft);
  --cream:var(--bg); --cream-2:var(--bg-2); --white:var(--surf);
  --radius:var(--r); --radius-sm:var(--r-sm); --radius-lg:var(--r-lg);
  --shadow-sm:var(--sh-1); --shadow:var(--sh-2); --shadow-lg:var(--sh-3);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0; font-family:var(--font); background:var(--bg); color:var(--ink);
  font-size:17px; line-height:1.55; letter-spacing:-0.011em;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
h1,h2,h3,h4,p{margin:0;}
p{text-wrap:pretty;}
a{color:inherit;}
img{max-width:100%;}
:focus-visible{outline:3px solid var(--garden); outline-offset:3px; border-radius:6px;}

.wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px;}
.wrap.narrow{max-width:780px;}
.eyebrow{font-size:13px; font-weight:800; letter-spacing:.10em; text-transform:uppercase; color:var(--garden);}
.eyebrow::before{content:""; display:inline-block; vertical-align:middle; width:22px; height:2px;
  margin:-2px 11px 0 0; background:currentColor; border-radius:2px; opacity:.85;}
.lede{color:var(--ink-2); font-size:19px; line-height:1.6;}
.center{text-align:center;}
.dot{width:8px; height:8px; border-radius:50%; background:var(--garden); box-shadow:0 0 0 4px var(--garden-soft); flex-shrink:0;}

/* ── Buttons ──────────────────────────────────────────────────────────────── */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:9px;
  height:50px; padding:0 24px; border-radius:var(--r-pill); font-weight:600; font-size:16px;
  letter-spacing:-0.01em; border:0; cursor:pointer; text-decoration:none;
  transition:transform .15s cubic-bezier(.3,.7,.4,1), box-shadow .15s, filter .15s, background .15s;}
.btn.primary{background:var(--garden); color:#fff; box-shadow:var(--sh-1);}
.btn.primary:hover{background:var(--garden-deep); box-shadow:var(--sh-2); transform:translateY(-1px);}
.btn.ghost{background:transparent; color:var(--ink); box-shadow:inset 0 0 0 1.6px var(--line-2);}
.btn.ghost:hover{box-shadow:inset 0 0 0 1.6px var(--ink-3); background:var(--surf);}
.btn.sm{height:42px; font-size:15px; padding:0 18px;}
.btn-row{display:flex; flex-wrap:wrap; gap:14px;}
.btn-row.center{justify-content:center;}

/* ── Nav ──────────────────────────────────────────────────────────────────── */
header.nav{position:sticky; top:0; z-index:50; background:color-mix(in oklab, var(--bg) 82%, transparent);
  backdrop-filter:saturate(1.4) blur(12px); border-bottom:1px solid color-mix(in oklab,var(--line) 70%, transparent);}
.nav-in{display:flex; align-items:center; gap:18px; height:70px;}
.brand{display:flex; align-items:center; gap:11px; font-weight:850; letter-spacing:-0.02em; font-size:18px; text-decoration:none;}
.mark{width:38px; height:38px; border-radius:11px; background:var(--garden); color:#F4F2EC;
  display:flex; align-items:center; justify-content:center; font-weight:900; font-size:20px; box-shadow:var(--sh-1); flex-shrink:0;}
.brand small{display:block; font-family:var(--font); font-size:11px; font-weight:700; letter-spacing:.02em; color:var(--ink-3); margin-top:-2px;}
.nav-links{margin-left:auto; display:flex; align-items:center; gap:28px;}
.nav-links a{font-weight:650; font-size:15px; color:var(--ink-2); text-decoration:none; transition:color .14s;}
.nav-links a:hover{color:var(--ink);}
.nav-links a[aria-current="page"]{color:var(--garden-deep); font-weight:750;}
.nav-cta{display:flex; align-items:center; gap:12px; margin-left:6px;}
.mobile-menu{display:none; position:relative; margin-left:auto;}
.mobile-menu summary{list-style:none; display:inline-flex; align-items:center; justify-content:center;
  height:42px; padding:0 16px; border-radius:var(--r-pill); cursor:pointer;
  color:var(--ink); font-size:15px; font-weight:750; box-shadow:inset 0 0 0 1.6px var(--line-2);
  background:color-mix(in oklab, var(--surf) 92%, transparent);}
.mobile-menu summary::marker{content:""; font-size:0;}
.mobile-menu summary::-webkit-details-marker{display:none;}
.mobile-menu[open] summary{background:var(--surf); box-shadow:inset 0 0 0 1.6px var(--garden);}
.mobile-menu nav{position:absolute; top:calc(100% + 12px); right:0; width:min(260px, calc(100vw - 48px));
  padding:10px; border:1px solid var(--line); border-radius:var(--r); background:var(--surf);
  box-shadow:var(--sh-3); display:flex; flex-direction:column; gap:2px;}
.mobile-menu nav a{display:flex; align-items:center; min-height:42px; padding:0 12px; border-radius:12px;
  color:var(--ink-2); text-decoration:none; font-weight:700;}
.mobile-menu nav a:hover{background:var(--surf-2); color:var(--ink);}
@media (min-width:861px){ .mobile-menu{display:none!important;} }
@media (max-width:860px){
  .nav-links{display:none;}
  .mobile-menu{display:block;}
  .nav-cta{margin-left:auto;}
}
@media (max-width:520px){
  .nav-cta{display:none;}
  .brand small{display:none;}
}

/* ── Trust strip ──────────────────────────────────────────────────────────── */
.trust{border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--surf-2);}
.trust-in{display:flex; flex-wrap:wrap; gap:14px 40px; justify-content:center; padding:22px 0;}
.trust-item{display:flex; align-items:center; gap:9px; font-weight:700; font-size:15px; color:var(--ink-2);}
.trust-item svg{color:var(--garden); flex-shrink:0;}

/* ── Section scaffolding ──────────────────────────────────────────────────── */
section{padding:88px 0;}
.band-soft{background:var(--surf-2); border-top:1px solid var(--line); border-bottom:1px solid var(--line);}
.band-tint{background:linear-gradient(180deg, var(--garden-soft), var(--bg));}
.band-ink{background:var(--ink); color:#EDEDF0;}

/* ── Manifesto band (dark, narrative) ─────────────────────────────────────── */
.manifesto{background:var(--ink); color:#EDEDF0;}
.manifesto .wrap{max-width:840px;}
.manifesto .eyebrow{color:#8FE0BD;}
.manifesto h2{font-size:36px; font-weight:850; letter-spacing:-0.03em; line-height:1.12; margin:14px 0 0;}
.manifesto p{color:#B9BAC4; font-size:19px; margin-top:22px;}
.manifesto strong{color:#fff; font-weight:750;}
.manifesto .sign{margin-top:30px; font-size:16px; color:#8FE0BD; font-weight:700;}
@media (max-width:680px){ .manifesto h2{font-size:27px;} }
.sec-head{max-width:720px; margin:0 auto 52px; text-align:center;}
.sec-head h2{font-size:40px; font-weight:880; letter-spacing:-0.03em; line-height:1.08; margin-top:14px;}
.sec-head p{margin-top:18px;}

/* ── Interior page hero ───────────────────────────────────────────────────── */
.page-hero{position:relative; overflow:hidden; padding:84px 0 64px; text-align:center;}
.page-hero::before{content:""; position:absolute; inset:0;
  background:radial-gradient(110% 80% at 50% -10%, var(--garden-soft), transparent 60%); z-index:0;}
.page-hero::after{content:""; position:absolute; inset:0; z-index:0; pointer-events:none; opacity:.22;
  background:
    url('assets/sprig-left.webp') left max(18px,6vw) bottom -150px / min(34vw,360px) auto no-repeat,
    url('assets/sprig-right.webp') right max(18px,6vw) bottom -150px / min(34vw,360px) auto no-repeat;}
.page-hero .wrap{position:relative; z-index:1;}
.page-hero h1{font-size:54px; line-height:1.04; font-weight:900; letter-spacing:-0.035em; margin:16px auto 0; max-width:16ch;}
.page-hero h1 .hl{color:var(--garden);}
.page-hero .lede{margin:22px auto 0; max-width:60ch;}
.page-hero .btn-row{margin-top:32px;}

/* ── Prose (text-heavy pages) ─────────────────────────────────────────────── */
.prose{max-width:720px; margin:0 auto;}
.prose h2{font-size:30px; font-weight:850; letter-spacing:-0.025em; line-height:1.14; margin:44px 0 0;}
.prose h2:first-child{margin-top:0;}
.prose h3{font-size:21px; font-weight:800; letter-spacing:-0.015em; margin:30px 0 0;}
.prose p{color:var(--ink-2); font-size:18px; margin-top:16px;}
.prose p strong{color:var(--ink); font-weight:750;}
.prose ul{margin:16px 0 0; padding-left:0; list-style:none; display:flex; flex-direction:column; gap:12px;}
.prose li{position:relative; padding-left:32px; color:var(--ink-2); font-size:17px;}
.prose li::before{content:""; position:absolute; left:6px; top:9px; width:9px; height:9px; border-radius:50%;
  background:var(--garden); box-shadow:0 0 0 4px var(--garden-soft);}

/* ── Cards grid ───────────────────────────────────────────────────────────── */
.cards{display:grid; grid-template-columns:repeat(3,1fr); gap:18px;}
.cards.two{grid-template-columns:repeat(2,1fr);}
.card{background:var(--surf); border:1px solid var(--line); border-radius:var(--r); padding:26px;
  box-shadow:var(--sh-1); transition:transform .18s, box-shadow .18s, border-color .18s;}
.card:hover{transform:translateY(-3px); box-shadow:var(--sh-2); border-color:var(--line-2);}
.card .ico{width:50px; height:50px; border-radius:14px; background:var(--garden-soft); color:var(--garden-deep);
  display:flex; align-items:center; justify-content:center; margin-bottom:18px;}
.card h3{font-size:20px; font-weight:800; letter-spacing:-0.02em;}
.card p{color:var(--ink-2); font-size:15.5px; margin-top:9px;}
.card .vs{margin-top:14px; font-size:13.5px; color:var(--ink-3); border-top:1px dashed var(--line-2); padding-top:12px;}
.card .vs b{color:var(--ink-2); font-weight:750;}
@media (max-width:900px){ .cards{grid-template-columns:repeat(2,1fr);} }
@media (max-width:600px){ .cards, .cards.two{grid-template-columns:1fr;} }

/* ── Feature rows (alternating) ───────────────────────────────────────────── */
.feature-row{display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; margin-top:40px;}
.feature-row:first-of-type{margin-top:0;}
.feature-row.flip .feature-text{order:2;}
.feature-text .eyebrow{margin-bottom:10px; display:block;}
.feature-text h3{font-size:28px; font-weight:850; letter-spacing:-0.025em; line-height:1.12;}
.feature-text p{color:var(--ink-2); font-size:17px; margin-top:14px;}
.feature-text ul{margin:18px 0 0; padding-left:0; list-style:none; display:flex; flex-direction:column; gap:10px;}
.feature-text li{position:relative; padding-left:30px; color:var(--ink-2); font-size:16px;}
.feature-text li::before{content:"✓"; position:absolute; left:0; top:0; width:21px; height:21px; border-radius:6px;
  background:var(--garden-soft); color:var(--garden-deep); font-size:13px; font-weight:900;
  display:flex; align-items:center; justify-content:center;}
.feature-visual{background:var(--surf); border:1px solid var(--line); border-radius:var(--r-lg);
  box-shadow:var(--sh-2); padding:24px; min-height:200px;}
@media (max-width:820px){
  .feature-row{grid-template-columns:1fr; gap:26px;}
  .feature-row.flip .feature-text{order:0;}
}

/* ── Mini work-item rows (for visuals) ────────────────────────────────────── */
.mini-head{display:flex; align-items:center; justify-content:space-between; padding:2px 4px 12px;}
.mini-eyebrow{font-size:12px; font-weight:750; color:var(--garden);}
.mini-h{font-size:20px; font-weight:850; letter-spacing:-0.02em;}
.mini-sync{display:inline-flex; align-items:center; gap:7px; font-size:12px; font-weight:700; color:var(--good-ink);
  background:var(--good-bg); padding:6px 11px; border-radius:var(--r-pill);}
.mini-sync .dot{width:7px;height:7px;box-shadow:0 0 0 3px color-mix(in oklab,var(--good-ink) 18%, transparent);background:var(--good-ink);}
.mrow{display:flex; align-items:center; gap:12px; padding:12px 13px; border:1px solid var(--line);
  border-radius:15px; background:var(--surf); box-shadow:var(--sh-1); margin-top:9px;}
.mrow.done{background:var(--surf-2); box-shadow:none;}
.glyph{width:36px; height:36px; border-radius:11px; display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:17px;}
.g-chore{background:var(--chore-bg); color:var(--chore);}
.g-event{background:var(--event-bg); color:var(--event);}
.g-task{background:var(--task-bg); color:var(--task);}
.g-routine{background:var(--routine-bg); color:var(--routine);}
.g-shop{background:var(--shop-bg); color:var(--shop);}
.mrow .body{flex:1; min-width:0;}
.mrow .t{font-weight:700; font-size:15px; letter-spacing:-0.01em;}
.mrow.done .t{color:var(--ink-3); text-decoration:line-through; text-decoration-color:var(--line-2);}
.mrow .m{display:flex; align-items:center; gap:8px; margin-top:5px; flex-wrap:wrap;}
.pill{display:inline-flex; align-items:center; gap:5px; height:24px; padding:0 9px; border-radius:var(--r-pill);
  font-size:12px; font-weight:700; background:var(--surf-3); color:var(--ink-2); white-space:nowrap;}
.pill.warn{background:var(--warn-bg); color:var(--warn-ink);}
.pill.who{background:transparent; box-shadow:inset 0 0 0 1.4px var(--line-2); color:var(--ink-2); padding-left:4px;}
.av{width:18px; height:18px; border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; font-size:10px; font-weight:800;}
.check{width:26px; height:26px; border-radius:50%; border:1.9px solid var(--line-2); background:var(--surf); flex-shrink:0;
  display:flex; align-items:center; justify-content:center; color:#fff;}
.check.on{background:var(--garden); border-color:var(--garden);}
.check.appr{border-color:var(--warn-ink); background:var(--warn-bg); color:var(--warn-ink);}

/* ── Promises ─────────────────────────────────────────────────────────────── */
.promises-card{background:var(--surf); border:1px solid var(--garden-line); border-radius:var(--r-lg);
  box-shadow:var(--sh-2); padding:42px; max-width:860px; margin:0 auto;}
.promises-card h2{font-size:30px; font-weight:850; letter-spacing:-0.025em; text-align:center;}
.promises-card .sub{text-align:center; color:var(--ink-2); margin:14px auto 30px; max-width:60ch;}
.plist{display:grid; grid-template-columns:1fr 1fr; gap:14px 28px;}
.promise{display:flex; gap:13px; align-items:flex-start;}
.promise .x{width:28px; height:28px; border-radius:9px; background:var(--garden); color:#fff; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; margin-top:1px; font-weight:900;}
.promise b{font-weight:750;}
.promise span{display:block; color:var(--ink-2); font-size:15px;}
@media (max-width:640px){ .plist{grid-template-columns:1fr;} .promises-card{padding:28px;} }

/* ── Comparison table ─────────────────────────────────────────────────────── */
.table-scroll{overflow-x:auto; -webkit-overflow-scrolling:touch; border-radius:var(--r); position:relative;}
.table-scroll::after{content:"Swipe to compare"; position:sticky; left:12px; bottom:10px; display:none;
  width:max-content; margin-top:-38px; padding:6px 10px; border-radius:var(--r-pill);
  background:color-mix(in oklab, var(--ink) 86%, transparent); color:#fff; font-size:12px; font-weight:800;
  pointer-events:none; box-shadow:var(--sh-1);}
@media (max-width:760px){ .table-scroll::after{display:block;} }
table.compare{width:100%; border-collapse:separate; border-spacing:0; min-width:720px;
  background:var(--surf); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; box-shadow:var(--sh-1);}
.compare th, .compare td{padding:16px 18px; text-align:left; border-bottom:1px solid var(--line); vertical-align:middle;}
.compare thead th{font-size:14px; font-weight:800; letter-spacing:-0.01em; background:var(--surf-2); color:var(--ink-2);}
.compare thead th.us{background:var(--garden-soft); color:var(--garden-deep);}
.compare tbody th{font-weight:700; font-size:15px; color:var(--ink); width:38%;}
.compare td{text-align:center; font-weight:700; color:var(--ink-2); font-size:14px;}
.compare td.us{background:color-mix(in oklab, var(--garden-soft) 55%, var(--surf));}
.compare tr:last-child th, .compare tr:last-child td{border-bottom:0;}
.mk{display:inline-flex; align-items:center; justify-content:center; width:26px; height:26px; border-radius:50%; font-weight:900;}
.mk.yes{background:var(--good-bg); color:var(--good-ink);}
.mk.no{background:var(--danger-bg); color:var(--danger);}
.mk.part{background:var(--warn-bg); color:var(--warn-ink);}
.compare caption{caption-side:bottom; text-align:left; color:var(--ink-3); font-size:13.5px; padding:16px 4px 0; line-height:1.5;}
.compare .colname{font-size:12px; font-weight:700; color:var(--ink-3); display:block; margin-top:2px;}
/* Two-column "head to head" variant — used by the /compare tabs and the standalone vs pages. */
.compare.duo{min-width:0;}
.table-scroll.tight::after{content:none;}

/* ── Honest callout ───────────────────────────────────────────────────────── */
.honest{display:flex; gap:16px; align-items:flex-start; max-width:780px; margin:0 auto;
  background:var(--surf); border:1px solid var(--line); border-left:4px solid var(--garden);
  border-radius:var(--r); padding:24px 26px; box-shadow:var(--sh-1);}
.honest .ic{flex-shrink:0; width:40px; height:40px; border-radius:11px; background:var(--garden-soft); color:var(--garden-deep);
  display:flex; align-items:center; justify-content:center;}
.honest h3{font-size:18px; font-weight:800; letter-spacing:-0.01em;}
.honest p{color:var(--ink-2); font-size:15.5px; margin-top:6px;}

/* ── Surfaces ─────────────────────────────────────────────────────────────── */
.surfaces{display:grid; grid-template-columns:repeat(4,1fr); gap:16px;}
.surf-card{background:var(--surf); border:1px solid var(--line); border-radius:var(--r); padding:24px; box-shadow:var(--sh-1);}
.surf-card .badge{display:inline-flex; align-items:center; gap:7px; font-size:12.5px; font-weight:800;
  letter-spacing:.04em; text-transform:uppercase; color:var(--garden-deep); background:var(--garden-soft);
  padding:6px 11px; border-radius:var(--r-pill); margin-bottom:14px;}
.surf-card h3{font-size:18px; font-weight:800; letter-spacing:-0.01em;}
.surf-card p{color:var(--ink-2); font-size:14.5px; margin-top:7px;}
.device-lineup{max-width:900px; margin:42px auto 0; pointer-events:none; scroll-margin-top:96px;}
.device-lineup img{display:block; width:100%; height:auto; border-radius:var(--r-lg);
  box-shadow:0 0 0 1px rgba(33,35,42,.05), var(--sh-3);}
#maker-note, .heather-band{scroll-margin-top:96px;}
/* Decorative watercolor band + about "name" figure (shared across pages; index.html also defines .heather-band inline) */
.heather-band{display:block; width:100%; overflow:hidden; line-height:0; background:transparent; position:relative; z-index:0;}
.heather-band img{display:block; width:100%; height:auto; max-height:300px; object-fit:cover; object-position:50% 100%;}
/* Stack the final-CTA "bubble" up onto the heather band so the flowers rise behind it */
.heather-band + .final{position:relative; z-index:1; padding-top:0; margin-top:-150px;}
@media (max-width:760px){ .heather-band + .final{margin-top:-96px;} }
@media (max-width:480px){ .heather-band + .final{margin-top:-60px;} }
.name-fig{max-width:560px; margin:4px auto 28px; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--sh-1); border:1px solid var(--line);}
.name-fig img{display:block; width:100%; height:auto;}
/* Secondary 3-device "trio" shot (e.g. pricing hero) — smaller, same rounded effect */
.hero-trio{max-width:600px; margin:38px auto 0;}
.hero-trio img{display:block; width:100%; height:auto; border-radius:var(--r-lg); box-shadow:0 0 0 1px rgba(33,35,42,.05), var(--sh-2);}
@media (max-width:860px){ .surfaces{grid-template-columns:repeat(2,1fr);} }
@media (max-width:680px){ .page-hero::after{opacity:.16; background-size:260px auto, 260px auto; background-position:left -92px bottom -120px,right -92px bottom -120px;} .device-lineup{margin:30px auto -4px;} }
@media (max-width:480px){ .surfaces{grid-template-columns:1fr;} }

/* ── Values / pillars ─────────────────────────────────────────────────────── */
.values{display:grid; grid-template-columns:repeat(2,1fr); gap:18px;}
.value{display:flex; gap:16px; align-items:flex-start; background:var(--surf); border:1px solid var(--line);
  border-radius:var(--r); padding:24px; box-shadow:var(--sh-1);}
.value .n{flex-shrink:0; width:40px; height:40px; border-radius:11px; background:var(--garden); color:#fff;
  display:flex; align-items:center; justify-content:center; font-weight:900; font-size:17px;}
.value h3{font-size:18px; font-weight:800; letter-spacing:-0.01em;}
.value p{color:var(--ink-2); font-size:15px; margin-top:6px;}
@media (max-width:680px){ .values{grid-template-columns:1fr;} }

/* ── Pull quote ───────────────────────────────────────────────────────────── */
.pull{max-width:780px; margin:0 auto; text-align:center;}
.pull blockquote{font-size:27px; line-height:1.3; font-weight:800; letter-spacing:-0.02em; color:var(--ink); margin:0;}
.pull .who{margin-top:18px; font-size:15px; font-weight:700; color:var(--garden-deep);}

/* ── FAQ ──────────────────────────────────────────────────────────────────── */
.faq{max-width:760px; margin:0 auto; display:flex; flex-direction:column; gap:12px;}
.faq details{background:var(--surf); border:1px solid var(--line); border-radius:var(--r); padding:4px 22px; box-shadow:var(--sh-1);}
.faq summary{font-weight:750; font-size:17px; padding:18px 0; cursor:pointer; list-style:none; display:flex; justify-content:space-between; align-items:center; gap:16px;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+"; font-size:24px; font-weight:600; color:var(--garden); transition:transform .2s;}
.faq details[open] summary::after{transform:rotate(45deg);}
.faq details p{color:var(--ink-2); font-size:16px; padding:0 0 20px;}

/* Pricing */
#pricing, #plans, .price-card{scroll-margin-top:96px;}
.pricing-grid{display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:18px; align-items:stretch; max-width:920px; margin:0 auto;}
.price-card{position:relative; background:var(--surf); border:1px solid var(--line); border-radius:var(--r-lg); padding:34px;
  box-shadow:var(--sh-1); display:flex; flex-direction:column; min-height:100%;}
.price-card.featured{border-color:var(--garden); box-shadow:var(--sh-3); background:linear-gradient(180deg,#fff,var(--garden-soft));}
.price-card .badge{align-self:flex-start; display:inline-flex; align-items:center; height:30px; padding:0 12px; border-radius:var(--r-pill);
  background:var(--garden-soft); color:var(--garden-deep); font-size:12.5px; font-weight:850; letter-spacing:.04em; text-transform:uppercase;}
.price-card.featured .badge{background:var(--garden); color:#fff;}
.price-card h3{font-size:22px; font-weight:850; letter-spacing:-0.02em; margin-top:18px;}
.price{display:flex; align-items:baseline; gap:8px; margin-top:18px;}
.price .amount{font-size:52px; line-height:1; font-weight:900; letter-spacing:-0.045em; color:var(--ink);}
.price .term{font-size:17px; color:var(--ink-2); font-weight:700;}
.price-card .sub{color:var(--ink-2); font-size:15.5px; margin-top:10px;}
.price-list{list-style:none; padding:0; margin:24px 0 0; display:flex; flex-direction:column; gap:12px;}
.price-list li{position:relative; padding-left:25px; color:var(--ink-2); font-size:15.5px;}
.price-list li::before{content:""; position:absolute; left:2px; top:10px; width:8px; height:8px; border-radius:50%; background:var(--garden);
  box-shadow:0 0 0 4px var(--garden-soft);}
.price-card .btn{margin-top:auto; align-self:flex-start;}
.price-card .price-list + .btn{margin-top:28px;}
.pricing-note{max-width:760px; margin:28px auto 0; text-align:center; color:var(--ink-2); font-size:15.5px;}
.pricing-proof{max-width:920px; margin:34px auto 0; display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:14px;}
.pricing-proof span{display:flex; align-items:center; justify-content:center; text-align:center; min-height:54px; padding:12px 14px; border-radius:var(--r);
  background:color-mix(in oklab,var(--surf) 78%, transparent); border:1px solid var(--line); color:var(--ink-2); font-weight:750; font-size:14px;}
@media (max-width:760px){ .pricing-grid{grid-template-columns:1fr;} .pricing-proof{grid-template-columns:1fr;} .price-card{padding:28px;} .price .amount{font-size:46px;} }

/* ── Final CTA ────────────────────────────────────────────────────────────── */
.final{text-align:center;}
.final-card{background:var(--garden); color:#fff; border-radius:var(--r-lg); padding:56px 32px; box-shadow:var(--sh-3);
  position:relative; overflow:hidden;}
.final-card::before{content:""; position:absolute; inset:0;
  background:radial-gradient(90% 120% at 50% -20%, rgba(255,255,255,.16), transparent 60%);}
.final-card > *{position:relative;}
.final-card h2{font-size:38px; font-weight:880; letter-spacing:-0.03em; line-height:1.08;}
.final-card p{color:rgba(255,255,255,.85); font-size:18px; margin:16px auto 30px; max-width:50ch;}
.final-card .btn.primary{background:#fff; color:var(--garden-deep);}
.final-card .btn.primary:hover{filter:none; background:#F4F2EC;}
.final-card .btn.ghost{box-shadow:inset 0 0 0 1.6px rgba(255,255,255,.5); color:#fff;}
.final-card .btn.ghost:hover{background:rgba(255,255,255,.1); box-shadow:inset 0 0 0 1.6px #fff;}
.final-note{color:rgba(255,255,255,.72); font-size:14px; margin-top:18px;}

/* ── Footer ───────────────────────────────────────────────────────────────── */
footer{position:relative; overflow:hidden; padding:48px 0 64px; border-top:1px solid var(--line); color:var(--ink-3); font-size:14.5px;}
footer::after{content:""; position:absolute; right:-90px; bottom:-210px; width:420px; height:420px; pointer-events:none;
  background:url('assets/sprig-right.webp') center / contain no-repeat; opacity:.12;}
.foot-in{display:flex; flex-wrap:wrap; gap:20px; align-items:center; justify-content:space-between;}
.foot-in{position:relative; z-index:1;}
.foot-brand{display:flex; align-items:center; gap:11px; font-weight:800; color:var(--ink); letter-spacing:-0.01em;}
footer a{color:var(--ink-2); text-decoration:none; font-weight:650;}
footer a:hover{color:var(--ink);}
.foot-nav{display:flex; flex-wrap:wrap; gap:6px 0; align-items:center;}
.foot-nav .sep{margin:0 12px; color:var(--line-2);}

/* ── Display type — Fraunces (warm editorial serif) ───────────────────────── */
.hero h1, .page-hero h1, .sec-head h2, .manifesto h2, .final-card h2,
.promises-card h2, .prose h2, .pull blockquote{
  font-family:var(--font-display);
  font-optical-sizing:auto;                 /* opsz follows font-size → display contrast */
  font-variation-settings:'SOFT' 30, 'WONK' 0;  /* gentle terminals, refined (un-wonky) glyphs */
  font-weight:600;
  letter-spacing:-0.012em;                  /* serifs want more air than the geometric sans */
  text-wrap:balance;
}
/* Largest sizes ride a lighter weight — the optical-size contrast carries them,
   so heavier weights would only muddy the thick/thin. */
.hero h1, .page-hero h1{ font-weight:560; letter-spacing:-0.018em; line-height:1.06; }
.pull blockquote{ letter-spacing:-0.008em; }
/* Brand wordmark in the serif; the small tagline stays in the sans. */
.brand > span{ font-family:var(--font-display); font-optical-sizing:auto;
  font-variation-settings:'SOFT' 30,'WONK' 0; font-weight:600; letter-spacing:-0.005em; }

/* ── Responsive type ──────────────────────────────────────────────────────── */
@media (max-width:680px){
  section{padding:64px 0;}
  .sec-head h2{font-size:31px;}
  .page-hero h1{font-size:38px;}
  .feature-text h3{font-size:23px;}
  .prose h2{font-size:25px;}
  .pull blockquote{font-size:22px;}
  .final-card h2{font-size:29px;}
}

@media (prefers-reduced-motion: reduce){
  *{animation:none !important; transition:none !important; scroll-behavior:auto !important;}
}
