/* ============================================================
   SHARED PAGE COMPONENTS (product / science / about)
   Builds on assets/styles.css tokens. Light, editorial, Seed-style.
   ============================================================ */
:root{--red:#8E2B2B;--red-soft:#F3E3DF;--brand-panel:#211A16}

/* breadcrumb */
.crumb{font-size:13px;color:var(--tx-soft);margin-bottom:18px}
.crumb a{color:var(--tx-soft)}.crumb b{color:var(--tx);font-weight:500}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* motion */
.float{animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
@keyframes kb{from{transform:scale(1)}to{transform:scale(1.1)}}
.breathe-im{animation:breathe 10s ease-in-out infinite}

/* ---- stat row (hero stats / provenance) ---- */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stats.four{grid-template-columns:repeat(4,1fr)}
.stat{text-align:center;padding:clamp(26px,3vw,40px) 18px;border-right:1px solid var(--line)}
.stat:last-child{border-right:none}
.stat .num{font-family:"Satoshi";font-weight:700;font-size:clamp(36px,5vw,60px);line-height:1;letter-spacing:-.02em}
.stat .num sup{font-size:.5em;font-weight:600;color:var(--tx-soft)}
.stat span{display:block;font-size:13px;color:var(--tx-soft);margin-top:12px;max-width:24ch;margin-inline:auto;line-height:1.4}

/* ---- light fact cards (problem / results) ---- */
.scards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.scard{background:var(--card);border:1px solid var(--line);border-radius:var(--r-glass);padding:26px}
.scard .big{font-family:"Satoshi";font-weight:700;font-size:clamp(34px,4vw,46px);line-height:1;margin-bottom:14px}
.scard .big sup{font-size:.5em;color:var(--tx-soft);font-weight:600}
.scard b{font-family:"Satoshi";font-size:16.5px;display:block;margin-bottom:8px}
.scard p{font-size:14px;color:var(--tx-soft);line-height:1.55}

/* ---- dark fact cards (strains / survival / how-made, inside card-dark) ---- */
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.g5{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.fcard{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-glass);padding:24px;position:relative}
.fcard .n{font-family:"Satoshi";font-weight:700;font-size:clamp(26px,3vw,34px);color:#fff;line-height:1;margin-bottom:10px;letter-spacing:-.01em}
.fcard .step{font-family:"Satoshi";font-weight:700;font-size:13px;letter-spacing:.1em;color:var(--tx-inv-soft);display:block;margin-bottom:14px}
.fcard b{font-family:"Satoshi";color:#fff;font-size:16px;display:block;margin-bottom:8px}
.fcard p{font-size:13px;color:#C9C2D2;line-height:1.55}
.fcard.key{background:rgba(255,255,255,.13);border-color:rgba(255,255,255,.32)}
.fcard.key .keyline{display:block;font-family:"Satoshi";font-weight:700;font-size:17px;color:#fff;margin-top:10px}
.dgrid-cap{font-size:12.5px;color:var(--tx-inv-soft);max-width:74ch;margin:20px auto 0;text-align:center;line-height:1.6}

/* ---- glass benefit panel over a photo (feel / values / sourcing) ---- */
.feel{position:relative;border-radius:var(--r-card);overflow:hidden;min-height:540px;display:flex;align-items:flex-start;color:#fff;margin:0 var(--inset)}
.feel.short{min-height:460px}
.feel__bg{position:absolute;inset:0;z-index:0}
.feel__bg img{width:100%;height:100%;object-fit:cover;animation:kb 18s ease-in-out infinite alternate}
.feel__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,16,12,.3),rgba(20,16,12,.6))}
.feel__in{position:relative;z-index:2;width:100%;padding:clamp(40px,5vw,72px)}
.feel .eyebrow{color:var(--tx-inv-soft)}
.feel h2{font-size:clamp(30px,4vw,52px);max-width:18ch;margin:14px 0 clamp(36px,6vw,90px);color:#fff}
.bpanel{display:grid;grid-template-columns:repeat(4,1fr);gap:0;background:rgba(255,255,255,.1);-webkit-backdrop-filter:saturate(120%) blur(18px);backdrop-filter:saturate(120%) blur(18px);border:1px solid rgba(255,255,255,.18);border-radius:var(--r-glass);overflow:hidden}
.bpanel.cols3{grid-template-columns:repeat(3,1fr)}
.bcol{padding:26px 24px;border-right:1px solid rgba(255,255,255,.14)}
.bcol:last-child{border-right:none}
.bico{width:40px;height:40px;margin-bottom:18px;color:#fff}
.bcol h4{font-family:"Satoshi";font-size:17px;margin-bottom:8px;color:#fff}
.bcol p{font-size:13px;color:#e6e0d8;line-height:1.5}
.negstrip{font-size:13px;color:var(--tx-soft);text-align:center;margin-top:26px;letter-spacing:.01em}

/* ---- dark split panel + annotations (alive / origin) ---- */
.alive{display:grid;grid-template-columns:.9fr 1.1fr;gap:14px;margin:0 var(--inset)}
.alive.rev{direction:rtl}.alive.rev>*{direction:ltr}
.alive__l{border-radius:var(--r-card);overflow:hidden;background:var(--cream-2);display:flex;align-items:center;justify-content:center;padding:40px;position:relative;min-height:440px}
.alive__l.img-cover{padding:0}.alive__l.img-cover img{width:100%;height:100%;object-fit:cover;max-height:none}
.alive__l img{max-height:380px;filter:drop-shadow(0 24px 40px rgba(0,0,0,.25))}
.alive__r{border-radius:var(--r-card);background:var(--brand-panel);color:#fff;padding:clamp(34px,4vw,60px);position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center}
.alive__r>*{position:relative;z-index:1}
.alive__r .eyebrow{color:var(--tx-inv-soft)}
.alive__r h2{color:#fff;font-size:clamp(26px,3vw,40px);max-width:18ch;margin:14px 0 16px}
.alive__r p{color:#c9bfb2;font-size:15px;max-width:46ch;margin-bottom:22px;line-height:1.6}
.alive__r .learn{display:inline-flex;align-items:center;gap:8px;font-family:"Satoshi";font-weight:600;border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:4px;width:fit-content}.alive__r .learn::after{content:"→"}
.alive__r .pull{font-family:"Satoshi";font-weight:600;font-size:clamp(18px,2vw,23px);color:#fff;line-height:1.35;border-left:2px solid rgba(255,255,255,.3);padding-left:18px;margin-top:8px}
.alive__r .pull em{color:#fff;font-style:normal}
.anno{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:30px}
.anno div{border-left:2px solid rgba(255,255,255,.3);padding-left:16px}
.anno b{font-family:"Satoshi";display:block;font-size:15px;margin-bottom:4px;color:#fff}
.anno span{font-size:13px;color:#c9bfb2}
.alive__vis{position:absolute;right:-5%;bottom:-8%;width:50%;max-width:340px;opacity:.16;z-index:0;pointer-events:none}
.alive__vis img{width:100%}

/* ---- vertical timeline (benefits / made-slowly) ---- */
.tline__head{text-align:center;margin-bottom:14px}
.tline__head h2{font-size:clamp(28px,3.6vw,46px);max-width:22ch;margin:14px auto 0}
.tline__head .lede{margin:14px auto 0;text-align:center}
.tline__head .see{display:inline-flex;align-items:center;gap:7px;font-family:"Satoshi";font-weight:600;margin-top:16px;border-bottom:1px solid var(--ink);padding-bottom:3px}.tline__head .see::after{content:"→"}
.tline{position:relative;padding-left:34px;max-width:760px;margin:48px auto 0}
.tline::before{content:"";position:absolute;left:7px;top:8px;bottom:8px;width:2px;background:var(--line)}
.tstep{position:relative;margin-bottom:34px}.tstep:last-child{margin-bottom:0}
.tstep::before{content:"";position:absolute;left:-34px;top:5px;width:16px;height:16px;border-radius:50%;background:var(--ink);border:3px solid var(--cream)}
.tstep.mute{opacity:.5}.tstep.mute::before{background:var(--line)}
.tbadge{display:inline-block;background:var(--ink);color:var(--cream);font-family:"Satoshi";font-weight:700;font-size:11.5px;letter-spacing:.05em;padding:4px 12px;border-radius:var(--pill);margin-right:10px}
.tstep.mute .tbadge{background:var(--line);color:var(--tx-soft)}
.tstep h4{display:inline;font-family:"Satoshi";font-size:17px}
.tstep p{font-size:14px;color:var(--tx-soft);margin-top:10px;line-height:1.55;max-width:60ch}

/* ---- certs / trust row ---- */
.certs{display:flex;gap:clamp(18px,4vw,46px);justify-content:center;flex-wrap:wrap;align-items:center;padding:30px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-top:46px}
.cert{text-align:center}
.cert b{font-family:"Satoshi";font-weight:700;font-size:14px;display:block}
.cert small{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--tx-soft)}

/* ---- flagship badge (standards) ---- */
.flagbadge{text-align:center;padding:clamp(30px,4vw,52px);background:var(--ink);color:var(--cream);border-radius:var(--r-card);margin:0 var(--inset)}
.flagbadge .b{font-family:"Satoshi";font-weight:900;font-size:clamp(40px,6vw,72px);letter-spacing:.02em;line-height:1}
.flagbadge p{color:#C7BDB0;font-size:14.5px;max-width:46ch;margin:16px auto 0;line-height:1.55}

/* ---- comparison table ---- */
.cmp{overflow-x:auto}.cmp table{width:100%;border-collapse:collapse;min-width:580px}
.cmp th,.cmp td{padding:16px;text-align:center;font-size:14px;border-bottom:1px solid var(--line)}
.cmp th:first-child,.cmp td:first-child{text-align:left;font-weight:500}
.cmp thead th{font-family:"Satoshi";font-weight:700}
.cmp .us{background:var(--card)}.cmp thead .us{background:var(--ink);color:var(--cream);border-radius:12px 12px 0 0}
.cmp tbody tr:last-child .us{border-radius:0 0 12px 12px}
.cmp .y{color:#3f7a4f;font-weight:700}.cmp .nn{color:var(--tx-soft)}
.cmp__foot{font-size:11.5px;color:var(--tx-soft);margin-top:12px;text-align:center}

/* ---- reviews / social proof ---- */
.rev__head{display:grid;grid-template-columns:auto 1fr;gap:clamp(24px,4vw,56px);align-items:center;margin-bottom:40px}
.rev__score{text-align:center}.rev__score .big{font-family:"Satoshi";font-weight:700;font-size:56px;line-height:1}
.rev__score .stars{color:var(--star);font-size:18px}.rev__score small{display:block;font-size:13px;color:var(--tx-soft);margin-top:6px}
.rev__lead{font-size:clamp(16px,1.6vw,19px);color:var(--tx);max-width:40ch;line-height:1.5}
.rev__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rev{background:#fff;border:1px solid var(--line);border-radius:var(--r-glass);padding:22px}
.rev .stars{color:var(--star);font-size:13px}.rev .vtag{font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:#3f7a4f;font-weight:700;margin-left:8px}
.rev p{font-size:14px;margin:12px 0 16px;line-height:1.55}.rev__by{font-size:13px;color:var(--tx-soft)}.rev__by b{color:var(--tx);font-family:"Satoshi";font-weight:600}

/* ---- accordion ---- */
.acc{border-top:1px solid var(--line)}
.acc summary{list-style:none;cursor:pointer;padding:18px 0;display:flex;justify-content:space-between;align-items:center;font-family:"Satoshi";font-weight:600;font-size:16px}
.acc summary::-webkit-details-marker{display:none}
.acc summary::after{content:"+";font-size:22px;color:var(--tx-soft)}.acc[open] summary::after{content:"–"}
.acc__b{padding-bottom:18px}
.acc__b p{font-size:13.5px;color:var(--tx-soft);line-height:1.6}
.acc__b ul{list-style:none;display:grid;gap:8px;margin-top:8px}
.acc__b li{font-size:13.5px;color:var(--tx-soft);display:flex;gap:9px}.acc__b li::before{content:"–";color:var(--tx-soft)}
.viewsci{display:inline-flex;align-items:center;gap:7px;font-family:"Satoshi";font-weight:600;font-size:14.5px;padding:14px 0;border-bottom:1px solid var(--line);width:fit-content}
.viewsci::after{content:"→"}

/* ---- honesty / how-to box ---- */
.howto{display:flex;gap:14px;align-items:flex-start;background:var(--card);border:1px solid var(--line);border-radius:var(--r-glass);padding:22px 24px}
.howto .ic{font-size:24px;flex:none}
.howto b{font-family:"Satoshi";font-size:15px;display:block;margin-bottom:6px}
.howto p{font-size:13.5px;color:var(--tx-soft);line-height:1.6}

/* ---- citations ---- */
.cites{display:grid;gap:6px}
.cites .grp{font-family:"Satoshi";font-weight:700;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--tx-inv-soft);margin:18px 0 6px}
.cites li{font-size:12.5px;color:#C9C2D2;line-height:1.6;list-style:none;padding-left:24px;position:relative}
.cites li .ix{position:absolute;left:0;color:var(--tx-inv-soft)}
.study{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-glass);padding:24px}
.study .yr{font-family:"Satoshi";font-weight:700;font-size:12px;letter-spacing:.06em;color:var(--tx-inv-soft);text-transform:uppercase}
.study p{font-size:15px;color:#fff;line-height:1.5;margin:12px 0 16px}
.study a{font-size:13px;color:#C9C2D2;border-bottom:1px solid rgba(255,255,255,.3);padding-bottom:2px}

/* ---- FAQ ---- */
.faq2{max-width:820px;margin:0 auto}.fq{border-bottom:1px solid var(--line)}
.fq summary{list-style:none;cursor:pointer;padding:22px 0;display:flex;justify-content:space-between;align-items:center;gap:16px;font-family:"Satoshi";font-weight:600;font-size:18px}
.fq summary::-webkit-details-marker{display:none}.fq summary::after{content:"+";font-size:24px;color:var(--tx-soft)}.fq[open] summary::after{content:"–"}
.fq__b{padding:0 0 22px;font-size:14.5px;color:var(--tx-soft);line-height:1.6;max-width:74ch}

/* ---- science sticky jump-nav ---- */
.sci-nav{position:sticky;top:88px;z-index:30;display:flex;gap:6px;justify-content:center;flex-wrap:wrap;
  background:rgba(251,247,240,.85);-webkit-backdrop-filter:saturate(140%) blur(14px);backdrop-filter:saturate(140%) blur(14px);
  border:1px solid var(--line);padding:8px;margin:0 var(--inset);border-radius:var(--pill)}
.sci-nav a{font-family:"Satoshi";font-weight:600;font-size:12.5px;color:var(--tx-soft);padding:8px 14px;border-radius:var(--pill);transition:.2s;white-space:nowrap}
.sci-nav a:hover{color:var(--tx)}.sci-nav a.on{background:var(--ink);color:var(--cream)}
@media(max-width:760px){.sci-nav{justify-content:flex-start;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}.sci-nav::-webkit-scrollbar{display:none}}

/* ---- about: manifesto hero ---- */
.mhero{position:relative;padding-block:clamp(76px,13vh,150px);overflow:hidden}
.mhero__bg{position:absolute;inset:0;z-index:0}
.mhero__bg img{width:100%;height:100%;object-fit:cover;opacity:.14;animation:kb 22s ease-in-out infinite alternate}
.mhero .inner{position:relative;z-index:2}
.mhero h1{font-size:clamp(38px,6vw,76px);max-width:17ch;margin:18px 0 26px;line-height:1.04}
.mhero .accent{color:var(--ink)}
.mhero .lede{max-width:56ch}

/* ---- about: recognition strip ---- */
.recog{display:flex;gap:clamp(16px,4vw,42px);justify-content:center;flex-wrap:wrap;align-items:center;padding:26px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.recog span{font-family:"Satoshi";font-weight:700;font-size:13.5px;color:var(--tx-soft);letter-spacing:.01em}
.recog .dot{width:4px;height:4px;border-radius:50%;background:var(--line)}

/* ---- about: founders ---- */
.signed{max-width:60ch;margin:0 auto 36px;text-align:center}
.signed p{color:#c9bfb2;font-size:15.5px;line-height:1.65}
.signed .sign{font-family:"Satoshi";font-weight:600;color:#fff;margin-top:16px;display:block}
.founders{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:680px;margin:0 auto}
.founder__ph{aspect-ratio:4/5;border-radius:var(--r-img);background:linear-gradient(150deg,#2c251f,#15110e);display:grid;place-items:center;margin-bottom:16px;overflow:hidden}
.founder__ph .mono{font-family:"Satoshi";font-weight:800;font-size:clamp(40px,5vw,58px);color:rgba(255,255,255,.26)}
.founder__ph img{width:100%;height:100%;object-fit:cover}
.founder{text-align:center}
.founder b{font-family:"Satoshi";font-size:18px;color:#fff;display:block}
.founder span{font-size:13px;color:var(--tx-inv-soft)}
.fquote{text-align:center;max-width:52ch;margin:40px auto 0;font-family:"Satoshi";font-weight:600;font-size:clamp(19px,2.2vw,26px);color:#fff;line-height:1.4}
.fquote em{color:#fff;font-style:normal}

/* ---- footer legal line ---- */
.foot__legal{font-size:12px;color:var(--tx-soft);padding:22px 0 4px;line-height:1.6}

/* ---- newsletter band ---- */
.nlband{text-align:center}
.nlband h2{max-width:20ch;margin:14px auto 12px}
.nlband .lede{margin:0 auto 26px;text-align:center}
.nlband .news{margin:0 auto}
.nlband .sec-link{display:inline-block;margin-top:20px;font-size:14px;color:var(--tx-soft);border-bottom:1px solid var(--line);padding-bottom:2px}

/* ============ RESPONSIVE ============ */
@media(max-width:980px){
  .alive{grid-template-columns:1fr}.alive.rev{direction:ltr}.alive__vis{display:none}
  .bpanel,.bpanel.cols3{grid-template-columns:1fr 1fr}
  .g4,.g5{grid-template-columns:repeat(2,1fr)}
  .rev__head,.rev__grid{grid-template-columns:1fr}
}
@media(max-width:720px){
  .stats,.stats.four,.scards,.g3,.g4,.g5,.bpanel,.bpanel.cols3,.founders{grid-template-columns:1fr}
  .stat{border-right:none;border-bottom:1px solid var(--line)}.stat:last-child{border-bottom:none}
  .bcol{border-right:none;border-bottom:1px solid rgba(255,255,255,.14)}.bcol:last-child{border-bottom:none}
  .anno{grid-template-columns:1fr}
  .feel h2{margin-bottom:30px}
}

/* ===== Figma-handoff placeholders (V1 spec boxes) ===== */
.ph{position:relative;width:100%;height:100%;min-height:240px;display:flex;align-items:center;justify-content:center;text-align:center;padding:18px;color:var(--tx-soft);background:repeating-linear-gradient(45deg,#ece4d6,#ece4d6 11px,#e7decd 11px,#e7decd 22px);border:1.5px dashed #b6a88f;border-radius:inherit;overflow:hidden}
.ph--dark{background:repeating-linear-gradient(45deg,#241d18,#241d18 11px,#1e1813 11px,#1e1813 22px);border-color:#4a3f34;color:#b6ab9c}
.ph__t{position:absolute;top:11px;left:11px;font-family:"Satoshi";font-weight:700;font-size:9.5px;letter-spacing:.09em;padding:4px 9px;border-radius:var(--pill);background:var(--ink);color:var(--cream)}
.ph--dark .ph__t{background:rgba(255,255,255,.16);color:#fff}
.ph__in{max-width:32ch}
.ph__ttl{font-family:"Satoshi";font-weight:700;font-size:13.5px;color:var(--tx);margin-bottom:6px;line-height:1.25}
.ph--dark .ph__ttl{color:#f3ece1}
.ph__d{font-size:11.5px;line-height:1.45;margin-bottom:10px}
.ph__s{display:inline-block;font-family:"Satoshi";font-weight:700;font-size:10px;letter-spacing:.03em;color:var(--tx-soft);border:1px solid currentColor;border-radius:var(--pill);padding:3px 9px}
.ph--dark .ph__s{color:#bdb4a8}
.phtag{position:absolute;top:14px;right:14px;z-index:6;background:rgba(20,16,12,.86);color:#f3ece1;border:1px dashed rgba(255,255,255,.55);border-radius:10px;padding:9px 12px;font-size:10.5px;line-height:1.4;max-width:230px;text-align:left}
.phtag b{display:block;font-family:"Satoshi";font-weight:700;font-size:9.5px;letter-spacing:.07em;margin-bottom:4px;color:#ffd2bb}
.phtag .s{display:block;margin-top:5px;font-weight:700;color:#ffd2bb;letter-spacing:.03em}
.problem__img,.alive__l,.founder__ph{position:relative}
