
/* ============ NEUE HAAS GROTESK (licensed, self-hosted) — Display Pro for titles, Text Pro for body ============ */
@font-face{
  font-family:"Neue Haas Grotesk Display Pro";
  src:url("/wp-content/uploads/gcm-home/assets/fonts/NeueHaasGroteskDisplayPro-75Bold.woff2") format("woff2");
  font-weight:700; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Neue Haas Grotesk Display Pro";
  src:url("/wp-content/uploads/gcm-home/assets/fonts/NeueHaasGroteskDisplayPro-95Black.woff2") format("woff2");
  font-weight:900; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Neue Haas Grotesk Text Pro";
  src:url("/wp-content/uploads/gcm-home/assets/fonts/NeueHaasGroteskTextPro-55Roman.woff2") format("woff2");
  font-weight:400; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Neue Haas Grotesk Text Pro";
  src:url("/wp-content/uploads/gcm-home/assets/fonts/NeueHaasGroteskTextPro-75Bold.woff2") format("woff2");
  font-weight:700; font-style:normal; font-display:swap;
}

/* ============ TOKENS ============ */
:root{
  --bg:#04070A;
  --bg-2:#070D10;
  --panel:#0A1318;
  --panel-2:#0D181E;
  --line:rgba(120,255,190,.10);
  --line-2:rgba(120,255,190,.18);
  --glass:rgba(13,24,30,.55);
  --green:#27F58C;
  --green-2:#0FD977;
  --green-dim:rgba(39,245,140,.14);
  --green-glow:rgba(39,245,140,.35);
  --ink:#F5FBF7;
  --ink-2:#DCE9E2;
  --ink-3:#A3BAAE;
  --mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  --disp:"Neue Haas Grotesk Display Pro", "Helvetica Now Display", "Helvetica Neue", Arial, sans-serif;
  --body:"Neue Haas Grotesk Text Pro", "Helvetica Neue", Arial, sans-serif;
  --r:18px;
  --r-lg:26px;
  --max:1320px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
body{background:var(--bg);color:var(--ink);font-family:var(--body);font-size:16px;line-height:1.6;overflow-x:clip;-webkit-font-smoothing:antialiased}
body.modal-open{overflow:hidden}
::selection{background:var(--green);color:#031008}
img{max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
:focus-visible{outline:2px solid var(--green);outline-offset:3px;border-radius:4px}

/* ============ TYPE ============ */
h1,h2,h3,h4{font-family:var(--disp);font-weight:600;letter-spacing:-.02em;line-height:1.05}
.h-mega{font-size:clamp(2.6rem,7vw,6.2rem);letter-spacing:-.035em}
.h-xl{font-size:clamp(2rem,4.6vw,3.9rem);letter-spacing:-.03em}
.h-lg{font-size:clamp(1.5rem,2.8vw,2.3rem)}
.eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--green);display:inline-flex;align-items:center;gap:.6rem}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--green)}
.lede{color:var(--ink-2);font-size:clamp(1rem,1.4vw,1.2rem);max-width:62ch}
.accent{color:var(--green)}
.outline-txt{color:transparent;-webkit-text-stroke:1.6px rgba(245,251,247,.8)}

/* ============ LAYOUT ============ */
.wrap{width:min(var(--max),calc(100% - 48px));margin-inline:auto}
section{padding:clamp(72px,9vw,140px) 0;position:relative}
.sec-head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:clamp(36px,5vw,64px)}
.sec-head .lede{margin-top:14px}

/* ============ PLACEHOLDER SLOT SYSTEM ============ */
.slot{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:
  repeating-linear-gradient(45deg,rgba(39,245,140,.025) 0 12px,transparent 12px 24px),var(--panel);
  border:1px dashed rgba(39,245,140,.30);border-radius:14px;color:var(--ink-3);text-align:center;overflow:hidden;min-height:90px;padding:14px;transition:border-color .3s,background .3s}
.slot:hover{border-color:var(--green);background:repeating-linear-gradient(45deg,rgba(39,245,140,.05) 0 12px,transparent 12px 24px),var(--panel-2)}
.slot::before,.slot::after{content:"";position:absolute;width:14px;height:14px;border:2px solid var(--green);opacity:.7}
.slot::before{top:8px;left:8px;border-right:0;border-bottom:0}
.slot::after{bottom:8px;right:8px;border-left:0;border-top:0}
.slot .s-ico{font-size:1.3rem;line-height:1;opacity:.9}
.slot .s-tag{font-family:var(--mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--green);opacity:.85}
.slot .s-name{font-family:var(--disp);font-size:.85rem;color:var(--ink-2);font-weight:500;line-height:1.3}
.slot.sm{min-height:64px;padding:10px}
.slot.sm .s-ico{font-size:1rem}
.slot.video-slot .play{width:54px;height:54px;border-radius:50%;background:rgba(39,245,140,.12);border:1px solid var(--green);display:grid;place-items:center;transition:transform .3s,background .3s}
.slot.video-slot .play svg{margin-left:3px}
.slot.video-slot:hover .play{transform:scale(1.12);background:rgba(39,245,140,.25);box-shadow:0 0 34px var(--green-glow)}
.ratio-16-9{aspect-ratio:16/9}
.ratio-4-3{aspect-ratio:4/3}
.ratio-1-1{aspect-ratio:1/1}
.ratio-9-16{aspect-ratio:9/16}

/* ============ BUTTONS ============ */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--disp);font-weight:600;font-size:.95rem;padding:15px 28px;border-radius:100px;border:1px solid transparent;transition:transform .25s,box-shadow .25s,background .25s,border-color .25s;white-space:nowrap}
.btn-green{background:linear-gradient(135deg,var(--green),var(--green-2));color:#03130A;box-shadow:0 0 0 0 var(--green-glow)}
.btn-green:hover{transform:translateY(-2px);box-shadow:0 12px 40px -8px var(--green-glow),0 0 24px var(--green-glow)}
.btn-ghost{background:rgba(255,255,255,.03);border-color:var(--line-2);color:var(--ink)}
.btn-ghost:hover{border-color:var(--green);background:var(--green-dim);transform:translateY(-2px)}
.btn .arr{transition:transform .25s}
.btn:hover .arr{transform:translateX(4px)}
.btn-sm{padding:10px 20px;font-size:.82rem}

/* ============ HEADER (non-sticky · centered name · logo flanking pill) ============ */
header{position:absolute;inset:0 0 auto 0;z-index:200;padding:20px 0 0}
header::after{content:"";position:absolute;inset:0 0 auto 0;height:1px;background:linear-gradient(90deg,transparent,rgba(39,245,140,.4),transparent)}
.h-name-row{position:relative;display:flex;justify-content:center;align-items:center;margin-bottom:16px}
.h-name{font-family:var(--disp);font-weight:700;font-size:clamp(1.15rem,2vw,1.5rem);letter-spacing:.04em;text-transform:uppercase;color:var(--ink);text-align:center;line-height:1.15}
.h-name small{display:block;font-family:var(--mono);font-weight:500;font-size:.6rem;letter-spacing:.34em;color:var(--green);text-transform:uppercase;margin-top:4px}
.h-navwrap{display:flex;align-items:stretch;justify-content:center;gap:18px}
.h-logo{display:flex;align-items:stretch;flex:none}
.h-logo img{height:100%;max-height:58px;width:auto;border-radius:12px;box-shadow:0 0 26px rgba(39,245,140,.22);object-fit:contain}
.logo .mark,.mark{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--green),#0B8F52);display:grid;place-items:center;color:#03130A;font-weight:700;font-size:.85rem;box-shadow:0 0 22px rgba(39,245,140,.4);font-family:var(--disp)}
.logo{display:flex;align-items:center;gap:11px;font-family:var(--disp);font-weight:700;font-size:1.06rem;letter-spacing:-.01em}
.logo small{display:block;font-family:var(--mono);font-weight:400;font-size:.56rem;letter-spacing:.22em;color:var(--ink-3);text-transform:uppercase}
nav.main{position:relative;display:grid;grid-template-columns:repeat(5,1fr);gap:0;background:linear-gradient(180deg,rgba(16,28,24,.78),rgba(8,15,12,.78));backdrop-filter:blur(18px) saturate(1.3);-webkit-backdrop-filter:blur(18px) saturate(1.3);border:1px solid var(--line-2);border-radius:18px;padding:6px 10px;box-shadow:0 24px 60px -24px rgba(0,0,0,.8),inset 0 1px 0 rgba(255,255,255,.05)}
nav.main::before{content:"";position:absolute;left:18px;right:18px;top:50%;height:1px;background:linear-gradient(90deg,transparent,var(--line-2) 18%,var(--line-2) 82%,transparent)}
nav.main a{position:relative;font-family:var(--disp);font-size:.7rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-2);padding:7px 9px;text-align:center;white-space:nowrap;transition:color .25s}
nav.main a::after{content:"";position:absolute;left:50%;bottom:7px;width:0;height:2px;border-radius:2px;background:var(--green);box-shadow:0 0 10px var(--green);transition:width .28s cubic-bezier(.2,.8,.2,1),left .28s cubic-bezier(.2,.8,.2,1)}
nav.main a:hover{color:var(--green)}
nav.main a:hover::after{width:55%;left:22.5%}
nav.main a.is-current{color:var(--green)}
nav.main a.is-current::after{width:55%;left:22.5%}
.h-cta{align-self:center}
.burger{display:none;background:none;border:1px solid var(--line-2);border-radius:10px;width:42px;height:42px;color:var(--ink);font-size:1.1rem}
.m-nav{display:none}
@media(max-width:1100px){
  .h-navwrap{display:none}
  .burger{display:grid;place-items:center;position:absolute;right:0;top:50%;transform:translateY(-50%)}
  .h-name-row{margin-bottom:0;padding-right:54px;padding-left:54px}
  .m-nav{position:fixed;inset:0;background:rgba(4,8,10,.96);backdrop-filter:blur(24px);z-index:190;flex-direction:column;align-items:center;justify-content:center;gap:6px;display:flex;opacity:0;pointer-events:none;transition:opacity .3s;overflow-y:auto;padding:40px 0}
  .m-nav.open{opacity:1;pointer-events:auto}
  .m-nav a{font-family:var(--disp);font-size:1.25rem;padding:10px;color:var(--ink-2)}
  .m-nav a:hover{color:var(--green)}
  .m-nav .btn{margin-top:16px}
}
/* ============ HERO ============ */
.hero{min-height:100svh;display:flex;align-items:center;padding-top:230px;padding-bottom:80px;overflow:hidden}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.hero-bg .grid-floor{position:absolute;inset:auto 0 -10% 0;height:62%;background:
  linear-gradient(rgba(39,245,140,.07) 1px,transparent 1px),
  linear-gradient(90deg,rgba(39,245,140,.07) 1px,transparent 1px);
  background-size:54px 54px;transform:perspective(700px) rotateX(62deg);transform-origin:top;mask-image:linear-gradient(transparent,black 30%,transparent 95%)}
.hero-bg .glow{position:absolute;width:900px;height:900px;border-radius:50%;background:radial-gradient(circle,rgba(39,245,140,.13),transparent 65%);top:-20%;left:50%;transform:translateX(-50%);filter:blur(20px)}
.hero-bg .scanline{position:absolute;left:0;right:0;height:140px;background:linear-gradient(transparent,rgba(39,245,140,.05),transparent);animation:scan 9s linear infinite}
@keyframes scan{0%{top:-20%}100%{top:120%}}
.hero-in{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:48px;align-items:center}
.hero .eyebrow{margin-bottom:22px}
.hero h1 span.line{display:block}
.hero .lede{margin:26px 0 36px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.hero-meta{display:flex;gap:34px;margin-top:46px;flex-wrap:wrap}
.hero-meta div b{font-family:var(--disp);font-size:1.5rem;color:var(--ink);display:block;letter-spacing:-.02em}
.hero-meta div span{font-family:var(--mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3)}
/* floating stack */
.hero-stage{position:relative;height:620px;perspective:1400px}
.f-panel{position:absolute;border-radius:16px;background:var(--glass);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid var(--line-2);box-shadow:0 30px 70px -20px rgba(0,0,0,.7);overflow:hidden;animation:floaty 7s ease-in-out infinite}
.f-panel .ph{padding:10px 12px;font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:7px}
.f-panel .ph .dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green)}
@keyframes floaty{0%,100%{transform:translateY(0) rotateY(var(--ry,0deg)) rotateX(var(--rx,0deg))}50%{transform:translateY(-14px) rotateY(var(--ry,0deg)) rotateX(var(--rx,0deg))}}
.fp-dash{width:330px;top:30px;right:30px;--ry:-9deg;--rx:4deg}
.fp-dash .bars{display:flex;align-items:flex-end;gap:8px;height:110px;padding:16px}
.fp-dash .bars i{flex:1;background:linear-gradient(180deg,var(--green),rgba(39,245,140,.15));border-radius:5px 5px 0 0;animation:barGrow 1.4s cubic-bezier(.2,.8,.2,1) both}
@keyframes barGrow{from{transform:scaleY(0)}to{transform:scaleY(1)}}
.fp-dash .bars i{transform-origin:bottom}
.fp-dash .kpis{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border-top:1px solid var(--line)}
.fp-dash .kpis div{background:var(--panel);padding:10px 14px}
.fp-dash .kpis b{font-family:var(--disp);color:var(--green);font-size:1.05rem;display:block}
.fp-dash .kpis span{font-family:var(--mono);font-size:.55rem;letter-spacing:.12em;color:var(--ink-3);text-transform:uppercase}
.fp-video{width:280px;bottom:120px;left:-10px;--ry:10deg;animation-delay:-2.5s}
.fp-video .slot{border:0;border-radius:0;min-height:150px}
.fp-site{width:240px;top:175px;left:0;--ry:7deg;--rx:-3deg;animation-delay:-4s}
.fp-site .slot{border:0;border-radius:0;min-height:120px}
.fp-logos{width:300px;bottom:0;right:60px;--ry:-7deg;animation-delay:-1.2s}
.fp-logos .row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:12px}
.fp-logos .slot{min-height:52px;padding:6px}
.fp-logos .slot .s-name{font-size:.58rem}
.fp-review{width:240px;top:330px;right:-20px;--ry:-12deg;animation-delay:-5.4s;z-index:3}
.fp-review .rv-body{padding:14px;font-size:.78rem;color:var(--ink-2)}
.fp-review .stars{color:var(--green);letter-spacing:3px;font-size:.85rem;margin-bottom:6px}
/* data lines */
.hero-stage svg.lines{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:-1}
.hero-stage svg.lines path{fill:none;stroke:var(--green);stroke-width:1.4;opacity:.5;stroke-dasharray:7 9;animation:dashmove 3s linear infinite}
@keyframes dashmove{to{stroke-dashoffset:-64}}
@media(max-width:1080px){
  .hero-in{grid-template-columns:1fr}
  .hero-stage{height:520px;margin-top:10px}
  .fp-dash{right:0;width:300px}
  .fp-review{right:0}
  .fp-video{left:0}
  .fp-site{left:10px;width:220px}
}
@media(max-width:640px){
  .hero-stage{height:760px}
  .f-panel{position:relative;inset:auto!important;width:100%!important;margin-bottom:16px;--ry:0deg;--rx:0deg;animation:none}
}

/* ============ LOGO WALL ============ */
.logowall{padding:54px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2)}
.logowall .label{text-align:center;font-family:var(--mono);font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-3);margin-bottom:30px}
.marquee{overflow:hidden;mask-image:linear-gradient(90deg,transparent,black 12%,black 88%,transparent)}
.marquee .track{display:flex;gap:18px;width:max-content;animation:marq 46s linear infinite}
.marquee:hover .track{animation-play-state:paused}
@keyframes marq{to{transform:translateX(-50%)}}
.marquee .slot{width:190px;min-height:74px;flex:none}

/* ============ SUCCESS GRID ============ */
.succ-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:22px}
.card{background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;position:relative;transition:transform .35s cubic-bezier(.2,.8,.2,1),border-color .35s,box-shadow .35s;transform-style:preserve-3d}
.card:hover{transform:translateY(-8px);border-color:var(--line-2);box-shadow:0 30px 60px -24px rgba(0,0,0,.8),0 0 0 1px rgba(39,245,140,.18),0 0 50px -16px var(--green-glow)}
.succ-card .cover{position:relative}
.succ-card .cover .slot{border-radius:0;border-left:0;border-right:0;border-top:0;min-height:185px}
.succ-card .logo-chip{position:absolute;left:16px;bottom:-26px;width:62px;height:62px;border-radius:14px;background:var(--panel);border:1px solid var(--line-2);box-shadow:0 10px 28px rgba(0,0,0,.6);z-index:2}
.succ-card .logo-chip .slot{border:0;min-height:100%;height:100%;border-radius:13px;padding:4px}
.succ-card .logo-chip .s-tag{font-size:.45rem}
.succ-card .body{padding:40px 20px 20px}
.succ-card .tag{font-family:var(--mono);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--green);background:var(--green-dim);border:1px solid rgba(39,245,140,.25);padding:4px 10px;border-radius:100px;display:inline-block;margin-bottom:12px}
.succ-card h3{font-size:1.18rem;margin-bottom:8px}
.succ-card p{color:var(--ink-2);font-size:.88rem;min-height:3.4em}
.succ-card .foot{display:flex;align-items:center;justify-content:space-between;margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.succ-card .stat{font-family:var(--mono);font-size:.68rem;color:var(--green)}
.link-btn{background:none;border:0;color:var(--ink);font-family:var(--disp);font-weight:600;font-size:.85rem;display:inline-flex;align-items:center;gap:8px;padding:0}
.link-btn .arr{color:var(--green);transition:transform .25s}
.link-btn:hover .arr{transform:translateX(4px)}
.link-btn:hover{color:var(--green)}

/* ============ MODAL ============ */
.modal-bg{position:fixed;inset:0;background:rgba(2,5,7,.8);backdrop-filter:blur(12px);z-index:300;display:grid;place-items:center;padding:22px;opacity:0;pointer-events:none;transition:opacity .3s}
.modal-bg.open{opacity:1;pointer-events:auto}
.modal{width:min(1060px,100%);max-height:90svh;overflow-y:auto;background:linear-gradient(180deg,#0C161C,#080F13);border:1px solid var(--line-2);border-radius:24px;transform:translateY(26px) scale(.97);transition:transform .35s cubic-bezier(.2,.8,.2,1);box-shadow:0 60px 120px -30px rgba(0,0,0,.9)}
.modal-bg.open .modal{transform:none}
.modal::-webkit-scrollbar{width:9px}
.modal::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:9px}
.modal .m-head{display:flex;align-items:center;gap:18px;padding:26px 30px;border-bottom:1px solid var(--line);position:sticky;top:0;background:rgba(12,22,28,.92);backdrop-filter:blur(14px);z-index:3;border-radius:24px 24px 0 0}
.modal .m-head .slot{width:62px;height:62px;min-height:62px;flex:none;padding:4px}
.modal .m-head .slot .s-tag{font-size:.42rem}
.modal .m-head h3{font-size:1.3rem}
.modal .m-head .ind{font-family:var(--mono);font-size:.62rem;color:var(--green);letter-spacing:.14em;text-transform:uppercase}
.m-close{margin-left:auto;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.04);border:1px solid var(--line-2);color:var(--ink);font-size:1.05rem;transition:background .25s,transform .25s}
.m-close:hover{background:var(--green-dim);transform:rotate(90deg);border-color:var(--green)}
.m-body{padding:28px 30px 36px}
.m-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}
.m-tab{font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;padding:9px 16px;border-radius:100px;border:1px solid var(--line-2);background:none;color:var(--ink-2);transition:all .25s}
.m-tab.active,.m-tab:hover{background:var(--green-dim);border-color:var(--green);color:var(--green)}
.m-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px}
.m-results{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-bottom:22px}
.m-results .res{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px}
.m-results .res b{font-family:var(--disp);font-size:1.5rem;color:var(--green);display:block;letter-spacing:-.02em}
.m-results .res span{font-family:var(--mono);font-size:.6rem;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-3)}
.m-story{color:var(--ink-2);font-size:.95rem;margin-bottom:24px;max-width:70ch}

/* ============ COMPARISON ============ */
.versus{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line-2);border-radius:var(--r-lg);overflow:hidden;position:relative}
.versus .col{padding:clamp(26px,4vw,48px)}
.versus .col.old{background:#0A0D0F}
.versus .col.gcm{background:linear-gradient(160deg,rgba(39,245,140,.10),rgba(39,245,140,.02)),var(--panel-2);border-left:1px solid rgba(39,245,140,.3)}
.versus h3{font-size:1.35rem;margin-bottom:6px}
.versus .sub{font-family:var(--mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:26px;display:block}
.versus .old .sub{color:#E0654F}.versus .gcm .sub{color:var(--green)}
.vs-item{display:flex;gap:13px;align-items:flex-start;padding:13px 0;border-bottom:1px solid var(--line);font-size:.92rem;color:var(--ink-2);transition:transform .25s,color .25s}
.vs-item:last-child{border-bottom:0}
.vs-item:hover{transform:translateX(6px);color:var(--ink)}
.vs-item .ic{flex:none;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:.7rem;margin-top:1px}
.old .vs-item .ic{background:rgba(224,101,79,.12);color:#E0654F;border:1px solid rgba(224,101,79,.3)}
.gcm .vs-item .ic{background:var(--green-dim);color:var(--green);border:1px solid rgba(39,245,140,.35)}
.vs-badge{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:64px;height:64px;border-radius:50%;background:var(--bg);border:1px solid var(--green);display:grid;place-items:center;font-family:var(--disp);font-weight:700;color:var(--green);z-index:2;box-shadow:0 0 40px var(--green-glow)}
@media(max-width:860px){.versus{grid-template-columns:1fr}.versus .col.gcm{border-left:0;border-top:1px solid rgba(39,245,140,.3)}.vs-badge{display:none}}

/* ============ WHY WE EXIST — old→new model, cinematic video (scroll-pinned) ============ */
.gcm-model-video-section{position:relative;width:100%;height:185vh;background:#050505;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.gcm-model-video-sticky{position:sticky;top:0;height:100vh;overflow:hidden;display:flex;align-items:center}
.gcm-model-bg-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0;background:#070707}
/* Light, left-weighted scrim — just enough to keep the type legible while the video stays clearly visible. */
.gcm-model-overlay{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(90deg,rgba(0,0,0,.6) 0%,rgba(0,0,0,.2) 46%,rgba(0,0,0,.12) 70%,rgba(0,0,0,.32) 100%),
            radial-gradient(70% 90% at 16% 60%,rgba(39,245,140,.08),transparent 58%),
            linear-gradient(180deg,rgba(5,5,5,.42),transparent 12%,transparent 86%,rgba(5,5,5,.5))}
.gcm-model-content{position:relative;z-index:2;width:min(1340px,92%);margin-left:clamp(20px,7vw,112px);
  transform:translateY(var(--textY,0px));will-change:transform}
.gcm-model-eyebrow{font-family:var(--mono);font-size:.74rem;font-weight:600;letter-spacing:.34em;text-transform:uppercase;color:var(--green);
  margin-bottom:clamp(18px,2.4vw,30px);opacity:var(--eyebrowOpacity,0)}
.gcm-model-title{font-family:var(--disp);font-weight:700;font-size:clamp(26px,3.4vw,50px);line-height:1.04;letter-spacing:-.02em;
  text-transform:uppercase;color:#fff;margin:0;display:flex;flex-direction:column;gap:.05em}
.gcm-title-line{display:block;will-change:opacity,transform,filter}
.gcm-old-line{opacity:var(--oldOpacity,1);filter:blur(var(--oldBlur,0px));transform:translateY(var(--oldY,0px))}
.gcm-to-line{opacity:var(--eyebrowOpacity,0);color:rgba(255,255,255,.94)}
.gcm-new-line{opacity:var(--newOpacity,1);transform:scale(var(--newScale,1));transform-origin:left center;color:var(--green);text-shadow:0 0 70px rgba(39,245,140,.3)}
.gcm-model-tagline{margin:clamp(26px,3vw,42px) 0 0;max-width:720px;color:rgba(245,251,247,.9);font-size:clamp(1rem,1.3vw,1.2rem);line-height:1.6;font-weight:500;
  opacity:var(--tagOpacity,0);transform:translateY(calc((1 - var(--tagOpacity,0)) * 18px));text-shadow:0 1px 24px rgba(0,0,0,.5)}

@media(prefers-reduced-motion:reduce){
  .gcm-model-eyebrow,.gcm-title-line,.gcm-model-tagline{opacity:1!important;filter:none!important;transform:none!important}
  .gcm-model-content{transform:none!important}
}
/* tablet / mobile — no pin, simple fade-in, full message visible */
@media(max-width:900px){
  .gcm-model-video-section{height:auto}
  .gcm-model-video-sticky{position:relative;height:auto;min-height:88svh;padding-block:clamp(80px,14vh,120px)}
  .gcm-model-content{width:auto;margin-inline:clamp(20px,6vw,46px);transform:none}
  .gcm-model-title{font-size:clamp(23px,6.2vw,40px)}
  .gcm-model-eyebrow,.gcm-title-line,.gcm-model-tagline{opacity:0;filter:none;transform:translateY(20px);
    transition:opacity .8s ease,transform .8s cubic-bezier(.16,1,.3,1)}
  #why-we-exist.in .gcm-model-eyebrow{opacity:1;transform:none;transition-delay:.05s}
  #why-we-exist.in .gcm-old-line{opacity:.82;transform:none;transition-delay:.18s}
  #why-we-exist.in .gcm-to-line{opacity:.94;transform:none;transition-delay:.3s}
  #why-we-exist.in .gcm-new-line{opacity:1;transform:none;transition-delay:.42s}
  #why-we-exist.in .gcm-model-tagline{opacity:1;transform:none;transition-delay:.56s}
}

/* ============ PER-SECTION CTA BANDS (all point to the lead form #contact) ============ */
.sec-cta{margin-top:clamp(44px,5vw,70px);display:flex;flex-direction:column;align-items:center;gap:clamp(16px,2vw,22px);text-align:center;
  opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s cubic-bezier(.16,1,.3,1)}
.sec-cta.in{opacity:1;transform:none}
.sec-cta-head{margin:0;font-family:var(--disp);font-weight:600;font-size:clamp(1.2rem,2.1vw,1.7rem);line-height:1.24;letter-spacing:-.01em;max-width:26ch}
.sec-cta.on-dark .sec-cta-head{color:var(--ink)}
.sec-cta.on-light .sec-cta-head{color:#14231c}
.sec-cta .sec-cta-btn{font-size:1rem}
/* CTA inside the old→new video section (reveals with the tagline) */
.gcm-model-cta{display:inline-flex;margin-top:clamp(26px,3vw,40px);opacity:var(--tagOpacity,0);transition:opacity .3s ease}
/* CTA overlaid on the architecture video (bottom-centre) */
.archx-cta{position:absolute;left:50%;bottom:clamp(24px,6vh,60px);transform:translateX(-50%) translateY(14px);z-index:4;
  box-shadow:0 12px 44px rgba(0,0,0,.55);opacity:0;transition:opacity .8s ease .25s,transform .8s cubic-bezier(.16,1,.3,1) .25s}
#ecosystem.in .archx-cta{opacity:1;transform:translateX(-50%)}
@media(max-width:900px){
  .gcm-model-cta{opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s cubic-bezier(.16,1,.3,1)}
  #why-we-exist.in .gcm-model-cta{opacity:1;transform:none;transition-delay:.7s}
  .archx-cta{bottom:14px;font-size:.82rem;padding:10px 18px}
}
@media(prefers-reduced-motion:reduce){
  .sec-cta,.gcm-model-cta,.archx-cta{opacity:1!important;transform:translateX(-50%)!important;transition:none!important}
  .sec-cta,.gcm-model-cta{transform:none!important}
}

/* ============ OWNED ============ */
.owned{display:grid;gap:26px}
.owned-card{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:0;background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:border-color .3s,box-shadow .3s}
.owned-card:hover{border-color:rgba(39,245,140,.3);box-shadow:0 0 60px -22px var(--green-glow)}
.owned-card .info{padding:clamp(26px,3.6vw,46px);display:flex;flex-direction:column;gap:16px}
.owned-card .badge{font-family:var(--mono);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:#03130A;background:var(--green);padding:5px 12px;border-radius:100px;align-self:flex-start;font-weight:600}
.owned-card .top{display:flex;align-items:center;gap:16px}
.owned-card .top .slot{width:68px;height:68px;min-height:68px;flex:none;padding:5px}
.owned-card .top .slot .s-tag{font-size:.44rem}.owned-card .top .slot .s-name{font-size:.55rem}
.owned-card p{color:var(--ink-2);font-size:.93rem}
.owned-card .proof{display:flex;gap:22px;flex-wrap:wrap;margin-top:4px}
.owned-card .proof div b{font-family:var(--disp);color:var(--green);font-size:1.2rem;display:block}
.owned-card .proof div span{font-family:var(--mono);font-size:.56rem;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-3)}
.owned-card .media{display:grid;grid-template-rows:1.4fr 1fr;gap:10px;padding:14px;background:rgba(0,0,0,.25)}
.owned-card .media .mini{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.owned-card .media .slot{min-height:0}
@media(max-width:900px){.owned-card{grid-template-columns:1fr}}

/* ============ VIDEOS ============ */
.vid-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:20px}
.vid-card .slot{border-radius:var(--r) var(--r) 0 0;border-bottom:0}
.vid-card .vinfo{background:var(--panel);border:1px solid var(--line);border-top:0;border-radius:0 0 var(--r) var(--r);padding:16px 18px}
.vid-card .vinfo h4{font-size:.98rem;font-weight:500;font-family:var(--body);line-height:1.4}
.vid-card .vinfo .meta{font-family:var(--mono);font-size:.62rem;color:var(--ink-3);margin-top:8px;display:flex;gap:14px}
.vid-card{transition:transform .3s}
.vid-card:hover{transform:translateY(-6px)}
.yt-btn{display:inline-flex;align-items:center;gap:10px}

/* ============ CREATIVE / BETTER CONTENT ============ */
.creative-wall{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:96px;gap:14px}
.creative-wall .slot{min-height:0}
.cw-a{grid-column:span 5;grid-row:span 3}
.cw-b{grid-column:span 3;grid-row:span 4}
.cw-c{grid-column:span 4;grid-row:span 2}
.cw-d{grid-column:span 4;grid-row:span 2}
.cw-e{grid-column:span 5;grid-row:span 2}
.cw-f{grid-column:span 4;grid-row:span 1}
.cw-g{grid-column:span 3;grid-row:span 2}
@media(max-width:860px){.creative-wall{grid-template-columns:repeat(2,1fr);grid-auto-rows:130px}.creative-wall>*{grid-column:span 1!important;grid-row:span 1!important}.cw-a,.cw-b{grid-column:span 2!important;grid-row:span 2!important}}
.metric-strip{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.metric-pill{font-family:var(--mono);font-size:.7rem;border:1px solid var(--line-2);border-radius:100px;padding:10px 18px;color:var(--ink-2)}
.metric-pill b{color:var(--green)}

/* ============ THE ARCHITECTURE — full-bleed cinematic video (self-contained) ============ */
/* The supplied video already carries the title + tagline + animation, so the section is just the
   video, shown full and clean. 16:9 band = the video fills perfectly (its baked-in type is never
   cropped); scrolling fades it in and drifts it subtly. */
#ecosystem.archx{position:relative;overflow:hidden;background:#050505;width:100%;aspect-ratio:16/9;max-height:100vh;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.archx-sr{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.archx-media{position:absolute;inset:0;z-index:0;overflow:hidden;background:#070707}
.archx-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;
  transform:translate3d(0,0,0) scale(1.08);opacity:0;transition:opacity 1.3s ease;will-change:transform,opacity}
#ecosystem.in .archx-video{opacity:1}
/* feather only the very top & bottom so the band melts into the dark sections above/below */
.archx-media::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,rgba(5,5,5,.5) 0%,transparent 13%,transparent 87%,rgba(5,5,5,.6) 100%)}
@media(prefers-reduced-motion:reduce){
  .archx-video{opacity:1!important;transform:translate3d(0,0,0) scale(1.08)!important;transition:none!important}
}

/* ============ FEATURED PROJECTS (hscroll) ============ */
.hscroll{display:flex;gap:20px;overflow-x:auto;padding:10px 4px 26px;scroll-snap-type:x mandatory;scrollbar-width:thin;scrollbar-color:var(--line-2) transparent}
.hscroll::-webkit-scrollbar{height:8px}
.hscroll::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:8px}
.hscroll>*{flex:0 0 min(420px,86vw);scroll-snap-align:start}
.proj-card .slot{border-radius:var(--r) var(--r) 0 0;border-bottom:0}
.proj-card .pinfo{background:var(--panel);border:1px solid var(--line);border-top:0;border-radius:0 0 var(--r) var(--r);padding:20px}
.proj-card .ptype{font-family:var(--mono);font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;color:var(--green)}
.proj-card h4{margin:8px 0 6px;font-size:1.1rem}
.proj-card p{color:var(--ink-2);font-size:.86rem}

/* ============ WEBSITES ============ */
.web-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:26px}
.web-card{background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:var(--r-lg);padding:22px;transition:transform .3s,border-color .3s}
.web-card:hover{transform:translateY(-7px);border-color:rgba(39,245,140,.3)}
.browser{border:1px solid var(--line-2);border-radius:12px;overflow:hidden;background:#0A1014;position:relative}
.browser .bbar{display:flex;align-items:center;gap:6px;padding:9px 12px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.02)}
.browser .bbar i{width:8px;height:8px;border-radius:50%;background:var(--ink-3);opacity:.5}
.browser .bbar i:first-child{background:var(--green);opacity:1}
.browser .url{font-family:var(--mono);font-size:.58rem;color:var(--ink-3);background:rgba(255,255,255,.03);border-radius:5px;padding:3px 9px;margin-left:6px}
.browser .slot{border:0;border-radius:0;min-height:170px}
.phone-pop{position:absolute;right:12px;bottom:-18px;width:78px;border:1px solid var(--line-2);border-radius:13px;background:#0A1014;padding:5px;box-shadow:0 14px 34px rgba(0,0,0,.6);z-index:2}
.phone-pop .slot{border-radius:9px;min-height:120px;padding:5px}
.phone-pop .s-tag{font-size:.38rem}
.web-card .wmeta{display:flex;align-items:center;gap:12px;margin-top:30px}
.web-card .wmeta .slot{width:46px;height:46px;min-height:46px;flex:none;padding:3px}
.web-card .wmeta .slot .s-tag{font-size:.4rem}
.web-card .wmeta h4{font-size:1rem}
.web-card .wacts{display:flex;gap:9px;margin-top:16px;flex-wrap:wrap}

/* ============ CASE STUDIES ============ */
.cs-row{display:grid;grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);gap:clamp(24px,4vw,56px);align-items:center;padding:clamp(36px,5vw,64px) 0;border-top:1px solid var(--line)}
.cs-row:nth-child(even){direction:rtl}
.cs-row:nth-child(even)>*{direction:ltr}
.cs-row .num{font-family:var(--mono);font-size:.66rem;color:var(--ink-3);letter-spacing:.16em}
.cs-row .ind{font-family:var(--mono);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--green);background:var(--green-dim);border:1px solid rgba(39,245,140,.25);padding:4px 11px;border-radius:100px;display:inline-block;margin:14px 0 12px;margin-left:10px}
.cs-row h3{font-size:clamp(1.45rem,2.6vw,2.1rem);margin-bottom:12px}
.cs-row p{color:var(--ink-2);font-size:.95rem;max-width:54ch}
.cs-stats{display:flex;gap:26px;margin:22px 0;flex-wrap:wrap}
.cs-stats div b{font-family:var(--disp);font-size:1.55rem;color:var(--green);letter-spacing:-.02em;display:block}
.cs-stats div span{font-family:var(--mono);font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3)}
.cs-media{display:grid;grid-template-columns:1.5fr 1fr;grid-template-rows:1fr 1fr;gap:12px;min-height:330px}
.cs-media .slot{min-height:0}
.cs-media .main{grid-row:span 2}
@media(max-width:880px){.cs-row{grid-template-columns:1fr}.cs-media{min-height:280px}}

/* ============ COMMAND CENTER ============ */
.command{background:radial-gradient(1100px 540px at 50% -10%,rgba(39,245,140,.09),transparent),var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cmd-room{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.cmd-panel{background:var(--glass);backdrop-filter:blur(12px);border:1px solid var(--line-2);border-radius:16px;padding:18px;position:relative;overflow:hidden}
.cmd-panel::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 96%,rgba(39,245,140,.16) 100%);background-size:100% 26px;pointer-events:none;opacity:.4}
.cmd-panel .cp-h{font-family:var(--mono);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--green);display:flex;align-items:center;gap:8px;margin-bottom:13px}
.cmd-panel .cp-h::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 9px var(--green);animation:blink 2.2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.cmd-a{grid-column:span 4}.cmd-b{grid-column:span 4}.cmd-c{grid-column:span 4}
.cmd-d{grid-column:span 7}.cmd-e{grid-column:span 5}
@media(max-width:900px){.cmd-room>*{grid-column:span 12!important}}
.tools{display:flex;gap:9px;flex-wrap:wrap}
.tool{font-family:var(--mono);font-size:.68rem;border:1px solid var(--line-2);background:rgba(255,255,255,.02);border-radius:100px;padding:8px 15px;display:flex;align-items:center;gap:8px;color:var(--ink-2);transition:all .25s}
.tool:hover{border-color:var(--green);color:var(--green);background:var(--green-dim)}
.tool i{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green)}
.flow{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-family:var(--mono);font-size:.66rem}
.flow .fstep{border:1px solid var(--line-2);border-radius:10px;padding:9px 13px;background:rgba(255,255,255,.02);color:var(--ink-2)}
.flow .farr{color:var(--green)}
.tickline{font-family:var(--mono);font-size:.66rem;color:var(--ink-2);display:flex;flex-direction:column;gap:9px}
.tickline span b{color:var(--green)}
.tickline span{display:flex;gap:9px;align-items:baseline}
.tickline .t{color:var(--ink-3);font-size:.58rem;flex:none}

/* ============ SEO ============ */
.seo-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:24px}
@media(max-width:900px){.seo-grid{grid-template-columns:1fr}}
.map-panel{position:relative;border:1px solid var(--line-2);border-radius:var(--r-lg);background:
  radial-gradient(circle at 30% 40%,rgba(39,245,140,.08),transparent 40%),
  linear-gradient(rgba(39,245,140,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(39,245,140,.05) 1px,transparent 1px),var(--panel);
  background-size:auto,42px 42px,42px 42px,auto;min-height:430px;overflow:hidden}
.pin{position:absolute;left:var(--x);top:var(--y);transform:translate(-50%,-50%)}
.pin .ring{position:absolute;inset:-14px;border:1px solid var(--green);border-radius:50%;animation:ping 2.6s ease-out infinite;animation-delay:var(--d,0s)}
@keyframes ping{0%{transform:scale(.4);opacity:1}100%{transform:scale(1.7);opacity:0}}
.pin .dot{width:13px;height:13px;border-radius:50%;background:var(--green);box-shadow:0 0 14px var(--green)}
.pin .lbl{position:absolute;top:13px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:.56rem;white-space:nowrap;color:var(--ink-2);background:rgba(4,8,10,.8);padding:3px 8px;border-radius:6px;border:1px solid var(--line)}
.seo-side{display:grid;gap:14px}
.seo-side .slot{min-height:120px}
.rank-row{display:flex;align-items:center;gap:13px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:13px 16px;font-size:.85rem}
.rank-row .pos{font-family:var(--disp);font-weight:700;color:var(--green);width:42px;font-size:1.05rem}
.rank-row .kw{color:var(--ink-2);flex:1}
.rank-row .up{font-family:var(--mono);font-size:.62rem;color:var(--green)}

/* ============ SOCIAL ============ */
.phones{display:flex;gap:26px;justify-content:center;flex-wrap:wrap;perspective:1000px}
.phone{width:228px;border:1px solid var(--line-2);border-radius:30px;background:#0A1014;padding:10px;box-shadow:0 30px 60px -20px rgba(0,0,0,.75);transition:transform .4s}
.phone .notch{width:80px;height:18px;background:#04070A;border-radius:0 0 13px 13px;margin:0 auto 8px}
.phone .slot{border-radius:20px}
.phone:nth-child(1){transform:rotate(-5deg) translateY(16px)}
.phone:nth-child(3){transform:rotate(5deg) translateY(16px)}
.phone:hover{transform:rotate(0) translateY(-8px) scale(1.03);z-index:2}
.social-tags{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:38px}

/* ============ REPORTS ============ */
.rep-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.rep-a{grid-column:span 7}.rep-b{grid-column:span 5}.rep-c{grid-column:span 4}.rep-d{grid-column:span 4}.rep-e{grid-column:span 4}
@media(max-width:880px){.rep-grid>*{grid-column:span 12!important}}
.rep-grid .slot{min-height:190px}

/* ============ GROWTH STACK ============ */
.stack{border:1px solid var(--line-2);border-radius:var(--r-lg);overflow:hidden}
.stack-row{display:grid;grid-template-columns:64px 1fr auto;align-items:center;gap:18px;padding:22px clamp(18px,3vw,34px);border-bottom:1px solid var(--line);background:transparent;width:100%;text-align:left;border-left:0;border-right:0;border-top:0;color:var(--ink);transition:background .3s;position:relative;cursor:pointer}
.stack-row:last-of-type{border-bottom:0}
.stack-row:hover,.stack-row.open{background:linear-gradient(90deg,var(--green-dim),transparent 60%)}
.stack-row .idx{font-family:var(--mono);font-size:.66rem;color:var(--ink-3)}
.stack-row h3{font-size:clamp(1.1rem,2.4vw,1.7rem);transition:color .3s,transform .3s}
.stack-row:hover h3,.stack-row.open h3{color:var(--green);transform:translateX(8px)}
.stack-row .plus{font-family:var(--mono);color:var(--green);font-size:1.2rem;transition:transform .3s}
.stack-row.open .plus{transform:rotate(45deg)}
.stack-panel{max-height:0;overflow:hidden;transition:max-height .5s cubic-bezier(.2,.8,.2,1);background:rgba(0,0,0,.22);border-bottom:1px solid var(--line)}
.stack-panel.open{max-height:430px}
.stack-panel .sp-in{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:24px;padding:26px clamp(18px,3vw,34px) 32px}
.stack-panel p{color:var(--ink-2);font-size:.9rem}
.stack-panel .ex{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.stack-panel .ex .slot{min-height:100px}
@media(max-width:780px){.stack-panel .sp-in{grid-template-columns:1fr}.stack-panel.open{max-height:640px}}

/* ============ STEPS ============ */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;counter-reset:step}
@media(max-width:1080px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.steps{grid-template-columns:1fr}}
.step{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:22px;position:relative;transition:transform .3s,border-color .3s}
.step:hover{transform:translateY(-6px);border-color:rgba(39,245,140,.35)}
.step .n{font-family:var(--mono);font-size:.62rem;color:var(--green);letter-spacing:.14em}
.step h4{font-size:1rem;margin:10px 0 7px}
.step p{font-size:.8rem;color:var(--ink-2)}
.step::after{content:"";position:absolute;left:22px;right:22px;top:0;height:2px;background:linear-gradient(90deg,var(--green),transparent);opacity:0;transition:opacity .3s}
.step:hover::after{opacity:1}

/* ============ TEAM ============ */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px}
.team-card{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);transition:transform .35s,border-color .35s}
.team-card:hover{transform:translateY(-8px);border-color:rgba(39,245,140,.35)}
.team-card .slot{border:0;border-radius:0;min-height:300px}
.team-card .tinfo{position:absolute;inset:auto 0 0 0;padding:42px 18px 16px;background:linear-gradient(transparent,rgba(3,7,9,.95) 55%)}
.team-card h4{font-size:1.05rem}
.team-card .role{font-family:var(--mono);font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;color:var(--green)}

/* ============ TEAM VIDEO COLLAGE — full-bleed cinematic storyboard above the team cards ============ */
.team-video-collage{width:100vw;margin-left:calc(50% - 50vw);margin-bottom:clamp(40px,5vw,68px);
  opacity:0;transform:translateY(20px);transition:opacity 1s ease,transform 1s cubic-bezier(.16,1,.3,1)}
.team-video-collage.in{opacity:1;transform:none}
.team-video-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0;line-height:0;
  border-radius:clamp(12px,1.4vw,22px);overflow:hidden}
.team-video-tile{position:relative;aspect-ratio:9/16;overflow:hidden;background:#0a0a0a}
.team-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block}
@media(max-width:1000px){ .team-video-grid{grid-template-columns:repeat(3,1fr)} }
@media(max-width:560px){ .team-video-grid{grid-template-columns:repeat(2,1fr)} }
@media(prefers-reduced-motion:reduce){ .team-video-collage{opacity:1 !important;transform:none !important} }

/* ============ REVIEWS ============ */
.rev-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:20px}
.rev-card{background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;transition:transform .3s,border-color .3s;display:flex;flex-direction:column;gap:16px}
.rev-card:hover{transform:translateY(-6px);border-color:rgba(39,245,140,.3)}
.rev-card .stars{color:var(--green);letter-spacing:4px}
.rev-card blockquote{color:var(--ink-2);font-size:.95rem;font-style:italic}
.rev-card .who{display:flex;align-items:center;gap:12px}
.rev-card .who .slot{width:48px;height:48px;min-height:48px;flex:none;padding:3px}
.rev-card .who .slot .s-tag{font-size:.4rem}
.rev-card .who b{font-family:var(--disp);font-size:.9rem;display:block}
.rev-card .who span{font-family:var(--mono);font-size:.58rem;color:var(--ink-3);text-transform:uppercase;letter-spacing:.12em}
.rev-card .slot.sm{min-height:70px}

/* ============ FINAL CTA ============ */
.final{background:radial-gradient(900px 500px at 50% 0,rgba(39,245,140,.12),transparent),var(--bg-2);border-top:1px solid var(--line)}
.final-grid{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:clamp(30px,5vw,70px);align-items:start}
@media(max-width:920px){.final-grid{grid-template-columns:1fr}}
.cmd-form{background:var(--glass);backdrop-filter:blur(16px);border:1px solid var(--line-2);border-radius:24px;overflow:hidden;box-shadow:0 40px 90px -30px rgba(0,0,0,.8)}
.cmd-form .cf-bar{display:flex;align-items:center;gap:9px;padding:14px 20px;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--green)}
.cmd-form .cf-bar i{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 9px var(--green);animation:blink 2s infinite}
.cmd-form form{padding:24px;display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:7px}
.field.full{grid-column:1/-1}
.field label{font-family:var(--mono);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3)}
.field input,.field select,.field textarea{background:rgba(255,255,255,.03);border:1px solid var(--line-2);border-radius:11px;padding:13px 15px;color:var(--ink);font-family:var(--body);font-size:.92rem;transition:border-color .25s,box-shadow .25s;width:100%}
.field textarea{min-height:104px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(39,245,140,.14)}
.field select option{background:#0A1318}
.cmd-form .btn{grid-column:1/-1;justify-content:center}
.cmd-form .note{grid-column:1/-1;font-family:var(--mono);font-size:.6rem;color:var(--ink-3);text-align:center;letter-spacing:.08em}
@media(max-width:560px){.cmd-form form{grid-template-columns:1fr}}

/* ============ FOOTER ============ */
footer{border-top:1px solid var(--line);padding:50px 0 36px;background:var(--bg-2)}
.f-in{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:22px}
footer .fine{font-family:var(--mono);font-size:.62rem;color:var(--ink-3);letter-spacing:.06em}
footer nav{display:flex;gap:18px;flex-wrap:wrap}
footer nav a{font-size:.8rem;color:var(--ink-2)}
footer nav a:hover{color:var(--green)}


/* ============ REAL ASSET IMAGES ============ */
.imgbox{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--line-2);background:#0A1014;display:block;min-height:90px}
.imgbox img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
.imgbox:hover img{transform:scale(1.04)}
.imgbox.contain img{object-fit:contain;padding:12px;background:#fff}
.imgbox.containdark img{object-fit:contain;padding:12px}
.imgbox .cap{position:absolute;left:0;right:0;bottom:0;padding:22px 12px 8px;background:linear-gradient(transparent,rgba(3,7,9,.92));font-family:var(--mono);font-size:.56rem;letter-spacing:.12em;text-transform:uppercase;color:var(--green);z-index:2}
.imgbox.imgfail img{display:none}
.imgbox.imgfail{border-style:dashed;border-color:rgba(39,245,140,.3)}
.imgbox.imgfail::after{content:"ASSET OFFLINE — UPLOAD MANUALLY";position:absolute;inset:0;display:grid;place-items:center;font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;color:var(--ink-3);text-align:center;padding:10px}
.video-embed{position:relative;aspect-ratio:16/9;border-radius:14px;overflow:hidden;border:1px solid var(--line-2);background:#000;box-shadow:0 24px 60px -20px rgba(0,0,0,.7)}
.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.vid-feature{display:grid;grid-template-columns:1.5fr 1fr;gap:20px;align-items:stretch}
@media(max-width:900px){.vid-feature{grid-template-columns:1fr}}
.vid-side{display:flex;flex-direction:column;gap:14px}
.vid-side .vthumb{display:grid;grid-template-columns:120px 1fr;gap:14px;align-items:center;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:12px;cursor:pointer;transition:border-color .25s,transform .25s;text-align:left;color:var(--ink)}
.vid-side .vthumb:hover{border-color:var(--green);transform:translateX(6px)}
.vid-side .vthumb .imgbox,.vid-side .vthumb .mini-play{aspect-ratio:16/9;border-radius:9px;min-height:0}
.vid-side .vthumb .mini-play{display:grid;place-items:center;background:radial-gradient(circle,rgba(39,245,140,.14),rgba(5,10,8,.9));border:1px solid var(--line-2)}
.vid-side .vthumb h4{font-size:.9rem;margin-bottom:4px}
.vid-side .vthumb span{font-family:var(--mono);font-size:.6rem;color:var(--ink-3);letter-spacing:.1em;text-transform:uppercase}
.badge-strip{display:flex;align-items:center;gap:26px;flex-wrap:wrap;justify-content:center;margin-top:40px;padding:22px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--panel)}
.badge-strip img{height:34px;width:auto;filter:grayscale(.2)}
.badge-strip .stars-img{height:26px}
.badge-strip b{font-family:var(--disp);color:var(--ink)}
.team-card .imgbox{border:0;border-radius:0;min-height:300px;aspect-ratio:4/5}
.team-card .imgbox img{filter:saturate(.92)}
.logo-chip .imgbox{border:0;border-radius:13px;height:100%;min-height:100%}


/* ============ CASE STUDY LIGHTBOX ============ */
.lightbox{width:min(1180px,100%);max-height:94svh;display:flex;flex-direction:column;background:linear-gradient(180deg,#0C161C,#070D11);border:1px solid var(--line-2);border-radius:24px;box-shadow:0 60px 140px -30px rgba(0,0,0,.92);overflow:hidden;transform:translateY(26px) scale(.97);transition:transform .35s cubic-bezier(.2,.8,.2,1)}
.modal-bg.open .lightbox{transform:none}
.lb-head{display:flex;align-items:center;gap:16px;padding:18px 24px;border-bottom:1px solid var(--line);flex:none}
.lb-head .lb-logo{width:54px;height:54px;flex:none;border-radius:12px;overflow:hidden}
.lb-head .lb-logo .imgbox{height:100%;min-height:100%;border-radius:12px}
.lb-head h3{font-size:1.2rem;line-height:1.1}
.lb-head .ind{font-family:var(--mono);font-size:.6rem;color:var(--green);letter-spacing:.14em;text-transform:uppercase}
.lb-head .lb-sum{display:none}
.lb-rating{font-family:var(--mono);font-size:.66rem;color:var(--green);border:1px solid rgba(39,245,140,.3);background:var(--green-dim);padding:6px 13px;border-radius:100px;white-space:nowrap}
.lb-actions{margin-left:auto;display:flex;align-items:center;gap:10px}
.lb-summary{padding:14px 24px 0;color:var(--ink-2);font-size:.92rem;flex:none}
.lb-filters{display:flex;gap:8px;flex-wrap:wrap;padding:14px 24px;flex:none}
.lb-stage-wrap{position:relative;padding:0 24px;flex:none}
.lb-stage{position:relative;aspect-ratio:16/9;max-height:52svh;width:100%;background:#04070A;border:1px solid var(--line-2);border-radius:16px;overflow:hidden;display:grid;place-items:center}
.lb-stage iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.lb-stage img{width:100%;height:100%;object-fit:contain;background:#06090C}
.lb-stage .lb-empty{color:var(--ink-3);font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-align:center;padding:20px}
.lb-cap{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:10px 26px 0;flex:none}
.lb-cap .t{font-size:.88rem;color:var(--ink-2)}
.lb-cap .n{font-family:var(--mono);font-size:.62rem;color:var(--ink-3);letter-spacing:.12em;white-space:nowrap}
.lb-arrow{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;background:rgba(6,12,10,.72);backdrop-filter:blur(8px);border:1px solid var(--line-2);color:var(--ink);font-size:1.15rem;display:grid;place-items:center;z-index:4;transition:all .25s}
.lb-arrow:hover{background:var(--green-dim);border-color:var(--green);color:var(--green);box-shadow:0 0 24px var(--green-glow)}
.lb-arrow.prev{left:36px}.lb-arrow.next{right:36px}
.lb-arrow:disabled{opacity:.25;pointer-events:none}
.lb-thumbs{display:flex;gap:10px;overflow-x:auto;padding:16px 24px 22px;flex:none;scrollbar-width:thin;scrollbar-color:var(--line-2) transparent}
.lb-thumbs::-webkit-scrollbar{height:7px}
.lb-thumbs::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:7px}
.lb-thumb{position:relative;flex:0 0 118px;aspect-ratio:16/10;border-radius:10px;overflow:hidden;border:2px solid transparent;background:#0A1014;cursor:pointer;padding:0;transition:border-color .25s,transform .25s;outline-offset:2px}
.lb-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.lb-thumb:hover{transform:translateY(-3px)}
.lb-thumb.active{border-color:var(--green);box-shadow:0 0 18px rgba(39,245,140,.3)}
.lb-thumb .tb-play{position:absolute;inset:0;display:grid;place-items:center;background:rgba(3,8,6,.35)}
.lb-thumb .tb-play span{width:28px;height:28px;border-radius:50%;background:rgba(39,245,140,.2);border:1px solid var(--green);display:grid;place-items:center}
.lb-thumb .tb-tag{position:absolute;left:0;right:0;bottom:0;font-family:var(--mono);font-size:.46rem;letter-spacing:.1em;text-transform:uppercase;color:var(--green);background:linear-gradient(transparent,rgba(3,7,9,.95));padding:10px 5px 3px;text-align:center}
.lb-thumb .tb-fallback{position:absolute;inset:0;display:grid;place-items:center;color:var(--ink-3);font-size:1.1rem}
@media(max-width:720px){
  .lb-head{padding:14px 16px;flex-wrap:wrap}
  .lb-summary,.lb-filters{padding-inline:16px}
  .lb-stage-wrap{padding:0 16px}
  .lb-arrow.prev{left:24px}.lb-arrow.next{right:24px}
  .lb-arrow{width:38px;height:38px}
  .lb-thumbs{padding:12px 16px 16px}
  .lb-thumb{flex-basis:96px}
  .lb-rating{display:none}
}
/* hover preview hint on case cards */
.succ-card{cursor:pointer}
.succ-card .cover::after{content:"⤢ OPEN GALLERY";position:absolute;inset:0;display:grid;place-items:center;font-family:var(--mono);font-size:.62rem;letter-spacing:.2em;color:var(--green);background:rgba(4,9,7,.55);backdrop-filter:blur(2px);opacity:0;transition:opacity .3s;z-index:3}
.succ-card:hover .cover::after{opacity:1}


/* owned-card media: fixed proportions so large/square photos can't stretch the card */
.owned-card .media{grid-template-rows:clamp(220px,24vw,330px) 112px}
.owned-card .media .imgbox{height:100%;min-height:0;overflow:hidden}
.owned-card .media .imgbox img{width:100%;height:100%;object-fit:cover}
.owned-card .media .slot{height:100%}
/* portrait screenshots: show the whole image instead of crop-zooming */
.imgbox.contain-shot img{object-fit:contain!important;background:#0A1014;padding:6px}


/* YouTube facade for file:// viewing (embeds require a hosted origin) */
.yt-facade{position:relative;display:block;width:100%;height:100%;background:#000}
.yt-facade img{width:100%;height:100%;object-fit:cover;opacity:.85}
.yt-facade .yf-play{position:absolute;inset:0;display:grid;place-items:center;background:rgba(3,8,6,.35);transition:background .25s}
.yt-facade:hover .yf-play{background:rgba(3,8,6,.15)}
.yt-facade .yf-play span{width:64px;height:64px;border-radius:50%;background:rgba(39,245,140,.18);border:1px solid var(--green);display:grid;place-items:center;box-shadow:0 0 34px var(--green-glow)}
.yt-facade .yf-note{position:absolute;left:0;right:0;bottom:0;padding:24px 14px 10px;background:linear-gradient(transparent,rgba(3,7,9,.95));font-family:var(--mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--green);text-align:center}


/* ============ READABILITY OVERRIDES — bigger, bolder, brighter text ============ */
body{font-size:17px}
.lede{color:var(--ink);font-size:clamp(1.08rem,1.5vw,1.3rem);font-weight:500;line-height:1.65}
.eyebrow{font-size:.8rem;font-weight:600}
.succ-card p{font-size:.98rem;font-weight:500;color:var(--ink-2)}
.succ-card .tag{font-size:.68rem;font-weight:600}
.succ-card .stat{font-size:.76rem;font-weight:600}
.cs-row p{font-size:1.05rem;font-weight:500;color:var(--ink-2)}
.cs-row .num{font-size:.74rem;color:var(--ink-3)}
.cs-row .ind{font-size:.68rem;font-weight:600}
.cs-stats div span{font-size:.66rem;font-weight:600}
.vs-item{font-size:1rem;font-weight:500;color:var(--ink-2)}
.versus .sub{font-size:.7rem;font-weight:600}
.owned-card p{font-size:1rem;font-weight:500}
.owned-card .proof div span{font-size:.64rem;font-weight:600}
.proj-card p{font-size:.94rem;font-weight:500}
.proj-card .ptype{font-size:.66rem;font-weight:600}
.vid-card .vinfo h4{font-size:1.05rem;font-weight:600}
.vid-card .vinfo .meta{font-size:.7rem}
.vid-side .vthumb span span,.vid-side .vthumb > span > span{font-size:.68rem}
.step p{font-size:.9rem;font-weight:500}
.step .n{font-size:.7rem;font-weight:600}
.stack-panel p{font-size:1rem;font-weight:500}
.stack-row .idx{font-size:.74rem}
.rev-card blockquote{font-size:1.05rem;color:var(--ink);font-weight:500}
.rev-card .who span{font-size:.66rem}
.team-card .role{font-size:.68rem;font-weight:600}
.rank-row{font-size:.95rem;font-weight:500}
.rank-row .kw{color:var(--ink)}
.rank-row .up{font-size:.7rem;font-weight:600}
.metric-pill{font-size:.8rem;font-weight:500;color:var(--ink-2);border-color:rgba(120,255,190,.28)}
.tool{font-size:.78rem;font-weight:500;color:var(--ink)}
.flow{font-size:.74rem}
.flow .fstep{color:var(--ink);font-weight:500}
.tickline{font-size:.76rem;color:var(--ink-2)}
.tickline .t{font-size:.66rem}
.cmd-panel .cp-h{font-size:.68rem;font-weight:600}
.slot .s-tag{font-size:.68rem;font-weight:600;opacity:1}
.slot .s-name{font-size:.92rem;color:var(--ink)}
.slot.sm .s-tag{font-size:.6rem}
.imgbox .cap{font-size:.64rem;font-weight:600;padding:26px 12px 9px}
.hero-meta div span{font-size:.7rem;font-weight:600;color:var(--ink-3)}
.hero-meta div b{font-size:1.65rem}
.f-panel .ph{font-size:.66rem;font-weight:600;color:var(--ink-2)}
.fp-dash .kpis span{font-size:.62rem;color:var(--ink-3)}
.fp-review .rv-body{font-size:.85rem;color:var(--ink)}
.logowall .label{font-size:.74rem;color:var(--ink-2)}
.logo small{color:var(--ink-3)}
.m-tab{font-size:.74rem;font-weight:600;color:var(--ink-2)}
.lb-summary{font-size:1.02rem;color:var(--ink);font-weight:500}
.lb-cap .t{font-size:.95rem;color:var(--ink);font-weight:500}
.lb-cap .n{font-size:.7rem}
.lb-head .ind{font-size:.66rem;font-weight:600}
.lb-rating{font-size:.74rem;font-weight:600}
.lb-thumb .tb-tag{font-size:.52rem;font-weight:600}
.m-story{color:var(--ink-2);font-size:1rem;font-weight:500}
.m-results .res span{font-size:.66rem;font-weight:600}
.field label{font-size:.68rem;font-weight:600;color:var(--ink-2)}
.field input,.field select,.field textarea{font-size:1rem}
.cmd-form .note{font-size:.66rem;color:var(--ink-3)}
.cmd-form .cf-bar{font-size:.66rem;font-weight:600}
footer .fine{font-size:.68rem;color:var(--ink-3)}
footer nav a{font-size:.88rem;color:var(--ink-2)}
.yt-facade .yf-note{font-size:.66rem;font-weight:600}
.lb-stage .lb-empty{font-size:.76rem;color:var(--ink-2)}
.eco-node{font-size:.9rem}
.seo-side .slot .s-name,.rep-grid .slot .s-name{font-size:.92rem}

/* ============ REVEAL ============ */
.rv{opacity:0;transform:translateY(34px);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1)}
.rv.in{opacity:1;transform:none}
.rv.d1{transition-delay:.08s}.rv.d2{transition-delay:.16s}.rv.d3{transition-delay:.24s}


/* ============================================================
   GCM HOMEPAGE UPGRADES
   ============================================================ */

/* ---- Section 3 · Owned-company logo chips ---- */
.owned-card .top .logo-box{width:80px;height:80px;flex:none;border-radius:16px;overflow:hidden;border:1px solid var(--line-2);background:#0B141A;box-shadow:0 10px 26px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.04);display:grid;place-items:center}
.owned-card .top .logo-box .imgbox{width:100%;height:100%;min-height:100%;border:0;border-radius:0;background:transparent;overflow:hidden}
.owned-card .top .logo-box .imgbox.contain img{object-fit:contain;padding:8px;background:#fff}
.owned-card .top .logo-box .imgbox.containdark img{object-fit:contain;padding:8px;background:transparent}
.owned-card .media .imgbox video{width:100%;height:100%;object-fit:cover;display:block}
/* single full-bleed cover (mini 3-box row removed) */
.owned-card .media{grid-template-rows:1fr;padding:0;background:transparent;gap:0}
.owned-card .media .imgbox{border:0;border-radius:0;height:100%;min-height:220px}
.owned-card .info{text-align:left}

/* ---- Owned companies · 3-up compact row (all 3 visible in one screen) ---- */
#owned{padding-top:clamp(40px,4.6vw,64px);padding-bottom:clamp(40px,4.6vw,64px)}
#owned .sec-head{margin-bottom:clamp(16px,2vw,28px)}
#owned .sec-head h2{font-size:clamp(1.55rem,3.3vw,2.7rem)}
#owned .sec-head .lede{font-size:clamp(.95rem,1.2vw,1.08rem)}
.owned{grid-template-columns:repeat(3,1fr);gap:clamp(16px,1.5vw,22px);align-items:stretch}
.owned-card{display:flex;flex-direction:column;grid-template-columns:none}
.owned-card .media{order:-1;display:block;height:clamp(126px,11vw,168px);min-height:0;aspect-ratio:auto}
.owned-card .media .imgbox{height:100%;min-height:0}
.owned-card .info{padding:clamp(14px,1.2vw,18px);gap:9px;flex:1}
.owned-card .proof{display:none}
.owned-card .badge{font-size:.54rem;padding:4px 9px;align-self:flex-start}
.owned-card .top{gap:11px}
.owned-card .top .logo-box{width:46px;height:46px;border-radius:12px}
.owned-card .top h3{font-size:clamp(1.02rem,1.35vw,1.22rem)}
.owned-card p{font-size:.86rem;line-height:1.48;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;margin:0}
.owned-card .info > *:last-child{margin-top:auto}
.owned-card .info > div:last-child{display:flex;gap:9px;flex-wrap:wrap;align-items:center}
.owned-card .link-btn{font-size:.8rem}
.owned-card .btn-sm{padding:7px 12px;font-size:.7rem}
@media(max-width:900px){
  #owned{padding-top:clamp(60px,9vw,120px);padding-bottom:clamp(60px,9vw,120px)}
  #owned .sec-head h2{font-size:clamp(2rem,4.6vw,3.9rem)}
  .owned{grid-template-columns:1fr;gap:20px}
  .owned-card .media{height:auto;aspect-ratio:16/9}
  .owned-card p{-webkit-line-clamp:unset}
}

/* ---- Section 1 · Cinematic video-background hero ---- */
.hero.vhero{display:block;min-height:0;padding:0;overflow:visible}
.vhero-pin{position:relative;height:180vh}
.vhero-stage{position:sticky;top:0;height:100svh;display:flex;align-items:flex-start;overflow:hidden;isolation:isolate;background:#04070A}
.vhero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;background:#04070A}
.vhero-scrim{position:absolute;inset:0;z-index:1;pointer-events:none;transition:opacity .9s cubic-bezier(.4,0,.2,1);
  background:
    linear-gradient(90deg, rgba(4,7,10,.93) 0%, rgba(4,7,10,.72) 30%, rgba(4,7,10,.34) 58%, rgba(4,7,10,.12) 78%, rgba(4,7,10,.55) 100%),
    linear-gradient(0deg, rgba(4,7,10,.9) 0%, rgba(4,7,10,.28) 26%, transparent 50%),
    linear-gradient(180deg, rgba(4,7,10,.78) 0%, rgba(4,7,10,.1) 16%, transparent 30%)}
.vhero-inner{position:relative;z-index:2;width:100%}
.vhero-copy{max-width:760px;padding-top:clamp(165px,20vh,200px);transition:opacity .9s cubic-bezier(.4,0,.2,1),transform .9s cubic-bezier(.4,0,.2,1),filter .9s ease;will-change:opacity,transform}
.vhero-copy .eyebrow{margin-bottom:22px}
.vhero-copy h1{text-shadow:0 2px 44px rgba(0,0,0,.6)}
.vhero-copy .lede{margin:26px 0 36px;max-width:60ch;text-shadow:0 1px 22px rgba(0,0,0,.75)}
.vhero-copy .hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.vhero-copy.is-faded{opacity:0;transform:translateY(-16px);filter:blur(7px);pointer-events:none}
.vhero-sound{position:absolute;right:clamp(16px,3vw,46px);bottom:clamp(18px,3.5vw,46px);z-index:5;display:inline-flex;align-items:center;gap:8px;height:42px;padding:0 16px;border-radius:999px;cursor:pointer;color:var(--ink);font-family:var(--mono);font-size:.66rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;background:rgba(10,14,18,.5);border:1px solid rgba(245,251,247,.22);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:background .25s,border-color .25s,transform .25s}
.vhero-sound:hover{background:rgba(39,245,140,.16);border-color:rgba(39,245,140,.5);transform:translateY(-1px)}
.vhero-sound.is-on{background:rgba(39,245,140,.18);border-color:rgba(39,245,140,.55)}
.vhero-sound svg{display:block}
.vhero-sound .vhero-sound-on{display:none}
.vhero-sound.is-on .vhero-sound-off{display:none}
.vhero-sound.is-on .vhero-sound-on{display:block}
.vhero-cue{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:7px;pointer-events:none;font-family:var(--mono);font-size:.6rem;font-weight:600;letter-spacing:.32em;color:rgba(245,251,247,.55)}
.vhero-cue i{width:1px;height:30px;transform-origin:top;background:linear-gradient(rgba(39,245,140,.9),transparent);animation:vheroCue 1.8s ease-in-out infinite}
@keyframes vheroCue{0%,100%{transform:scaleY(.35);opacity:.35}50%{transform:scaleY(1);opacity:1}}
.vhero-stage.is-clean .vhero-cue{opacity:0;transition:opacity .6s ease}
.vhero-proof{display:flex;flex-wrap:wrap;gap:clamp(22px,4vw,46px);justify-content:center;text-align:center;padding:clamp(30px,4vw,44px) 24px;border-bottom:1px solid var(--line);background:var(--bg-2);position:relative;z-index:2}
.vhero-proof div b{font-family:var(--disp);font-size:clamp(1.6rem,3vw,2rem);color:var(--ink);display:block;letter-spacing:-.02em}
.vhero-proof div span{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);font-weight:600}
@media(max-width:1100px){.vhero-copy{padding-top:clamp(92px,12vh,124px)}}
@media(max-width:760px){
  .vhero-stage{align-items:flex-end}
  .vhero-copy{padding-top:0;padding-bottom:118px;max-width:100%}
  .vhero-sound{height:38px;padding:0 12px}
  .vhero-sound .vhero-sound-lbl{display:none}
}
@media(prefers-reduced-motion:reduce){
  .vhero-cue i{animation:none}
  .vhero-copy{transition:opacity .45s ease}
  .vhero-copy.is-faded{filter:none;transform:none}
}

/* ---- Section 4 · Recent Videos showcase ---- */
.rvid-feature{display:grid;grid-template-columns:1.55fr 1fr;gap:clamp(20px,2.6vw,30px);align-items:center;margin-bottom:clamp(30px,4vw,48px)}
@media(max-width:900px){.rvid-feature{grid-template-columns:1fr}}
.rvid-feature .video-embed{box-shadow:0 30px 80px -30px rgba(0,0,0,.85),0 0 60px -34px var(--green-glow)}
.rvid-reel{aspect-ratio:1656/854}
.video-embed video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;background:#000}
.rvid-feature-meta{display:flex;flex-direction:column;gap:16px;align-items:flex-start}
.rvid-badge{font-family:var(--mono);font-size:.66rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--green);background:var(--green-dim);border:1px solid rgba(39,245,140,.25);padding:6px 13px;border-radius:100px}
.rvid-feature-meta p{color:var(--ink-2);font-size:1.02rem;font-weight:500;line-height:1.65}
.rvid-filterbar{display:flex;gap:9px;flex-wrap:wrap;justify-content:center;margin-bottom:clamp(24px,3vw,36px)}
.rvid-filter{font-family:var(--mono);font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:9px 16px;border-radius:100px;border:1px solid var(--line-2);background:transparent;color:var(--ink-2);transition:color .2s,border-color .2s,background .2s,box-shadow .2s}
.rvid-filter:hover{color:var(--ink);border-color:var(--green)}
.rvid-filter.is-active{color:#03130A;background:var(--green);border-color:transparent;box-shadow:0 6px 18px -8px var(--green-glow)}
@media(max-width:680px){.rvid-filterbar{flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;-webkit-mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent);mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent);padding-bottom:4px;scrollbar-width:none}.rvid-filterbar::-webkit-scrollbar{display:none}.rvid-filter{flex:none}}
.rvid-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:clamp(16px,2vw,26px)}
@media(max-width:760px){.rvid-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}}
@media(max-width:460px){.rvid-grid{grid-template-columns:1fr}}
.rvid-card{display:flex;flex-direction:column;gap:12px;text-align:left;padding:0;background:none;cursor:pointer}
.rvid-card__media{position:relative;aspect-ratio:16/10;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);background:var(--panel-2);box-shadow:0 18px 40px -28px rgba(0,0,0,.9);transition:transform .32s cubic-bezier(.16,1,.3,1),border-color .32s,box-shadow .32s}
.rvid-card__thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.1s cubic-bezier(.16,1,.3,1),filter .32s;filter:saturate(1.02)}
.rvid-card__media::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,transparent 45%,rgba(3,8,6,.66));z-index:1}
.rvid-card__media::before{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;z-index:2;background:linear-gradient(90deg,var(--green),transparent);opacity:.9;transition:height .32s,opacity .32s}
.rvid-card__play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.9);z-index:3;width:62px;height:62px;border-radius:50%;display:grid;place-items:center;color:#04140C;background:var(--green);box-shadow:0 8px 26px -6px var(--green-glow),0 0 0 1px rgba(255,255,255,.18);opacity:.92;transition:transform .32s cubic-bezier(.2,.9,.25,1),opacity .32s;padding-left:3px}
.rvid-card__cat{position:absolute;left:10px;top:10px;z-index:3;font-family:var(--mono);font-size:.6rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#dffaec;padding:4px 9px;border-radius:100px;background:rgba(4,12,9,.6);border:1px solid var(--line-2);backdrop-filter:blur(6px)}
.rvid-card__title{font-size:.98rem;line-height:1.4;color:var(--ink-2);font-weight:500;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color .32s}
@media(hover:hover){
  .rvid-card:hover .rvid-card__media{transform:translateY(-5px);border-color:var(--line-2);box-shadow:0 30px 60px -30px #000,0 0 36px -14px var(--green-glow)}
  .rvid-card:hover .rvid-card__thumb{transform:scale(1.06);filter:saturate(1.14)}
  .rvid-card:hover .rvid-card__play{transform:translate(-50%,-50%) scale(1.06);opacity:1}
  .rvid-card:hover .rvid-card__title{color:#fff}
  .rvid-card:hover .rvid-card__media::before{height:5px;opacity:1}
}
.rvid-card:focus-visible .rvid-card__media{border-color:var(--green);box-shadow:0 0 0 2px var(--green)}
.rvid-proofline{text-align:center;font-family:var(--mono);font-size:.74rem;letter-spacing:.06em;color:var(--ink-3);margin-top:clamp(26px,3vw,38px)}

/* ---- Section 5 · Creative wall (mixed masonry) ---- */
.cwall{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:86px;grid-auto-flow:dense;gap:14px}
.cwall .imgbox{min-height:0;border-color:var(--line-2);background:#0A1014}
.cwall .imgbox img{width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .6s cubic-bezier(.16,1,.3,1)}
.cwall .imgbox:hover{border-color:var(--green);box-shadow:0 24px 60px -30px rgba(0,0,0,.85),0 0 34px -16px var(--green-glow)}
.cwall .imgbox:hover img{transform:scale(1.05)}
.cwall .imgbox .cap{font-size:.62rem;letter-spacing:.08em;padding:30px 11px 10px}
.cwall .imgbox .cap b{color:var(--green);text-transform:uppercase;letter-spacing:.12em;font-size:.56rem;display:block;margin-bottom:3px}
.cwx-w{grid-column:span 5;grid-row:span 3}
.cwx-l{grid-column:span 4;grid-row:span 2}
.cwx-m{grid-column:span 3;grid-row:span 2}
.cwx-s{grid-column:span 4;grid-row:span 3}
.cwx-t{grid-column:span 3;grid-row:span 4}
.cwx-ts{grid-column:span 3;grid-row:span 3}
@media(max-width:1024px){
  .cwall{grid-template-columns:repeat(6,1fr);grid-auto-rows:78px}
  .cwx-w,.cwx-s{grid-column:span 4;grid-row:span 3}
  .cwx-l{grid-column:span 3;grid-row:span 2}
  .cwx-m{grid-column:span 3;grid-row:span 2}
  .cwx-t{grid-column:span 3;grid-row:span 4}
  .cwx-ts{grid-column:span 3;grid-row:span 3}
}
@media(max-width:560px){
  .cwall{grid-template-columns:repeat(2,1fr);grid-auto-rows:84px}
  .cwall>*{grid-column:span 1!important}
  .cwx-w,.cwx-s,.cwx-l,.cwx-m{grid-row:span 2!important}
  .cwx-t,.cwx-ts{grid-row:span 3!important}
}

/* ---- Section 6 · Websites We Built (live recordings) ---- */
.browser.webrec{border-radius:14px;box-shadow:0 26px 60px -34px rgba(0,0,0,.85)}
.webrec-screen{position:relative;aspect-ratio:1376/736;background:#06090C;overflow:hidden}
.webrec-screen video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
.web-card:hover .browser.webrec{border-color:rgba(39,245,140,.4);box-shadow:0 34px 70px -34px rgba(0,0,0,.9),0 0 40px -18px var(--green-glow)}
.web-owned{font-family:var(--mono);font-size:.55rem;letter-spacing:.16em;text-transform:uppercase;color:#03130A;background:var(--green);padding:5px 11px;border-radius:100px;font-weight:600}

/* ---- Section 7 · AI + Automation ---- */
.ai2-subhead{font-family:var(--mono);font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--green);text-align:center;margin-bottom:30px;display:flex;align-items:center;gap:.7rem;justify-content:center}
.ai2-subhead::before,.ai2-subhead::after{content:"";width:30px;height:1px;background:var(--line-2)}
.ai2-flow{position:relative;display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-bottom:clamp(44px,5.5vw,68px)}
.ai2-flow-line{position:absolute;top:30px;left:0;width:100%;height:8px;z-index:0;overflow:visible}
.ai2-flow-line .track{fill:none;stroke:var(--line-2);stroke-width:1.5}
.ai2-flow-line .live{fill:none;stroke:var(--green);stroke-width:1.5;stroke-dasharray:8 12;filter:drop-shadow(0 0 4px var(--green-glow));stroke-dashoffset:200;animation:ai2Flow 3.4s linear infinite}
@keyframes ai2Flow{to{stroke-dashoffset:0}}
.ai2-stage{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px}
.ai2-stage .ic{width:60px;height:60px;border-radius:16px;display:grid;place-items:center;font-size:1.5rem;background:radial-gradient(circle at 35% 30%,rgba(39,245,140,.22),var(--panel-2));border:1px solid var(--green);box-shadow:0 0 26px -10px var(--green-glow)}
.ai2-stage .meta{display:flex;flex-direction:column;align-items:center;gap:7px}
.ai2-stage .num{font-family:var(--mono);font-size:.58rem;font-weight:600;letter-spacing:.16em;color:var(--green)}
.ai2-stage h4{font-family:var(--disp);font-size:1rem}
.ai2-stage p{font-size:.86rem;color:var(--ink-2);max-width:24ch;font-weight:500}
.ai2-stage .chip{font-family:var(--mono);font-size:.58rem;letter-spacing:.03em;color:var(--ink-2);background:rgba(255,255,255,.03);border:1px solid var(--line-2);border-radius:8px;padding:6px 9px}
@media(max-width:860px){
  .ai2-flow{grid-template-columns:1fr;gap:0;padding-left:30px}
  .ai2-flow::before{content:"";position:absolute;left:11px;top:14px;bottom:14px;width:2px;background:linear-gradient(var(--green),rgba(39,245,140,.15));border-radius:2px}
  .ai2-flow-line{display:none}
  .ai2-stage{flex-direction:row;align-items:flex-start;text-align:left;gap:14px;padding:13px 0}
  .ai2-stage .ic{width:48px;height:48px;font-size:1.2rem;flex:none}
  .ai2-stage .meta{align-items:flex-start}
  .ai2-stage p{max-width:none}
}
.ai2-wins{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px;margin-bottom:clamp(40px,5vw,60px)}
.ai2-win{border-radius:14px;overflow:hidden;border:1px solid var(--line-2);background:var(--panel);box-shadow:0 24px 60px -34px rgba(0,0,0,.8);transition:transform .3s,border-color .3s,box-shadow .3s;display:flex;flex-direction:column}
.ai2-win:hover{transform:translateY(-6px);border-color:rgba(39,245,140,.4);box-shadow:0 34px 70px -34px rgba(0,0,0,.9),0 0 40px -18px var(--green-glow)}
.ai2-win__bar{display:flex;align-items:center;gap:7px;padding:10px 14px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.02)}
.ai2-win__bar i{width:8px;height:8px;border-radius:50%;background:var(--ink-3);opacity:.5}
.ai2-win__bar i:first-child{background:var(--green);opacity:1}
.ai2-win__bar span{font-family:var(--mono);font-size:.6rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);margin-left:6px}
.ai2-win__body{position:relative;aspect-ratio:16/10;background:#06090C;overflow:hidden}
.ai2-win__body img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
.ai2-win__cap{padding:14px 16px;font-size:.88rem;color:var(--ink-2);font-weight:500;line-height:1.5;border-top:1px solid var(--line)}
.ai2-win__cap b{color:var(--ink);font-family:var(--disp);font-weight:600}
.ai2-foot{display:flex;flex-direction:column;align-items:center;gap:26px;text-align:center}
.ai2-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;width:100%}
@media(max-width:680px){.ai2-stats{grid-template-columns:repeat(2,1fr)}}
.ai2-stat{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:20px 14px;transition:border-color .3s,transform .3s}
.ai2-stat:hover{border-color:rgba(39,245,140,.35);transform:translateY(-4px)}
.ai2-stat b{font-family:var(--disp);font-size:clamp(1.5rem,3vw,2rem);color:var(--green);display:block;letter-spacing:-.02em}
.ai2-stat span{font-family:var(--mono);font-size:.6rem;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-3)}
.ai2-stack{display:flex;flex-wrap:wrap;gap:9px;justify-content:center;max-width:760px}
.ai2-stack-label{font-family:var(--mono);font-size:.64rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);width:100%;text-align:center;margin-bottom:4px}
.ai2-cta-note{font-family:var(--mono);font-size:.68rem;color:var(--ink-3);max-width:54ch;line-height:1.6}

/* ---- Section 8 · SEO & Local Domination bento ---- */
.seo2-stats{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:22px}
.seo2-stats .metric-pill b{color:var(--green)}
.seo2{display:grid;gap:16px}
.seo2 .imgbox{border-color:var(--line-2);background:#0A1014;overflow:hidden}
.seo2 .imgbox img{width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .6s cubic-bezier(.16,1,.3,1)}
.seo2 .imgbox:hover{border-color:var(--green);box-shadow:0 24px 60px -30px rgba(0,0,0,.85),0 0 34px -16px var(--green-glow)}
.seo2 .imgbox:hover img{transform:scale(1.04)}
.seo2 .imgbox .cap{font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--green);padding:26px 12px 10px}
.seo2-top{display:grid;grid-template-columns:1.45fr 1fr;gap:16px}
.seo2-hero{min-height:clamp(320px,42vw,470px)}
.seo2-right{display:grid;grid-template-rows:1fr 1fr;gap:16px;min-height:clamp(320px,42vw,470px)}
.seo2-right .imgbox{min-height:0}
.seo2-bottom{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.seo2-card{background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line-2);border-radius:14px;padding:20px;display:flex;flex-direction:column;gap:11px;min-height:300px}
.seo2-label{font-family:var(--mono);font-size:.62rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--green)}
.seo2-ranks .rank-row{flex:1}
.seo2-service{min-height:300px}
.seo2-tools-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;flex:1}
.seo2-tools-grid .imgbox{min-height:0;border-radius:10px}
.seo2-tools-grid .imgbox .cap{display:none}
@media(max-width:900px){
  .seo2-top{grid-template-columns:1fr}
  .seo2-right{grid-template-rows:auto auto;min-height:0}
  .seo2-right .imgbox{min-height:200px}
  .seo2-bottom{grid-template-columns:1fr}
  .seo2-hero{min-height:300px}
}

/* ---- Section 9 · Social — 12 phone mockups ---- */
.phonewall{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,24px);max-width:1060px;margin-inline:auto;perspective:1200px}
.pmock{border:1px solid var(--line-2);border-radius:30px;background:#0A1014;padding:8px;box-shadow:0 30px 60px -26px rgba(0,0,0,.78),inset 0 1px 0 rgba(255,255,255,.04);transition:transform .4s cubic-bezier(.16,1,.3,1),border-color .4s,box-shadow .4s;position:relative}
.pmock:hover{transform:translateY(-9px) scale(1.025);border-color:rgba(39,245,140,.45);box-shadow:0 44px 80px -28px rgba(0,0,0,.86),0 0 44px -18px var(--green-glow);z-index:2}
.pmock .notch{width:62px;height:16px;background:#04070A;border-radius:0 0 12px 12px;margin:0 auto 7px;position:relative;z-index:2}
.pmock .pscreen{position:relative;border-radius:22px;overflow:hidden;aspect-ratio:9/16;background:#06090C}
.pmock .pscreen img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;display:block;transition:transform .6s cubic-bezier(.16,1,.3,1)}
.pmock:hover .pscreen img{transform:scale(1.05)}
@media(max-width:900px){.phonewall{grid-template-columns:repeat(3,1fr);max-width:none}}
@media(max-width:560px){.phonewall{grid-template-columns:repeat(2,1fr);gap:14px}}

/* ---- Section 10 · Performance Reports (screen recordings) ---- */
.rep2-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:clamp(20px,2.4vw,30px)}
@media(max-width:760px){.rep2-grid{grid-template-columns:1fr}}
.rep2-card{display:flex;flex-direction:column}
.rep2-card .browser.webrec{transition:transform .3s,border-color .3s,box-shadow .3s}
.rep2-card:hover .browser.webrec{transform:translateY(-6px);border-color:rgba(39,245,140,.4);box-shadow:0 34px 70px -34px rgba(0,0,0,.9),0 0 40px -18px var(--green-glow)}
.rep2-screen{position:relative;aspect-ratio:16/9;background:#06090C;overflow:hidden}
.rep2-screen video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
.rep2-meta{margin-top:16px;display:flex;flex-direction:column;gap:6px}
.rep2-meta h4{font-family:var(--disp);font-size:1.08rem}
.rep2-stat{font-family:var(--mono);font-size:.72rem;color:var(--green);letter-spacing:.03em}

/* ---- Section 7 · AI + Automation · "The Index" editorial platform stage ---- */
/* Full-bleed black band; the component owns its own padding + single green ambient. */
#ai-automation{padding:0;background:var(--bg)}
.aiidx{--ease-out-expo:cubic-bezier(.16,1,.3,1);--ease-out-soft:cubic-bezier(.22,1,.36,1);--ease-inout:cubic-bezier(.65,0,.35,1);
  position:relative;width:100vw;margin-left:calc(50% - 50vw);padding-block:clamp(78px,9vh,130px);overflow:hidden;isolation:isolate}
.aiidx-grain{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.045;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.aiidx::before{content:"";position:absolute;top:-8%;right:0;width:min(960px,82vw);height:520px;z-index:0;pointer-events:none;
  background:radial-gradient(900px 480px at 82% 0,rgba(39,245,140,.06),transparent 60%)}
.aiidx-wrap{position:relative;z-index:1;max-width:var(--max);margin-inline:auto;padding-inline:clamp(20px,5vw,80px)}

/* Header — asymmetric, left-aligned */
.aiidx-eyebrow{font-family:var(--mono);font-weight:500;text-transform:uppercase;font-size:11px;letter-spacing:.14em;color:var(--ink-3);margin:0 0 18px}
.aiidx-title{font-family:var(--disp);font-weight:500;font-size:clamp(2rem,4.4vw,3.4rem);line-height:1.04;letter-spacing:-.02em;color:var(--ink);max-width:20ch;margin:0}
.aiidx-title .em{font-style:italic;font-family:Georgia,"Times New Roman",serif;letter-spacing:-.01em;color:var(--ink)}

/* Body grid — 5fr index / 7fr stage */
.aiidx-body{margin-top:clamp(38px,5vh,62px);display:grid;grid-template-columns:minmax(0,5fr) minmax(0,7fr);column-gap:clamp(40px,5vw,96px);align-items:stretch}

/* The numbered type index (the type scale IS the selected state) */
.aiidx-list{list-style:none;margin:0;padding:0;align-self:center}
.aiidx-row{position:relative;display:grid;grid-template-columns:auto 1fr;column-gap:16px;align-items:baseline;
  padding-block:clamp(13px,1.5vh,19px);border-top:1px solid rgba(255,255,255,.08);cursor:pointer;outline:none}
.aiidx-row:last-child{border-bottom:1px solid rgba(255,255,255,.08)}
.aiidx-row .num{font-family:var(--mono);font-size:.7rem;color:var(--ink-3);transition:color .2s var(--ease-inout),font-size .24s var(--ease-inout),transform .18s var(--ease-inout)}
.aiidx-row .num i{font-style:normal;opacity:.5;margin-left:1px}
.aiidx-row .namewrap{min-width:0}
.aiidx-row .name{display:block;font-family:var(--disp);font-weight:500;font-size:clamp(1.15rem,1.5vw,1.4rem);color:var(--ink-2);letter-spacing:-.01em;
  transition:font-size .26s var(--ease-inout),color .26s var(--ease-inout),letter-spacing .26s var(--ease-inout)}
.aiidx-row .tag{display:grid;grid-template-rows:0fr;opacity:0;font-family:var(--body);font-size:.78rem;line-height:1.4;color:var(--ink-3);
  transition:grid-template-rows .26s var(--ease-inout),opacity .22s var(--ease-inout)}
.aiidx-row .tag>span{overflow:hidden;min-height:0}
.aiidx-row .mark{position:absolute;left:-16px;top:16%;bottom:16%;width:2px;background:var(--green);transform:scaleY(0);transform-origin:top;transition:transform .3s var(--ease-out-expo)}
.aiidx-row .rule{position:absolute;left:0;right:0;bottom:-1px;height:1px;background:var(--green);clip-path:inset(0 100% 0 0);transition:clip-path .36s var(--ease-inout);pointer-events:none}
.aiidx-row:hover .num{transform:translateX(3px)}
.aiidx-row:hover .name{color:var(--ink)}
.aiidx-row:hover .tag,.aiidx-row.is-active .tag{grid-template-rows:1fr;opacity:1;margin-top:5px}
.aiidx-row.is-active .num{color:var(--green);font-size:.82rem}
.aiidx-row.is-active .name{font-size:clamp(1.5rem,2.2vw,2.1rem);color:var(--ink);letter-spacing:-.02em}
.aiidx-row.is-active .mark{transform:scaleY(1)}
.aiidx-row.is-active .rule{clip-path:inset(0)}
.aiidx-row:focus-visible{outline:2px solid var(--green);outline-offset:4px;border-radius:2px}

/* The single cinematic stage */
.aiidx-stage{position:relative;margin:0;display:flex;flex-direction:column;min-height:min(66vh,580px)}
.aiidx-stage .meta{display:flex;align-items:flex-start;gap:14px;margin-bottom:20px;min-height:84px}
.aiidx-stage .chip{width:56px;height:56px;flex:none;border-radius:8px;background:#fff;display:grid;place-items:center;padding:11px;box-shadow:0 0 18px -6px var(--green-glow)}
.aiidx-stage .chipimg{max-width:100%;max-height:100%;display:block}
.aiidx-stage .metatext{min-width:0}
.aiidx-stage .sname{display:block;font-family:var(--disp);font-weight:500;font-size:clamp(1.6rem,2.4vw,2.2rem);letter-spacing:-.02em;line-height:1.05;color:var(--ink)}
.aiidx-stage .sdesc{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
  font-family:var(--body);font-size:clamp(.95rem,1.05vw,1.06rem);line-height:1.55;color:var(--ink-2);max-width:46ch;margin-top:8px}
.aiidx-stage .canvas{flex:1;min-height:0;display:flex;gap:14px}
.aiidx-stage .win{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;border-radius:4px;overflow:hidden;border:1px solid var(--line-2);background:#06090C;box-shadow:0 30px 80px -40px rgba(0,0,0,.7)}
.aiidx-stage .win[hidden],.aiidx-stage .checklist[hidden]{display:none}
.aiidx-stage .win-bar{flex:none;display:flex;align-items:center;gap:7px;padding:10px 14px;background:rgba(255,255,255,.04);border-bottom:1px solid var(--line)}
.aiidx-stage .win-bar i{width:9px;height:9px;border-radius:50%;background:#2a3a33}
.aiidx-stage .win-bar i:nth-child(1){background:#ff5f57}.aiidx-stage .win-bar i:nth-child(2){background:#febc2e}.aiidx-stage .win-bar i:nth-child(3){background:#28c840}
.aiidx-stage .wlabel{margin-left:10px;font-family:var(--mono);font-size:.62rem;letter-spacing:.05em;color:var(--ink-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.aiidx-stage .win-body{flex:1;min-height:0;position:relative;background:#06090C;overflow:hidden}
.aiidx-stage .win-body::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(180deg,transparent 58%,rgba(0,0,0,.4))}
.aiidx-stage .wimg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
.aiidx-stage .wimg.reveal{animation:aiidx-curtain .52s var(--ease-out-soft) .06s both}
.aiidx-stage .strip{flex:none;width:clamp(108px,11vw,152px);display:flex;flex-direction:column;gap:9px;overflow-y:auto;scrollbar-width:none}
.aiidx-stage .strip.off{display:none}
.aiidx-stage .strip::-webkit-scrollbar{display:none}
.aiidx-stage .thumb{flex:none;height:clamp(58px,6.6vw,82px);border-radius:6px;border:1px solid var(--line);background-color:#06090C;background-size:cover;background-position:top center;background-repeat:no-repeat;cursor:pointer;position:relative;overflow:hidden;filter:saturate(.9);transition:filter .2s,border-color .2s,transform .2s}
.aiidx-stage .thumb:hover{border-color:var(--line-2);transform:translateY(-1px);filter:saturate(1)}
.aiidx-stage .thumb.is-active{border-color:var(--green);box-shadow:0 0 0 1px var(--green);filter:saturate(1)}
.aiidx-stage .thumb span{position:absolute;left:0;right:0;bottom:0;padding:3px 6px;font-family:var(--mono);font-size:.46rem;letter-spacing:.04em;text-transform:uppercase;color:#d8efe4;background:linear-gradient(transparent,rgba(0,0,0,.82));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.aiidx-stage .cap{flex:none;margin:12px 0 0;font-family:var(--mono);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
/* Ecommerce honest empty state */
.aiidx-stage .checklist{flex:1;min-height:0;display:flex;flex-direction:column;gap:8px;justify-content:center;border:1px dashed var(--line-2);border-radius:8px;padding:clamp(22px,2.6vw,34px)}
.aiidx-stage .cl-head{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.aiidx-stage .cl-tag{font-family:var(--mono);font-size:.56rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--green);border:1px solid rgba(39,245,140,.4);border-radius:100px;padding:4px 10px}
.aiidx-stage .cl-url{font-family:var(--mono);font-size:.62rem;letter-spacing:.05em;color:var(--ink-3)}
.aiidx-stage .cl-row{display:flex;align-items:center;gap:13px;font-family:var(--body);font-size:1.02rem;color:var(--ink);padding:9px 0;border-bottom:1px solid var(--line)}
.aiidx-stage .cl-row:last-child{border-bottom:0}
.aiidx-stage .cl-tick{font-family:var(--mono);color:var(--green);font-size:.95rem;flex:none}

/* CTA */
.aiidx-cta{margin-top:clamp(40px,6vh,72px);display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.aiidx-cta-note{font-family:var(--mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3)}

/* Motion */
@keyframes aiidx-curtain{from{clip-path:inset(0 0 100% 0);opacity:0;transform:scale(1.04)}to{clip-path:inset(0 0 0 0);opacity:1;transform:scale(1)}}
@keyframes aiidx-metain{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.aiidx-stage.swap .metatext{animation:aiidx-metain .22s var(--ease-out-soft)}

/* One-time entrance (IO adds .in, then unobserves) */
.aiidx-head,.aiidx-stage,.aiidx-cta{opacity:0;transform:translateY(22px)}
.aiidx-row{opacity:0;transform:translateY(20px)}
.aiidx.in .aiidx-head{opacity:1;transform:none;transition:opacity .7s var(--ease-out-expo),transform .7s var(--ease-out-expo)}
.aiidx.in .aiidx-stage{opacity:1;transform:none;transition:opacity .7s var(--ease-out-expo) .18s,transform .7s var(--ease-out-expo) .18s}
.aiidx.in .aiidx-cta{opacity:1;transform:none;transition:opacity .7s var(--ease-out-expo) .36s,transform .7s var(--ease-out-expo) .36s}
.aiidx.in .aiidx-row{opacity:1;transform:none;transition:opacity .66s var(--ease-out-expo) calc(.12s + var(--i)*52ms),transform .66s var(--ease-out-expo) calc(.12s + var(--i)*52ms)}

@media(prefers-reduced-motion:reduce){
  .aiidx-head,.aiidx-stage,.aiidx-cta,.aiidx-row{opacity:1!important;transform:none!important;transition:none!important}
  .aiidx-stage .wimg.reveal{animation:none!important}
  .aiidx-stage.swap .metatext{animation:none!important}
}

/* Responsive */
@media(max-width:1180px){
  .aiidx-body{column-gap:clamp(34px,4vw,56px)}
  .aiidx-wrap{padding-inline:clamp(20px,4vw,48px)}
  .aiidx-stage{min-height:min(66vh,560px)}
}
@media(max-width:900px){
  .aiidx{padding-block:clamp(64px,9vh,112px)}
  .aiidx-body{grid-template-columns:1fr;row-gap:26px;margin-top:clamp(32px,5vh,48px)}
  .aiidx-list{display:flex;flex-direction:row;gap:8px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:6px;align-self:auto;
    -webkit-mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent);mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent)}
  .aiidx-list::-webkit-scrollbar{display:none}
  .aiidx-row{flex:none;scroll-snap-align:center;border:1px solid var(--line)!important;border-radius:100px;padding:9px 15px;grid-template-columns:auto auto;column-gap:8px;align-items:center}
  .aiidx-row .num,.aiidx-row.is-active .num{font-size:.6rem;color:var(--ink-3);transform:none}
  .aiidx-row.is-active .num{color:var(--green)}
  .aiidx-row .name,.aiidx-row.is-active .name{font-size:.92rem;letter-spacing:0;color:var(--ink-2)}
  .aiidx-row.is-active .name{color:var(--ink)}
  .aiidx-row .tag{display:none}
  .aiidx-row .rule,.aiidx-row .mark{display:none}
  .aiidx-row.is-active{background:linear-gradient(120deg,var(--green-dim),transparent);border-color:var(--green)!important}
  .aiidx-stage{min-height:0}
  .aiidx-stage .meta{min-height:0;margin-bottom:16px}
  .aiidx-stage .canvas{flex-direction:column}
  .aiidx-stage .win{height:min(52vh,420px);flex:none}
  .aiidx-stage .strip{width:auto;flex-direction:row;overflow-x:auto;overflow-y:hidden}
  .aiidx-stage .thumb{width:128px;height:78px;flex:none}
}
@media(max-width:480px){
  .aiidx-wrap{padding-inline:20px}
  .aiidx-stage .win{height:min(48vh,360px)}
  .aiidx-stage .sdesc{-webkit-line-clamp:4;max-width:36ch}
  .aiidx-cta{gap:14px}
  .aiidx-cta .btn{width:100%;justify-content:center}
}

/* ============================================================
   ALTERNATING BLACK / WHITE SECTION THEME SYSTEM
   .sec-light = white editorial section (scoped variable flip)
   ============================================================ */
.sec-light{
  --bg:#ffffff; --bg-2:#ffffff;
  --panel:#ffffff; --panel-2:#f3f7f4;
  --glass:rgba(255,255,255,.82);
  --line:rgba(17,40,28,.12);
  --line-2:rgba(10,130,74,.30);
  --green:#0a8f4f; --green-2:#0c9e58;
  --green-dim:rgba(10,150,82,.10);
  --green-glow:rgba(10,150,82,.22);
  --ink:#111613; --ink-2:#414e47; --ink-3:#647269;
  background:#ffffff; color:var(--ink);
  position:relative;
}
/* normalize black sections to one consistent black (kills "random dark panels") */
section:not(.sec-light), .logowall:not(.sec-light){background-color:#04070A}
.command{background:radial-gradient(1100px 540px at 50% -10%,rgba(39,245,140,.09),transparent),#04070A}

/* premium transitions: crisp green hairline + soft inset bleed at every boundary
   (strict alternation → a white section always follows black, and vice-versa) */
section::before, .logowall::before{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(90deg,transparent,var(--line-2),transparent);opacity:.7;pointer-events:none;z-index:4}
.sec-light::before{opacity:.5}
.sec-light{box-shadow:inset 0 17px 28px -22px rgba(4,7,10,.16)}        /* soft shadow cast by the black section above */
section:not(.sec-light):not(.hero), footer:not(.sec-light){box-shadow:inset 0 17px 26px -24px rgba(220,245,232,.08)}  /* soft light bleed from the white section above */

/* ---- typography on white ---- */
.sec-light .lede{color:var(--ink-2)}
.sec-light .outline-txt{-webkit-text-stroke:1.6px rgba(17,30,24,.45);color:transparent}
.sec-light .imgbox .cap{color:#34d98a}
.sec-light .imgbox .cap b{color:#34d98a}

/* ---- buttons on white ---- */
.sec-light .btn-green{background:linear-gradient(135deg,#16c46f,#08a256);color:#04140b;box-shadow:0 10px 26px -10px rgba(8,162,86,.5)}
.sec-light .btn-green:hover{box-shadow:0 16px 40px -12px rgba(8,162,86,.55),0 0 22px rgba(8,162,86,.32)}
.sec-light .btn-ghost{background:rgba(10,130,74,.05);border-color:var(--line-2);color:var(--ink)}
.sec-light .btn-ghost:hover{border-color:var(--green);background:rgba(10,130,74,.1)}

/* ---- generic cards / imgbox / glass on white ---- */
.sec-light .imgbox{background:#eef3f0;border-color:var(--line)}
.sec-light .metric-pill{border-color:var(--line-2);color:var(--ink-2)}
.sec-light .metric-pill b{color:var(--green)}

/* ---- logo wall ---- */
.logowall.sec-light .imgbox{background:#fff;border:1px solid var(--line);box-shadow:0 3px 12px rgba(17,40,28,.07)}
/* Light/white cut-out logos can't show on a white chip — give them a dark chip instead. */
.logowall .imgbox.chip-dark{background:#0c1612;border:1px solid var(--line-2);box-shadow:inset 0 0 0 1px rgba(255,255,255,.03)}
.logowall .imgbox.chip-dark img{object-fit:contain;padding:13px;background:transparent}

/* ---- versus comparison (growth-system) ---- */
.sec-light .versus{box-shadow:0 24px 60px -34px rgba(17,40,28,.18)}
.sec-light .versus .col.old{background:#f5f7f6}
.sec-light .versus .col.gcm{background:linear-gradient(160deg,rgba(10,160,90,.09),rgba(10,160,90,.02)),#ffffff;border-left:1px solid rgba(10,140,80,.28)}
.sec-light .vs-badge{background:#fff;border:1px solid var(--green);color:var(--green);box-shadow:0 0 0 6px #fff,0 10px 30px -10px rgba(10,150,82,.3)}

/* ---- recent videos showcase (videos) ---- */
.sec-light .rvid-card__media{box-shadow:0 12px 32px -18px rgba(17,40,28,.2)}
.sec-light .rvid-card:hover .rvid-card__title{color:#111}
.sec-light .rvid-filter.is-active{color:#fff;background:#0a9a52;box-shadow:0 6px 18px -8px rgba(10,150,82,.4)}

/* ---- light browser mockups (websites + reports) ---- */
.sec-light .web-card{box-shadow:0 16px 44px -28px rgba(17,40,28,.22)}
.sec-light .browser{background:#ffffff;border-color:var(--line)}
.sec-light .browser .bbar{background:#f1f5f3;border-bottom-color:var(--line)}
.sec-light .browser .bbar i{background:#c4cfc9;opacity:1}
.sec-light .browser .bbar i:first-child{background:#0fb866}
.sec-light .browser .url{background:#fff;color:var(--ink-3);border:1px solid var(--line)}

/* ---- seo bento ---- */
.sec-light .seo2-card{box-shadow:0 16px 44px -30px rgba(17,40,28,.2)}
.sec-light .seo2 .imgbox{background:#eef3f0;box-shadow:0 12px 32px -22px rgba(17,40,28,.18)}
.sec-light .rank-row{box-shadow:0 4px 14px -8px rgba(17,40,28,.12)}

/* ---- reports ---- */
.sec-light .rep2-card .browser.webrec{box-shadow:0 18px 48px -30px rgba(17,40,28,.24)}

/* ---- team cards (captions over photo stay light) ---- */
.sec-light .team-card{box-shadow:0 16px 44px -30px rgba(17,40,28,.22)}
.sec-light .team-card .tinfo h4{color:#fff !important}
.sec-light .team-card .role{color:#3ee08c}

/* ---- contact / final + form ---- */
.sec-light.final{background:radial-gradient(900px 520px at 50% 0,rgba(10,160,90,.08),transparent),#ffffff}
.sec-light .cmd-form{background:#ffffff;border:1px solid var(--line);box-shadow:0 34px 80px -34px rgba(17,40,28,.2)}
.sec-light .cmd-form .cf-bar{background:#f5f8f6;border-bottom-color:var(--line);color:var(--green)}
.sec-light .field input,.sec-light .field select,.sec-light .field textarea{background:#f5f8f6;border:1px solid var(--line);color:var(--ink)}
.sec-light .field input::placeholder,.sec-light .field textarea::placeholder{color:#9aa8a1}
.sec-light .field input:focus,.sec-light .field select:focus,.sec-light .field textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(10,160,90,.14)}
.sec-light .field select option{background:#fff;color:#111}

/* ---- footer ---- */
footer.sec-light{background:#ffffff;border-top:1px solid var(--line)}

/* ============================================================
   LOGO CHIP SIZING — enlarge logos to fill their small boxes
   (contain = no cropped/cut-off logos; just much less padding)
   ============================================================ */
.logowall .imgbox.contain img, .logowall .imgbox.containdark img{padding:5px}
.succ-card .logo-chip .imgbox img{padding:3px}
.succ-card .logo-chip{width:68px;height:68px;bottom:-30px}
.owned-card .top .logo-box .imgbox.contain img, .owned-card .top .logo-box .imgbox.containdark img{padding:5px}
.lb-head .lb-logo .imgbox.contain img, .lb-head .lb-logo .imgbox.containdark img{padding:4px}
/* @@UPGRADES_END@@ */

/* ============================================================
   NEUE HAAS GROTESK TYPOGRAPHY SYSTEM
   Display Pro -> titles (uppercase) - Text Pro -> body/nav/buttons
   JetBrains Mono -> micro labels only. Faces self-hosted (see @font-face at top).
   Typography only: no layout/spacing/colour/content changes.
   ============================================================ */
body{
  font-family:var(--body);
  font-weight:400;
}
h1, h2, h3, h4,
.h-mega,
.h-xl,
.h-lg,
.gcm-model-title,
.aiidx-title,
.sec-cta-head{
  font-family:var(--disp);
  text-transform:uppercase;
  /* Uppercase needs real breathing room — the mixed-case original was tuned tight (-0.02em),
     which reads jammed once forced to caps. Generous tracking + word-spacing so words and
     letters clearly separate; roomy line-height so stacked lines don't touch. */
  letter-spacing:0.035em;
  word-spacing:0.12em;
  line-height:1.22;
}
.h-xl{ letter-spacing:0.02em; }          /* large display: needs a touch less tracking than mid/small */
.h-mega,
.hero h1,
.vhero-copy h1{
  font-weight:900;
  letter-spacing:0.015em;                /* huge caps: small positive tracking, never negative */
  word-spacing:0.06em;
  line-height:1.12;
}
/* Contact CTA heading uses the same giant .h-mega size as the hero, but sits in a ~half-width
   grid column — so its long word "INFRASTRUCTURE?" overflowed and ran under the form. Size it to
   fit its column so the whole heading is fully readable (text scale only; hero mega unaffected). */
#contact .h-mega{ font-size:clamp(1.9rem, 3.7vw, 3.2rem) }
h2, h3, h4,
.h-xl,
.h-lg,
.sec-cta-head{
  font-weight:700;
}
p,
.lede,
.vs-item,
.owned-card p,
.proj-card p,
.cs-row p,
.step p,
.rev-card blockquote,
.field input,
.field select,
.field textarea,
footer,
li{
  font-family:var(--body);
  font-weight:400;
  line-height:1.65;
}
.btn,
nav.main a,
.h-name,
.logo,
.link-btn,
button{
  font-family:var(--body);
  font-weight:700;
}
.eyebrow,
.h-name small,
.logo small,
.slot .s-tag,
.succ-card .tag,
.succ-card .stat,
.metric-pill,
.rvid-badge,
.rvid-filter,
.web-owned,
.seo2-label,
.rep2-stat,
.step .n,
.team-card .role,
.field label,
.cmd-form .cf-bar,
.cmd-form .note,
footer .fine{
  font-family:var(--mono);
}

/* WP homepage only: the injected global nav (gcm-global-nav.php) hardcodes 'Space Grotesk'.
   These .gcmnav-* selectors match nothing in the standalone HTML (harmless no-op) and, on the
   WP homepage, re-skin the nav to Neue Haas Text Pro so no Google body font is used. */
.gcmnav-brand,
.gcmnav-menu a,
.gcmnav-cta,
.gcmnav-overlay-links a,
.gcmnav-overlay-cta,
.gcmnav-mark{
  font-family:var(--body) !important;
  font-weight:700;
}
.gcmnav-brand small{ font-family:var(--mono) !important; }


/* Hero headline sized to fit one screen (2026-07 update) */
.vhero-copy .h-mega{font-size:clamp(1.75rem,4vw,3.4rem);line-height:1.05;letter-spacing:-.02em}
.vhero-copy{padding-top:clamp(140px,16vh,180px)}
@media(max-width:600px){.vhero-copy .h-mega{font-size:clamp(1.6rem,7.4vw,2.3rem)}}
