/* ============================================================
   Kaizen Collective — shared design system
   Deep Forest palette · Montserrat + Poppins · paper grain
   ============================================================ */
:root{
  --paper:#f7f5f0;        /* bone / accent */
  --paper-2:#ece4d4;
  --ink:#0f2d26;          /* deep forest / primary */
  --ink-soft:#3f5249;
  --muted:#6f7f73;        /* sage / muted */
  --teal:#0f2d26;         /* primary action = forest */
  --teal-deep:#0a201b;
  --teal-soft:#e7decb;    /* soft tan highlight */
  --flame:#dcc9a3;        /* tan/gold / secondary */
  --flame-deep:#a8884f;   /* deeper gold for text on light */
  --tan:#dcc9a3;
  --tan-soft:#ece0c9;
  --line:#e4ddcf;
  --shadow:rgba(10,30,24,.14);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:'Poppins',sans-serif;
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* paper grain */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.4;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.045'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px;position:relative;z-index:2}
h1,h2,h3,.serif{font-family:'Montserrat',sans-serif;font-weight:700;letter-spacing:-.02em;line-height:1.05}
a{color:inherit}
.eyebrow{font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;color:var(--teal)}
.eyebrow.flame{color:var(--flame-deep)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:.95rem;text-decoration:none;padding:11px 20px;border-radius:40px;transition:transform .18s ease,box-shadow .18s ease,background .2s;border:none;cursor:pointer;font-family:inherit}
.btn-solid{background:var(--ink);color:var(--paper)}
.btn-solid:hover{transform:translateY(-2px);box-shadow:0 10px 24px var(--shadow)}
.btn-teal{background:var(--teal);color:#fff}
.btn-teal:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(15,45,38,.3);background:var(--teal-deep)}
.btn-flame{background:var(--flame);color:#0f2d26}
.btn-flame:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(168,136,79,.45);background:var(--flame-deep);color:#fff}
.btn-ghost{border:1.5px solid var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}

/* ---------- header / nav ---------- */
header{position:sticky;top:0;z-index:50;background:rgba(247,245,240,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.bar{display:flex;align-items:center;justify-content:space-between;height:66px}
.logo{font-family:'Montserrat',serif;font-weight:600;font-size:1.32rem;letter-spacing:-.02em;display:flex;align-items:center;gap:9px;text-decoration:none}
.logo .dot{width:9px;height:9px;border-radius:50%;background:var(--teal);display:inline-block}
.logo small{font-family:'Poppins';font-weight:600;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.navlinks{display:flex;gap:28px;font-size:.92rem;font-weight:500;align-items:center}
.navlinks a{text-decoration:none;color:var(--ink-soft);transition:color .2s}
.navlinks a:hover,.navlinks a.active{color:var(--teal)}
/* dropdown */
.navdrop{position:relative}
.navdrop-t{display:inline-flex;align-items:center;gap:5px;cursor:pointer}
.navdrop-t svg{width:13px;height:13px;transition:transform .2s}
.navdrop:hover .navdrop-t svg{transform:rotate(180deg)}
.navdrop-menu{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:8px;min-width:248px;box-shadow:0 22px 48px -24px var(--shadow);opacity:0;visibility:hidden;transition:opacity .2s,transform .2s;z-index:60}
.navdrop:hover .navdrop-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.navdrop-menu::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}
.navdrop-menu a{display:block;padding:11px 13px;border-radius:9px;color:var(--ink);transition:background .18s}
.navdrop-menu a:hover{background:var(--paper-2)}
.navdrop-menu a b{display:block;font-weight:600;font-size:.92rem}
.navdrop-menu a span{display:block;font-size:.78rem;color:var(--muted);margin-top:1px}
/* mobile toggle */
.navtoggle{display:none;background:none;border:none;cursor:pointer;padding:6px;color:var(--ink)}
.navtoggle svg{width:26px;height:26px;display:block}
.mobnav{display:none;border-top:1px solid var(--line);background:var(--paper)}
.mobnav.open{display:block}
.mobnav .wrap{padding-top:14px;padding-bottom:18px;display:grid;gap:2px}
.mobnav a{text-decoration:none;color:var(--ink-soft);font-weight:500;padding:11px 4px;border-bottom:1px solid var(--line)}
.mobnav a.sub{padding-left:18px;font-size:.92rem;color:var(--muted)}
.mobnav a:last-child{border-bottom:none}
.mobnav .btn{margin-top:14px;justify-content:center}
@media(max-width:880px){.navlinks{display:none}.navtoggle{display:block}.bar > .btn{display:none}}

/* ---------- hero ---------- */
.hero{padding:52px 0 44px;position:relative}
.hero-grid{display:grid;grid-template-columns:1.32fr .85fr;gap:40px;align-items:center}
.hero h1{font-size:clamp(1.9rem,4.2vw,3.2rem)}
.hero h1 em{font-style:normal;color:inherit;background:linear-gradient(180deg,transparent 56%,var(--teal-soft) 56%);padding:0 .04em;border-radius:2px}
.hero h1 .punch{display:block;color:var(--teal);font-size:.58em;margin-top:.32em;font-weight:700}
.hero .lede{margin-top:20px;font-size:1.02rem;color:var(--ink-soft);max-width:46ch}
.hero .lede b{color:var(--ink);font-weight:600}
.lede-tag{display:inline-block;margin-top:12px;font-weight:600;color:var(--teal)}
.cta-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px;align-items:center}
.price-note{font-size:.86rem;color:var(--muted);margin-top:16px}
.price-note strong{color:var(--ink)}
@media(max-width:880px){.hero-grid{grid-template-columns:1fr;gap:46px}}

/* product mock — phone (used on fitness page) */
.phone-stage{display:flex;justify-content:center;position:relative}
.phone{position:relative;width:264px;background:#0e1413;border-radius:38px;padding:11px;box-shadow:0 30px 70px -28px var(--shadow);border:1px solid #222b29}
.phone .notch{position:absolute;top:11px;left:50%;transform:translateX(-50%);width:96px;height:20px;background:#0e1413;border-radius:0 0 14px 14px;z-index:3}
.screen{background:var(--paper);border-radius:30px;overflow:hidden;position:relative}
.scr-top{padding:26px 18px 8px}
.scr-top .kick{font-size:.56rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:600}
.scr-top .hi{font-family:'Montserrat';font-weight:700;font-size:1.2rem;margin-top:2px}
.ring-wrap{display:flex;justify-content:center;padding:6px 0 12px}
.rings{position:relative;width:118px;height:118px}
.rings svg{transform:rotate(-90deg)}
.scr-pts{display:flex;justify-content:center;margin-top:-4px}
.scr-pts span{background:#fff;border:1px solid var(--line);border-radius:30px;font-size:.62rem;font-weight:600;color:var(--ink-soft);padding:4px 12px}
.scr-pts b{color:var(--teal)}
.scr-habits{padding:12px 14px 20px;display:grid;gap:8px}
.scr-habits .hb{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:13px;padding:9px 11px}
.scr-habits .hb .em{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;font-size:.86rem;flex:none}
.scr-habits .hb .t{font-size:.7rem;font-weight:600;color:var(--ink)}
.scr-habits .hb .t small{display:block;font-weight:500;color:var(--muted);font-size:.6rem}
.scr-habits .hb .tick{margin-left:auto;width:18px;height:18px;border-radius:6px;border:1.5px solid var(--teal);flex:none;display:grid;place-items:center;color:#fff}
.scr-habits .hb .tick.done{background:var(--teal)}
.scr-habits .hb .tick svg{width:11px;height:11px;display:block}
.scr-tab{display:flex;justify-content:space-around;padding:9px 0 12px;border-top:1px solid var(--line);background:#fff}
.scr-tab i{width:18px;height:18px;border-radius:6px;background:var(--tan)}
.scr-tab i.on{background:var(--teal)}
.stamp{position:absolute;bottom:6px;right:-14px;background:var(--flame);color:#0f2d26;font-family:'Montserrat';font-style:italic;font-size:.9rem;padding:8px 15px;border-radius:30px;transform:rotate(-5deg);box-shadow:0 10px 22px -8px rgba(168,136,79,.55);z-index:4}

/* ---------- fade-in ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- marquee ---------- */
.strip{background:var(--ink);color:var(--paper);overflow:hidden;white-space:nowrap;padding:14px 0;position:relative;z-index:2}
.strip .track{display:inline-block;animation:scroll 26s linear infinite;font-family:'Montserrat';font-style:italic;font-size:1.18rem}
.strip .track span{margin:0 26px;opacity:.92}
.strip .track span b{color:var(--flame);font-style:normal;font-weight:600}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- section base ---------- */
section{padding:58px 0;position:relative;z-index:2}
.sec-head{max-width:62ch}
.sec-head.center{margin:0 auto;text-align:center}
.sec-head h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-top:12px}
.sec-head p{margin-top:14px;color:var(--ink-soft);font-size:1rem}

/* ---------- section tones (break up the rhythm) ---------- */
/* white */
.tone-white{background:#fff}
/* tan — cards go white so they pop off the tan */
.tone-tan{background:var(--paper-2)}
.tone-tan .pillar,.tone-tan .stat,.tone-tan .ncard,.tone-tan .res,.tone-tan .card,.tone-tan .founder,.tone-tan .ep{background:#fff}
.tone-tan .mod{background:#fff}
.tone-tan .mod:hover{background:#fffaf0}
/* forest — invert text + components to light */
.tone-forest{background:var(--ink);color:var(--paper)}
.tone-forest .eyebrow,.tone-forest .eyebrow.flame{color:var(--flame)}
.tone-forest .sec-head h2{color:var(--paper)}
.tone-forest .sec-head p{color:#C7CECB}
.tone-forest .pillar{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.14)}
.tone-forest .pillar .ico{background:rgba(255,255,255,.08);color:var(--flame)}
.tone-forest .pillar h3{color:var(--paper)}
.tone-forest .pillar p{color:#C7CECB}
.tone-forest .pillar ul li{color:#C7CECB}
.tone-forest .pillar ul li svg{color:var(--flame)}
.tone-forest .modules{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.14)}
.tone-forest .mod{background:var(--ink)}
.tone-forest .mod:hover{background:var(--teal-deep)}
.tone-forest .mod .num{color:var(--flame)}
.tone-forest .mod h3{color:var(--paper)}
.tone-forest .mod p{color:#AEB5B2}
.tone-forest .build{background:transparent;border:none;padding:0;margin-top:24px}
.tone-forest .step{border-color:rgba(255,255,255,.14)}
.tone-forest .step .n{color:var(--flame)}
.tone-forest .step h4{color:var(--paper)}
.tone-forest .step p{color:#C7CECB}
.tone-forest .step .tag{color:var(--flame);background:rgba(220,201,163,.16)}
.tone-forest .build .reality{color:var(--paper);border-color:rgba(255,255,255,.2)}
.tone-forest .stat{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.14)}
.tone-forest .stat .big{color:var(--flame)}
.tone-forest .stat .lab{color:#C7CECB}

/* ---------- hero image ---------- */
.hero-img{position:relative;min-height:400px;border-radius:20px;overflow:hidden;box-shadow:0 30px 70px -30px var(--shadow);border:1px solid var(--line);
  background:linear-gradient(150deg,rgba(15,45,38,.32),rgba(220,201,163,.30)),var(--paper-2);
  background-size:cover;background-position:center center}
/* drop a /hero.jpg into the project root and it shows automatically */
.hero-img.photo{background-image:linear-gradient(150deg,rgba(15,45,38,.34) 0%,rgba(15,45,38,.05) 45%,rgba(220,201,163,.18) 100%),url('/hero.jpg')}
.hero-img.photo-service{background-image:linear-gradient(150deg,rgba(15,45,38,.34) 0%,rgba(15,45,38,.05) 45%,rgba(220,201,163,.18) 100%),url('/hero-service.jpg')}
.hero-img.photo-fitness{background-image:linear-gradient(150deg,rgba(15,45,38,.34) 0%,rgba(15,45,38,.05) 45%,rgba(220,201,163,.18) 100%),url('/hero-fitness.jpg')}
/* "who we work with" tag panel on a hero image */
.hero-tags{position:absolute;left:16px;right:16px;bottom:16px;background:rgba(247,245,240,.94);backdrop-filter:blur(6px);border-radius:14px;padding:14px 16px;box-shadow:0 14px 34px -14px rgba(10,30,24,.5)}
.hero-tags .k{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--flame-deep);margin-bottom:10px}
.hero-tags .pills{display:flex;flex-wrap:wrap;gap:7px}
.hero-tags .pills span{background:#fff;border:1px solid var(--line);border-radius:30px;padding:5px 13px;font-size:.84rem;font-weight:600;color:var(--ink)}
/* scattered floating industry tags on a hero image */
.float-tag{position:absolute;display:inline-flex;align-items:center;gap:7px;background:rgba(247,245,240,.95);backdrop-filter:blur(6px);border:1px solid var(--line);border-radius:30px;padding:7px 14px;font-size:.82rem;font-weight:600;color:var(--ink);box-shadow:0 14px 30px -14px rgba(10,30,24,.55);white-space:nowrap}
.float-tag::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--flame);flex:none}
.float-tag.alt::before{background:var(--teal)}
@media(max-width:480px){.float-tag{font-size:.74rem;padding:6px 11px}}
.hero-chip{position:absolute;background:rgba(247,245,240,.94);backdrop-filter:blur(6px);border-radius:14px;padding:12px 16px;box-shadow:0 14px 34px -14px rgba(10,30,24,.5)}
.hero-chip .big{font-family:'Montserrat';font-weight:800;font-size:1.5rem;color:var(--teal);line-height:1}
.hero-chip .lab{font-size:.74rem;color:var(--ink-soft);margin-top:3px;font-weight:500}
.hero-chip.tl{top:18px;left:18px}
.hero-chip.br{bottom:18px;right:18px}
@media(max-width:880px){.hero-img{min-height:280px}}

/* ---------- problem (old vs new cols) ---------- */
.pcols{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:34px}
.pcol{border:1px solid var(--line);border-radius:14px;padding:26px 24px;background:var(--paper)}
.pcol.old{background:var(--paper-2)}
.pcol.new{border-color:var(--teal);box-shadow:0 18px 44px -32px rgba(15,45,38,.5)}
.pcol .ph{display:flex;align-items:center;gap:10px;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--muted);margin-bottom:18px}
.pcol.new .ph{color:var(--teal)}
.pcol .ph .pill{font-size:.6rem;letter-spacing:.1em;padding:3px 9px;border-radius:20px;background:var(--line);color:var(--ink-soft)}
.pcol.new .ph .pill{background:var(--teal);color:#fff}
.plist{list-style:none;display:grid;gap:13px}
.plist li{display:flex;gap:11px;font-size:.92rem;color:var(--ink-soft);line-height:1.45;align-items:flex-start}
.plist li .ic{flex:none;width:19px;height:19px;margin-top:1px}
.plist li .ic svg{width:100%;height:100%;display:block}
.pcol.old .ic{color:#b4736a}
.pcol.new .ic{color:var(--teal)}
.pcol .pres{margin-top:20px;padding-top:18px;border-top:1px dashed var(--line);font-family:'Montserrat';font-weight:600;font-size:.96rem;color:var(--ink);line-height:1.4}
.pcol.new .pres{color:var(--teal-deep)}
@media(max-width:720px){.pcols{grid-template-columns:1fr}}
/* tech reassurance band */
.reassure{display:flex;align-items:center;gap:22px;margin-top:22px;background:var(--ink);color:var(--paper);border-radius:14px;padding:24px 28px;flex-wrap:wrap}
.reassure .big{font-family:'Montserrat';font-weight:700;font-size:1.15rem;flex:1;min-width:240px}
.reassure .big em{font-style:normal;color:var(--flame)}
.reassure p{font-size:.9rem;color:#C7CECB;flex:1.4;min-width:240px}

/* ---------- modules grid ---------- */
.modules{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-top:34px}
.mod{background:var(--paper);padding:22px 20px;transition:background .25s}
.mod:hover{background:#fffaf0}
.mod .num{font-family:'Montserrat';font-style:italic;color:var(--teal);font-size:1rem}
.mod h3{font-size:1.12rem;margin:8px 0 6px}
.mod p{font-size:.88rem;color:var(--ink-soft)}

/* ---------- build steps ---------- */
.build{background:var(--paper-2);border-radius:20px;padding:38px 34px;margin-top:34px;border:1px solid var(--line)}
.steps{margin-top:8px;display:grid;gap:0}
.step{display:grid;grid-template-columns:54px 1fr;gap:18px;padding:18px 0;border-top:1px solid var(--line)}
.step:first-child{border-top:none}
.step .n{font-family:'Montserrat';font-weight:700;font-size:1.7rem;color:var(--teal);line-height:1}
.step h4{font-family:'Montserrat';font-weight:600;font-size:1.12rem;margin-bottom:5px}
.step p{color:var(--ink-soft);font-size:.92rem}
.step .tag{display:inline-block;margin-top:10px;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;color:var(--flame-deep);background:rgba(168,136,79,.16);padding:4px 11px;border-radius:20px}
.build .reality{margin-top:22px;padding-top:20px;border-top:1px dashed var(--line);font-family:'Montserrat';font-style:italic;font-weight:500;font-size:1.05rem;color:var(--ink)}

/* ---------- pivot (dark feature band) ---------- */
.pivot{background:var(--ink);color:var(--paper);border-radius:20px;padding:44px 40px;margin-top:24px;position:relative;overflow:hidden}
.pivot::after{content:"";position:absolute;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(220,201,163,.3),transparent 65%);top:-120px;right:-90px;filter:blur(8px)}
.pivot .eyebrow{color:var(--flame)}
.pivot h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-top:12px;max-width:20ch}
.pivot h2 em{font-style:normal;color:var(--ink);background:linear-gradient(180deg,transparent 56%,var(--flame) 56%);padding:0 .06em;border-radius:2px}
.pivot p.sub{color:#C7CECB;margin-top:14px;max-width:50ch;font-size:1rem}
.incl{display:grid;grid-template-columns:repeat(3,1fr);gap:13px;margin-top:28px}
@media(max-width:760px){.incl{grid-template-columns:1fr 1fr}}
@media(max-width:440px){.incl{grid-template-columns:1fr}}
.incl .i{border:1px solid rgba(255,255,255,.14);border-radius:12px;padding:18px 15px;background:rgba(255,255,255,.03)}
.incl .i .ico{width:34px;height:34px;color:var(--flame);margin-bottom:11px}
.incl .i .ico svg{width:100%;height:100%;display:block}
.incl .i .k{display:block;font-weight:600;font-size:1rem;color:var(--paper)}
.incl .i p{font-size:.86rem;color:#AEB5B2;margin-top:6px}
.pivot .foot{display:flex;flex-wrap:wrap;align-items:center;gap:16px;margin-top:28px}
.pivot .terms{font-size:.88rem;color:#969D9A}
.pivot .terms b{color:var(--paper)}

/* ---------- compare / pricing cards ---------- */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:34px auto 0;max-width:760px}
.compare.three{grid-template-columns:repeat(3,1fr);max-width:980px}
.card{border:1px solid var(--line);border-radius:14px;padding:24px 22px;background:var(--paper)}
.card.feat{border-color:var(--teal);box-shadow:0 18px 40px -30px rgba(15,45,38,.45);position:relative}
.card.feat .badge{position:absolute;top:-11px;left:22px;background:var(--teal);color:#fff;font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:4px 11px;border-radius:20px}
.card .plan{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--muted)}
.card .amt{font-family:'Montserrat';font-size:1.9rem;margin:6px 0 3px}
.card .amt small{font-size:.82rem;color:var(--muted);font-family:'Poppins'}
.card ul{list-style:none;margin:16px 0 20px;display:grid;gap:8px}
.card li{display:flex;gap:9px;font-size:.84rem;color:var(--ink-soft);line-height:1.4}
.card li::before{content:"";flex:none;width:6px;height:6px;border-radius:50%;background:var(--flame);margin-top:7px}
.card li b{color:var(--ink);font-weight:600}
.card.feat li::before{background:var(--teal)}
.card .btn{width:100%;justify-content:center;font-size:.86rem;padding:10px 16px}
@media(max-width:820px){.compare.three{grid-template-columns:1fr;max-width:420px}}
@media(max-width:680px){.compare{grid-template-columns:1fr;max-width:380px}}

/* ---------- nav cards (how we help hub) ---------- */
.navcards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:38px}
@media(max-width:820px){.navcards{grid-template-columns:1fr}}
.ncard{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:16px;padding:28px 26px;background:var(--paper);text-decoration:none;color:inherit;transition:transform .2s,box-shadow .2s,border-color .2s}
.ncard:hover{transform:translateY(-4px);box-shadow:0 22px 48px -30px var(--shadow);border-color:var(--teal)}
.ncard .ico{width:42px;height:42px;border-radius:12px;background:var(--paper-2);color:var(--teal);display:grid;place-items:center;margin-bottom:18px}
.ncard .ico svg{width:23px;height:23px;display:block}
.ncard h3{font-size:1.24rem;margin-bottom:8px}
.ncard p{font-size:.92rem;color:var(--ink-soft);flex:1}
.ncard .go{margin-top:18px;font-weight:600;font-size:.9rem;color:var(--teal);display:inline-flex;align-items:center;gap:6px}
.ncard .go svg{width:15px;height:15px;transition:transform .2s}
.ncard:hover .go svg{transform:translateX(4px)}

/* ---------- value / pillars ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:38px}
@media(max-width:760px){.pillars{grid-template-columns:1fr}}
.pillar{border:1px solid var(--line);border-radius:16px;padding:28px 26px;background:var(--paper)}
.pillar .k{font-family:'Montserrat';font-style:italic;color:var(--flame-deep);font-size:.95rem}
.pillar h3{font-size:1.3rem;margin:6px 0 8px}
.pillar p{font-size:.92rem;color:var(--ink-soft)}
.pillar .ico{width:40px;height:40px;border-radius:11px;background:var(--paper-2);color:var(--teal);display:grid;place-items:center;margin-bottom:16px}
.pillar .ico svg{width:22px;height:22px;display:block}
.pillar ul{list-style:none;margin-top:14px;display:grid;gap:9px}
.pillar ul li{display:flex;gap:9px;font-size:.88rem;color:var(--ink-soft);line-height:1.4;align-items:flex-start}
.pillar ul li svg{flex:none;width:16px;height:16px;margin-top:2px;color:var(--teal)}

/* ---------- quad overview row ---------- */
.quad{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:34px}
@media(max-width:820px){.quad{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.quad{grid-template-columns:1fr}}
.qc{border:1px solid var(--line);border-radius:14px;padding:20px 20px;background:var(--paper)}
.qc .k{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--flame-deep)}
.qc p{font-size:.92rem;font-weight:600;color:var(--ink);margin-top:7px;line-height:1.35}

/* ---------- stat row ---------- */
.stats{display:flex;flex-wrap:wrap;gap:18px;margin-top:34px}
.stat{flex:1;min-width:180px;border:1px solid var(--line);border-radius:14px;padding:22px 24px;background:var(--paper)}
.stat .big{font-family:'Montserrat';font-weight:800;font-size:2.1rem;color:var(--teal);line-height:1}
.stat .lab{font-size:.88rem;color:var(--ink-soft);margin-top:8px}

/* ---------- prose (about / long copy) ---------- */
.prose{max-width:68ch}
.prose h2{font-size:clamp(1.4rem,2.6vw,1.9rem);margin:40px 0 14px}
.prose h2:first-child{margin-top:0}
.prose p{color:var(--ink-soft);margin-bottom:16px}
.prose p b,.prose p strong{color:var(--ink);font-weight:600}
.prose em{font-style:italic}

/* ---------- founders ---------- */
.founders{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:34px}
@media(max-width:680px){.founders{grid-template-columns:1fr}}
.founder{border:1px solid var(--line);border-radius:16px;padding:26px 24px;background:var(--paper)}
.founder .av{width:54px;height:54px;border-radius:50%;background:var(--ink);color:var(--flame);font-family:'Montserrat';font-weight:700;font-size:1.3rem;display:grid;place-items:center;margin-bottom:16px}
.founder h3{font-size:1.2rem}
.founder .role{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:600;margin:2px 0 12px}
.founder p{font-size:.9rem;color:var(--ink-soft)}

/* ---------- podcast / resource list ---------- */
.eplist{display:grid;gap:14px;margin-top:34px}
.ep{display:grid;grid-template-columns:64px 1fr auto;gap:18px;align-items:center;border:1px solid var(--line);border-radius:14px;padding:18px 22px;background:var(--paper);text-decoration:none;color:inherit;transition:border-color .2s,transform .2s}
.ep:hover{border-color:var(--teal);transform:translateX(3px)}
.ep .epn{font-family:'Montserrat';font-weight:800;font-size:1.4rem;color:var(--flame-deep);text-align:center}
.ep h3{font-size:1.06rem;margin-bottom:3px}
.ep p{font-size:.86rem;color:var(--ink-soft)}
.ep .play{width:38px;height:38px;border-radius:50%;border:1.5px solid var(--ink);display:grid;place-items:center;color:var(--ink);flex:none}
.ep .play svg{width:15px;height:15px}
@media(max-width:560px){.ep{grid-template-columns:48px 1fr}.ep .play{display:none}}

.reslist{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:34px}
@media(max-width:680px){.reslist{grid-template-columns:1fr}}
.res{border:1px solid var(--line);border-radius:16px;padding:26px 24px;background:var(--paper);display:flex;flex-direction:column}
.res .tagk{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--flame-deep)}
.res h3{font-size:1.18rem;margin:8px 0 8px}
.res p{font-size:.9rem;color:var(--ink-soft);flex:1}
.res .btn{margin-top:18px;align-self:flex-start}

/* ---------- soft CTA band ---------- */
.ctaband{background:var(--paper-2);border:1px solid var(--line);border-radius:20px;padding:44px 40px;margin-top:8px;text-align:center}
.ctaband h2{font-size:clamp(1.5rem,2.8vw,2.1rem);max-width:24ch;margin:12px auto 0}
.ctaband p{color:var(--ink-soft);margin:14px auto 0;max-width:52ch}
.ctaband .cta-row{justify-content:center}

/* ---------- thank-you / success ---------- */
.success{max-width:640px;margin:0 auto;text-align:center;padding:18px 0 4px}
.success .check{width:66px;height:66px;border-radius:50%;background:var(--teal);display:grid;place-items:center;margin:0 auto 22px;box-shadow:0 16px 34px -14px rgba(15,45,38,.5)}
.success .check svg{width:34px;height:34px;color:#fff}
.success h1{font-size:clamp(1.9rem,4vw,2.8rem)}
.success h1 em{font-style:normal;color:var(--teal);background:linear-gradient(180deg,transparent 56%,var(--teal-soft) 56%);padding:0 .04em;border-radius:2px}
.success p{color:var(--ink-soft);margin:16px auto 0;font-size:1.05rem;max-width:50ch}
.success p b{color:var(--ink);font-weight:600}
.cal-embed{max-width:920px;margin:36px auto 0;background:#fff;border:1px solid var(--line);border-radius:18px;padding:10px;box-shadow:0 24px 54px -32px var(--shadow);overflow:hidden}
.cal-embed iframe{width:100%;min-height:700px;border:none;display:block;border-radius:12px}
.cal-placeholder{display:grid;place-items:center;min-height:520px;text-align:center;padding:34px}
.cal-placeholder .badge{display:inline-block;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--flame-deep);background:rgba(168,136,79,.16);padding:5px 14px;border-radius:20px;margin-bottom:14px}
.cal-placeholder h3{font-size:1.2rem;margin-bottom:8px}
.cal-placeholder p{color:var(--muted);font-size:.92rem;max-width:42ch}

/* ---------- coming soon / stub ---------- */
.stub{text-align:center;padding:30px 0 10px}
.stub .badge{display:inline-block;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--flame-deep);background:rgba(168,136,79,.16);padding:5px 14px;border-radius:20px}

/* ---------- faq ---------- */
.faq{margin-top:28px;border-top:1px solid var(--line)}
.q{border-bottom:1px solid var(--line);padding:17px 0;cursor:pointer}
.q summary{list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px;font-family:'Montserrat';font-size:1.04rem;font-weight:600}
.q summary::-webkit-details-marker{display:none}
.q summary .ic{flex:none;width:26px;height:26px;border:1.5px solid var(--ink);border-radius:50%;display:grid;place-items:center;font-size:1.1rem;transition:transform .25s,background .25s,color .25s}
.q[open] summary .ic{transform:rotate(45deg);background:var(--teal);border-color:var(--teal);color:#fff}
.q p{margin-top:14px;color:var(--ink-soft);max-width:66ch}

/* ---------- footer ---------- */
footer{background:var(--ink);color:var(--paper);padding:48px 0 32px;position:relative;z-index:2}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px}
@media(max-width:720px){.foot-top{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.foot-top{grid-template-columns:1fr}}
footer .logo{color:var(--paper)}
footer .logo small{color:#8b938f}
footer .tagline{font-family:'Montserrat';font-style:italic;font-size:1.18rem;max-width:26ch;color:#D2D7D4;margin-top:16px}
.foot-col h4{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#8b938f;font-weight:600;margin-bottom:14px}
.foot-col a{display:block;text-decoration:none;color:#D2D7D4;font-size:.92rem;padding:5px 0;transition:color .2s}
.foot-col a:hover{color:var(--flame)}
footer .fine{margin-top:36px;border-top:1px solid rgba(255,255,255,.12);padding-top:20px;font-size:.82rem;color:#8b938f;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}

/* ---------- email gateway modal ---------- */
.overlay{position:fixed;inset:0;z-index:200;background:rgba(14,20,19,.62);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;padding:24px}
.overlay.show{display:flex}
.modal{background:var(--paper);border-radius:18px;max-width:430px;width:100%;padding:34px 30px;position:relative;box-shadow:0 30px 80px -20px rgba(0,0,0,.5);border:1px solid var(--line)}
.modal .x{position:absolute;top:14px;right:16px;background:none;border:none;font-size:1.5rem;line-height:1;color:var(--muted);cursor:pointer}
.modal .eyebrow{color:var(--flame-deep)}
.modal h3{font-size:1.5rem;margin:10px 0 8px}
.modal p{font-size:.92rem;color:var(--ink-soft);margin-bottom:18px}
.modal input{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:11px;font-family:inherit;font-size:.95rem;background:#fff;margin-bottom:12px}
.modal input:focus{outline:none;border-color:var(--teal)}
.modal .btn{width:100%;justify-content:center}
.modal .fine{font-size:.74rem;color:var(--muted);margin-top:14px;text-align:center}
.modal .done-state{display:none;text-align:center}
.modal.done .form-state{display:none}
.modal.done .done-state{display:block}
.modal .done-state .check{width:54px;height:54px;border-radius:50%;background:var(--teal);display:grid;place-items:center;margin:0 auto 16px}
.modal .done-state .check svg{width:28px;height:28px;color:#fff}
