/* The Second Floor — shared design system (subpages) */
:root{
  --ink:#0B0B0D; --ink-2:#131318; --paper:#EFECE3; --paper-2:#E4E0D4;
  --acid:#D9FF4B; --lilac:#B9A4FF; --coral:#FF6B4A;
  --mute:#8E8E97; --mute-d:#6d6a60;
  --line:rgba(239,236,227,.13); --line-d:rgba(11,11,13,.14);
  --display:'Clash Display','Syne',sans-serif;
  --body:'General Sans','Space Grotesk',sans-serif;
  --mono:'Space Grotesk',monospace;
  --nav-h:64px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--ink);color:var(--paper);font-family:var(--body);font-size:16.5px;line-height:1.62;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body.no-cursor *{cursor:none!important}
::selection{background:var(--acid);color:var(--ink)}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1;letter-spacing:-.015em}
.wrap{max-width:1360px;margin:0 auto;padding:0 5vw}
.narrow{max-width:860px}
section{position:relative}
.pad{padding:7rem 0}
.eyebrow{font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;color:var(--mute);display:flex;align-items:center;gap:.8rem;margin-bottom:1.6rem;font-weight:600}
.eyebrow .trk{color:var(--acid);font-family:var(--mono)}
.eyebrow::before{content:"";width:2.4rem;height:1px;background:var(--acid)}
.light .eyebrow{color:var(--mute-d)}
.light .eyebrow::before{background:var(--ink)}

.grain{position:fixed;inset:-50%;width:200%;height:200%;pointer-events:none;z-index:98;opacity:.055;
background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");
animation:grain 7s steps(10) infinite}
@keyframes grain{0%,100%{transform:translate(0,0)}10%{transform:translate(-3%,2%)}20%{transform:translate(2%,-4%)}30%{transform:translate(-4%,-2%)}40%{transform:translate(3%,4%)}50%{transform:translate(-2%,3%)}60%{transform:translate(4%,-3%)}70%{transform:translate(-3%,-4%)}80%{transform:translate(2%,2%)}90%{transform:translate(-1%,4%)}}

#cursor{position:fixed;top:0;left:0;width:10px;height:10px;border-radius:50%;background:var(--acid);z-index:150;pointer-events:none;transform:translate(-50%,-50%);transition:width .25s,height .25s,opacity .3s;mix-blend-mode:difference}
#cursor.hov{width:64px;height:64px;background:#fff}
#cursor.hide{opacity:0}
@media (hover:none){#cursor{display:none}}

/* nav */
nav{position:fixed;top:0;left:0;right:0;z-index:60;transition:transform .4s,background .3s;background:rgba(11,11,13,.8);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
nav.away{transform:translateY(-100%)}
.nav-in{max-width:1360px;margin:0 auto;padding:0 5vw;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;gap:2rem}
.logo{font-family:var(--display);font-weight:700;font-size:1rem;letter-spacing:.04em;display:flex;align-items:center;gap:.5rem;text-transform:uppercase}
.logo .up{color:var(--acid);font-size:1.1em;display:inline-block;transition:transform .3s}
.logo:hover .up{transform:translateY(-3px)}
.nav-links{display:flex;gap:2rem;font-size:.86rem;font-weight:500}
.nav-links a{position:relative;padding:.3rem 0;color:var(--mute);transition:color .25s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;background:var(--acid);transform:scaleX(0);transform-origin:right;transition:transform .35s cubic-bezier(.2,.8,.2,1)}
.nav-links a:hover{color:var(--paper)}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}
.nav-links a.on{color:var(--paper)}
.nav-links a.on::after{transform:scaleX(1)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-weight:600;font-size:.92rem;padding:.9rem 1.7rem;border-radius:99px;border:1px solid transparent;cursor:pointer;position:relative;overflow:hidden;transition:color .3s,border-color .3s;font-family:var(--body)}
.btn .lab{position:relative;z-index:2}
.btn-acid{background:var(--acid);color:var(--ink)}
.btn-acid::before{content:"";position:absolute;inset:0;background:var(--paper);border-radius:99px;transform:translateY(101%);transition:transform .4s cubic-bezier(.2,.8,.2,1)}
.btn-acid:hover::before{transform:translateY(0)}
.btn-ghost{border-color:var(--line);color:var(--paper);background:transparent}
.btn-ghost:hover{border-color:var(--acid);color:var(--acid)}
.light .btn-ghost{border-color:var(--line-d);color:var(--ink)}
.light .btn-ghost:hover{border-color:var(--ink)}
nav .btn{padding:.55rem 1.3rem;font-size:.82rem}
.btn-big{padding:1.2rem 2.4rem;font-size:1.05rem}
.btn.mag{will-change:transform}

/* page hero */
.page-hero{padding:calc(var(--nav-h) + 7rem) 0 4.5rem;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:-20% -10%;background:
 radial-gradient(50% 45% at 80% 10%,rgba(70,51,168,.4),transparent 70%),
 radial-gradient(35% 35% at 8% 90%,rgba(217,255,75,.08),transparent 70%);z-index:-1}
.page-hero h1{font-size:clamp(2.8rem,8vw,7.5rem);text-transform:uppercase;font-weight:700;letter-spacing:-.02em}
.page-hero h1 .ol{color:transparent;-webkit-text-stroke:1.5px var(--paper)}
.page-hero h1 .ac{color:var(--acid)}
.page-hero .sub{max-width:36rem;color:#C9C6BD;font-size:1.08rem;margin-top:1.8rem}
.crumb{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);margin-bottom:2rem;display:flex;gap:.6rem;align-items:center}
.crumb a:hover{color:var(--acid)}
.crumb em{font-style:normal;color:var(--acid)}

/* chips & stats */
.chip-row{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:2.2rem}
.stat-chip{border:1px solid var(--line);border-radius:99px;padding:.6rem 1.3rem;font-size:.88rem;font-weight:600}
.stat-chip em{font-style:normal;color:var(--acid)}
.tag{font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;padding:.3rem .7rem;border:1px solid var(--line);border-radius:99px;color:var(--mute);white-space:nowrap}

/* filter bar */
.filter-bar{display:flex;flex-wrap:wrap;gap:.6rem;padding:1.6rem 0 2.6rem}
.filter-bar .lab{font-family:var(--mono);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);align-self:center;margin-right:.6rem}
.fbtn{font-family:var(--body);font-size:.82rem;font-weight:600;border:1px solid var(--line);background:transparent;color:var(--mute);border-radius:99px;padding:.55rem 1.2rem;cursor:pointer;transition:all .25s}
.fbtn:hover{color:var(--paper);border-color:var(--paper)}
.fbtn.on{background:var(--acid);color:var(--ink);border-color:var(--acid)}

/* archive grid */
.arch-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.8rem;padding-bottom:6rem}
.acard{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:var(--ink-2);display:block;transition:border-color .3s,transform .3s}
.acard:hover{border-color:var(--acid);transform:translateY(-4px)}
.acard .media{aspect-ratio:16/9;position:relative;overflow:hidden}
.acard .media .fill{position:absolute;inset:0;transition:transform .6s}
.acard:hover .media .fill{transform:scale(1.05)}
.acard .media::after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(11,11,13,.32) 1px,transparent 1.4px);background-size:5px 5px;mix-blend-mode:overlay}
.acard .mark{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;font-size:clamp(1.3rem,2.4vw,1.9rem);text-transform:uppercase;color:rgba(239,236,227,.94);z-index:2;text-align:center;padding:1rem}
.acard .chip{position:absolute;top:1rem;left:1rem;z-index:3;background:rgba(11,11,13,.72);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:99px;padding:.4rem .95rem;font-size:.76rem;font-weight:600}
.acard .chip em{font-style:normal;color:var(--acid)}
.acard .info{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.1rem 1.3rem}
.acard .info b{font-size:.98rem;font-weight:600}
.acard .tags{display:flex;gap:.4rem;flex-wrap:wrap;justify-content:flex-end}

/* palettes */
.g1{background:linear-gradient(130deg,#191538,#4936b8 55%,#8ef0c3 130%)}
.g2{background:linear-gradient(150deg,#2a1220,#b53a64 65%,#ffc36b 140%)}
.g3{background:linear-gradient(140deg,#0d2018,#1f8a62 70%,#d9ff4b 160%)}
.g4{background:linear-gradient(135deg,#27200f,#b08a2e 65%,#efece3 170%)}
.g5{background:linear-gradient(125deg,#11131f,#2e4bbd 60%,#ff6b4a 165%)}
.g6{background:linear-gradient(160deg,#231c4d,#5a3fd4 60%,#d9ff4b 150%)}
.g7{background:linear-gradient(160deg,#0f2b22,#19805c 65%,#b9a4ff 150%)}
.g8{background:linear-gradient(160deg,#33150f,#cf4d2b 70%,#efece3 160%)}
.g9{background:linear-gradient(145deg,#1d1d24,#52525e 65%,#d9ff4b 170%)}
.g10{background:linear-gradient(140deg,#101b2e,#1f5fa8 65%,#ffc36b 155%)}
.g11{background:linear-gradient(150deg,#2b0f2b,#8a3a8a 65%,#8ef0c3 150%)}

/* sections / headings */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;margin-bottom:3.4rem;flex-wrap:wrap}
.sec-head h2{font-size:clamp(2.2rem,5.4vw,4.4rem);text-transform:uppercase;font-weight:700}
.sec-head .side{max-width:24rem;color:var(--mute);font-size:.96rem}
.light .sec-head .side{color:var(--mute-d)}

/* light band */
.band{background:var(--paper);color:var(--ink);border-radius:32px;margin:0 0}
.band .pad-in{padding:6rem 0}

/* service blocks (capability pages) */
.svc{border-top:1px solid var(--line);padding:3.2rem 0;display:grid;grid-template-columns:auto 1.2fr 1.6fr;gap:3rem;align-items:start;scroll-margin-top:calc(var(--nav-h) + 1.5rem)}
.svc .idx{font-family:var(--mono);font-size:.8rem;color:var(--acid);letter-spacing:.2em}
.svc h3{font-size:clamp(1.6rem,3.4vw,2.6rem);text-transform:uppercase}
.svc h3 small{display:block;font-family:var(--body);font-size:.85rem;font-weight:500;color:var(--mute);text-transform:none;letter-spacing:0;margin-top:.6rem;line-height:1.5}
.svc .det p{color:#C9C6BD;font-size:.97rem;max-width:34rem}
.svc .det ul{list-style:none;display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1.3rem}
.svc .det li{font-size:.8rem;font-weight:500;border:1px solid var(--line);border-radius:99px;padding:.45rem 1rem;color:#C9C6BD;transition:all .25s}
.svc .det li:hover{background:var(--acid);color:var(--ink);border-color:var(--acid)}

/* process steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.step{border:1px solid var(--line);border-radius:18px;padding:1.9rem;background:var(--ink-2)}
.step .n{font-family:var(--mono);font-size:.75rem;color:var(--acid);letter-spacing:.2em}
.step h4{font-size:1.25rem;text-transform:uppercase;margin:.9rem 0 .5rem}
.step p{font-size:.88rem;color:var(--mute)}

/* mini stat row */
.mini-stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.ms{padding:2rem 1.6rem;border-right:1px solid var(--line)}
.ms:last-child{border-right:0}
.ms .big{font-family:var(--display);font-weight:700;font-size:clamp(1.9rem,3.4vw,3rem);color:var(--acid)}
.ms p{font-size:.82rem;color:var(--mute);margin-top:.3rem}

/* FAQ */
.faq{border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:2rem;padding:1.7rem 0;font-family:var(--display);font-weight:600;font-size:clamp(1.05rem,2vw,1.45rem)}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{color:var(--acid);font-size:1.4rem;transition:transform .3s;flex-shrink:0}
.faq details[open] summary .pm{transform:rotate(45deg)}
.faq .ans{padding:0 0 1.8rem;color:#C9C6BD;max-width:46rem;font-size:.97rem}

/* case study */
.case-media{border-radius:20px;overflow:hidden;border:1px solid var(--line);position:relative;aspect-ratio:16/8;margin:3rem 0}
.case-media video,.case-media .fill{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.case-media .fpo{position:absolute;left:1rem;bottom:1rem;z-index:3;font-family:var(--mono);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(239,236,227,.55);background:rgba(11,11,13,.5);padding:.3rem .6rem;border-radius:4px}
.case-grid{display:grid;grid-template-columns:1fr 2fr;gap:4rem;padding:3rem 0;border-top:1px solid var(--line)}
.case-grid h2{font-size:clamp(1.5rem,3vw,2.3rem);text-transform:uppercase;position:sticky;top:calc(var(--nav-h) + 2rem)}
.case-grid h2 .trk{display:block;font-family:var(--mono);font-size:.7rem;letter-spacing:.22em;color:var(--acid);margin-bottom:.8rem;font-weight:500}
.case-grid .body p{color:#C9C6BD;margin-bottom:1.2rem;max-width:42rem}
.case-grid .body ul{list-style:none;margin:1rem 0}
.case-grid .body li{padding:.8rem 0;border-bottom:1px dashed var(--line);color:#C9C6BD;display:flex;gap:.9rem}
.case-grid .body li::before{content:"→";color:var(--acid)}
.summary-box{border:1px solid rgba(217,255,75,.35);background:rgba(217,255,75,.05);border-radius:18px;padding:2.2rem;margin:4rem 0}
.summary-box h3{font-size:1.1rem;text-transform:uppercase;letter-spacing:.08em;display:flex;align-items:center;gap:.7rem;margin-bottom:1rem}
.summary-box h3::before{content:"✦";color:var(--acid)}
.summary-box p{color:#D9D6CD;font-size:.97rem;max-width:54rem}
.summary-box .note{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--mute);margin-top:1.2rem}

/* pull quote */
.pull{font-family:var(--display);font-weight:600;font-size:clamp(1.5rem,3.4vw,2.6rem);line-height:1.2;max-width:50rem;padding:4rem 0}
.pull .ac{color:var(--acid)}
.pull-attr{color:var(--mute);font-size:.88rem;margin-top:1.4rem;font-family:var(--body)}

/* insights rows */
.ins-rows{border-top:1px solid var(--line)}
.ins-row{display:grid;grid-template-columns:auto 1fr auto auto;gap:2.4rem;align-items:center;padding:2rem 0;border-bottom:1px solid var(--line);transition:opacity .3s}
.ins-rows:hover .ins-row:not(:hover){opacity:.35}
.ins-row .num{font-family:var(--mono);font-size:.8rem;color:var(--mute)}
.ins-row h3{font-size:clamp(1.2rem,2.4vw,1.85rem);font-weight:600;transition:transform .35s}
.ins-row:hover h3{transform:translateX(1rem)}
.ins-row .cat{font-family:var(--mono);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--acid);white-space:nowrap}
.ins-row .cat.soon{color:var(--mute)}
.ins-row .arr{font-size:1.5rem;color:var(--mute);transition:transform .35s,color .3s}
.ins-row:hover .arr{transform:rotate(-45deg);color:var(--acid)}

/* featured insight */
.feat-post{display:grid;grid-template-columns:1.2fr 1fr;border:1px solid var(--line);border-radius:20px;overflow:hidden;margin-bottom:4rem;background:var(--ink-2);transition:border-color .3s}
.feat-post:hover{border-color:var(--acid)}
.feat-post .media{position:relative;min-height:320px}
.feat-post .media .fill{position:absolute;inset:0}
.feat-post .txt{padding:2.6rem;display:flex;flex-direction:column}
.feat-post .txt h3{font-size:clamp(1.5rem,2.8vw,2.2rem);line-height:1.1;flex:1}
.feat-post .meta{font-family:var(--mono);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);margin-bottom:1.2rem}
.feat-post .meta em{font-style:normal;color:var(--acid)}
.feat-post .read{margin-top:2rem;font-weight:700;color:var(--acid)}

/* article prose */
.prose{max-width:760px}
.prose .meta{display:flex;gap:1.4rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--mute);margin:1.8rem 0 0}
.prose .meta em{font-style:normal;color:var(--acid)}
.prose h2{font-size:clamp(1.5rem,3vw,2.1rem);margin:3.2rem 0 1.1rem}
.prose p{color:#C9C6BD;margin-bottom:1.25rem}
.prose p b,.prose p strong{color:var(--paper)}
.prose ul{margin:0 0 1.4rem 1.2rem;color:#C9C6BD}
.prose li{margin-bottom:.5rem}
.tldr{border:1px solid var(--line);border-left:3px solid var(--acid);border-radius:0 16px 16px 0;padding:1.8rem 2rem;margin:2.6rem 0;background:var(--ink-2)}
.tldr h3{font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--acid);margin-bottom:1rem;font-family:var(--body);font-weight:700}
.tldr ul{list-style:none;margin:0}
.tldr li{padding:.45rem 0;color:#D9D6CD;display:flex;gap:.8rem;font-size:.95rem}
.tldr li::before{content:"✦";color:var(--acid)}

/* pillars-as-cards (audience page) */
.pillar-cards{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.pcard{border:1px solid var(--line);border-radius:18px;padding:2.2rem;background:var(--ink-2);transition:border-color .3s}
.pcard:hover{border-color:var(--acid)}
.pcard .idx{font-family:var(--mono);font-size:.75rem;color:var(--acid);letter-spacing:.2em}
.pcard h3{font-size:1.45rem;text-transform:uppercase;margin:1rem 0 .6rem}
.pcard p{font-size:.92rem;color:var(--mute)}

/* values / team */
.val-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.tcard{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--ink-2)}
.tcard .ph{aspect-ratio:4/5;position:relative;display:flex;align-items:center;justify-content:center;color:var(--mute);font-family:var(--mono);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase}
.tcard .ph::before{content:"";position:absolute;inset:0;opacity:.55}
.tcard:nth-child(1) .ph::before{background:linear-gradient(150deg,#231c4d,#5a3fd4)}
.tcard:nth-child(2) .ph::before{background:linear-gradient(150deg,#0f2b22,#19805c)}
.tcard:nth-child(3) .ph::before{background:linear-gradient(150deg,#33150f,#cf4d2b)}
.tcard:nth-child(4) .ph::before{background:linear-gradient(150deg,#101b2e,#1f5fa8)}
.tcard .ph span{position:relative}
.tcard .nm{padding:1.1rem 1.3rem}
.tcard .nm b{display:block;font-size:.95rem}
.tcard .nm span{font-size:.8rem;color:var(--mute)}

/* forms */
.form-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:4rem;align-items:start}
form .row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
label{display:block;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);margin:1.6rem 0 .5rem;font-weight:600}
input,textarea,select{width:100%;background:var(--ink-2);border:1px solid var(--line);border-radius:12px;padding:.95rem 1.1rem;color:var(--paper);font-family:var(--body);font-size:.95rem;transition:border-color .25s}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--acid)}
textarea{min-height:130px;resize:vertical}
.side-info{border:1px solid var(--line);border-radius:18px;padding:2.2rem;background:var(--ink-2)}
.side-info h4{font-size:1.1rem;text-transform:uppercase;margin-bottom:1.2rem}
.side-info p{font-size:.92rem;color:var(--mute);margin-bottom:1rem}
.side-info .joke{font-size:.8rem;color:var(--mute)}
.side-info a{color:var(--acid)}
.tick{display:flex;gap:.7rem;font-size:.9rem;color:#C9C6BD;padding:.35rem 0}
.tick::before{content:"✓";color:var(--acid);font-weight:700}

/* AI terminal (review page) */
.term{border:1px solid var(--line);border-radius:18px;background:var(--ink-2);overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.45)}
.term-bar{display:flex;align-items:center;gap:.45rem;padding:.9rem 1.2rem;border-bottom:1px solid var(--line)}
.term-bar i{width:.65rem;height:.65rem;border-radius:50%;background:#3a3a42}
.term-bar i:first-child{background:var(--coral)}
.term-bar i:nth-child(2){background:#e8c14d}
.term-bar i:nth-child(3){background:var(--acid)}
.term-bar span{margin-left:auto;font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mute)}
.term-body{padding:1.6rem 1.5rem 1.8rem;display:flex;flex-direction:column;gap:1rem;font-size:.95rem}
.msg{max-width:92%;padding:.95rem 1.15rem;border-radius:14px;line-height:1.5}
.msg.q{align-self:flex-end;background:#22222b;border-bottom-right-radius:4px}
.msg.q::before{content:"A potential fan / customer";display:block;font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);margin-bottom:.35rem}
.msg.a{align-self:flex-start;background:rgba(217,255,75,.07);border:1px solid rgba(217,255,75,.25);border-bottom-left-radius:4px}
.msg.a::before{content:"AI assistant";display:block;font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--acid);margin-bottom:.35rem}
.msg.a b{color:var(--acid)}
.msg.a .gap{color:var(--coral);font-weight:600}

/* CTA band */
.cta-band{text-align:center;padding:8rem 0 7rem}
.cta-band h2{font-size:clamp(2.6rem,8vw,7rem);text-transform:uppercase;font-weight:700;line-height:.96}
.cta-band h2 .ol{color:transparent;-webkit-text-stroke:1.5px var(--paper)}
.cta-band h2 .ac{color:var(--acid)}
.cta-band p{color:var(--mute);margin:1.8rem auto 2.6rem;max-width:28rem}
.cta-band .row{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* footer */
footer{border-top:1px solid var(--line);padding:4rem 0 2.4rem;font-size:.88rem;color:var(--mute)}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:2.5rem}
.foot-grid h4{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--paper);margin-bottom:1.1rem;font-weight:600;font-family:var(--body)}
.foot-grid ul{list-style:none}
.foot-grid li{padding:.3rem 0}
.foot-grid a{transition:color .2s}
.foot-grid a:hover{color:var(--acid)}
.foot-grid address{font-style:normal;line-height:1.8}
.foot-grid address .joke{color:var(--mute);font-size:.78rem}
.foot-bottom{display:flex;justify-content:space-between;gap:1rem;margin-top:3.2rem;padding-top:1.6rem;border-top:1px solid var(--line);font-size:.76rem;flex-wrap:wrap}

/* reveal */
.rv{opacity:0;transform:translateY(34px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.rv.in{opacity:1;transform:none}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .rv{opacity:1!important;transform:none!important}
  #cursor{display:none}
  .grain{animation:none}
  video{display:none}
}
@media (max-width:980px){
  .nav-links{display:none}
  .arch-grid{grid-template-columns:1fr}
  .svc{grid-template-columns:1fr;gap:1.4rem}
  .steps{grid-template-columns:1fr 1fr}
  .mini-stats{grid-template-columns:1fr 1fr}
  .ms{border-bottom:1px solid var(--line)}
  .case-grid{grid-template-columns:1fr;gap:1.6rem}
  .case-grid h2{position:static}
  .feat-post{grid-template-columns:1fr}
  .pillar-cards,.val-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .form-grid{grid-template-columns:1fr}
  form .row{grid-template-columns:1fr}
  .ins-row{grid-template-columns:auto 1fr auto;gap:1.2rem}
  .ins-row .cat{display:none}
