:root{
  --bg0:#050b18;
  --bg1:#071325;
  --bg2:#0b1730;
  --panel:rgba(12,24,47,.82);
  --panel2:rgba(8,16,32,.92);
  --stroke:rgba(255,255,255,.08);
  --stroke2:rgba(255,255,255,.12);
  --text:#ffffff;
  --muted:#a9bfd5;
  --muted2:#7f97b3;
  --accent:#22d7ff;
  --accent2:#0e4cd3;
  --success:#59ffb2;
  --shadow:0 40px 110px rgba(0,0,0,.55);
  --shadow2:0 20px 70px rgba(0,0,0,.45);
  --radius:18px;
  --radius2:28px;
  --container:1280px;
  --light:#f6f9fd;
  --lighttext:#081327;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:
    radial-gradient(1200px 700px at 15% -10%, rgba(14,76,211,.30), transparent 58%),
    radial-gradient(900px 600px at 80% 10%, rgba(34,215,255,.24), transparent 54%),
    linear-gradient(180deg, var(--bg0), #02060f 68%, #02060f);
  overflow-x:hidden;
}
img{max-width:100%; display:block}
a{color:inherit}
button{font:inherit}
.container{max-width:var(--container); margin:0 auto; padding:0 40px}
@media (max-width: 900px){ .container{padding:0 18px} }

.reveal{opacity:0; transform:translateY(22px); transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1; transform:none}

/* Header */
.site-header{ isolation:isolate;
  position:fixed; inset:0 0 auto 0; z-index:1000;
  background:rgba(5,11,24,.58);
  backdrop-filter: blur(14px);
  border-bottom:1px solid rgba(255,255,255,.04);
  transition: background .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.site-header.is-solid{
  background:rgba(255,255,255,.95);
  border-color:rgba(0,0,0,.08);
  box-shadow:0 10px 36px rgba(0,0,0,.10);
}
.navbar{
  min-height:78px;
  display:flex; align-items:center; justify-content:space-between;
  gap:16px;
}
.brand{display:flex; align-items:center; text-decoration:none}
.brand img{height:44px; width:auto}
.nav{
  display:flex; align-items:center; gap:12px;
}
.nav-link, .nav-btn{
  color:#fff; text-decoration:none; font-size:14px;
  padding:10px 12px; border-radius:999px;
  opacity:.94; border:1px solid transparent; background:transparent;
  cursor:pointer; position:relative;
}
.nav-link:hover, .nav-btn:hover{background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.07)}
.site-header.is-solid .nav-link,
.site-header.is-solid .nav-btn{ color:#081327; }
.site-header.is-solid .nav-link:hover,
.site-header.is-solid .nav-btn:hover{ background:rgba(0,0,0,.04); border-color:rgba(0,0,0,.06); }

.nav-cta{
  border:0; cursor:pointer;
  padding:12px 18px; border-radius:999px;
  color:#06111c; font-weight:800; letter-spacing:.02em;
  background:linear-gradient(90deg, var(--accent), #bff5ff);
  box-shadow:0 18px 48px rgba(34,215,255,.18);
}
.nav-cta:hover{filter:brightness(1.02)}
.burger{
  display:none; border:0; background:transparent; color:#fff;
  width:44px; height:44px; border-radius:12px; cursor:pointer;
  touch-action: manipulation; -webkit-tap-highlight-color: transparent;
}
.burger:hover{ background:rgba(255,255,255,.06)}
.site-header.is-solid .burger{ color:#081327 }
.site-header.is-solid .burger:hover{ background:rgba(0,0,0,.05) }

.mega-wrap{position:relative}
.mega-panel{
  position:absolute; top:calc(100% + 8px); left:0; width:760px;
  padding:18px; border-radius:18px;
  background:rgba(5,12,28,.97);
  border:1px solid rgba(117,157,231,0.18);
  box-shadow:0 24px 60px rgba(0,0,0,.5);
  z-index:1200;
  opacity:0;
  pointer-events:none;
  transform:translateY(-6px);
  transition:opacity .18s ease, transform .18s ease;
}
.mega-wrap:hover .mega-panel,
.mega-wrap.open .mega-panel{
  opacity:1;
  pointer-events:auto;
  transform:translateY(0);
}
.site-header.is-solid .mega-panel{
  background:rgba(255,255,255,.98);
  border-color:rgba(0,0,0,.08);
}
.mega-grid{display:grid; grid-template-columns:1.1fr 1fr; gap:18px}
.mega-left{
  border-radius:16px; padding:18px;
  background:linear-gradient(180deg, rgba(34,215,255,.14), rgba(14,76,211,.10));
  border:1px solid rgba(255,255,255,.10);
}
.site-header.is-solid .mega-left{
  background:linear-gradient(180deg, rgba(34,215,255,.10), rgba(14,76,211,.06));
  border-color:rgba(0,0,0,.06);
}
.mega-title{margin:0 0 10px 0; font-size:13px; font-weight:900; letter-spacing:.12em; text-transform:uppercase}
.mega-desc{margin:0; color:var(--muted); line-height:1.6; font-size:14px}
.site-header.is-solid .mega-desc{ color:#445b73 }
.mega-links{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.mega-card{
  text-decoration:none; border-radius:14px; padding:14px;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
  transition:transform .15s ease, border-color .15s ease, background .15s ease;
}
.mega-card:hover{ transform:translateY(-2px); border-color:rgba(34,215,255,.25); background:rgba(255,255,255,.06)}
.site-header.is-solid .mega-card{ background:rgba(0,0,0,.03); border-color:rgba(0,0,0,.07)}
.site-header.is-solid .mega-card:hover{ background:rgba(0,0,0,.04); border-color:rgba(14,76,211,.18)}
.mega-card h4{margin:0 0 6px 0; font-size:14px}
.mega-card p{margin:0; font-size:12px; line-height:1.5; color:var(--muted)}
.site-header.is-solid .mega-card p{ color:#4e637b }

.mobile-drawer{
  position:fixed;
  top:0; right:0;
  width: min(300px, 88vw);
  height:100vh;
  z-index:999;
  background:rgba(3,9,24,.98);
  border-left:1px solid rgba(117,157,231,0.16);
  backdrop-filter:blur(16px);
  padding:72px 24px 40px;
  display:flex;
  flex-direction:column;
  gap:4px;
  overflow-y:auto;
  transform:translateX(100%);
  transition:transform .28s ease;
  /* NO display:none — use transform only */
}
.mobile-drawer.open{ transform:translateX(0) }
.mobile-drawer a, .mobile-drawer .mobile-section{
  display:block; text-decoration:none; color:#f5f8ff;
  padding:11px 14px; border-radius:10px; font-weight:600; font-size:14px;
  border-bottom:1px solid rgba(117,157,231,0.08);
}
.mobile-drawer .mobile-section{
  font-size:10px; letter-spacing:0.18em; text-transform:uppercase;
  color:#2ed8ff; font-weight:800; border-bottom:none; margin-top:12px;
  padding-bottom:4px;
}
.mobile-drawer a:hover{ background:rgba(255,255,255,0.05); }
.mobile-sub{ padding-left:8px; display:grid; gap:2px; margin-bottom:4px; }
.mobile-sub a{ font-weight:500; color:#bfd0e8; font-size:13px; border-bottom:none; }
.mobile-drawer-overlay{
  display:none;
  position:fixed; inset:0;
  background:rgba(0,0,0,0.55);
  z-index:998;
}
.mobile-drawer-overlay.open{ display:block; }
.mobile-drawer-close{
  position:absolute; top:18px; right:18px;
  background:none; border:none;
  color:#f5f8ff; font-size:22px;
  cursor:pointer; line-height:1;
  padding:6px; border-radius:6px;
}
.mobile-drawer-close:hover{ background:rgba(255,255,255,0.08); }

@media (max-width: 980px){
  .nav{ display:none }
  .burger{ display:block }
  .nav-cta{ display:none } /* per request: hide on mobile landing/header */
  .navbar{ justify-content:space-between }
}

/* Hero */
.hero{
  position:relative;
  min-height:96vh;
  padding-top:130px; padding-bottom:120px;
  overflow:hidden;
}
.hero-video{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
}
.hero-overlay{
  position:absolute; inset:0;
  background:
    radial-gradient(1000px 700px at 15% 20%, rgba(34,215,255,.12), transparent 58%),
    radial-gradient(1000px 600px at 85% 8%, rgba(14,76,211,.24), transparent 54%),
    linear-gradient(rgba(5,11,24,.84), rgba(5,11,24,.94));
}
.hero-grid{
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image: radial-gradient(circle at 50% 35%, rgba(0,0,0,1), rgba(0,0,0,0) 76%);
  opacity:.52;
}
.hero-inner{
  position:relative; display:grid; grid-template-columns:1.05fr .95fr; gap:72px; align-items:center;
}
@media (max-width: 980px){ .hero-inner{ grid-template-columns:1fr; gap:28px } }

.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  padding:8px 12px; border-radius:999px;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.12);
  font-size:12px; color:rgba(255,255,255,.92); letter-spacing:.02em;
  margin-bottom:18px;
}
.pill-dot{
  width:8px; height:8px; border-radius:999px; background:var(--accent);
  box-shadow:0 0 0 6px rgba(34,215,255,.10);
}
.hero h1{
  font-size:68px; line-height:1.03; letter-spacing:-.03em;
  margin:0 0 18px 0;
}
.hero p.lead{
  margin:0 0 26px 0; font-size:18px; line-height:1.6; color:var(--muted);
  max-width:58ch;
}
.hero-copyline{
  margin-top:18px; font-size:20px; font-weight:800; letter-spacing:.04em;
}
.hero-copyline span{ color:var(--accent) }
@media (max-width: 560px){
  .hero h1{ font-size:46px }
  .hero-copyline{ font-size:16px }
}

.cta-row{ display:flex; gap:12px; flex-wrap:wrap }
.btn{
  display:inline-flex; align-items:center; gap:10px;
  text-decoration:none; cursor:pointer;
  border-radius:999px; padding:14px 18px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
  color:#fff; font-weight:800; font-size:13px; letter-spacing:.02em;
  transition: transform .15s ease, border-color .15s ease, background .15s ease;
}
.btn:hover{ transform:translateY(-1px); background:rgba(255,255,255,.08); border-color:rgba(34,215,255,.22) }
.btn.primary{
  color:#05131f; border-color:transparent;
  background:linear-gradient(90deg, var(--accent), #bff5ff);
}
.btn.primary:hover{ filter:brightness(1.02) }

.trust-tags{
  display:flex; gap:12px; flex-wrap:wrap; margin-top:34px;
}
.trust-tag{
  padding:10px 14px; border-radius:999px;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.10);
  color:rgba(255,255,255,.88); font-size:12px;
}

/* Floating UI */
.float-stack{ position:relative }
.panel{
  border-radius:var(--radius2); background:var(--panel);
  border:1px solid rgba(255,255,255,.10); box-shadow:var(--shadow); overflow:hidden;
}
.panel-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 18px; border-bottom:1px solid rgba(255,255,255,.08);
}
.panel-title{
  margin:0; font-size:12px; font-weight:900; letter-spacing:.14em; text-transform:uppercase;
}
.kpi-row{ display:flex; gap:10px }
.kpi{
  padding:8px 12px; border-radius:999px;
  background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.10);
  font-size:12px; color:rgba(255,255,255,.90)
}
.panel-body{ padding:16px 18px 18px }

.mini-grid{ display:grid; grid-template-columns:1fr 1fr; gap:12px }
.mini-card{
  padding:14px; border-radius:16px;
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.08);
}
.mini-card .label{ font-size:12px; color:rgba(255,255,255,.75) }
.mini-card .value{ font-size:18px; font-weight:950; margin-top:8px }
.progress{
  height:14px; margin-top:12px; border-radius:999px;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); overflow:hidden;
}
.progress > span{
  display:block; height:100%; border-radius:999px;
  background: linear-gradient(90deg, rgba(34,215,255,.12), rgba(34,215,255,.6), rgba(14,76,211,.35));
  box-shadow:0 10px 30px rgba(34,215,255,.18);
}

.threat-map{
  position:relative; margin-top:14px; padding:10px;
  height:240px; border-radius:18px;
  background:
    radial-gradient(900px 360px at 20% 25%, rgba(34,215,255,.18), transparent 60%),
    radial-gradient(800px 340px at 80% 55%, rgba(14,76,211,.22), transparent 60%),
    rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
}
.threat-map canvas{ width:100%; height:100%; display:block; border-radius:14px }
.floating-badge{
  position:absolute; right:12px; top:12px;
  padding:10px 12px; border-radius:999px;
  background:rgba(5,11,24,.62); border:1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(10px); font-size:12px;
}
.floating-badge strong{ color:var(--accent) }

/* Marquee */
.marquee-wrap{
  overflow:hidden;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
  background:rgba(255,255,255,.02);
}
.marquee{
  display:flex; gap:18px; white-space:nowrap;
  width:max-content; padding:14px 0;
  animation: marquee 28s linear infinite;
}
.marquee:hover{ animation-play-state:paused }
.marquee-item{
  padding:10px 16px; border-radius:999px;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.10);
  font-size:13px; color:rgba(255,255,255,.90)
}
.marquee-item strong{ color:var(--accent) }
@keyframes marquee{
  from{ transform:translateX(0) }
  to{ transform:translateX(-50%) }
}

/* Sections */
.section{ padding:140px 0 }
.section.tight{ padding:96px 0 }
.section.light{ background:var(--light); color:var(--lighttext) }
.kicker{
  color:var(--accent); font-size:12px; letter-spacing:.16em; text-transform:uppercase; font-weight:900; margin:0 0 12px 0;
}
.section.light .kicker{ color:#0e4cd3 }
.section h2{ margin:0 0 16px 0; font-size:46px; letter-spacing:-.02em }
.sub{ margin:0; font-size:16px; line-height:1.65; color:var(--muted); max-width:72ch }
.section.light .sub{ color:#455c74 }

.stats{
  display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:54px;
}
@media (max-width:980px){ .stats{ grid-template-columns:repeat(2,1fr) } }
@media (max-width:520px){ .stats{ grid-template-columns:1fr } }
.stat{
  border-radius:18px; padding:18px;
  border:1px solid rgba(255,255,255,.10); background:rgba(255,255,255,.03);
}
.section.light .stat{ border-color:rgba(0,0,0,.08); background:rgba(0,0,0,.02) }
.stat .num{ font-size:28px; font-weight:950; letter-spacing:-.02em }
.stat .lbl{ margin-top:6px; color:var(--muted); font-size:12px; line-height:1.55 }
.section.light .stat .lbl{ color:#4f667f }

.feature-row{
  display:grid; grid-template-columns:1fr 1fr; gap:70px; align-items:center; margin-top:78px;
}
@media (max-width:980px){ .feature-row{ grid-template-columns:1fr; gap:28px } }
.feature-title{ margin:0 0 10px 0; font-size:28px; letter-spacing:-.01em }
.bullets{ margin-top:18px; display:grid; gap:10px }
.bullet{ display:flex; gap:12px; align-items:flex-start; font-size:14px; line-height:1.6 }
.bullet .tick{
  width:18px; height:18px; flex:0 0 auto; margin-top:2px;
  border-radius:8px; border:1px solid rgba(34,215,255,.30); background:rgba(34,215,255,.12);
  box-shadow:0 0 0 6px rgba(34,215,255,.08);
}
.section.light .bullet .tick{
  border-color:rgba(14,76,211,.18); background:rgba(14,76,211,.10); box-shadow:0 0 0 6px rgba(14,76,211,.08)
}

.ui-mock{
  height:390px; border-radius:var(--radius2); overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(900px 420px at 25% 30%, rgba(34,215,255,.18), transparent 60%),
    radial-gradient(900px 420px at 75% 60%, rgba(14,76,211,.22), transparent 60%),
    rgba(255,255,255,.03);
  box-shadow:var(--shadow2);
}
.section.light .ui-mock{
  border-color:rgba(0,0,0,.08);
  background:
    radial-gradient(900px 420px at 25% 30%, rgba(14,76,211,.10), transparent 60%),
    radial-gradient(900px 420px at 75% 60%, rgba(34,215,255,.12), transparent 60%),
    rgba(0,0,0,.02);
}
.topbar{
  height:48px; display:flex; align-items:center; justify-content:space-between;
  padding:0 14px; border-bottom:1px solid rgba(255,255,255,.08); background:rgba(255,255,255,.03);
}
.section.light .topbar{ border-color:rgba(0,0,0,.08); background:rgba(0,0,0,.02) }
.dots{ display:flex; gap:7px }
.dot{ width:10px; height:10px; border-radius:99px; background:rgba(255,255,255,.18) }
.dot:nth-child(1){ background:rgba(255,98,98,.42) }
.dot:nth-child(2){ background:rgba(255,208,98,.42) }
.dot:nth-child(3){ background:rgba(88,255,158,.42) }
.title{ font-size:12px; font-weight:900; letter-spacing:.10em; text-transform:uppercase; color:rgba(255,255,255,.84) }
.section.light .title{ color:#21354e }
.content{
  padding:16px; height:calc(100% - 48px);
  display:grid; grid-template-columns:1.2fr .8fr; gap:14px;
}
@media (max-width:980px){ .content{ grid-template-columns:1fr } }
.ui-card{
  border-radius:18px; padding:14px; border:1px solid rgba(255,255,255,.08); background:rgba(255,255,255,.03)
}
.section.light .ui-card{ border-color:rgba(0,0,0,.08); background:rgba(0,0,0,.02) }
.ui-card h4{ margin:0 0 10px 0; font-size:12px; font-weight:900; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.86) }
.section.light .ui-card h4{ color:#1e3249 }
.ui-lines{ display:grid; gap:10px }
.ui-line{
  height:12px; border-radius:999px; position:relative; overflow:hidden;
  background:linear-gradient(90deg, rgba(255,255,255,.08), rgba(34,215,255,.18), rgba(255,255,255,.06));
}
.section.light .ui-line{
  background:linear-gradient(90deg, rgba(0,0,0,.05), rgba(14,76,211,.10), rgba(0,0,0,.03));
}
.ui-line::after{
  content:""; position:absolute; inset:0; transform:translateX(-70%);
  background:linear-gradient(90deg, transparent, rgba(34,215,255,.24), transparent);
  animation:sweep 2.8s linear infinite;
}
.ui-chart{ height:164px; border-radius:14px; border:1px solid rgba(255,255,255,.08); background:rgba(255,255,255,.03); overflow:hidden }
.section.light .ui-chart{ border-color:rgba(0,0,0,.08); background:rgba(0,0,0,.02) }
.ui-chart canvas{ width:100%; height:100%; display:block }
@keyframes sweep{ to{ transform:translateX(70%) } }

.tab-row{
  display:flex; gap:10px; flex-wrap:wrap; margin-top:22px
}
.filter-chip{
  border:1px solid rgba(255,255,255,.10); background:rgba(255,255,255,.04); color:#fff;
  padding:10px 14px; border-radius:999px; cursor:pointer; font-weight:700; font-size:13px;
}
.filter-chip.active{ background:linear-gradient(90deg, var(--accent), #bff5ff); color:#05131f; border-color:transparent }

.cards{
  display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:26px
}
@media (max-width:980px){ .cards{ grid-template-columns:1fr 1fr } }
@media (max-width:620px){ .cards{ grid-template-columns:1fr } }
.card{
  border-radius:22px; border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03); padding:22px;
  transition:transform .16s ease, background .16s ease, border-color .16s ease;
}
.card:hover{ transform:translateY(-4px); background:rgba(255,255,255,.05); border-color:rgba(34,215,255,.22) }
.section.light .card{ border-color:rgba(0,0,0,.08); background:rgba(0,0,0,.02) }
.section.light .card:hover{ background:rgba(0,0,0,.03); border-color:rgba(14,76,211,.18) }
.card h3{ margin:0 0 10px 0; font-size:20px }
.card p{ margin:0; color:var(--muted); font-size:14px; line-height:1.6 }
.section.light .card p{ color:#526982 }

.cta-band{
  margin-top:58px; padding:34px 36px;
  border-radius:var(--radius2); border:1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(900px 420px at 25% 30%, rgba(34,215,255,.18), transparent 60%),
    radial-gradient(900px 420px at 75% 60%, rgba(14,76,211,.22), transparent 60%),
    rgba(255,255,255,.03);
  display:flex; align-items:center; justify-content:space-between; gap:22px;
}
@media (max-width:980px){ .cta-band{ flex-direction:column; align-items:flex-start } }
.section.light .cta-band{
  border-color:rgba(0,0,0,.08);
  background:
    radial-gradient(900px 420px at 25% 30%, rgba(14,76,211,.08), transparent 60%),
    radial-gradient(900px 420px at 75% 60%, rgba(34,215,255,.10), transparent 60%),
    rgba(0,0,0,.02);
}
.cta-band h3{ margin:0; font-size:25px; letter-spacing:-.01em }
.cta-band p{ margin:8px 0 0 0; color:var(--muted); line-height:1.6 }
.section.light .cta-band p{ color:#46607a }

/* Consultation form */
.form-shell{
  margin-top:54px; border-radius:24px; overflow:hidden;
  border:1px solid rgba(255,255,255,.10); background:#f3f5f7; color:#16263b;
}
.form-head{
  padding:22px 28px; background:#277db0; color:#fff; font-weight:900; letter-spacing:.02em; text-transform:uppercase;
}
.form-body{ padding:28px }
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px 24px }
@media (max-width:780px){ .form-grid{ grid-template-columns:1fr } }
.form-field label{
  display:block; font-size:14px; font-weight:700; margin-bottom:8px;
}
.form-field input, .form-field textarea{
  width:100%; border:1px solid #8f9cab; background:#fff;
  border-radius:0; padding:12px 14px; font-size:15px; color:#12253c;
}
.form-field textarea{ min-height:90px; resize:vertical }
.radio-row{
  display:flex; flex-wrap:wrap; gap:20px; margin-top:8px
}
.radio-row .option{ display:flex; align-items:center; gap:10px; font-size:15px }
.form-submit{
  margin-top:26px; width:100%;
  border:0; background:#277db0; color:#fff; font-weight:900; letter-spacing:.08em; text-transform:uppercase;
  padding:18px 20px; cursor:pointer;
}
.form-note{ margin-top:12px; color:#5e6b7a; font-size:13px }

/* Team */
.team-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:32px }
@media (max-width:980px){ .team-grid{ grid-template-columns:1fr 1fr } }
@media (max-width:620px){ .team-grid{ grid-template-columns:1fr } }
.person{
  border-radius:22px; overflow:hidden; border:1px solid rgba(255,255,255,.10); background:rgba(255,255,255,.03)
}
.person img{ aspect-ratio: 1 / 1; object-fit:cover; width:100% }
.person-body{ padding:18px }
.person h3{ margin:0 0 6px 0; font-size:18px }
.role{ color:var(--accent); font-weight:800; font-size:12px; letter-spacing:.10em; text-transform:uppercase }
.person p{ color:var(--muted); font-size:14px; line-height:1.6 }

/* Resources accordion */
.accordion{ display:grid; gap:12px; margin-top:32px }
.acc-item{
  border:1px solid rgba(255,255,255,.10); border-radius:18px; background:rgba(255,255,255,.03); overflow:hidden
}
.acc-head{
  width:100%; text-align:left; cursor:pointer; border:0; background:transparent; color:inherit;
  padding:18px 18px; font-weight:800; display:flex; align-items:center; justify-content:space-between
}
.acc-body{
  display:none; padding:0 18px 18px; color:var(--muted); line-height:1.7
}
.acc-item.open .acc-body{ display:block }

.socials{ display:flex; gap:10px; flex-wrap:wrap; margin-top:16px }
.social{
  display:inline-flex; align-items:center; gap:8px;
  border:1px solid rgba(255,255,255,.10); background:rgba(255,255,255,.04);
  padding:10px 12px; border-radius:999px; text-decoration:none; font-size:13px;
}
.social:hover{ border-color:rgba(34,215,255,.22); background:rgba(255,255,255,.06) }

/* Footer */
.site-footer{
  margin-top:0; padding:90px 0; background:#02060f; border-top:1px solid rgba(255,255,255,.06)
}
.footer-grid{ display:grid; grid-template-columns:1.3fr 1fr 1fr 1fr; gap:36px }
@media (max-width:980px){ .footer-grid{ grid-template-columns:1fr 1fr } }
@media (max-width:620px){ .footer-grid{ grid-template-columns:1fr } }
.footer-brand img{ height:42px; width:auto; margin-bottom:16px }
.fh{ margin:0 0 12px 0; font-size:12px; letter-spacing:.16em; text-transform:uppercase; opacity:.9 }
.fp{ margin:0; color:var(--muted); line-height:1.7; font-size:14px }
.flist{ display:grid; gap:10px; color:var(--muted); font-size:14px }
.flist a{text-decoration:none}
.flist a:hover{ color:#fff }
.copyright{ margin-top:34px; color:rgba(255,255,255,.55); font-size:12px }



.team-grid{
display:grid;
grid-template-columns:repeat(4,1fr);
gap:32px;
margin-top:40px;
}

.team-modal{
position:fixed;
inset:0;
background:rgba(0,0,0,.7);
display:none;
align-items:center;
justify-content:center;
z-index:2000;
}

.team-modal.open{
display:flex;
}

.team-modal-inner{
background:#0b1730;
padding:40px;
max-width:600px;
border-radius:16px;
border:1px solid rgba(255,255,255,.1);
}

.team-close{
position:absolute;
right:20px;
top:20px;
font-size:28px;
cursor:pointer;
}



/* --- Interactive Team Cards Upgrade --- */

.team-grid{
display:grid;
grid-template-columns:repeat(4,1fr);
gap:32px;
margin-top:40px;
}

.person{
position:relative;
border-radius:18px;
overflow:hidden;
cursor:pointer;
transition:transform .25s ease, box-shadow .25s ease;
}

.person img{
width:100%;
display:block;
transition:transform .4s ease;
}

.person:hover{
transform:translateY(-6px) scale(1.02);
box-shadow:0 25px 60px rgba(0,0,0,.45);
}

.person:hover img{
transform:scale(1.06);
}

.person::after{
content:"View Bio";
position:absolute;
bottom:0;
left:0;
right:0;
padding:14px;
text-align:center;
font-weight:600;
letter-spacing:.03em;
background:linear-gradient(180deg,transparent,rgba(0,0,0,.8));
color:white;
opacity:0;
transform:translateY(10px);
transition:.25s;
}

.person:hover::after{
opacity:1;
transform:translateY(0);
}

.person-body{
padding:16px 18px;
background:rgba(10,20,40,.85);
backdrop-filter:blur(10px);
}

.person-body h3{
margin:4px 0;
font-size:18px;
}

.person-body .role{
font-size:13px;
opacity:.75;
}

/* Modal Animation */

.team-modal{
position:fixed;
inset:0;
background:rgba(0,0,0,.75);
display:none;
align-items:center;
justify-content:center;
z-index:3000;
}

.team-modal.open{
display:flex;
animation:fadeIn .25s ease;
}

.team-modal-inner{
background:#071325;
padding:40px;
max-width:640px;
border-radius:20px;
border:1px solid rgba(255,255,255,.1);
animation:popIn .3s ease;
}

@keyframes popIn{
from{transform:scale(.92);opacity:0}
to{transform:scale(1);opacity:1}
}

.team-close{
position:absolute;
right:24px;
top:20px;
font-size:28px;
cursor:pointer;
}



/* ===== Mobile form responsiveness hotfix ===== */
.form-shell{
  overflow:hidden;
}

.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px 24px;
}

.radio-row{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px 22px;
  align-items:start;
}

.radio-row .option{
  display:flex;
  align-items:flex-start;
  gap:10px;
  min-width:0;
  line-height:1.35;
  font-size:15px;
}

.radio-row .option input{
  margin-top:2px;
  flex:0 0 auto;
}

@media (max-width: 900px){
  .form-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width: 640px){
  .form-body{
    padding:20px 16px;
  }

  .form-grid{
    gap:16px;
  }

  .form-field{
    min-width:0;
  }

  .form-field label{
    line-height:1.35;
  }

  .form-field input,
  .form-field textarea{
    font-size:16px;
  }

  .radio-row{
    grid-template-columns:1fr;
    gap:12px;
  }

  .radio-row .option{
    align-items:center;
    font-size:16px;
  }

  .form-submit{
    width:100%;
  }
}


/* ===== V2 mobile form hard fix ===== */
.form-shell,
.form-body,
.form-grid,
.form-field,
.radio-row,
.radio-row .option{
  max-width:100%;
  min-width:0;
}

.form-grid{
  display:grid;
  grid-template-columns: minmax(0,1fr) minmax(0,1fr);
  gap:18px 24px;
}

.form-field{
  width:100%;
  overflow:hidden;
}

.form-field input,
.form-field textarea{
  width:100%;
  max-width:100%;
}

.radio-row{
  display:grid !important;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:14px 18px;
  align-items:start;
}

.radio-row .option{
  display:grid !important;
  grid-template-columns: 22px minmax(0,1fr);
  align-items:start;
  column-gap:10px;
  row-gap:0;
  width:100%;
  margin:0;
  white-space:normal;
  overflow-wrap:anywhere;
  word-break:break-word;
  line-height:1.35;
}

.radio-row .option input{
  margin:2px 0 0 0;
  width:22px;
  height:22px;
}

@media (max-width: 900px){
  .form-grid{
    grid-template-columns:minmax(0,1fr);
  }
}

@media (max-width: 640px){
  .form-shell{
    border-radius:18px;
  }

  .form-body{
    padding:18px 14px !important;
  }

  .form-head{
    padding:18px 14px;
    font-size:14px;
    line-height:1.35;
  }

  .form-grid{
    gap:14px;
  }

  .form-field label{
    font-size:13px;
    line-height:1.35;
    margin-bottom:6px;
  }

  .form-field input,
  .form-field textarea{
    font-size:16px;
    padding:12px;
  }

  .radio-row{
    grid-template-columns:minmax(0,1fr) !important;
    gap:12px;
  }

  .radio-row .option{
    grid-template-columns: 22px minmax(0,1fr);
    font-size:15px;
  }

  .form-submit{
    width:100%;
    padding:16px 18px;
  }

  .form-note{
    font-size:12px;
    line-height:1.45;
  }
}


/* ===== Mobile company/team layout fix ===== */
.team-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:32px;
  margin-top:40px;
}

.person{
  min-width:0;
  width:100%;
}

.person-body{
  min-width:0;
}

.person-body h3,
.person-body p,
.person-body .role{
  overflow-wrap:anywhere;
  word-break:break-word;
}

@media (max-width: 1100px){
  .team-grid{
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:24px;
  }
}

@media (max-width: 800px){
  .team-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:20px;
  }
}

@media (max-width: 640px){
  .team-grid{
    grid-template-columns:minmax(0, 1fr) !important;
    gap:18px;
  }

  .person{
    border-radius:16px;
  }

  .person img{
    width:100%;
    height:auto;
    aspect-ratio:1 / 1;
    object-fit:cover;
  }

  .person-body{
    padding:14px 14px 16px;
  }

  .person-body h3{
    font-size:18px;
    line-height:1.25;
  }

  .person-body p{
    font-size:14px;
    line-height:1.5;
  }

  .person-body .role{
    font-size:12px;
    line-height:1.35;
  }

  .team-modal-inner{
    width:min(92vw, 640px);
    max-height:85vh;
    overflow:auto;
    padding:22px 18px;
    border-radius:16px;
  }
}




/* ── MOBILE RESPONSIVENESS ───────────────────────────────────── */
@media (max-width: 980px) {
  .nav     { display: none; }
  .nav-cta { display: none; }
  .burger  { display: block; }
}

@media (max-width: 1024px) {
  .hero-inner  { grid-template-columns: 1fr !important; }
  .float-stack { display: none !important; }
  .feature-row { grid-template-columns: 1fr !important; gap: 32px; }
}

@media (max-width: 768px) {
  h1           { font-size: clamp(32px, 8vw, 50px) !important; }
  h2           { font-size: clamp(24px, 6vw, 38px) !important; }
  .lead        { font-size: 15px; }
  .cards       { grid-template-columns: 1fr !important; }
  .stats       { grid-template-columns: repeat(2,1fr) !important; gap: 14px; }
  .mini-grid   { grid-template-columns: 1fr !important; }
  .form-grid   { grid-template-columns: 1fr !important; }
  .radio-row   { flex-wrap: wrap; gap: 10px; }
  .footer-grid { grid-template-columns: 1fr !important; gap: 28px; }
  .cta-row     { flex-direction: column; }
  .cta-row .btn{ width: 100%; text-align: center; }
  .trust-tags  { flex-wrap: wrap; gap: 8px; }
  .section, .section.light { padding: 56px 0; }
  .mega-panel  { display: none !important; }
  .platform-panels,
  .panel-row   { grid-template-columns: 1fr !important; }
}

@media (max-width: 480px) {
  .container   { padding: 0 18px; }
  .stats       { grid-template-columns: 1fr !important; }
}

/* ── KPI LIVE DOT ────────────────────────────────────────────── */
.kpi-live {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 700; color: #2ed8ff;
}
.kpi-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: #2ed8ff; display: block; flex-shrink: 0;
  animation: kpiPulse 2s infinite;
}
@keyframes kpiPulse {
  0%,100%{ opacity:1; transform:scale(1); }
  50%     { opacity:.55; transform:scale(1.25); }
}
