/* ============================================================
   Bright5G — shared design system
   Black canvas · gold accent · RF signal-wave motif
   ============================================================ */
:root{
  /* accent — change these three to re-skin the whole site */
  --gold:#3D7BFF;
  --gold-2:#6FA1FF;
  --gold-pale:#BBD3FF;

  --bg:#0A0A0A;
  --bg-2:#111111;
  --bg-3:#161514;
  --bg-card:#161514;
  --line:rgba(61,123,255,.18);
  --line-soft:rgba(244,233,204,.08);

  --head:#FDF6E6;       /* headings / bright highlights */
  --text:#E7DCC4;       /* body paragraphs (warm white) */
  --muted:#9A8A6A;      /* secondary text */

  --head-font:'Montserrat', system-ui, sans-serif;
  --body-font:'Inter', system-ui, sans-serif;
  --maxw:1240px;
  --radius:16px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body-font);
  background:var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
  overflow-x:hidden;
}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
}
h1,h2,h3,h4,h5,.h{font-family:var(--head-font);color:var(--head);font-weight:600;letter-spacing:-.02em;line-height:1.08}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.section{padding:108px 0}
@media(max-width:680px){.section{padding:72px 0}.wrap{padding:0 22px}}

/* ---------- type helpers ---------- */
.eyebrow{font-family:var(--body-font);font-weight:600;font-size:12.5px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:11px}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold);display:inline-block;opacity:.7}
.display{font-size:clamp(40px,6vw,76px);font-weight:700;letter-spacing:-.03em}
.h2{font-size:clamp(30px,4vw,50px)}
.h3{font-size:clamp(22px,2.4vw,30px)}
.lead{font-size:clamp(17px,1.6vw,20px);color:var(--text);max-width:62ch}
.muted{color:var(--muted)}
.gold{color:var(--gold-2)}
.center{text-align:center}
.center .eyebrow{justify-content:center}
.center .lead{margin-left:auto;margin-right:auto}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--body-font);font-weight:600;
  font-size:15px;padding:15px 26px;border-radius:10px;cursor:pointer;border:1px solid transparent;
  transition:transform .18s ease, box-shadow .25s ease, background .2s ease, border-color .2s ease;
  white-space:nowrap}
.btn .arr{transition:transform .2s ease}
.btn:hover .arr{transform:translateX(4px)}
.btn-gold{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#fff;
  box-shadow:0 12px 34px -14px rgba(61,123,255,.8)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 18px 44px -14px rgba(61,123,255,.9)}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--head)}
.btn-ghost:hover{border-color:var(--gold);background:rgba(61,123,255,.06)}
/* header CTA: matched compact sizing + clear hierarchy */
.hdr-cta .btn{padding:11px 20px;font-size:14px}
.btn-cmd{background:transparent;border:1px solid var(--line-soft);color:var(--text);gap:7px}
.btn-cmd:hover{border-color:var(--gold);background:rgba(61,123,255,.08);color:var(--gold-2)}
.btn-cmd svg{opacity:.7}
.btn-cmd:hover svg{opacity:1}

/* ---------- signal-wave motif ---------- */
.wave{display:block;width:100%;height:auto;color:var(--gold)}
.wave .ln{fill:none;stroke:currentColor;stroke-width:1.5;vector-effect:non-scaling-stroke}
.wave .peak{fill:var(--gold-pale)}
.divider{padding:8px 0;opacity:.6}
.divider .wave{max-width:var(--maxw);margin:0 auto}

/* ---------- sticky header ---------- */
.hdr{position:sticky;top:0;z-index:60;background:rgba(9,10,12,.97);backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line-soft)}
.hdr-in{display:flex;align-items:center;justify-content:space-between;height:88px;position:relative}
.logo{display:inline-flex;align-items:center;text-decoration:none;flex:none}
.logo .wm{font-family:'Space Grotesk',var(--head-font);font-weight:700;color:var(--head);
  font-size:35px;line-height:1;display:inline-flex;align-items:baseline;white-space:nowrap;letter-spacing:-.02em}
.logo .twr{display:inline-block;height:.924em;width:.472em;line-height:0;vertical-align:baseline;
  transform:translateY(.06em);margin:0 -.012em}
.logo .twr .twr-svg{height:100%;width:100%;display:block;overflow:visible}
.logo .g5{font-weight:600;font-size:1.1em;letter-spacing:-.01em;margin-left:.02em;
  background:linear-gradient(0deg,#163C9E,#5B9BFF 52%,#DCEBFF);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.ft .logo .wm{font-size:28px}
.mnav-head .logo .wm{font-size:35px}
@media(max-width:560px){.logo .wm{font-size:29px}}
.nav{display:flex;align-items:center;gap:26px;font-size:14px;font-weight:500;
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}
.nav a{color:var(--text);opacity:.82;transition:opacity .15s,color .15s;white-space:nowrap}
.nav a:hover,.nav a.active{opacity:1;color:var(--gold-2)}
.hdr-cta{display:flex;align-items:center;gap:10px;flex:none}
.menu-btn{display:none;background:none;border:0;color:var(--head);cursor:pointer}
@media(max-width:1040px){.nav{gap:18px;font-size:13px}.hdr-cta .btn-gold{padding:11px 16px;font-size:13.5px}}
@media(max-width:1100px){.nav{display:none}.menu-btn{display:block}.hdr-cta .btn-cmd{padding:10px 15px;font-size:13.5px}}
/* on phones, drop the secondary Command login so the primary contact CTA always has room */
@media(max-width:560px){.hdr-cta .btn-cmd{display:none}}
@media(max-width:420px){.hdr-cta .btn-gold{padding:11px 15px;font-size:13px}}
@media(max-width:520px){.hdr-cta .btn{padding:12px 16px;font-size:13.5px}}
/* mobile menu */
/* full-screen mobile menu overlay */
.mnav{position:fixed;top:88px;left:0;right:0;z-index:300;background:#0b0d12;
  border-bottom:1px solid var(--line);display:none;flex-direction:column;
  max-height:calc(100dvh - 88px);overflow-y:auto;box-shadow:0 30px 60px -22px rgba(0,0,0,.78)}
.mnav.open{display:flex}
.mnav-head{display:none}
.mnav-close{background:none;border:0;color:var(--head);cursor:pointer;padding:6px;line-height:0}
.mnav-links{display:flex;flex-direction:column;gap:0;padding:6px 0}
.mnav-links a{display:flex;align-items:center;justify-content:space-between;gap:16px;
  font-family:var(--head-font);font-weight:600;font-size:16.5px;letter-spacing:-.01em;
  color:var(--head);padding:15px 26px;border-bottom:1px solid var(--line-soft);transition:color .15s ease,background .15s ease}
.mnav-links a::after{content:"\203A";color:var(--muted);font-size:1.15em;line-height:1}
.mnav-links a:hover{color:var(--gold-2);background:rgba(91,155,255,.06)}
.mnav-foot{padding:16px 26px 24px;border-top:1px solid var(--line-soft);display:flex;flex-direction:column;gap:12px}
.mnav-foot .btn{justify-content:center;font-size:16px;padding:16px}
.mnav-foot .contact{font-size:13px;color:var(--muted)}
.mnav-foot .contact a{color:var(--text)}
.mnav-foot .gline{color:var(--gold-2);font-family:var(--head-font);font-weight:500}
body.nav-lock{overflow:hidden}

/* ============================================================
   Animated signal-wave divider (between major sections)
   ============================================================ */
.sigwave{position:relative;height:54px;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 14%,#000 86%,transparent);mask-image:linear-gradient(90deg,transparent,#000 14%,#000 86%,transparent)}
.sigwave svg{position:absolute;top:50%;left:0;width:200%;height:40px;transform:translate(0,-50%)}
.sigwave svg path{fill:none;stroke-linecap:round;vector-effect:non-scaling-stroke}
.sigwave .w1{animation:wave-flow 9s linear infinite}
.sigwave .w1 path{stroke:var(--gold-2);stroke-width:1.8;opacity:.9;animation:wave-pulse 7s ease-in-out infinite}
.sigwave .w2{animation:wave-flow 14s linear infinite reverse}
.sigwave .w2 path{stroke:var(--gold);stroke-width:1.4;opacity:.42}
.sigwave .w3{animation:wave-flow 21s linear infinite}
.sigwave .w3 path{stroke:var(--gold);stroke-width:1.1;opacity:.22}
.section:has(+ .sigwave),.phead:has(+ .sigwave){border-bottom:0}
@keyframes wave-flow{from{transform:translate(0,-50%)}to{transform:translate(-50%,-50%)}}
@keyframes wave-pulse{
  0%,82%,100%{opacity:.85;stroke-width:1.7;filter:none}
  90%{opacity:1;stroke-width:2.6;filter:drop-shadow(0 0 6px rgba(91,155,255,.9))}
}

/* ============================================================
   Smooth page load + reveal + reduced-motion
   ============================================================ */
@keyframes pageIn{from{opacity:0}to{opacity:1}}
body{animation:pageIn .5s ease both}
.reveal{transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1)}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1 !important;transform:none !important}
  .sigwave .w1,.sigwave .w2,.sigwave .w3{animation:none}
  .sigwave .w1 path{animation:none}
  body{animation:none}
}

/* ---------- generic section head ---------- */
.shead{max-width:720px}
.shead .h2{margin-top:16px}
.shead .lead{margin-top:18px}

/* ---------- cards ---------- */
.card{background:var(--bg-card);border:1px solid var(--line-soft);border-radius:var(--radius);
  padding:30px;transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease}
.card:hover{transform:translateY(-4px);border-color:var(--line);box-shadow:0 26px 60px -40px #000}
.card .ic{width:48px;height:48px;border-radius:11px;background:rgba(61,123,255,.1);
  border:1px solid var(--line);display:grid;place-items:center;color:var(--gold-2);margin-bottom:18px}
.card h3{font-size:20px}
.card p{font-size:14.5px;color:var(--muted);margin-top:9px}

/* grids */
.grid{display:grid;gap:22px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:980px){.g4{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:1fr}}
@media(max-width:680px){.g2,.g3,.g4{grid-template-columns:1fr}}
/* collapse doubled padding where two sections meet — kills dead space site-wide */
.section + .section{padding-top:0}

/* ---------- placeholder imagery ---------- */
.ph{position:relative;overflow:hidden;border-radius:var(--radius);border:1px solid var(--line-soft);
  background:
   repeating-linear-gradient(135deg, rgba(61,123,255,.06) 0 10px, rgba(61,123,255,0) 10px 20px),
   #100f0d;}
.ph .tag{position:absolute;left:12px;bottom:11px;font-family:'Inter',monospace;font-size:11px;
  letter-spacing:.03em;color:var(--muted);background:rgba(10,10,10,.6);padding:3px 9px;border-radius:6px}

/* ---------- stats ---------- */
.stat .num{font-family:var(--head-font);font-size:clamp(34px,4vw,52px);font-weight:700;color:var(--head);letter-spacing:-.03em}
.stat .num .u{color:var(--gold-2)}
.stat .lbl{font-size:13.5px;color:var(--muted);margin-top:6px}

/* ---------- footer ---------- */
.ft{background:var(--bg-2);border-top:1px solid var(--line-soft);padding:72px 0 34px}
.ft-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px}
.ft .blurb{color:var(--muted);font-size:14px;margin-top:18px;max-width:300px}
.ft h5{font-family:var(--head-font);font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold-2);font-weight:600;margin-bottom:16px}
.ft a{display:block;color:var(--text);opacity:.8;font-size:14px;margin-bottom:11px;transition:opacity .15s,color .15s}
.ft a:hover{opacity:1;color:var(--gold-2)}
.ft .nlf{display:flex;gap:8px;margin-top:12px}
.ft .nlf input{flex:1;background:rgba(255,255,255,.04);border:1px solid var(--line-soft);color:var(--head);
  border-radius:9px;padding:12px 14px;font-family:var(--body-font);font-size:14px}
.ft .nlf input:focus{outline:none;border-color:var(--gold)}
.ft-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
  margin-top:52px;padding-top:24px;border-top:1px solid var(--line-soft);font-size:13px;color:var(--muted)}
@media(max-width:860px){.ft-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:520px){.ft-grid{grid-template-columns:1fr}}

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

/* ---------- Guardian dashboard tiles ---------- */
.console{background:linear-gradient(180deg,#0e0d0b,#080807);border:1px solid var(--line);
  border-radius:18px;padding:18px;box-shadow:0 50px 120px -60px #000, inset 0 1px 0 rgba(255,255,255,.03)}
.console-top{display:flex;align-items:center;justify-content:space-between;padding:6px 8px 16px;
  border-bottom:1px solid var(--line-soft)}
.console-top .brandline{display:flex;align-items:center;gap:10px;font-family:var(--head-font);font-weight:600;
  font-size:14px;color:var(--head)}
.console-top .live{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;color:var(--gold-2);
  letter-spacing:.06em}
.console-top .live .dot{width:8px;height:8px;border-radius:50%;background:#37d27a;box-shadow:0 0 10px #37d27a;
  animation:blink 2s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.35}}
.tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:16px}
.tile{background:#100f0d;border:1px solid var(--line-soft);border-radius:12px;padding:16px}
.tile .t-lbl{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.tile .t-val{font-family:var(--head-font);font-size:26px;font-weight:600;color:var(--head);margin-top:8px;letter-spacing:-.02em}
.tile .t-val small{font-size:13px;color:var(--gold-2);font-weight:500}
.tile .t-sub{font-size:11.5px;color:var(--muted);margin-top:4px}
.tile.span2{grid-column:span 2}
.spark{display:flex;align-items:flex-end;gap:3px;height:34px;margin-top:10px}
.spark i{flex:1;background:linear-gradient(180deg,var(--gold-2),rgba(61,123,255,.25));border-radius:2px 2px 0 0;
  transition:height .6s cubic-bezier(.2,.8,.2,1)}
@media(max-width:760px){.tiles{grid-template-columns:repeat(2,1fr)}.tile.span2{grid-column:span 2}}

/* mini site-map with nodes */
.sitemap{position:relative;height:100%;min-height:150px;border-radius:10px;overflow:hidden;
  background:radial-gradient(120% 120% at 30% 20%, #14130f, #0a0a0a)}
.sitemap .grid-lines{position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(var(--line-soft) 1px,transparent 1px),linear-gradient(90deg,var(--line-soft) 1px,transparent 1px);
  background-size:34px 34px}
.node{position:absolute;width:10px;height:10px;border-radius:50%;background:var(--gold-2);
  transform:translate(-50%,-50%);box-shadow:0 0 0 4px rgba(61,123,255,.18)}
.node::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:1px solid var(--gold);
  animation:ring 3s ease-out infinite}
@keyframes ring{0%{transform:scale(.6);opacity:.9}100%{transform:scale(2.4);opacity:0}}
.node.n2::after{animation-delay:1s}.node.n3::after{animation-delay:2s}

/* ============================================================
   Vertical detail pages (shared) — golf, marinas, education,
   estates, disaster, utilities, ski
   ============================================================ */
.vhero{position:relative;overflow:hidden;padding:108px 0 80px;border-bottom:1px solid var(--line-soft)}
.vhero .bg{position:absolute;inset:0;z-index:0;
  background:radial-gradient(820px 480px at 78% -8%, rgba(61,123,255,.20), transparent 60%),
             radial-gradient(560px 440px at 6% 110%, rgba(61,123,255,.10), transparent 60%)}
.vhero .ewave{position:absolute;left:0;right:0;top:52%;z-index:1;opacity:.45;height:90px}
.vhero .flyover{position:absolute;inset:0;z-index:0;overflow:hidden}
.vhero .flyover::after{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(8,9,12,.52),rgba(8,9,12,.82))}
.vhero .wrap{position:relative;z-index:3}
.vcrumb{font-size:13px;color:var(--muted)}
.vcrumb a{color:var(--gold-2)}
.vhero h1{font-size:clamp(40px,5.4vw,68px);font-weight:700;letter-spacing:-.03em;margin-top:14px;max-width:17ch}
.vhero h1 .g{color:var(--gold-2)}
.vhero .lead{margin-top:22px}
.vhero .cta-row{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap}
.vstats{display:grid;grid-template-columns:repeat(4,1fr);margin-top:70px;border-top:1px solid var(--line-soft)}
.vstats .stat{padding:26px 24px 0;border-right:1px solid var(--line-soft)}
.vstats .stat:last-child{border-right:0}
@media(max-width:760px){.vstats{grid-template-columns:repeat(2,1fr)}.vstats .stat:nth-child(2n){border-right:0}}

/* problem + coverage meter */
.stakes{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
@media(max-width:860px){.stakes{grid-template-columns:1fr;gap:30px}}
.meter{background:#100f0d;border:1px solid var(--line-soft);border-radius:14px;padding:24px}
.meter h4{font-family:var(--head-font);font-size:13px;letter-spacing:.04em;color:var(--muted);font-weight:600;text-transform:uppercase}
.bar-row{display:flex;align-items:center;gap:14px;margin-top:18px}
.bar-row .name{font-size:13px;color:var(--text);min-width:128px}
.bar-track{flex:1;height:12px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden}
.bar-fill{height:100%;border-radius:999px;width:0;transition:width 1.1s cubic-bezier(.2,.8,.2,1)}
.bar-fill.bad{background:linear-gradient(90deg,#d04040,#e87a5a)}
.bar-fill.good{background:linear-gradient(90deg,var(--gold),var(--gold-2))}
.bar-row .pct{font-family:var(--head-font);font-size:14px;font-weight:600;color:var(--head);min-width:42px;text-align:right}

/* guardian tie-in + layer rows */
.vguard{display:grid;grid-template-columns:.92fr 1.08fr;gap:54px;align-items:center}
@media(max-width:980px){.vguard{grid-template-columns:1fr;gap:36px}}
.g-badge{display:inline-flex;align-items:center;gap:9px;font-family:var(--head-font);font-weight:600;font-size:13px;
  color:var(--gold-2);border:1px solid var(--line);border-radius:999px;padding:7px 14px;letter-spacing:.04em}
.vlayers{display:grid;gap:10px;margin-top:24px}
.vlyr{display:flex;gap:14px;align-items:flex-start;padding:14px 18px;background:#100f0d;border:1px solid var(--line-soft);border-radius:12px}
.vlyr .k{font-family:var(--head-font);font-size:12px;font-weight:700;color:var(--gold-2);min-width:80px;letter-spacing:.02em}
.vlyr .d{font-size:13.5px;color:var(--muted)}

/* outcome band */
.cta-band{background:linear-gradient(135deg,#0e1118,#0a0a0a);border-top:1px solid var(--line-soft)}
.bigstat{font-family:var(--head-font);font-weight:700;color:var(--gold-2);letter-spacing:-.03em;
  font-size:clamp(54px,8vw,96px);line-height:1}
.bigstat .u{color:var(--gold-pale);font-size:.5em}
.bigstat-lbl{color:var(--muted);font-size:15px;margin-top:10px;max-width:34ch;margin-left:auto;margin-right:auto}

/* ============================================================
   Cinematic aerial fly-over hero (golf, events, ski)
   Full-bleed video + animated coverage overlay + scrim
   ============================================================ */
.vhero-cine{padding:0;position:relative;min-height:clamp(580px,88vh,940px);display:flex;align-items:flex-end;overflow:hidden;border-bottom:1px solid var(--line-soft)}
.cine-media{position:absolute;inset:0;z-index:0}
.cine-video{width:100%;height:100%;object-fit:cover;display:block;background:#06080d}
.cine-tag{position:absolute;left:18px;bottom:14px;z-index:6;font-family:var(--body-font);font-size:11px;letter-spacing:.02em;
  color:var(--gold-pale);background:rgba(8,10,16,.62);border:1px solid var(--line);padding:5px 11px;border-radius:7px;
  display:inline-flex;align-items:center;gap:8px;backdrop-filter:blur(4px)}
.cine-tag::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--gold-2);box-shadow:0 0 8px var(--gold-2)}
.cine-scrim{position:absolute;inset:0;z-index:3;pointer-events:none;
  background:linear-gradient(105deg,rgba(6,8,13,.92) 0%,rgba(6,8,13,.6) 38%,rgba(6,8,13,.12) 66%,rgba(6,8,13,0) 88%),
             linear-gradient(180deg,rgba(6,8,13,.5) 0%,rgba(6,8,13,0) 30%,rgba(6,8,13,.1) 55%,rgba(6,8,13,.95) 100%)}
/* coverage overlay */
.cov-field{position:absolute;inset:0;z-index:2;pointer-events:none;overflow:hidden}
.cov-glow{position:absolute;border-radius:50%;transform:translate(-50%,-50%) scale(.4);mix-blend-mode:screen;opacity:0;
  background:radial-gradient(circle, rgba(61,123,255,.55), rgba(111,161,255,.18) 45%, rgba(61,123,255,0) 70%);
  animation:cov-bloom 12s ease-in-out infinite}
.cov-node{position:absolute;width:12px;height:12px;border-radius:50%;transform:translate(-50%,-50%) scale(0);opacity:0;
  background:var(--gold-pale);box-shadow:0 0 16px 4px rgba(61,123,255,.85);animation:cov-ignite 12s ease-in-out infinite}
.cov-node::after{content:"";position:absolute;inset:-7px;border-radius:50%;border:1px solid var(--gold-2);opacity:0;
  animation:cov-ring 12s ease-out infinite}
@keyframes cov-bloom{0%{opacity:0;transform:translate(-50%,-50%) scale(.4)}13%{opacity:.85}22%{transform:translate(-50%,-50%) scale(1)}70%{opacity:.6}92%{opacity:.5}97%{opacity:0}100%{opacity:0}}
@keyframes cov-ignite{0%{opacity:0;transform:translate(-50%,-50%) scale(0)}9%{opacity:1;transform:translate(-50%,-50%) scale(1.3)}15%{transform:translate(-50%,-50%) scale(1)}88%{opacity:1}97%{opacity:0}100%{opacity:0}}
@keyframes cov-ring{0%{opacity:0;transform:scale(.5)}11%{opacity:.8}40%{opacity:0;transform:scale(2.7)}100%{opacity:0;transform:scale(2.7)}}
.cine-wave{position:absolute;left:0;right:0;bottom:20%;z-index:2;opacity:.45;height:64px;pointer-events:none;color:var(--gold-2)}
/* content */
.cine-content{position:relative;z-index:4;width:100%;padding-top:128px;padding-bottom:62px}
.cine-content .vcrumb{color:var(--gold-pale)}
.cine-content .kicker{display:inline-flex;align-items:center;gap:10px;margin-top:14px;font-family:var(--body-font);
  font-weight:600;font-size:13.5px;letter-spacing:.01em;color:var(--gold-pale);background:rgba(61,123,255,.1);
  border:1px solid var(--line);border-radius:999px;padding:8px 16px}
.cine-content h1{font-size:clamp(42px,6vw,80px);font-weight:700;letter-spacing:-.03em;margin-top:18px;max-width:15ch;
  text-shadow:0 2px 30px rgba(0,0,0,.5)}
.cine-content h1 .g{color:var(--gold-2)}
.cine-content .lead{margin-top:20px;max-width:60ch;text-shadow:0 1px 16px rgba(0,0,0,.5)}
.cine-content .cta-row{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.cine-content .vstats{margin-top:56px;border-top-color:rgba(244,233,204,.16)}
@media(prefers-reduced-motion:reduce){
  .cov-glow{opacity:.5;transform:translate(-50%,-50%) scale(1);animation:none}
  .cov-node{opacity:1;transform:translate(-50%,-50%) scale(1);animation:none}
  .cov-node::after{display:none}
}

/* ============================================================
   Reusable drag-to-reveal coverage slider (industry pages)
   ============================================================ */
.compare{position:relative;width:100%;aspect-ratio:16/9;border-radius:18px;overflow:hidden;margin-top:44px;
  border:1px solid var(--line);user-select:none;touch-action:none;cursor:ew-resize;box-shadow:0 50px 110px -60px #000}
.cmap-img{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:0;object-fit:cover}
.compare .layer{position:absolute;inset:0}
.compare .veil{position:absolute;inset:0;background:linear-gradient(150deg,rgba(6,6,6,.2),rgba(6,6,6,.55));z-index:0}
.compare .glow{position:absolute;border-radius:50%;transform:translate(-50%,-50%);mix-blend-mode:screen;
  background:radial-gradient(circle,rgba(61,123,255,.6),rgba(61,123,255,0) 70%)}
.compare .dead{position:absolute;border-radius:50%;transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(208,64,64,.34),rgba(208,64,64,0) 70%)}
.compare .cov-dot{position:absolute;width:11px;height:11px;border-radius:50%;transform:translate(-50%,-50%)}
.compare .layer.after .cov-dot{background:var(--gold-2);box-shadow:0 0 12px 3px rgba(61,123,255,.6)}
.compare .cov-dot.weak{background:#6b6457}
.compare .cov-dot.dead{background:#d04040;box-shadow:0 0 8px 1px rgba(208,64,64,.5)}
.compare .layer.before{clip-path:inset(0 50% 0 0)}
.cbadge{position:absolute;top:18px;font-size:12px;font-weight:600;letter-spacing:.03em;padding:8px 14px;border-radius:999px;
  display:inline-flex;align-items:center;gap:8px;backdrop-filter:blur(5px)}
.cbadge .pip{width:8px;height:8px;border-radius:50%}
.cbadge b{font-family:var(--head-font)}
.b-after{right:18px;background:rgba(61,123,255,.18);color:var(--gold-pale);border:1px solid rgba(61,123,255,.45)}
.b-after .pip{background:var(--gold-2)}
.b-before{left:18px;background:rgba(208,64,64,.16);color:#f0a6a6;border:1px solid rgba(208,64,64,.45)}
.b-before .pip{background:#d04040}
.cdiv{position:absolute;top:0;bottom:0;left:50%;width:2px;background:rgba(253,246,230,.85);transform:translateX(-1px);box-shadow:0 0 14px rgba(0,0,0,.5)}
.chandle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;
  background:var(--head);color:#0a0a0a;border:0;display:grid;place-items:center;cursor:ew-resize;box-shadow:0 6px 20px rgba(0,0,0,.5)}
.chandle svg{width:22px;height:22px}

/* ============================================================
   Guardian operations dashboard (guardian.html centerpiece)
   ============================================================ */
.tile.span3{grid-column:span 3}.tile.span4{grid-column:span 4}
.gops{border:1px solid var(--line);border-radius:20px;overflow:hidden;background:linear-gradient(180deg,#0b0e16,#080a10);
  box-shadow:0 70px 150px -70px #000, inset 0 1px 0 rgba(255,255,255,.03)}
.gops-grid{display:grid;grid-template-columns:224px 1fr}
@media(max-width:1200px){.gops-grid{grid-template-columns:1fr}.gops-grid .gops-side{flex-direction:row;flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;border-right:0;border-bottom:1px solid var(--line-soft);align-items:center;gap:6px;-webkit-overflow-scrolling:touch}.gops-grid .gops-brand{border-bottom:0;margin:0;padding:8px 10px;border-right:1px solid var(--line-soft);flex:none}.gops-grid .gnav{padding:8px 11px;flex:none;white-space:nowrap}.gops-grid .gops-sfoot{display:none}}
.gops-side{background:rgba(255,255,255,.02);border-right:1px solid var(--line-soft);padding:16px 12px;display:flex;flex-direction:column;gap:3px}
.gops-brand{display:flex;align-items:center;gap:9px;font-family:var(--head-font);font-weight:700;color:var(--head);font-size:15px;padding:8px 10px 14px;border-bottom:1px solid var(--line-soft);margin-bottom:8px}
.gnav{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:9px;font-size:13px;color:var(--muted);cursor:default}
.gnav svg{flex:none;opacity:.85}
.gnav.on{background:rgba(61,123,255,.12);color:var(--gold-pale);border:1px solid var(--line)}
.gops-sfoot{margin-top:auto;padding:14px 10px 4px;border-top:1px solid var(--line-soft);font-size:11.5px;color:var(--muted);line-height:1.5}
.gops-sfoot .ok{color:#37d27a}
.gops-top{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-bottom:1px solid var(--line-soft);flex-wrap:wrap}
.gops-top .site{font-family:var(--head-font);font-weight:600;color:var(--head);font-size:14px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.gops-top .chip{font-size:11px;color:var(--gold-pale);border:1px solid var(--line);border-radius:999px;padding:4px 10px;font-family:var(--body-font);font-weight:500}
.gops-top .right{display:flex;gap:18px;align-items:center;font-size:12px;color:var(--muted)}
.gops-top .live{display:inline-flex;align-items:center;gap:7px;color:var(--gold-2);letter-spacing:.04em}
.gops-top .live .dot{width:8px;height:8px;border-radius:50%;background:#37d27a;box-shadow:0 0 10px #37d27a;animation:blink 2s ease-in-out infinite}
.gops-body{padding:14px;display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:760px){.gops-body{grid-template-columns:repeat(2,1fr)}}
/* gauge ring */
.gauge{position:relative;width:104px;height:104px;border-radius:50%;margin-top:8px;
  background:conic-gradient(var(--gold-2) calc(var(--p,99)*1%), rgba(255,255,255,.06) 0)}
.gauge::after{content:"";position:absolute;inset:9px;border-radius:50%;background:#0c0f17}
.gauge .gv{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--head-font);font-weight:700;color:var(--head);font-size:22px}
/* spectrum */
.spec{display:flex;gap:4px;align-items:flex-end;height:48px;margin-top:12px}
.spec i{flex:1;border-radius:2px 2px 0 0;background:rgba(61,123,255,.22)}
.spec i.live{background:linear-gradient(180deg,var(--gold-2),rgba(61,123,255,.3))}
/* radios + lists */
.rlist{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.rrow{display:flex;align-items:center;justify-content:space-between;font-size:12.5px}
.rrow .s{display:inline-flex;align-items:center;gap:8px;color:var(--text)}
.rrow .dotg{width:8px;height:8px;border-radius:50%;background:#37d27a;box-shadow:0 0 8px #37d27a}
.rrow .v{color:var(--muted);font-family:var(--head-font)}
/* alerts */
.alist{display:flex;flex-direction:column;gap:11px;margin-top:12px}
.al{display:flex;gap:11px;align-items:flex-start}
.al .ai{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;flex:none}
.al.ok .ai{background:rgba(55,210,122,.12);color:#37d27a}
.al.warn .ai{background:rgba(61,123,255,.12);color:var(--gold-2)}
.al .at{font-size:12.5px;color:var(--text);line-height:1.4}
.al .am{font-size:11.5px;color:var(--muted);margin-top:2px}
/* camera grid (shared) */
.cams{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}
.tile:has(.cams){display:flex;flex-direction:column}
.tile:has(.cams) .cams{flex:1 1 auto;grid-auto-rows:1fr}
.tile:has(.cams) .cam{aspect-ratio:auto;min-height:108px;background-size:cover;background-position:center}
.cam{position:relative;border-radius:8px;overflow:hidden;aspect-ratio:16/10;
  background:repeating-linear-gradient(135deg,rgba(61,123,255,.06) 0 8px,rgba(61,123,255,0) 8px 16px),#0c0b09;border:1px solid var(--line-soft)}
.cam .rec{position:absolute;top:6px;left:6px;font-size:9px;color:#e87a7a;display:flex;align-items:center;gap:4px}
.cam .rec i{width:6px;height:6px;border-radius:50%;background:#e87a7a;display:inline-block;animation:blink 1.6s ease-in-out infinite}
.cam .cl{position:absolute;bottom:5px;right:7px;font-size:9px;color:var(--muted);font-family:var(--body-font)}
/* node coming-online flash (site map) */
.node.flash{animation:node-flash 1.1s ease-out}
@keyframes node-flash{0%{box-shadow:0 0 0 0 rgba(111,161,255,.9), 0 0 0 4px rgba(61,123,255,.18)}100%{box-shadow:0 0 0 14px rgba(111,161,255,0), 0 0 0 4px rgba(61,123,255,.18)}}
.gops-layers{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:46px}
@media(max-width:900px){.gops-layers{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.gops-layers{grid-template-columns:1fr}}
.glayer{background:var(--bg-card);border:1px solid var(--line-soft);border-radius:16px;padding:26px;position:relative;overflow:hidden}
.glayer::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold)}
.glayer .gi{width:46px;height:46px;border-radius:11px;background:rgba(61,123,255,.1);border:1px solid var(--line);display:grid;place-items:center;color:var(--gold-2);margin-bottom:16px}
.glayer .gk{font-family:var(--head-font);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-2);font-weight:700}
.glayer h3{font-size:19px;margin-top:7px}
.glayer p{font-size:13.5px;color:var(--muted);margin-top:9px}
.glayer ul{list-style:none;margin-top:14px;display:grid;gap:7px}
.glayer li{font-size:12.5px;color:var(--text);display:flex;gap:8px}
.glayer li::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--gold-2);margin-top:7px;flex:none}

/* ============================================================
   VISUAL UPGRADE PASS — finished placeholders, heat-map slider,
   fly-over hero, Cisco-grade polish
   ============================================================ */

/* --- no blank spots: rich mesh-gradient placeholders --- */
.ph{
  background:
   radial-gradient(110% 90% at 12% 6%, rgba(61,123,255,.20), transparent 55%),
   radial-gradient(110% 90% at 90% 16%, rgba(111,161,255,.15), transparent 55%),
   radial-gradient(130% 120% at 72% 112%, rgba(61,123,255,.12), transparent 60%),
   linear-gradient(155deg,#12161f,#0a0d14);
}
.ph::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:linear-gradient(rgba(244,233,204,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(244,233,204,.045) 1px,transparent 1px);
  background-size:42px 42px;
  -webkit-mask-image:radial-gradient(120% 100% at 50% 0%, #000, transparent 80%);
          mask-image:radial-gradient(120% 100% at 50% 0%, #000, transparent 80%)}
.ph::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(70% 60% at 30% 18%, rgba(255,255,255,.05), transparent 60%)}
.ph .tag{z-index:2}

/* trusted-by logo slots: frosted chips, not empty boxes */
.logo-slot{border:1px solid var(--line-soft);border-radius:10px;color:var(--muted);
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.015));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);letter-spacing:.14em;text-transform:uppercase;font-size:10.5px}

/* --- heat-map coverage slider --- */
.compare{box-shadow:0 60px 130px -60px #000, 0 0 0 1px rgba(61,123,255,.12)}
/* Bright5G side: even, cool, edge-to-edge coverage wash */
.compare .layer.after::after{content:"";position:absolute;inset:0;pointer-events:none;mix-blend-mode:screen;
  background:radial-gradient(130% 120% at 50% 45%, rgba(61,123,255,.30), rgba(61,123,255,.16) 58%, rgba(61,123,255,.07) 100%)}
.compare .layer.after .glow{background:radial-gradient(circle,rgba(111,161,255,.5),rgba(61,123,255,0) 70%)}
/* carrier side: hot red and orange dead zones bleeding */
.compare .layer.before .veil{background:linear-gradient(150deg,rgba(26,8,4,.4),rgba(34,12,4,.6))}
.compare .dead{mix-blend-mode:screen;
  background:radial-gradient(circle, rgba(232,72,40,.55), rgba(245,150,46,.34) 42%, rgba(245,150,46,0) 72%)}
.compare .cov-dot.dead{background:#ff6a3d;box-shadow:0 0 10px 2px rgba(245,120,46,.6)}
/* refined divider + handle */
.cdiv{width:2px;background:linear-gradient(180deg,rgba(111,161,255,.25),rgba(253,246,230,.95) 45%,rgba(111,161,255,.25))}
.chandle{width:52px;height:52px;background:linear-gradient(180deg,#ffffff,#dfe7f5);
  box-shadow:0 10px 26px rgba(0,0,0,.55), 0 0 0 6px rgba(61,123,255,.20)}
.chandle svg{color:#0a0d14}

/* --- animated aerial fly-over hero --- */
.flyover{position:absolute;inset:0;z-index:0;overflow:hidden}
.flyover .fv-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;will-change:transform;
  transform:scale(1.08);animation:kenburns 40s ease-in-out infinite alternate}
.flyover .fv-atmo{position:absolute;inset:0;mix-blend-mode:screen;pointer-events:none;
  background:radial-gradient(58% 50% at 74% 10%, rgba(61,123,255,.24), transparent 62%);
  animation:atmo-drift 28s ease-in-out infinite alternate}
@keyframes kenburns{0%{transform:scale(1.07) translate3d(0,0,0)}100%{transform:scale(1.17) translate3d(-2.4%,-2%,0)}}
@keyframes atmo-drift{0%{transform:translate3d(0,0,0)}100%{transform:translate3d(3%,2%,0)}}
@media(prefers-reduced-motion:reduce){.flyover .fv-img{animation:none;transform:scale(1.08)}.flyover .fv-atmo{animation:none}}

/* --- Cisco-grade polish: depth, type, spacing, motion --- */
.card{background:linear-gradient(180deg,#171b24,#11141b);box-shadow:0 1px 0 rgba(255,255,255,.03) inset, 0 24px 50px -38px #000}
.card:hover{box-shadow:0 1px 0 rgba(255,255,255,.05) inset, 0 36px 70px -36px #000, 0 0 0 1px rgba(61,123,255,.2)}
.card .ic{box-shadow:inset 0 1px 0 rgba(255,255,255,.06), 0 8px 18px -10px rgba(61,123,255,.5)}
.btn-gold{box-shadow:0 12px 34px -14px rgba(61,123,255,.8), inset 0 1px 0 rgba(255,255,255,.35)}
.btn:focus-visible{outline:2px solid var(--gold-2);outline-offset:3px}
.lead{line-height:1.62}
.eyebrow::before{box-shadow:0 0 8px rgba(61,123,255,.7)}
.shead .lead{margin-top:20px}
.section{padding:116px 0}
@media(max-width:680px){.section{padding:74px 0}}
.console,.gops{box-shadow:0 80px 160px -70px #000, 0 0 0 1px rgba(61,123,255,.1), inset 0 1px 0 rgba(255,255,255,.04)}
.tile{background:linear-gradient(180deg,#11151d,#0c0f16)}
.feature-cs,.feat{box-shadow:0 40px 90px -56px #000}
.ind-card{box-shadow:0 24px 54px -40px #000}
.ind-card:hover{box-shadow:0 40px 80px -42px #000, 0 0 0 1px rgba(61,123,255,.22)}
.hdr{box-shadow:0 1px 0 rgba(61,123,255,.06)}

/* coverage-slider corner labels */
.cov-tag{position:absolute;top:16px;z-index:6;font:600 14px/1 Inter,sans-serif;padding:10px 16px;border-radius:999px;
  box-shadow:0 6px 20px rgba(0,0,0,.45);max-width:44%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none}
.cov-tag--carrier{left:16px;color:#ffd9d4;background:rgba(120,18,18,.82);border:1px solid rgba(255,120,105,.7)}
.cov-tag--b5{right:16px;color:#dcebff;background:rgba(20,55,160,.82);border:1px solid rgba(120,170,255,.7)}
/* on small screens the two pills would collide in the middle — shrink them and drop the Bright5G pill to the bottom-right corner */
@media(max-width:600px){
  .cov-tag{font-size:11.5px;padding:7px 11px;top:10px;max-width:48%}
  .cov-tag--carrier{left:10px}
  .cov-tag--b5{right:10px;top:auto;bottom:10px}
}
