:root{--ink:#07090B;--cream:#F2F0EB;--cy:#0AB5C8;--white:#FFFFFF;--border:rgba(242,240,235,.12);--border-light:rgba(7,9,11,.1);--display:'Bricolage Grotesque',sans-serif;--body:'Geist','Inter',sans-serif;--ease:cubic-bezier(.4,0,.2,1);}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;scroll-behavior:smooth;}
body{background:var(--ink);color:var(--cream);font-family:var(--body);line-height:1.6;overflow-x:hidden;}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:300;display:flex;align-items:center;justify-content:space-between;padding:1.25rem 3rem;border-bottom:1px solid var(--border);background:rgba(7,9,11,.88);backdrop-filter:blur(18px);}
.nav-logo{font-family:var(--display);font-size:17px;font-weight:800;color:var(--cream);letter-spacing:-.02em;text-decoration:none;}
.nav-links{display:flex;gap:.25rem;}
.nav-links a{font-size:13px;font-weight:400;color:rgba(242,240,235,.5);text-decoration:none;padding:.5rem 1rem;border-radius:3px;transition:color .2s,background .2s;}
.nav-links a:hover{color:var(--cream);background:rgba(242,240,235,.06);}
.nav-links a.active{color:var(--cream);}
.nav-cta{background:var(--cream);color:var(--ink);border:none;padding:9px 22px;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--body);transition:background .2s,color .2s;}
.nav-cta:hover{background:var(--cy);color:var(--white);}

/* LAYOUT */
.page{padding-top:62px;}
.s-dark{background:var(--ink);color:var(--cream);}
.s-light{background:var(--cream);color:var(--ink);}
.s-inner{max-width:1320px;margin:0 auto;padding:5.5rem 3rem;}
.s-inner-lg{max-width:1320px;margin:0 auto;padding:4rem 3rem;}
.s-label{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;margin-bottom:1.25rem;}
.s-dark .s-label{color:var(--cy);}
.s-light .s-label{color:rgba(7,9,11,.4);}
.s-h2{font-family:var(--display);font-size:clamp(32px,5vw,56px);font-weight:800;letter-spacing:-.025em;line-height:1.08;}
.s-dark .s-h2{color:var(--cream);}
.s-light .s-h2{color:var(--ink);}
.s-h2 .cy{color:var(--cy);}
.s-lead{font-size:17px;line-height:1.85;max-width:640px;margin-top:1.25rem;}
.s-dark .s-lead{color:rgba(242,240,235,.6);}
.s-light .s-lead{color:rgba(7,9,11,.6);}

/* BUTTONS */
.btn-p{background:var(--cream);color:var(--ink);border:none;padding:13px 28px;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--body);transition:background .2s,color .2s;text-decoration:none;display:inline-block;}
.btn-p:hover{background:var(--cy);color:var(--white);}
.btn-s{background:transparent;color:var(--cream);border:1px solid rgba(242,240,235,.25);padding:13px 28px;font-size:13px;font-weight:500;cursor:pointer;font-family:var(--body);transition:border-color .2s,color .2s;text-decoration:none;display:inline-block;}
.btn-s:hover{border-color:var(--cy);color:var(--cy);}
.btn-light-p{background:var(--ink);color:var(--cream);border:none;padding:13px 28px;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--body);transition:background .2s;text-decoration:none;display:inline-block;}
.btn-light-p:hover{background:var(--cy);color:var(--white);}
.btn-light-s{background:transparent;color:var(--ink);border:1px solid rgba(7,9,11,.25);padding:13px 28px;font-size:13px;cursor:pointer;font-family:var(--body);transition:border-color .2s,color .2s;text-decoration:none;display:inline-block;}
.btn-light-s:hover{border-color:var(--cy);color:var(--cy);}

/* TICKER */
.ticker{overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:rgba(242,240,235,.04);padding:.9rem 0;}
.ticker-track{display:flex;width:max-content;animation:tickMove 42s linear infinite;}
.ticker:hover .ticker-track{animation-play-state:paused;}
@keyframes tickMove{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.tick{display:flex;align-items:center;gap:10px;padding:0 2.25rem;border-right:1px solid var(--border);white-space:nowrap;}
.tick-label{font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:rgba(242,240,235,.22);}
.tick-val{font-size:13px;font-weight:500;color:rgba(242,240,235,.65);}

/* STATS BAR */
.stats-bar{background:var(--cream);color:var(--ink);display:flex;border-bottom:1px solid var(--border-light);}
.stat{flex:1;padding:2rem 3rem;border-right:1px solid var(--border-light);}
.stat:last-child{border-right:none;}
.stat-n{font-family:var(--display);font-size:44px;font-weight:800;line-height:1;letter-spacing:-.02em;color:var(--ink);}
.stat-l{font-size:11px;font-weight:500;color:rgba(7,9,11,.4);margin-top:8px;letter-spacing:.05em;text-transform:uppercase;}

/* GRID PRIMITIVES */
.grid-1px{gap:1px;background:var(--border-light);}
.grid-1px-dark{gap:1px;background:rgba(242,240,235,.08);}
.cell{background:var(--cream);}
.cell-dark{background:var(--ink);}

/* FRAMEWORK STRIP */
.fw-strip{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:rgba(242,240,235,.04);padding:2rem 3rem;}
.fw-inner{max-width:1320px;margin:0 auto;display:flex;align-items:center;gap:3.5rem;}
.fw-label-sm{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(242,240,235,.28);white-space:nowrap;}
.fw-items{display:flex;gap:2.5rem;flex-wrap:wrap;}
.fw-item{font-size:13px;font-weight:500;color:rgba(242,240,235,.4);transition:color .2s;cursor:default;}
.fw-item:hover{color:var(--cream);}

/* PAGE HERO (non-home) */
.page-hero{padding:5rem 3rem 3.5rem;max-width:1320px;margin:0 auto;}
.page-hero-eye{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--cy);margin-bottom:1.25rem;display:flex;align-items:center;gap:12px;}
.page-hero-eye::before{content:'';width:28px;height:1px;background:var(--cy);}
.page-hero-h1{font-family:var(--display);font-size:clamp(40px,7vw,96px);font-weight:800;letter-spacing:-.03em;line-height:.96;color:var(--cream);text-transform:uppercase;}
.page-hero-h1 .cy{color:var(--cy);}
.page-hero-sub{font-size:17px;color:rgba(242,240,235,.55);line-height:1.8;max-width:580px;margin-top:1.75rem;}
.page-hero-sub strong{color:var(--cream);font-weight:600;}

/* WHO GRID */
.who-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;margin-top:3.5rem;align-items:start;}
.who-pull{font-family:var(--display);font-size:clamp(22px,3vw,32px);font-weight:700;line-height:1.3;color:var(--ink);letter-spacing:-.02em;margin-bottom:2rem;}
.who-body{font-size:15px;color:rgba(7,9,11,.62);line-height:1.9;}
.who-body p+p{margin-top:1rem;}
.pillar-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(7,9,11,.1);}
.wp{background:var(--cream);padding:1.75rem;}
.wp-icon{font-size:20px;color:var(--ink);margin-bottom:1rem;}
.wp-title{font-family:var(--display);font-size:15px;font-weight:700;color:var(--ink);margin-bottom:4px;letter-spacing:-.01em;}
.wp-body{font-size:13px;color:rgba(7,9,11,.52);line-height:1.65;}

/* HOW WE WORK */
.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(7,9,11,.1);margin-top:3rem;}
.how-card{background:var(--cream);padding:2rem;position:relative;overflow:hidden;}
.how-card::before{content:attr(data-n);position:absolute;right:1.25rem;top:.75rem;font-family:var(--display);font-size:56px;font-weight:800;color:rgba(7,9,11,.06);line-height:1;letter-spacing:-.03em;}
.how-icon{font-size:20px;color:var(--ink);margin-bottom:1.1rem;}
.how-title{font-family:var(--display);font-size:15px;font-weight:700;color:var(--ink);margin-bottom:.5rem;letter-spacing:-.01em;}
.how-body{font-size:13px;color:rgba(7,9,11,.52);line-height:1.75;}

/* VISION */
.vision-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start;margin-bottom:4rem;}
.vision-h2{font-family:var(--display);font-size:clamp(36px,5.5vw,64px);font-weight:800;color:var(--ink);letter-spacing:-.025em;line-height:1.06;}
.vision-h2 .cy{color:var(--cy);}
.vision-lead{font-size:16px;color:rgba(7,9,11,.62);line-height:1.9;}
.vision-lead strong{color:var(--ink);font-weight:600;}
.vision-quote{font-family:var(--display);font-size:clamp(19px,2.2vw,24px);font-weight:700;color:var(--ink);line-height:1.4;letter-spacing:-.015em;margin-top:2rem;border-left:3px solid var(--cy);padding-left:1.5rem;}
.timeline{display:flex;border-top:1px solid var(--border-light);}
.tl{flex:1;padding:1.75rem 1.5rem;border-right:1px solid var(--border-light);}
.tl:last-child{border-right:none;}
.tl-dot{width:8px;height:8px;border-radius:50%;margin-bottom:1rem;}
.tl-dot.done{background:var(--ink);}
.tl-dot.wip{background:var(--cy);animation:tlPulse 2s ease-in-out infinite;}
@keyframes tlPulse{0%,100%{box-shadow:0 0 0 0 rgba(10,181,200,.4)}60%{box-shadow:0 0 0 7px rgba(10,181,200,0)}}
.tl-dot.fut{border:1.5px solid rgba(7,9,11,.2);}
.tl-name{font-family:var(--display);font-size:14px;font-weight:700;color:var(--ink);letter-spacing:-.01em;margin-bottom:3px;}
.tl-name.dim{color:rgba(7,9,11,.32);}
.tl-sub{font-size:12px;color:rgba(7,9,11,.4);}
.tl-tag{display:inline-block;font-size:10px;font-weight:600;letter-spacing:.06em;padding:3px 9px;margin-top:8px;}
.tt-live{background:rgba(52,211,153,.15);color:#059669;}
.tt-wip{background:rgba(10,181,200,.12);color:var(--cy);}
.tt-fut{background:rgba(7,9,11,.06);color:rgba(7,9,11,.35);}

/* TEAM */
.team-layout{display:grid;grid-template-columns:1fr 320px;gap:1px;background:rgba(7,9,11,.1);margin-top:3rem;}
.founder{background:var(--cream);padding:2.75rem;display:flex;gap:1.75rem;}
.f-av{width:52px;height:52px;background:var(--ink);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-size:16px;font-weight:800;color:var(--cream);flex-shrink:0;letter-spacing:-.02em;}
.f-name{font-family:var(--display);font-size:22px;font-weight:800;color:var(--ink);letter-spacing:-.02em;margin-bottom:3px;}
.f-role{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--cy);margin-bottom:1.25rem;}
.f-bio{font-size:14px;color:rgba(7,9,11,.6);line-height:1.85;margin-bottom:1.4rem;}
.f-tags{display:flex;flex-wrap:wrap;gap:6px;}
.ftag{font-size:11px;font-weight:500;color:rgba(7,9,11,.52);border:1px solid rgba(7,9,11,.14);padding:5px 11px;}
.cap-status{background:var(--cream);padding:2rem;}
.cs-label{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(7,9,11,.38);margin-bottom:1rem;}
.cs-row{display:flex;align-items:center;gap:10px;padding:.75rem 0;border-bottom:1px solid rgba(7,9,11,.08);font-size:13px;}
.cs-row:first-of-type{border-top:1px solid rgba(7,9,11,.08);}
.cs-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;}
.cs-on{background:#34D399;}
.cs-off{border:1.5px solid rgba(7,9,11,.18);}
.cs-text{color:rgba(7,9,11,.65);}
.cs-text.dim{color:rgba(7,9,11,.28);}

/* CAPABILITIES TABS */
.cap-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:3rem;}
.ctab{background:none;border:none;color:rgba(242,240,235,.38);font-size:13px;font-weight:500;padding:1rem 0;margin-right:2.5rem;border-bottom:1px solid transparent;margin-bottom:-1px;cursor:pointer;font-family:var(--body);transition:color .2s,border-color .2s;}
.ctab:hover{color:var(--cream);}
.ctab.active{color:var(--cream);border-bottom-color:var(--cy);}
.cap-panel{display:none;}
.cap-panel.active{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);animation:fadeUp .4s var(--ease);}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.cap-left,.cap-right{background:var(--ink);padding:2.5rem;}
.cap-title{font-family:var(--display);font-size:28px;font-weight:700;color:var(--cream);letter-spacing:-.02em;margin-bottom:.5rem;}
.cap-sub{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--cy);margin-bottom:1.5rem;}
.cap-desc{font-size:14px;color:rgba(242,240,235,.58);line-height:1.85;margin-bottom:2rem;}
.cap-row{display:flex;align-items:center;gap:12px;padding:.75rem 0;border-bottom:1px solid var(--border);font-size:13px;color:rgba(242,240,235,.52);}
.cap-row:last-child{border-bottom:none;}
.cr-dot{width:4px;height:4px;border-radius:50%;background:var(--cream);flex-shrink:0;}
.cr-text{flex:1;}
.cr-tag{font-size:10px;font-weight:600;letter-spacing:.08em;padding:2px 9px;}
.tag-live{color:#34D399;border:1px solid rgba(52,211,153,.3);}
.tag-dev{color:#60A5FA;border:1px solid rgba(96,165,250,.3);}
.tag-road{color:rgba(242,240,235,.28);border:1px solid rgba(242,240,235,.1);}
.cm{padding:1.75rem 0;border-bottom:1px solid var(--border);}
.cm:first-child{padding-top:0;}
.cm:last-of-type{border-bottom:none;}
.cm-val{font-family:var(--display);font-size:34px;font-weight:800;color:var(--cream);letter-spacing:-.02em;line-height:1;}
.cm-label{font-size:12px;color:rgba(242,240,235,.38);margin-top:6px;}
.cm-bar-wrap{height:2px;background:rgba(242,240,235,.1);margin-top:12px;overflow:hidden;}
.cm-bar{height:2px;background:var(--cy);transition:width 1.1s var(--ease);width:0;}
.cap-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:1.5rem;}
.cap-tag{font-size:11px;font-weight:500;padding:5px 12px;border:1px solid var(--border);color:rgba(242,240,235,.38);}

/* FOUR PILLARS */
.four-pillars{padding:4rem 3rem;border-top:1px solid var(--border);}
.fp-label{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(242,240,235,.28);text-align:center;margin-bottom:2rem;}
.fp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;max-width:1200px;margin:0 auto;background:var(--border);}
.fp-card{background:var(--ink);padding:2.25rem 1.75rem;text-align:center;}
.fp-icon{font-size:22px;color:var(--cy);display:block;margin-bottom:1rem;}
.fp-title{font-family:var(--display);font-size:14px;font-weight:700;color:var(--cream);margin-bottom:.5rem;letter-spacing:-.01em;}
.fp-body{font-size:13px;color:rgba(242,240,235,.42);line-height:1.7;}

/* PRODUCTS */
.prod-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);margin-top:3rem;}
.prod{background:var(--ink);padding:2.75rem;}
.prod-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;}
.prod-name{font-family:var(--display);font-size:36px;font-weight:800;color:var(--cream);letter-spacing:-.025em;}
.prod-badge{font-size:10px;font-weight:600;letter-spacing:.1em;padding:4px 11px;}
.pb-live{color:#34D399;border:1px solid rgba(52,211,153,.3);}
.pb-wip{color:#60A5FA;border:1px solid rgba(96,165,250,.3);}
.prod-type{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--cy);margin-bottom:1.1rem;}
.prod-desc{font-size:14px;color:rgba(242,240,235,.58);line-height:1.8;margin-bottom:1.75rem;}
.prod-feats{list-style:none;}
.pf{display:flex;gap:10px;align-items:flex-start;padding:.65rem 0;border-bottom:1px solid var(--border);font-size:13px;color:rgba(242,240,235,.5);}
.pf i{font-size:13px;color:var(--cy);flex-shrink:0;margin-top:2px;}
.pf.dim{color:rgba(242,240,235,.2);}
.pf.dim i{color:rgba(242,240,235,.14);}
.prod-foot{margin-top:1.75rem;padding-top:1.25rem;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
.prod-link{font-size:13px;font-weight:600;color:var(--cream);text-decoration:none;transition:color .2s;}
.prod-link:hover{color:var(--cy);}
.prod-note{font-size:11px;color:rgba(242,240,235,.32);}

/* CONTACT */
.ct-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(7,9,11,.1);margin-top:3rem;}
.ct{background:var(--cream);padding:2.25rem;}
.ct-eye{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--cy);margin-bottom:1rem;}
.ct h3{font-family:var(--display);font-size:22px;font-weight:700;color:var(--ink);letter-spacing:-.02em;margin-bottom:.85rem;}
.ct p{font-size:13px;color:rgba(7,9,11,.52);line-height:1.75;}
.ct a{color:var(--ink);text-decoration:none;font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:6px;margin-top:1rem;transition:color .2s;}
.ct a:hover{color:var(--cy);}

/* CTA BAND */
.cta-band{background:var(--ink);border-top:1px solid var(--border);padding:5rem 3rem;}
.cta-inner{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:3rem;align-items:center;}
.cta-h2{font-family:var(--display);font-size:clamp(28px,4vw,48px);font-weight:800;color:var(--cream);letter-spacing:-.025em;line-height:1.1;}
.cta-h2 .cy{color:var(--cy);}
.cta-btns{display:flex;gap:1px;flex-shrink:0;}
.cta-band-light{background:var(--cream);border-top:1px solid var(--border-light);padding:5rem 3rem;}
.cta-inner-light{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:3rem;align-items:center;}
.cta-h2-light{font-family:var(--display);font-size:clamp(28px,4vw,48px);font-weight:800;color:var(--ink);letter-spacing:-.025em;line-height:1.1;}
.cta-h2-light .cy{color:var(--cy);}

/* CERT + FOOTER */
.cert-bar{background:var(--ink);border-top:1px solid var(--border);padding:1.4rem 3rem;display:flex;align-items:center;justify-content:center;gap:3rem;flex-wrap:wrap;}
.cert-item{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:500;color:rgba(242,240,235,.32);}
.cert-item i{font-size:13px;color:rgba(242,240,235,.36);}
footer{background:var(--ink);border-top:1px solid var(--border);padding:1.4rem 3rem;display:flex;justify-content:space-between;align-items:center;}
.foot-l{font-size:12px;color:rgba(242,240,235,.28);}
.foot-r{display:flex;gap:2rem;}
.foot-r a{font-size:12px;color:rgba(242,240,235,.28);text-decoration:none;transition:color .2s;}
.foot-r a:hover{color:var(--cream);}

/* REVEAL */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .65s var(--ease),transform .65s var(--ease);}
.reveal.visible{opacity:1;transform:none;}
.rd1{transition-delay:.08s}.rd2{transition-delay:.16s}.rd3{transition-delay:.24s}.rd4{transition-delay:.32s}

/* HOME HERO SPECIFIC */
.hero{position:relative;height:100vh;overflow:hidden;display:flex;align-items:center;}
#grid-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;}
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(7,9,11,.28) 0%,rgba(7,9,11,0) 35%,rgba(7,9,11,.7) 100%);}
.hero-content{position:relative;z-index:2;padding:0 3rem;max-width:1320px;width:100%;}
.hero-eyebrow{font-family:var(--body);font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--cy);margin-bottom:2rem;display:flex;align-items:center;gap:12px;opacity:0;animation:riseIn .6s .2s var(--ease) forwards;}
.ey-line{width:32px;height:1px;background:var(--cy);}
.hero-h1{font-family:var(--display);font-weight:800;font-size:clamp(60px,10vw,148px);line-height:.93;letter-spacing:-.03em;color:var(--cream);text-transform:uppercase;margin-bottom:2.5rem;opacity:0;transform:translateY(30px);animation:riseIn .9s .35s var(--ease) forwards;}
.hero-h1 .cy{color:var(--cy);}
.hero-bottom{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;opacity:0;animation:riseIn .7s .65s var(--ease) forwards;}
.hero-desc{font-size:16px;font-weight:300;color:rgba(242,240,235,.68);line-height:1.75;max-width:460px;}
.hero-desc strong{color:var(--cream);font-weight:500;}
.hero-actions{display:flex;gap:1px;flex-shrink:0;}
@keyframes riseIn{to{opacity:1;transform:translateY(0);}}

/* HOME CAPABILITY TEASERS */
.cap-teasers{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);margin-top:3rem;}
.cap-teaser{background:var(--ink);padding:2rem;position:relative;overflow:hidden;transition:background .3s;}
.cap-teaser:hover{background:rgba(10,181,200,.06);}
.ct-num{font-family:var(--display);font-size:48px;font-weight:800;color:rgba(242,240,235,.06);position:absolute;right:1.25rem;top:.75rem;line-height:1;letter-spacing:-.03em;}
.ct-icon{font-size:22px;color:var(--cy);margin-bottom:1.25rem;}
.ct-title{font-family:var(--display);font-size:18px;font-weight:700;color:var(--cream);letter-spacing:-.015em;margin-bottom:.5rem;}
.ct-body{font-size:13px;color:rgba(242,240,235,.48);line-height:1.7;margin-bottom:1.25rem;}
.ct-link{font-size:12px;font-weight:600;color:var(--cy);text-decoration:none;letter-spacing:.02em;transition:opacity .2s;}
.ct-link:hover{opacity:.7;}
.ct-status{display:inline-block;font-size:10px;font-weight:600;letter-spacing:.08em;padding:2px 9px;margin-top:.75rem;}

/* ══════════════════════════════════════════════
   RESPONSIVE — tablet (≤900px) + mobile (≤640px)
══════════════════════════════════════════════ */

/* ── TABLET ── */
@media (max-width: 900px) {
  .nav { padding: 1rem 1.5rem; }
  .nav-links { display: none; }
  .s-inner, .s-inner-lg { padding: 4rem 1.5rem; }
  .page-hero { padding: 4rem 1.5rem 2.5rem; }
  .fw-strip { padding: 2rem 1.5rem; }
  .four-pillars { padding: 3rem 1.5rem; }
  .cert-bar { padding: 1.25rem 1.5rem; gap: 1.5rem; }
  footer { padding: 1.25rem 1.5rem; }
  .cta-band, .cta-band-light { padding: 4rem 1.5rem; }
  .cta-inner, .cta-inner-light { grid-template-columns: 1fr; gap: 2rem; }
  .cta-btns { flex-wrap: wrap; }

  /* grids → 2 col */
  .who-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .pillar-grid { grid-template-columns: 1fr 1fr; }
  .how-grid { grid-template-columns: 1fr 1fr; }
  .cap-teasers { grid-template-columns: 1fr 1fr; }
  .fp-grid { grid-template-columns: 1fr 1fr; }
  .ct-grid { grid-template-columns: 1fr; gap: 1px; }
  .prod-grid { grid-template-columns: 1fr; gap: 1px; }
  .stats-bar { flex-wrap: wrap; }
  .stat { flex: 1 1 50%; border-right: none; border-bottom: 1px solid rgba(7,9,11,.1); }
  .team-layout { grid-template-columns: 1fr; }
  .vision-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .timeline { flex-wrap: wrap; }
  .tl { flex: 1 1 33%; border-right: none; border-bottom: 1px solid rgba(7,9,11,.08); }
  .cap-panel.active { grid-template-columns: 1fr; }
  .fw-inner { flex-direction: column; gap: 1rem; align-items: flex-start; }
  .fw-items { gap: 1.5rem; }
  .hero-bottom { flex-direction: column; align-items: flex-start; gap: 1.5rem; }
}

/* ── MOBILE ── */
@media (max-width: 640px) {
  .nav { padding: .9rem 1.25rem; }
  .nav-cta { padding: 8px 16px; font-size: 12px; }
  .page { padding-top: 56px; }

  /* hero */
  .hero-content { padding: 0 1.25rem; }
  .hero-eyebrow { font-size: 10px; margin-bottom: 1.25rem; }
  .hero-h1 { font-size: clamp(48px, 15vw, 72px); margin-bottom: 1.75rem; }
  .hero-desc { font-size: 15px; }
  .hero-actions { flex-direction: column; width: 100%; }
  .hero-actions .btn-p, .hero-actions .btn-s { width: 100%; text-align: center; }

  /* sections */
  .s-inner, .s-inner-lg { padding: 3rem 1.25rem; }
  .page-hero { padding: 3rem 1.25rem 2rem; }
  .page-hero-h1 { font-size: clamp(36px, 13vw, 58px); }
  .s-h2 { font-size: clamp(26px, 7vw, 38px); }
  .s-lead { font-size: 15px; }

  /* stats */
  .stats-bar { flex-direction: column; }
  .stat { flex: none; width: 100%; padding: 1.5rem 1.25rem; }
  .stat-n { font-size: 36px; }

  /* grids → 1 col */
  .who-grid, .pillar-grid, .how-grid, .cap-teasers,
  .fp-grid, .ct-grid, .prod-grid, .team-layout { grid-template-columns: 1fr; }

  /* four pillars in 2 col on small screens */
  .fp-grid { grid-template-columns: 1fr 1fr; }

  /* timeline stacked */
  .timeline { flex-direction: column; }
  .tl { flex: none; width: 100%; padding: 1.25rem; border-right: none; border-bottom: 1px solid rgba(7,9,11,.08); }

  /* tabs */
  .cap-tabs { gap: 0; overflow-x: auto; -webkit-overflow-scrolling: touch; padding-bottom: 0; }
  .ctab { margin-right: 0; padding: .85rem 1.1rem; font-size: 12px; white-space: nowrap; }
  .cap-panel.active { grid-template-columns: 1fr; }
  .cap-left, .cap-right { padding: 1.5rem 1.25rem; }

  /* products */
  .prod { padding: 1.75rem 1.25rem; }
  .prod-name { font-size: 28px; }

  /* contact */
  .ct { padding: 1.75rem 1.25rem; }

  /* founder */
  .founder { flex-direction: column; padding: 1.75rem 1.25rem; }
  .f-av { width: 44px; height: 44px; font-size: 14px; }

  /* cta */
  .cta-band, .cta-band-light { padding: 3rem 1.25rem; }
  .cta-inner, .cta-inner-light { gap: 1.5rem; }
  .cta-h2, .cta-h2-light { font-size: clamp(24px, 6vw, 36px); }
  .cta-btns { flex-direction: column; width: 100%; }
  .cta-btns .btn-p, .cta-btns .btn-s,
  .cta-btns .btn-light-p, .cta-btns .btn-light-s { width: 100%; text-align: center; }

  /* fw strip */
  .fw-strip { padding: 1.5rem 1.25rem; }
  .fw-inner { gap: .75rem; }
  .fw-items { gap: 1rem; }
  .fw-item { font-size: 12px; }

  /* cert + footer */
  .cert-bar { padding: 1.25rem; gap: 1rem; flex-direction: column; align-items: flex-start; }
  footer { flex-direction: column; gap: 1rem; padding: 1.25rem; align-items: flex-start; }
  .foot-r { gap: 1.25rem; }

  /* who section */
  .who-pull { font-size: 20px; }
  .vision-h2 { font-size: clamp(28px, 7vw, 42px); }
  .vision-quote { font-size: 18px; padding-left: 1rem; }

  /* vision grid */
  .vision-grid { grid-template-columns: 1fr; gap: 2rem; }
}

/* ── NAV MOBILE HAMBURGER (hidden links → mostro solo logo + cta) ── */
@media (max-width: 900px) {
  .nav { gap: 0; }
  .nav-logo { flex: 1; }
}

/* ── HAMBURGER NAV MOBILE ── */
.nav-ham { display: none; flex-direction: column; gap: 4px; cursor: pointer; padding: 4px; background: none; border: none; }
.nav-ham span { width: 22px; height: 1.5px; background: var(--cream); transition: all .3s var(--ease); display: block; }
.nav-ham.open span:nth-child(1) { transform: translateY(5.5px) rotate(45deg); }
.nav-ham.open span:nth-child(2) { opacity: 0; }
.nav-ham.open span:nth-child(3) { transform: translateY(-5.5px) rotate(-45deg); }
.nav-mobile { display: none; position: fixed; top: 56px; left: 0; right: 0; z-index: 299; background: rgba(7,9,11,.97); backdrop-filter: blur(20px); border-bottom: 1px solid var(--border); padding: 1.5rem 1.25rem; flex-direction: column; gap: 4px; }
.nav-mobile a { font-size: 15px; font-weight: 500; color: rgba(242,240,235,.65); text-decoration: none; padding: .85rem 1rem; border-bottom: 1px solid var(--border); transition: color .2s; }
.nav-mobile a:last-child { border-bottom: none; }
.nav-mobile a:hover, .nav-mobile a.active { color: var(--cream); }
.nav-mobile.open { display: flex; }
@media (max-width: 900px) {
  .nav-ham { display: flex; }
  .nav-mobile { top: 56px; }
}

/* ── FOOTER FULL v2 ── */
.footer-full {
  background: #0A0C0F;
  border-top: 1px solid var(--border);
}
.footer-top {
  max-width: 1320px; margin: 0 auto;
  padding: 3rem 3rem 2.5rem;
  display: grid;
  grid-template-columns: 180px 1fr 1fr 1fr;
  gap: 2rem;
  border-bottom: 1px solid var(--border);
}
.footer-brand .f-logo {
  font-family: var(--display); font-size: 16px; font-weight: 800;
  color: var(--cream); letter-spacing: -.02em;
  text-decoration: none; display: block; margin-bottom: .85rem;
}
.footer-brand p {
  font-size: 12px; color: rgba(242,240,235,.35); line-height: 1.7;
  margin-bottom: 1.25rem;
}
.footer-social { display: flex; gap: 8px; }
.f-soc {
  width: 30px; height: 30px; border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  color: rgba(242,240,235,.35); text-decoration: none; font-size: 14px;
  transition: border-color .2s, color .2s;
}
.f-soc:hover { border-color: var(--cy); color: var(--cy); }

.footer-col h4 {
  font-size: 11px; font-weight: 600; letter-spacing: .1em;
  text-transform: uppercase; color: rgba(242,240,235,.4);
  margin-bottom: 1rem;
}
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: .5rem; }
.footer-col ul li { font-size: 13px; color: rgba(242,240,235,.38); }
.footer-col ul li a {
  color: rgba(242,240,235,.5); text-decoration: none;
  transition: color .2s;
}
.footer-col ul li a:hover { color: var(--cream); }
.footer-col .f-group { margin-top: 1rem; }
.footer-col .f-group:first-child { margin-top: 0; }
.footer-col .f-group-label {
  font-size: 11px; font-weight: 600; color: rgba(242,240,235,.28);
  letter-spacing: .06em; text-transform: uppercase;
  margin-bottom: .4rem;
}

.footer-bottom {
  max-width: 1320px; margin: 0 auto;
  padding: 1rem 3rem;
  display: flex; justify-content: space-between; align-items: center;
}
.footer-bottom-l { font-size: 11px; color: rgba(242,240,235,.22); }
.footer-bottom-r { display: flex; gap: 1.75rem; }
.footer-bottom-r a {
  font-size: 11px; color: rgba(242,240,235,.28);
  text-decoration: none; transition: color .2s;
}
.footer-bottom-r a:hover { color: var(--cream); }

@media (max-width: 900px) {
  .footer-top {
    grid-template-columns: 1fr 1fr;
    padding: 2.5rem 1.5rem 2rem;
    gap: 2rem;
  }
  .footer-bottom { padding: 1rem 1.5rem; flex-direction: column; gap: .6rem; align-items: flex-start; }
}
@media (max-width: 640px) {
  .footer-top { grid-template-columns: 1fr 1fr; padding: 2rem 1.25rem 1.75rem; gap: 1.5rem; }
  .footer-bottom { padding: .9rem 1.25rem; }
  .footer-bottom-r { gap: 1rem; flex-wrap: wrap; }
}
