/* ==========================================================================
   SMG — shared site stylesheet (V2 · "The idea, switched on")
   This is the single source of truth for all pages, and the basis for the
   custom CSS we will inject into Squarespace 7.1.
   ========================================================================== */

:root{
  --bg:#080F20;            /* cinematic near-black navy */
  --bg-2:#0C1730;
  --navy:#26448E;
  --navy-700:#1B2F5E;
  --orange:#CE6219;
  --ember:#F6811F;         /* lit filament */
  --paper:#F6F4EE;         /* warm editorial paper */
  --paper-2:#EFEBE1;
  --ink:#111A2E;
  --slate:#54607A;
  --line-d:rgba(255,255,255,.12);
  --line-l:rgba(17,26,46,.12);
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Archivo',system-ui,-apple-system,Segoe UI,sans-serif;color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,.disp{font-family:'Archivo Expanded','Archivo',system-ui,sans-serif;line-height:1.02;letter-spacing:-.02em;font-weight:800}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.eyebrow{font-family:'Archivo';font-weight:700;font-size:.72rem;letter-spacing:.24em;text-transform:uppercase}
a{color:inherit;text-decoration:none}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.7em;font-family:'Archivo';font-weight:600;font-size:.95rem;padding:.55em .7em .55em 1.5em;border-radius:999px;cursor:pointer;border:1px solid transparent;transition:transform .22s cubic-bezier(.2,.7,.2,1),box-shadow .22s,background .22s}
.btn .arw{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform .22s ease}
.btn:hover .arw{transform:translateX(3px)}
.btn-ember{background:var(--ember);color:#fff}
.btn-ember .arw{background:rgba(255,255,255,.22)}
.btn-ember:hover{transform:translateY(-2px);box-shadow:0 16px 34px -12px rgba(246,129,31,.7)}
.btn-line{background:transparent;color:#fff;border-color:rgba(255,255,255,.28);padding:.55em 1.5em}
.btn-line:hover{border-color:#fff;transform:translateY(-2px)}
.btn-ink{background:var(--ink);color:#fff}
.btn-ink .arw{background:rgba(255,255,255,.2)}
.btn-ink:hover{transform:translateY(-2px);box-shadow:0 16px 34px -14px rgba(17,26,46,.6)}
.arrow{font-family:'Archivo';font-weight:600;display:inline-flex;align-items:center;gap:.5em;transition:gap .2s}
.arrow:hover{gap:.85em}

/* nav */
header.nav{position:absolute;top:0;left:0;right:0;z-index:40}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:94px}
.brand{display:flex;align-items:center;gap:.7em;color:#fff}
.brand .mark{height:50px;width:auto;display:block}
.brand .wm{font-family:'Archivo Expanded',sans-serif;font-weight:700;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;line-height:1.25}
.nav-links{display:flex;gap:2.2rem;align-items:center}
.nav-links a{color:rgba(255,255,255,.72);font-size:.92rem;font-weight:500;position:relative}
.nav-links a:hover{color:#fff}
@media(max-width:900px){.nav-links{display:none}}

/* home hero */
.hero{position:relative;min-height:760px;display:flex;align-items:center;color:#fff;background:radial-gradient(1100px 700px at 74% 42%,#12224a 0%,var(--bg-2) 42%,var(--bg) 78%);overflow:hidden}
.noise{position:absolute;inset:0;z-index:1;opacity:.05;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.hero .vignette{position:absolute;inset:0;z-index:1;background:radial-gradient(120% 90% at 50% 40%,transparent 55%,rgba(0,0,0,.45))}
.hero-inner{position:relative;z-index:3;display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:center;width:100%;padding-top:60px}
@media(max-width:900px){.hero-inner{grid-template-columns:1fr}.hero-visual{display:none}}
.hero .eyebrow{color:var(--ember);margin-bottom:1.4em;opacity:0;animation:up .7s .1s forwards}
.hero h1{font-size:clamp(2.5rem,5.6vw,4.3rem);margin-bottom:.5em}
.hero h1 .l{display:block;opacity:0;transform:translateY(24px);animation:up .8s forwards;color:#fff}
.hero h1 .l1{animation-delay:.15s}.hero h1 .l2{animation-delay:.28s}.hero h1 .l3{animation-delay:.41s}
.hero h1 .ember{color:var(--ember)}
.hero .sub{font-size:clamp(1.05rem,1.7vw,1.24rem);color:rgba(255,255,255,.8);max-width:520px;margin-bottom:2.2em;opacity:0;animation:up .8s .55s forwards}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;opacity:0;animation:up .8s .7s forwards}
@keyframes up{to{opacity:1;transform:none}}
.hero-visual{position:relative;display:flex;align-items:center;justify-content:center;height:480px}
.bulb-light{position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(246,129,31,.42),rgba(246,129,31,.12) 42%,transparent 68%);opacity:0;transform:scale(.6);animation:ignite 1.3s .5s forwards}
@keyframes ignite{0%{opacity:0;transform:scale(.6)}60%{opacity:1;transform:scale(1.08)}100%{opacity:.85;transform:scale(1)}}
.hero-visual .bulb{height:440px;width:auto;display:block;filter:drop-shadow(0 24px 60px rgba(0,0,0,.55));position:relative;z-index:2}

/* interior page hero */
.page-hero{position:relative;overflow:hidden;color:#fff;background:radial-gradient(1000px 620px at 74% 24%,#12224a 0%,var(--bg-2) 46%,var(--bg) 82%);padding:172px 0 96px}
.page-hero .wrap{position:relative;z-index:3}
.page-hero .eyebrow{color:var(--ember);display:block;margin-bottom:1.3em}
.page-hero h1{font-size:clamp(2.4rem,5vw,3.9rem);max-width:17ch;margin-bottom:.45em}
.page-hero p{color:rgba(255,255,255,.82);font-size:clamp(1.05rem,1.7vw,1.28rem);max-width:56ch}
.page-hero .bulb-wm{position:absolute;right:5%;top:50%;transform:translateY(-50%);height:300px;width:auto;opacity:.09;z-index:2}
@media(max-width:900px){.page-hero .bulb-wm{display:none}}

/* proof strip */
.proof{background:var(--bg);color:#fff;border-top:1px solid var(--line-d)}
.proof .wrap{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:24px 32px;flex-wrap:wrap}
.proof .lbl{font-family:'Archivo';font-weight:700;font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ember);margin-right:1em}
.proof p{font-size:1rem;color:rgba(255,255,255,.82)}.proof strong{color:#fff;font-weight:600}

/* sections */
section.block{padding:120px 0}
.paper{background:var(--paper)}
.dark{background:var(--bg);color:#fff;position:relative;overflow:hidden}
.dark .sec-head h2{color:#fff}
.dark .sec-head p{color:rgba(255,255,255,.78)}
.sec-eyebrow{color:var(--orange);display:block;margin-bottom:1.3em}
.dark .sec-eyebrow{color:var(--ember)}
.sec-head{max-width:760px;margin-bottom:64px}
.sec-head h2{font-size:clamp(2rem,3.8vw,2.9rem);margin-bottom:.35em;color:var(--ink)}
.sec-head p{color:var(--slate);font-size:1.12rem;max-width:60ch}

/* offerings — ruled editorial rows */
.offers{border-top:1px solid var(--line-l)}
.dark .offers{border-top-color:var(--line-d)}
.offer{display:grid;grid-template-columns:.9fr 1.6fr auto;gap:32px;padding:38px 0;border-bottom:1px solid var(--line-l);align-items:baseline;transition:padding-left .3s ease}
.dark .offer{border-bottom-color:var(--line-d)}
.offer:hover{padding-left:12px}
.offer h3{font-family:'Archivo Expanded';font-weight:700;font-size:1.4rem;letter-spacing:-.01em;color:var(--ink)}
.dark .offer h3{color:#fff}
.offer .lede{font-weight:600;color:var(--ink)}
.dark .offer .lede{color:#fff}
.offer p{color:var(--slate);font-size:1.02rem;margin-top:.2em}
.dark .offer p{color:rgba(255,255,255,.7)}
.offer .go{color:var(--orange);font-size:1.4rem;justify-self:end;transition:transform .25s ease}
.offer:hover .go{transform:translateX(6px)}
@media(max-width:820px){.offer{grid-template-columns:1fr;gap:8px}.offer .go{display:none}}

/* operator / brand-moment (dark, text + logo) */
.operator{background:var(--bg);color:#fff;position:relative;overflow:hidden}
.operator .wrap{position:relative;z-index:2;max-width:1120px;display:grid;grid-template-columns:1.35fr .65fr;gap:52px;align-items:center}
@media(max-width:820px){.operator .wrap{grid-template-columns:1fr}}
.operator h2{font-size:clamp(2rem,4vw,3.1rem);max-width:18ch;margin-bottom:.55em}
.operator p{color:rgba(255,255,255,.8);max-width:64ch;margin-bottom:1.1em;font-size:1.1rem}
.operator .ember{color:var(--ember)}
.op-logo{width:auto;height:190px;max-width:100%;justify-self:end;opacity:.97}
@media(max-width:820px){.op-logo{display:none}}

/* feature (image/UI beside copy) */
.feature{display:grid;grid-template-columns:1.02fr .98fr;gap:60px;align-items:center}
@media(max-width:900px){.feature{grid-template-columns:1fr;gap:36px}}
.feature h2{font-size:clamp(2.1rem,4vw,3rem);margin:.25em 0 .4em;color:var(--navy)}
.feature p{color:var(--slate);font-size:1.08rem;margin-bottom:1.4em}
.pill{display:inline-block;font-family:'Archivo';font-weight:700;font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--orange);border:1px solid rgba(206,98,25,.4);padding:.45em .9em;border-radius:999px;margin-bottom:1.3em}

/* DistrictWise chat UI */
.ui-mock{background:#fff;border:1px solid var(--line-l);border-radius:16px;box-shadow:0 40px 80px -40px rgba(11,23,48,.4);overflow:hidden}
.ui-bar{background:var(--bg);padding:15px 20px;display:flex;align-items:center;gap:.6em;color:#fff;font-family:'Archivo';font-weight:600;font-size:.88rem}
.ui-bar .d{width:8px;height:8px;border-radius:50%;background:var(--ember)}
.ui-body{padding:24px;min-height:240px}
.bubble{padding:13px 16px;border-radius:14px;font-size:.9rem;margin-bottom:12px;max-width:88%;opacity:0;transform:translateY(8px)}
.ui-mock.in .bubble{animation:pop .5s ease forwards}
.ui-mock.in .b2{animation-delay:.7s}.ui-mock.in .b3{animation-delay:1.4s}.ui-mock.in .b4{animation-delay:2s}
@keyframes pop{to{opacity:1;transform:none}}
.bubble.q{background:var(--paper-2);margin-left:auto;border-bottom-right-radius:4px;color:var(--ink)}
.bubble.a{background:#EEF2FB;border-bottom-left-radius:4px;color:var(--ink)}
.bubble.a .src{display:block;margin-top:8px;font-size:.72rem;color:var(--navy);font-weight:600}

/* modules grid (DistrictWise page) */
.modules{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:820px){.modules{grid-template-columns:1fr}}
.module{background:#fff;border:1px solid var(--line-l);border-radius:16px;padding:34px 32px}
.module .tag{font-family:'Archivo';font-weight:700;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;padding:.32em .8em;border-radius:999px;display:inline-block;margin-bottom:1em}
.module .tag.live{color:#1a7f4b;background:rgba(26,127,75,.1)}
.module .tag.soon{color:var(--slate);background:rgba(84,96,122,.12)}
.module h3{font-family:'Archivo Expanded';font-weight:700;font-size:1.28rem;margin-bottom:.45em;color:var(--ink)}
.module p{color:var(--slate)}
.engine-line{margin-top:34px;color:var(--slate);font-size:.98rem}
.engine-line strong{color:var(--ink)}

/* DistrictWise — the policy-layers stack (a funnel: broad authority -> local rule) */
.howit{position:relative;overflow:hidden}
.pstack{position:relative;max-width:740px;margin:0 auto}
.prail{position:absolute;left:26px;top:52px;bottom:52px;width:2px;background:linear-gradient(180deg,rgba(246,129,31,.25),var(--ember),rgba(246,129,31,.25));box-shadow:0 0 12px rgba(246,129,31,.5)}
.pchip{display:inline-flex;align-items:baseline;gap:.5em;font-family:'Archivo';font-weight:600;font-size:.92rem;padding:.65em 1.15em;border-radius:999px;margin-left:52px;position:relative;z-index:3}
.pchip.q{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.18)}
.pchip.a{background:var(--ember);color:#fff;box-shadow:0 12px 30px -10px rgba(246,129,31,.7)}
.pchip .src{opacity:.85;font-weight:400;font-size:.82rem}
.prow{position:relative;display:flex;align-items:center;gap:24px;padding:8px 0}
.pnode{position:relative;z-index:2;width:14px;height:14px;border-radius:50%;background:var(--ember);margin-left:20px;flex:0 0 auto;box-shadow:0 0 0 5px rgba(246,129,31,.14),0 0 16px rgba(246,129,31,.6)}
.pslab{flex:1;background:linear-gradient(120deg,rgba(255,255,255,.10),rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:15px 22px}
.pslab .lname{font-family:'Archivo Expanded';font-weight:700;font-size:1.02rem;color:#fff}
.pslab .ldesc{color:rgba(255,255,255,.64);font-size:.88rem;margin-top:1px}
.pslab .lex{color:var(--ember);font-size:.78rem;font-weight:600;margin-top:5px}
.prow.l2 .pslab{margin-right:56px}
.prow.l3 .pslab{margin-right:112px}
.prow.l4 .pslab{margin-right:168px}
.prow.l5 .pslab{margin-right:224px}
@media(max-width:820px){.prow .pslab{margin-right:0!important}}
/* cascade the slabs in when the stack enters view (falls back to visible) */
.pstack.in .prow,.pstack.in .pchip{animation:up .55s both}
.pstack.in .pchip.q{animation-delay:.05s}
.pstack.in .l1{animation-delay:.16s}.pstack.in .l2{animation-delay:.28s}.pstack.in .l3{animation-delay:.40s}.pstack.in .l4{animation-delay:.52s}.pstack.in .l5{animation-delay:.64s}
.pstack.in .pchip.a{animation-delay:.82s}

/* FAQ */
.faq{max-width:820px;margin:0 auto;border-top:1px solid var(--line-l)}
.faq details{border-bottom:1px solid var(--line-l);padding:24px 2px}
.faq summary{font-family:'Archivo Expanded';font-weight:700;font-size:1.08rem;color:var(--ink);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--ember);font-size:1.5rem;font-weight:400;line-height:1}
.faq details[open] summary::after{content:"\2013"}
.faq p{color:var(--slate);margin-top:14px;font-size:1.02rem;max-width:70ch}

/* ===== DistrictWise v2 — relevance-activation graphic + feature visuals ===== */
.dwgraphic{display:grid;grid-template-columns:1.6fr .4fr;gap:26px;align-items:stretch;max-width:980px;margin:0 auto}
@media(max-width:820px){.dwgraphic{grid-template-columns:1fr}}
.spine{position:relative}
.qrow{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:16px 20px;color:#fff;font-size:1rem;margin-bottom:24px}
.qrow .qbadge{display:inline-block;font-family:'Archivo';font-weight:700;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ember);margin-right:.7em}
.lrail{position:absolute;left:7px;top:98px;height:210px;width:2px;background:linear-gradient(180deg,var(--ember),rgba(246,129,31,.3));box-shadow:0 0 12px rgba(246,129,31,.5)}
.lyr{position:relative;display:flex;align-items:center;gap:20px;padding:9px 0}
.lyr .dot{width:16px;height:16px;border-radius:50%;flex:0 0 auto;background:var(--ember);box-shadow:0 0 0 5px rgba(246,129,31,.14),0 0 16px rgba(246,129,31,.6)}
.lyr .lc{flex:1;background:linear-gradient(120deg,rgba(255,255,255,.10),rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.16);border-radius:11px;padding:13px 18px;color:#fff}
.lyr .lc b{font-family:'Archivo Expanded';font-weight:700;font-size:.98rem}
.lyr .lc span{color:var(--ember);font-size:.82rem;font-weight:600;display:block;margin-top:2px}
.answer{margin-top:24px;margin-left:36px;background:linear-gradient(150deg,rgba(246,129,31,.16),rgba(246,129,31,.04));border:1px solid rgba(246,129,31,.42);border-radius:14px;padding:18px 22px}
.answer p{color:#fff;font-size:.96rem;margin:.6em 0}
.answer .cite{color:rgba(255,255,255,.6);font-size:.76rem}
.risk{display:inline-block;font-family:'Archivo';font-weight:700;font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;padding:.38em .8em;border-radius:6px}
.risk.high{background:#C0392B;color:#fff}
.risk.med{background:#C98A1B;color:#fff}
.risk.low{background:#1A7F4B;color:#fff}
.cba{background:rgba(255,255,255,.03);border:1px dashed rgba(255,255,255,.22);border-radius:14px;padding:20px;display:flex;flex-direction:column;justify-content:center;opacity:.5}
.cba .k{font-family:'Archivo Expanded';font-weight:700;color:#fff;font-size:.92rem}
.cba p{color:rgba(255,255,255,.6);font-size:.84rem;margin:.3em 0 1em}
.cba .state{font-size:.74rem;color:rgba(255,255,255,.5);border-top:1px solid rgba(255,255,255,.12);padding-top:10px}
.riskqueue{display:flex;flex-direction:column;gap:12px}
.ri{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line-l);border-radius:12px;padding:15px 18px;font-size:.95rem;color:var(--ink)}
.ri .t{margin-left:auto;color:var(--slate);font-size:.84rem;text-align:right}
.change-card{background:#fff;border:1px solid var(--line-l);border-left:3px solid var(--ember);border-radius:12px;padding:22px 24px}
.tagnew{font-family:'Archivo';font-weight:700;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ember)}
.change-card p{color:var(--ink);margin:.6em 0}
.change-card .cite{color:var(--slate);font-size:.82rem}
.compare{display:grid;grid-template-columns:1fr auto 1fr;gap:18px;align-items:center}
.compare .col{background:#fff;border:1px solid var(--line-l);border-radius:12px;padding:20px}
.compare .col .h{font-family:'Archivo';font-weight:700;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--slate);display:block;margin-bottom:.7em}
.compare .col p{color:var(--ink);font-size:.9rem}
.compare .vs{font-family:'Archivo Expanded';color:var(--ember);font-weight:800}
.compare .diff{grid-column:1/-1;text-align:center;margin-top:8px;color:var(--ember);font-weight:600;font-size:.9rem}
@media(max-width:820px){.compare{grid-template-columns:1fr}.compare .vs{display:none}}

/* numbered process (services) — a real sequence, so numbers earn their place */
.process{display:grid;grid-template-columns:repeat(3,1fr);gap:34px;margin-top:20px}
@media(max-width:820px){.process{grid-template-columns:1fr}}
.step .n{font-family:'Archivo Expanded';font-weight:800;color:var(--ember);font-size:1.05rem;letter-spacing:.02em}
.step h4{font-family:'Archivo Expanded';font-weight:700;font-size:1.2rem;margin:.5em 0 .35em;color:var(--ink)}
.dark .step h4{color:#fff}
.step p{color:var(--slate)}
.dark .step p{color:rgba(255,255,255,.72)}

/* prose (about) */
.prose{max-width:720px}
.prose p{font-size:1.14rem;color:var(--slate);margin-bottom:1.25em}
.prose h2{font-size:clamp(1.7rem,3.2vw,2.4rem);margin:1.5em 0 .5em;color:var(--ink)}
.prose strong{color:var(--ink);font-weight:600}
.linkout{margin-top:14px;padding:26px 30px;border:1px solid var(--line-l);border-radius:16px;background:#fff;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.linkout p{margin:0;color:var(--slate)}

/* contact form */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:start}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr;gap:40px}}
.form{display:grid;gap:20px}
.form .row{display:grid;gap:20px;grid-template-columns:1fr 1fr}
@media(max-width:560px){.form .row{grid-template-columns:1fr}}
.form label{font-family:'Archivo';font-weight:600;font-size:.82rem;color:var(--ink);display:block;margin-bottom:.45em}
.form input,.form select,.form textarea{width:100%;padding:.85em 1em;border:1px solid var(--line-l);border-radius:10px;font-family:'Archivo';font-size:1rem;background:#fff;color:var(--ink)}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--ember);box-shadow:0 0 0 3px rgba(246,129,31,.14)}
.form textarea{min-height:140px;resize:vertical}
.contact-side h3{font-family:'Archivo Expanded';font-size:1.2rem;margin-bottom:.5em;color:var(--ink)}
.contact-side p{color:var(--slate);margin-bottom:1.1em}
.contact-side a{color:var(--orange);font-weight:600}

/* CTA */
.cta{background:radial-gradient(900px 500px at 50% 120%,#12224a,var(--bg) 70%);color:#fff;text-align:center;padding:130px 0;position:relative;overflow:hidden}
.cta .glow{position:absolute;left:50%;bottom:-140px;transform:translateX(-50%);width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(246,129,31,.3),transparent 65%)}
.cta-bulb{position:absolute;right:7%;top:50%;transform:translateY(-50%);height:360px;width:auto;opacity:.06;z-index:1}
.cta .wrap{position:relative;z-index:2}
.cta h2{font-size:clamp(2.1rem,4.6vw,3.2rem);max-width:16ch;margin:0 auto .5em}
.cta p{color:rgba(255,255,255,.8);font-size:1.15rem;margin-bottom:2em}
.cta .hero-cta{justify-content:center}
@media(max-width:820px){.cta-bulb{display:none}}

/* footer */
footer{background:#05090F;color:rgba(255,255,255,.62);padding:66px 0 46px}
.foot-inner{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;flex-wrap:wrap}
.foot-brand img{height:150px;width:auto;display:block}
.foot-links{display:flex;gap:1.7rem;flex-wrap:wrap}
.foot-links a{color:rgba(255,255,255,.62);font-size:.92rem}.foot-links a:hover{color:#fff}
.foot-tag{font-family:'Archivo';color:rgba(255,255,255,.4);font-size:.82rem;margin-top:22px;width:100%}

/* scroll reveal */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.mock-flag{position:fixed;bottom:16px;right:16px;z-index:99;background:#000;color:#fff;font-family:'Archivo';font-size:.72rem;font-weight:600;padding:.5em 1em;border-radius:999px;opacity:.8}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal,.hero .l,.hero .eyebrow,.hero .sub,.hero-cta,.bubble,.bulb-light{opacity:1!important;transform:none!important}}

/* ==========================================================================
   Mobile hardening (appended) — must live at the END of the file so these
   win by source order. Fixes: the mobile hero-visual hide was declared
   *before* the base `.hero-visual{display:flex}` rule, so the bulb never
   hid on phones and its width pushed the hero off-screen (text clipping).
   ========================================================================== */
@media(max-width:900px){
  .hero-visual{display:none!important}          /* hide the big hero bulb on phones */
  .hero{min-height:0}                            /* let the hero size to its content */
}
/* belt-and-suspenders: never allow horizontal overflow on small screens */
@media(max-width:900px){
  .hero,.proof,section.block,.operator,.cta{overflow-x:hidden}
}
/* Dark-background headings: pin white so they never inherit a stray dark
   colour. (These were `!important` Squarespace theme-overrides; on a static
   host normal specificity is enough.) Ember spans keep their accent. */
.hero h1 .l:not(.ember){color:#fff}
.page-hero h1,.operator h2,.cta h2{color:#fff}
.operator h2 .ember,.cta h2 .ember{color:var(--ember)}
