:root {
  --blue: #2d84ff;
  --blue-deep: #005ea8;
  --cyan: #00aeef;
  --navy: #061322;
  --navy-2: #0a1b2f;
  --line: rgba(114, 172, 255, 0.28);
  --text: #111827;
  --muted: #64748b;
  --soft: #f5f7fa;
  --white: #ffffff;
  --max: 1440px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, Manrope, "Segoe UI", Arial, sans-serif;
  color: var(--text);
  background: var(--white);
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

.site-header {
  position: fixed;
  inset: 0 0 auto;
  z-index: 20;
  height: 76px;
  display: grid;
  grid-template-columns: minmax(190px, 280px) 1fr minmax(190px, 250px);
  align-items: center;
  padding: 0 clamp(18px, 6vw, 88px);
  color: #fff;
  background: rgba(4, 15, 28, 0.82);
  border-bottom: 1px solid rgba(167, 199, 255, 0.18);
  backdrop-filter: blur(18px);
  transition: background 0.25s ease, height 0.25s ease;
}
.site-header.scrolled { height: 66px; background: rgba(4, 15, 28, 0.96); }
.brand img { width: 202px; height: 54px; object-fit: contain; object-position: left center; }
.main-nav { display: flex; justify-content: center; gap: clamp(18px, 2.6vw, 38px); font-size: 13px; font-weight: 700; text-transform: uppercase; }
.main-nav a { position: relative; padding: 30px 0 26px; color: rgba(255,255,255,.9); }
.main-nav a.active, .main-nav a:hover { color: var(--blue); }
.main-nav a::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 2px;
  transform: scaleX(0);
  background: var(--blue);
  transition: transform .25s ease;
}
.main-nav a.active::after, .main-nav a:hover::after { transform: scaleX(1); }
.header-contact { justify-self: end; display: grid; gap: 8px; padding-left: 20px; border-left: 1px solid rgba(255,255,255,.22); font-size: 14px; }
.header-contact a { color: #fff; }
.menu-toggle { display: none; }

.hero {
  min-height: 568px;
  position: relative;
  overflow: hidden;
  color: #fff;
  background: var(--navy);
  padding-top: 76px;
}
.hero-bg {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(2,12,24,.96) 0%, rgba(2,12,24,.92) 36%, rgba(2,12,24,.48) 63%, rgba(2,12,24,.22) 100%),
    radial-gradient(circle at 58% 22%, rgba(45,132,255,.2), transparent 34%),
    linear-gradient(180deg, rgba(8,31,56,.85), rgba(3,14,26,.96));
}
.hero-shell {
  position: relative;
  max-width: 1536px;
  min-height: 492px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(560px, 620px) minmax(0, 1fr);
  align-items: center;
  gap: 30px;
  padding: 28px clamp(18px, 6.1vw, 94px) 28px;
}
.hero-copy { z-index: 2; }
.eyebrow {
  margin: 0 0 14px;
  color: #3b91ff;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0;
}
h1, h2, h3, p { margin-top: 0; }
h1 {
  margin-bottom: 18px;
  font-size: clamp(34px, 3vw, 48px);
  line-height: 1.08;
  letter-spacing: 0;
}
h1 span { color: #3f8cff; }
.hero-text {
  max-width: 600px;
  color: rgba(255,255,255,.88);
  font-size: 15px;
  line-height: 1.55;
}
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin: 22px 0 28px; }
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 24px;
  border-radius: 5px;
  border: 1px solid rgba(45,132,255,.72);
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
}
.btn:hover, .btn:focus-visible { transform: translateY(-2px); box-shadow: 0 0 34px rgba(45,132,255,.28); border-color: rgba(0,174,239,.9); }
.btn:disabled { cursor: wait; opacity: .68; transform: none; box-shadow: none; }
.btn.primary { background: linear-gradient(180deg, #3a91ff, #1672eb); color: #fff; border-color: transparent; }
.btn.ghost, .btn.compact { color: #fff; background: rgba(4,19,37,.28); }
.btn.compact { min-height: 38px; padding: 0 18px; font-size: 11px; }
.capability-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(120px, 1fr));
  gap: 0;
  max-width: 720px;
  color: rgba(255,255,255,.88);
}
.capability-row span {
  min-height: 48px;
  padding: 4px 20px;
  display: flex;
  align-items: center;
  border-left: 1px solid rgba(255,255,255,.24);
  font-size: 13px;
  line-height: 1.35;
}
.ops-visual {
  position: relative;
  align-self: stretch;
  min-height: 486px;
  margin-right: calc(clamp(18px, 6.1vw, 94px) * -1);
  border-left: 1px solid rgba(120, 180, 255, .16);
  overflow: hidden;
  transform: translate3d(0, var(--parallax-y, 0px), 0);
  transition: transform .18s ease-out;
}
.ops-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  opacity: .96;
  filter: saturate(1.05) contrast(1.03);
  animation: imageDrift 13s ease-in-out infinite alternate;
}
.ops-visual::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(6,19,34,.88) 0%, rgba(6,19,34,.24) 20%, transparent 44%);
  pointer-events: none;
  z-index: 1;
}
.ops-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(115deg, transparent 0 38%, rgba(0,174,239,.12) 48%, transparent 58% 100%);
  transform: translateX(-24%);
  animation: panelSweep 7s ease-in-out infinite;
  pointer-events: none;
  z-index: 2;
}
.scan-line,
.camera-frame,
.map-pulse,
.map-route,
.monitor-glow {
  position: absolute;
  z-index: 3;
  pointer-events: none;
}
.scan-line {
  left: 1%;
  right: 24%;
  top: 49%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(77, 168, 255, .9), transparent);
  box-shadow: 0 0 18px rgba(45,132,255,.6);
  animation: scanTravel 4.8s ease-in-out infinite;
}
.camera-frame {
  width: 14.4%;
  height: 16%;
  border: 1px solid rgba(84, 170, 255, .42);
  border-radius: 4px;
  box-shadow: inset 0 0 18px rgba(0,174,239,.14), 0 0 18px rgba(0,174,239,.12);
  animation: cameraFocus 3.8s ease-in-out infinite;
}
.camera-a { left: 19%; bottom: 9%; }
.camera-b { left: 42%; bottom: 9%; animation-delay: 1.1s; }
.map-pulse {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #45a0ff;
  box-shadow: 0 0 0 0 rgba(69,160,255,.55), 0 0 20px rgba(69,160,255,.8);
  animation: mapPulse 2.4s ease-in-out infinite;
}
.map-pulse::after {
  content: "";
  position: absolute;
  inset: -7px;
  border: 1px solid rgba(69,160,255,.35);
  border-radius: inherit;
  opacity: .8;
}
.map-pulse.p1 { left: 43%; top: 34%; }
.map-pulse.p2 { left: 51%; top: 43%; animation-delay: .35s; background: #22d38d; }
.map-pulse.p3 { left: 57%; top: 31%; animation-delay: .7s; background: #ffbc42; }
.map-pulse.p4 { left: 62%; top: 49%; animation-delay: 1.05s; }
.map-pulse.p5 { left: 47%; top: 55%; animation-delay: 1.4s; background: #ff7a45; }
.map-pulse.p6 { left: 69%; top: 38%; animation-delay: 1.75s; background: #78f7ff; }
.map-route {
  width: 19%;
  height: 2px;
  transform-origin: left center;
  background: linear-gradient(90deg, transparent, rgba(42, 144, 255, .82), rgba(35, 209, 139, .72), transparent);
  filter: drop-shadow(0 0 8px rgba(0,174,239,.5));
  animation: routeFlow 2.8s linear infinite;
}
.route-a { left: 44%; top: 39%; transform: rotate(18deg); }
.route-b { left: 51%; top: 48%; transform: rotate(-27deg); animation-delay: .65s; }
.monitor-glow {
  bottom: 6%;
  width: 18%;
  height: 22%;
  border-radius: 5px;
  background: radial-gradient(circle at 50% 42%, rgba(45,132,255,.22), transparent 62%);
  animation: monitorBlink 3.2s ease-in-out infinite;
}
.glow-a { left: 17%; }
.glow-b { left: 41%; animation-delay: 1.3s; }

section { padding: 72px clamp(18px, 6vw, 88px); }
.solutions { padding-top: 26px; padding-bottom: 24px; }
.platforms { padding-top: 34px; padding-bottom: 38px; }
.dark-band { color: #fff; background: linear-gradient(180deg, #07182b, #041121); border-top: 1px solid rgba(145,190,255,.16); }
.light-band { background: linear-gradient(180deg, #fff, #f6f8fb); }
.platforms.light-band {
  color: #fff;
  background:
    radial-gradient(circle at 68% 8%, rgba(45,132,255,.16), transparent 31%),
    linear-gradient(180deg, #061322 0%, #07182b 58%, #040d19 100%);
  border-top: 1px solid rgba(145,190,255,.16);
}
.section-grid {
  max-width: var(--max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 42px;
  align-items: start;
}
.section-intro h2, .wide h2 {
  font-size: clamp(24px, 2.35vw, 36px);
  line-height: 1.14;
  letter-spacing: 0;
  margin-bottom: 22px;
}
.section-intro p:not(.eyebrow) { color: rgba(255,255,255,.76); line-height: 1.6; }
.solution-console {
  display: grid;
  grid-template-columns: 1fr;
  min-height: 0;
  border: 1px solid rgba(148, 190, 255, .28);
  border-radius: 8px;
  overflow: hidden;
  background: linear-gradient(145deg, rgba(19,48,79,.48), rgba(7,22,40,.78));
  backdrop-filter: blur(12px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05), 0 24px 46px rgba(0,0,0,.18);
}
.solution-tabs {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  align-content: stretch;
  gap: 0;
  padding: 0;
  border-right: 0;
  border-bottom: 1px solid rgba(148, 190, 255, .18);
  background: rgba(2, 12, 24, .28);
}
.solution-tab {
  min-height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border: 1px solid transparent;
  border-right-color: rgba(148, 190, 255, .14);
  border-radius: 0;
  padding: 0 12px;
  color: rgba(255,255,255,.78);
  background: transparent;
  font: inherit;
  font-size: 13px;
  font-weight: 800;
  text-align: center;
  cursor: pointer;
  transition: background .18s ease, border-color .18s ease, color .18s ease, transform .18s ease;
}
.solution-tab:last-child { border-right-color: transparent; }
.solution-tab span { width: 20px; color: var(--blue); font-size: 18px; text-align: center; }
.solution-tab:hover, .solution-tab:focus-visible { transform: translateY(-2px); color: #fff; border-color: rgba(45,132,255,.42); background: rgba(45,132,255,.12); }
.solution-tab.active { color: #fff; border-color: rgba(0,174,239,.72); background: linear-gradient(180deg, rgba(45,132,255,.25), rgba(0,174,239,.08)); box-shadow: inset 0 -3px 0 var(--cyan), 0 0 26px rgba(45,132,255,.18); }
.solution-detail {
  position: relative;
  min-height: 112px;
  padding: 16px 22px;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(190px, .34fr) minmax(260px, .66fr) auto;
  gap: 18px 26px;
  align-items: center;
}
.solution-detail::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 88% 18%, rgba(0,174,239,.16), transparent 28%),
    linear-gradient(90deg, rgba(45,132,255,.08), transparent 48%);
  pointer-events: none;
}
.solution-detail > * { position: relative; }
.solution-detail-top { grid-row: 1 / span 3; }
.solution-detail h3,
.solution-detail p,
.solution-detail ul { grid-column: 2; }
.solution-detail h3 { grid-row: 1; }
.solution-detail p { grid-row: 2; }
.solution-detail ul { grid-row: 3; }
.solution-detail .solution-link { grid-column: 3; grid-row: 1 / span 3; align-self: center; }
.solution-detail-top {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 16px;
  margin-bottom: 0;
  color: #58a3ff;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}
.solution-detail h3 {
  max-width: 360px;
  margin-bottom: 6px;
  font-size: clamp(20px, 1.8vw, 28px);
  line-height: 1.1;
}
.solution-detail p {
  max-width: 580px;
  margin: 0;
  color: rgba(255,255,255,.78);
  font-size: 13px;
  line-height: 1.45;
}
.solution-detail ul {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 0;
  margin: 8px 0 0;
  list-style: none;
}
.solution-detail li {
  padding: 6px 9px;
  border: 1px solid rgba(148,190,255,.24);
  border-radius: 999px;
  color: rgba(255,255,255,.82);
  background: rgba(255,255,255,.055);
  font-size: 12px;
  font-weight: 800;
}
.solution-link {
  display: inline-flex;
  white-space: nowrap;
  color: #8bc5ff;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  transition: transform .18s ease, color .18s ease;
}
.solution-link:hover { transform: translateX(4px); color: #fff; }
.solution-detail.switching { animation: detailSwitch .22s ease both; }
.anchor-offset {
  position: relative;
  top: -96px;
  display: block;
  width: 1px;
  height: 1px;
  overflow: hidden;
}
.unified-showcase {
  padding-top: 28px;
  padding-bottom: 44px;
  scroll-margin-top: 92px;
}
.unified-showcase .section-grid {
  grid-template-columns: minmax(235px, 300px) 1fr;
  gap: 30px;
}
.unified-showcase .section-intro h2 {
  font-size: clamp(28px, 3vw, 44px);
  line-height: 1.08;
}
.unified-showcase .section-intro p:not(.eyebrow) {
  color: rgba(255,255,255,.74);
  font-size: 14px;
}
.unified-showcase .solution-console {
  min-height: 0;
  background:
    radial-gradient(circle at 72% 6%, rgba(45,132,255,.18), transparent 30%),
    linear-gradient(145deg, rgba(15,42,70,.62), rgba(4,17,31,.88));
}
.solution-showcase {
  display: grid;
  grid-template-columns: minmax(320px, .42fr) minmax(500px, 1fr);
  gap: 0;
  min-height: 378px;
}
.unified-showcase .solution-detail {
  min-height: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  align-content: center;
  padding: clamp(24px, 3vw, 40px);
  border-right: 1px solid rgba(145,190,255,.16);
  background: linear-gradient(90deg, rgba(45,132,255,.1), rgba(2,12,24,.08));
}
.unified-showcase .solution-detail-top,
.unified-showcase .solution-detail h3,
.unified-showcase .solution-detail p,
.unified-showcase .solution-detail ul,
.unified-showcase .solution-detail .solution-link {
  grid-column: 1;
  grid-row: auto;
}
.unified-showcase .solution-detail-top {
  flex-direction: row;
  justify-content: space-between;
  margin-bottom: 26px;
}
.unified-showcase .solution-detail h3 {
  max-width: 430px;
  margin-bottom: 16px;
  font-size: clamp(25px, 2.6vw, 34px);
  line-height: 1.08;
}
.unified-showcase .solution-detail p {
  max-width: 430px;
  margin-bottom: 22px;
  font-size: 15px;
  line-height: 1.52;
}
.unified-showcase .solution-detail ul { margin: 0 0 26px; }
.unified-showcase .solution-detail li {
  padding: 8px 10px;
  background: rgba(255,255,255,.065);
}
.unified-showcase .solution-detail .solution-link {
  align-self: start;
  font-size: 13px;
}
.solution-media {
  position: relative;
  min-height: 378px;
  margin: 0;
  overflow: hidden;
  background: #05101d;
  isolation: isolate;
}
.solution-media img {
  width: 100%;
  height: 100%;
  min-height: 378px;
  display: block;
  object-fit: cover;
  object-position: center center;
  background: #05101d;
  filter: saturate(1.08) contrast(1.04);
  transform: scale(1.012);
  animation: mediaDrift 12s ease-in-out infinite alternate;
}
.solution-media::before,
.solution-media::after,
.media-scan,
.media-node,
.media-flow {
  content: "";
  position: absolute;
  pointer-events: none;
  z-index: 2;
}
.solution-media::before {
  inset: 0;
  background:
    linear-gradient(90deg, rgba(4,13,25,.34), transparent 34%),
    radial-gradient(circle at 75% 34%, rgba(0,206,255,.14), transparent 26%);
}
.solution-media::after {
  inset: 0;
  background: linear-gradient(110deg, transparent 0 42%, rgba(255,255,255,.13) 50%, transparent 58% 100%);
  animation: panelSweep 6.4s ease-in-out infinite;
}
.media-scan {
  left: 8%;
  right: 8%;
  top: 50%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(77,168,255,.9), transparent);
  box-shadow: 0 0 18px rgba(45,132,255,.52);
  animation: scanTravel 4.6s ease-in-out infinite;
}
.media-node {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #2d84ff;
  box-shadow: 0 0 0 8px rgba(45,132,255,.14), 0 0 22px rgba(45,132,255,.72);
  animation: mapPulse 2.3s ease-in-out infinite;
}
.media-node.m1 { left: 57%; top: 43%; }
.media-node.m2 { left: 72%; top: 57%; animation-delay: .45s; background: #23d18b; }
.media-node.m3 { left: 82%; top: 32%; animation-delay: .9s; background: #ffbc42; }
.media-flow {
  height: 2px;
  width: 24%;
  background: linear-gradient(90deg, transparent, rgba(45,132,255,.8), rgba(35,209,139,.62), transparent);
  transform-origin: left center;
  filter: drop-shadow(0 0 7px rgba(0,206,255,.45));
  animation: routeFlow 2.8s linear infinite;
}
.media-flow.f1 { left: 56%; top: 47%; transform: rotate(19deg); }
.media-flow.f2 { left: 70%; top: 56%; transform: rotate(-24deg); animation-delay: .55s; }
.solution-media.ptt .media-node.m1 { left: 48%; top: 43%; }
.solution-media.ptt .media-node.m2 { left: 73%; top: 44%; }
.solution-media.ptt .media-node.m3 { left: 86%; top: 42%; }
.solution-media.ptt .media-flow.f1 { left: 33%; top: 48%; width: 22%; transform: rotate(0deg); }
.solution-media.ptt .media-flow.f2 { left: 50%; top: 48%; width: 26%; transform: rotate(0deg); }
.solution-media.bodycam .media-node.m1 { left: 43%; top: 33%; }
.solution-media.bodycam .media-node.m2 { left: 54%; top: 56%; }
.solution-media.bodycam .media-node.m3 { left: 77%; top: 37%; }
.solution-media.ai .media-node,
.solution-media.aria .media-node { box-shadow: 0 0 0 10px rgba(0,206,255,.12), 0 0 26px rgba(0,206,255,.8); }
.solution-media.switching { animation: detailSwitch .24s ease both; }

.platform-list { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.platform-console {
  display: grid;
  border: 1px solid rgba(91, 159, 255, .28);
  border-radius: 8px;
  overflow: hidden;
  background: linear-gradient(145deg, rgba(18,45,74,.58), rgba(4,17,31,.86));
  box-shadow: 0 28px 64px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.06);
  backdrop-filter: blur(10px);
}
.platform-tabs {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  border-bottom: 1px solid rgba(145,190,255,.18);
  background: rgba(2, 12, 24, .42);
}
.platform-tab {
  min-height: 50px;
  border: 0;
  border-right: 1px solid rgba(145,190,255,.16);
  color: rgba(255,255,255,.7);
  background: transparent;
  font: inherit;
  font-size: 13px;
  font-weight: 900;
  cursor: pointer;
  transition: color .18s ease, background .18s ease, box-shadow .18s ease, transform .18s ease;
}
.platform-tab:last-child { border-right: 0; }
.platform-tab:hover, .platform-tab:focus-visible { color: #fff; background: rgba(45,132,255,.13); transform: translateY(-1px); }
.platform-tab.active { color: #fff; background: linear-gradient(180deg, rgba(45,132,255,.26), rgba(0,174,239,.08)); box-shadow: inset 0 -3px 0 var(--blue), 0 0 22px rgba(45,132,255,.14); }
.platform-shell {
  display: grid;
  grid-template-columns: minmax(280px, .72fr) minmax(420px, 1.1fr);
  min-height: 300px;
}
.platform-detail {
  display: grid;
  align-content: center;
  padding: clamp(22px, 3vw, 36px);
  background:
    linear-gradient(90deg, rgba(45,132,255,.12), transparent 62%),
    rgba(2, 12, 24, .18);
}
.platform-detail h3 { margin-bottom: 12px; font-size: clamp(25px, 2.4vw, 38px); line-height: 1.06; }
.platform-detail h3 span { color: #1685ff; }
.platform-detail p:not(.eyebrow) { max-width: 460px; color: rgba(255,255,255,.78); line-height: 1.55; font-size: 14px; }
.platform-detail ul {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 0;
  margin: 18px 0;
  list-style: none;
}
.platform-detail li {
  padding: 8px 10px;
  border: 1px solid rgba(145,190,255,.22);
  border-radius: 999px;
  background: rgba(255,255,255,.055);
  color: rgba(255,255,255,.78);
  font-size: 12px;
  font-weight: 800;
}
.platform-link { color: #8bc5ff; font-weight: 900; font-size: 13px; text-transform: uppercase; transition: transform .18s ease, color .18s ease; }
.platform-link:hover { color: #fff; }
.platform-link:hover { transform: translateX(4px); }
.platform-visual {
  position: relative;
  min-height: 300px;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(45,132,255,.13) 1px, transparent 1px),
    linear-gradient(180deg, rgba(0,174,239,.11) 1px, transparent 1px),
    radial-gradient(circle at 62% 38%, rgba(45,132,255,.24), transparent 34%),
    linear-gradient(180deg, #10243a, #061322);
  background-size: 42px 42px, 42px 42px, auto, auto;
  transform: translate3d(0, var(--parallax-y, 0px), 0);
  transition: transform .18s ease-out, background .24s ease, filter .24s ease;
}
.platform-visual::before {
  content: "";
  position: absolute;
  inset: 26px;
  border: 1px solid rgba(0,174,239,.34);
  border-radius: 8px;
  background: linear-gradient(145deg, rgba(5,18,33,.2), rgba(255,255,255,.04));
  backdrop-filter: blur(4px);
  box-shadow: inset 0 0 34px rgba(45,132,255,.12), 0 16px 36px rgba(0,0,0,.24);
}
.platform-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 72% 24%, rgba(35,209,139,.14), transparent 18%),
    linear-gradient(105deg, transparent 0 42%, rgba(255,255,255,.16) 50%, transparent 58% 100%);
  animation: panelSweep 6.2s ease-in-out infinite;
  pointer-events: none;
}
.visual-node {
  position: absolute;
  width: 15px;
  height: 15px;
  border-radius: 50%;
  background: #2d84ff;
  box-shadow: 0 0 0 8px rgba(45,132,255,.14), 0 0 22px rgba(45,132,255,.7);
  z-index: 2;
  animation: nodePulse 2.4s ease-in-out infinite;
}
.visual-node.n1 { left: 30%; top: 32%; }
.visual-node.n2 { left: 58%; top: 47%; animation-delay: .35s; background: #23d18b; box-shadow: 0 0 0 8px rgba(35,209,139,.14), 0 0 22px rgba(35,209,139,.72); }
.visual-node.n3 { left: 72%; top: 27%; animation-delay: .7s; background: #ffbc42; box-shadow: 0 0 0 8px rgba(255,188,66,.14), 0 0 22px rgba(255,188,66,.7); }
.visual-line {
  position: absolute;
  height: 2px;
  transform-origin: left center;
  background: linear-gradient(90deg, rgba(45,132,255,0), rgba(45,132,255,.8), rgba(0,174,239,0));
  z-index: 1;
  animation: flowLine 2.8s linear infinite;
}
.visual-line.l1 { left: 31%; top: 35%; width: 180px; transform: rotate(19deg); }
.visual-line.l2 { left: 58%; top: 49%; width: 150px; transform: rotate(-30deg); animation-delay: .4s; }
.platform-visual.virtualtrunk::before {
  background:
    radial-gradient(circle at 57% 52%, rgba(45,132,255,.95) 0 22px, rgba(45,132,255,.24) 23px 48px, transparent 49px),
    linear-gradient(90deg, transparent 0 18%, rgba(35,145,255,.9) 19% 20%, transparent 21% 24%, rgba(35,145,255,.62) 25% 26%, transparent 27% 100%),
    repeating-linear-gradient(90deg, transparent 0 10px, rgba(45,132,255,.72) 11px 12px, transparent 13px 20px) 22% 54% / 34% 24px no-repeat,
    linear-gradient(#132a44 0 0) 28px 32px / 24% 36px no-repeat,
    linear-gradient(#10263e 0 0) 28px 88px / 20% 28px no-repeat,
    linear-gradient(#0f2439 0 0) 67% 29px / 22% 78% no-repeat,
    linear-gradient(145deg, rgba(5,18,33,.2), rgba(255,255,255,.04));
}
.platform-visual.virtualtrunk .visual-node.n1 { left: 57%; top: 52%; }
.platform-visual.virtualtrunk .visual-node.n2 { left: 76%; top: 31%; }
.platform-visual.virtualtrunk .visual-node.n3 { left: 30%; top: 72%; }
.platform-visual.virtualtrunk .visual-line.l1 { left: 31%; top: 54%; width: 230px; transform: rotate(0deg); }
.platform-visual.virtualtrunk .visual-line.l2 { left: 57%; top: 54%; width: 180px; transform: rotate(0deg); animation-delay: .4s; }
.platform-visual.agent::before {
  background:
    linear-gradient(#18324f 0 0) 28px 28px / 78% 28px no-repeat,
    linear-gradient(#102b47 0 0) 28px 78px / 62% 28px no-repeat,
    linear-gradient(#1b3b5f 0 0) 28px 138px / 86% 76px no-repeat,
    linear-gradient(145deg, rgba(5,18,33,.2), rgba(255,255,255,.04));
}
.platform-visual.bodycam::before {
  background:
    radial-gradient(circle at 78% 30%, rgba(0,174,239,.95) 0 7px, transparent 8px),
    linear-gradient(#193d63 0 0) 32px 34px / 70% 24px no-repeat,
    linear-gradient(#173453 0 0) 32px 90px / 82% 90px no-repeat,
    linear-gradient(145deg, rgba(5,18,33,.2), rgba(255,255,255,.04));
}
.platform-visual.etag::before {
  background:
    radial-gradient(circle at 50% 52%, #2d84ff 0 12px, rgba(45,132,255,.22) 13px 32px, transparent 33px),
    radial-gradient(circle at 64% 38%, #23d18b 0 6px, transparent 7px),
    linear-gradient(45deg, transparent 48%, rgba(35,209,139,.56) 49% 51%, transparent 52%),
    linear-gradient(125deg, transparent 48%, rgba(45,132,255,.52) 49% 51%, transparent 52%),
    linear-gradient(145deg, rgba(5,18,33,.2), rgba(255,255,255,.04));
}
.platform-visual.aria::before {
  background:
    linear-gradient(#173a5c 0 0) 28px 28px / 76% 24px no-repeat,
    linear-gradient(#102c47 0 0) 28px 76px / 58% 70px no-repeat,
    radial-gradient(circle at 28% 36%, #2d84ff 0 6px, transparent 7px),
    radial-gradient(circle at 52% 48%, #23d18b 0 6px, transparent 7px),
    radial-gradient(circle at 78% 64%, #ff4d5a 0 6px, transparent 7px),
    linear-gradient(145deg, rgba(5,18,33,.2), rgba(255,255,255,.04));
}
.platform-visual.switching { animation: detailSwitch .24s ease both; }
.platform-visual.agent .visual-node.n3,
.platform-visual.bodycam .visual-node.n2,
.platform-visual.etag .visual-node.n1,
.platform-visual.aria .visual-node.n2 { animation-duration: 1.7s; }
.platform-card {
  min-height: 185px;
  display: grid;
  grid-template-columns: 1fr 230px;
  gap: 20px;
  padding: 28px;
  border-radius: 8px;
  background: #f2f5f9;
  overflow: hidden;
  transition: transform .22s ease, box-shadow .22s ease, background .22s ease;
}
.platform-card.wide-card { grid-column: 1 / -1; grid-template-columns: minmax(0, 1fr) minmax(280px, 420px); }
.platform-card:hover { transform: translateY(-4px); background: #eef4fb; box-shadow: 0 18px 36px rgba(15, 37, 63, .12); }
.platform-card h3 { font-size: 28px; margin-bottom: 12px; }
.platform-card h3 span { color: #1685ff; }
.platform-card p { color: #1f2937; line-height: 1.5; }
.platform-card ul { display: flex; flex-wrap: wrap; gap: 8px; padding: 0; margin: 0 0 18px; list-style: none; color: var(--muted); font-size: 12px; }
.platform-card a { color: #006be6; font-weight: 800; font-size: 13px; }
.device-mockup {
  min-height: 150px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.1), rgba(255,255,255,0)),
    linear-gradient(180deg, #10243a, #071525);
  border: 1px solid rgba(0,0,0,.2);
  box-shadow: 0 18px 26px rgba(4,17,33,.18);
  transform: translate3d(0, var(--parallax-y, 0px), 0);
  transition: transform .18s ease-out, filter .22s ease;
}
.platform-card:hover .device-mockup { filter: saturate(1.08) contrast(1.04); }
.device-mockup.map {
  background-image:
    radial-gradient(circle at 68% 35%, #0fd190 0 4px, transparent 5px),
    radial-gradient(circle at 35% 55%, #2d84ff 0 4px, transparent 5px),
    linear-gradient(45deg, transparent 47%, rgba(45,132,255,.45) 48% 50%, transparent 51%),
    linear-gradient(180deg, #10243a, #071525);
}
.device-mockup.chat {
  background-image:
    linear-gradient(#162b43 0 0),
    linear-gradient(#162b43 0 0),
    linear-gradient(#1d3652 0 0),
    linear-gradient(180deg, #0f2135, #071525);
  background-size: 75% 22px, 58% 22px, 85% 42px, 100% 100%;
  background-position: 18px 24px, 18px 60px, 18px 108px, 0 0;
  background-repeat: no-repeat;
}
.device-mockup.bodycam {
  background-image:
    radial-gradient(circle at 72% 30%, rgba(0,174,239,.95) 0 6px, transparent 7px),
    linear-gradient(90deg, transparent 0 28%, rgba(0,174,239,.58) 29% 30%, transparent 31% 100%),
    linear-gradient(#193d63 0 0),
    linear-gradient(#173453 0 0),
    linear-gradient(180deg, #102b48, #071525);
  background-size: auto, 100% 100%, 64% 20px, 76% 74px, 100% 100%;
  background-position: center, center, 18px 24px, 18px 72px, 0 0;
  background-repeat: no-repeat;
}
.device-mockup.etag {
  background-image:
    radial-gradient(circle at 48% 52%, #2d84ff 0 10px, rgba(45,132,255,.28) 11px 22px, transparent 23px),
    radial-gradient(circle at 58% 44%, #23d18b 0 5px, transparent 6px),
    linear-gradient(35deg, transparent 47%, rgba(35,209,139,.48) 48% 50%, transparent 51%),
    linear-gradient(125deg, transparent 47%, rgba(45,132,255,.52) 48% 50%, transparent 51%),
    linear-gradient(180deg, #10243a, #071525);
}
.device-mockup.aria-security {
  background-image:
    linear-gradient(90deg, rgba(45,132,255,.16) 1px, transparent 1px),
    linear-gradient(180deg, rgba(0,174,239,.14) 1px, transparent 1px),
    radial-gradient(circle at 22% 28%, #2d84ff 0 5px, transparent 6px),
    radial-gradient(circle at 48% 42%, #23d18b 0 5px, transparent 6px),
    radial-gradient(circle at 74% 62%, #ffbc42 0 5px, transparent 6px),
    linear-gradient(#173a5c 0 0),
    linear-gradient(#102c47 0 0),
    linear-gradient(180deg, #0e2742, #061322);
  background-size: 42px 42px, 42px 42px, auto, auto, auto, 78% 24px, 62% 74px, 100% 100%;
  background-position: center, center, center, center, center, 22px 24px, 22px 76px, 0 0;
  background-repeat: repeat, repeat, no-repeat, no-repeat, no-repeat, no-repeat, no-repeat, no-repeat;
}

.wide { max-width: var(--max); margin: 0 auto; }
.sectors {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(180deg, #fff 0%, #f5f8fc 100%);
}
.sectors::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 78% 12%, rgba(45,132,255,.12), transparent 30%),
    linear-gradient(90deg, transparent, rgba(0,174,239,.05), transparent);
  pointer-events: none;
}
.sectors .wide { position: relative; }
.differential { background: #fff; }
.sector-grid, .diff-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
}
.sector-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
}
.sector-card {
  min-height: 188px;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 8px;
  overflow: hidden;
  padding: 18px;
  border: 1px solid rgba(92,148,210,.28);
  border-radius: 8px;
  color: #fff;
  background:
    linear-gradient(180deg, rgba(4,13,25,.08) 0%, rgba(4,13,25,.72) 58%, rgba(4,13,25,.94) 100%),
    var(--sector-img) center / cover no-repeat;
  box-shadow: 0 16px 34px rgba(15,37,63,.1);
  isolation: isolate;
  transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease, filter .24s ease;
}
.sector-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(90deg, rgba(45,132,255,.12) 1px, transparent 1px),
    linear-gradient(180deg, rgba(0,174,239,.1) 1px, transparent 1px);
  background-size: 34px 34px;
  opacity: .22;
  transform: translateY(8px);
  transition: opacity .24s ease, transform .24s ease;
}
.sector-card::after {
  content: "";
  position: absolute;
  left: 14px;
  right: 14px;
  top: 18px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(92,190,255,.9), transparent);
  box-shadow: 0 0 18px rgba(45,132,255,.55);
  opacity: .55;
  animation: sectorScan 4.2s ease-in-out infinite;
}
.sector-card span {
  position: relative;
  font-size: 18px;
  line-height: 1.15;
  font-weight: 900;
  text-shadow: 0 2px 12px rgba(0,0,0,.42);
}
.sector-card span::before {
  content: "";
  display: block;
  width: 34px;
  height: 3px;
  margin-bottom: 10px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--blue), var(--cyan));
  box-shadow: 0 0 16px rgba(45,132,255,.5);
}
.sector-card small {
  max-width: 210px;
  color: rgba(235,246,255,.82);
  font-size: 12px;
  line-height: 1.35;
  transform: translateY(8px);
  opacity: .82;
  transition: transform .24s ease, opacity .24s ease;
}
.sector-card:hover,
.sector-card:focus-visible {
  transform: translateY(-6px);
  border-color: rgba(0,174,239,.72);
  box-shadow: 0 26px 56px rgba(15,37,63,.2);
  filter: saturate(1.08) contrast(1.03);
}
.sector-card:hover::before { opacity: .4; transform: translateY(0); }
.sector-card:hover small { transform: translateY(0); opacity: 1; }
.sector-card:nth-child(1) { transition-delay: 0ms; }
.sector-card:nth-child(2) { transition-delay: 35ms; }
.sector-card:nth-child(3) { transition-delay: 70ms; }
.sector-card:nth-child(4) { transition-delay: 105ms; }
.sector-card:nth-child(5) { transition-delay: 140ms; }
.sector-card:nth-child(6) { transition-delay: 175ms; }
.sector-card:nth-child(7) { transition-delay: 210ms; }
.sector-card:nth-child(8) { transition-delay: 245ms; }
.sector-card:nth-child(9) { transition-delay: 260ms; }
.sector-card:nth-child(10) { transition-delay: 260ms; }
.sector-card:nth-child(11) { transition-delay: 260ms; }
.sector-card:nth-child(4),
.sector-card:nth-child(8),
.sector-card:nth-child(11) {
  min-height: 228px;
}
.differential {
  position: relative;
  overflow: hidden;
}
.differential::before {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 220px;
  background: linear-gradient(180deg, transparent, rgba(45,132,255,.06));
  pointer-events: none;
}
.diff-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  position: relative;
}
.diff-card {
  min-height: 212px;
  position: relative;
  overflow: hidden;
  padding: 20px;
  border: 1px solid #d8e0ea;
  border-radius: 8px;
  background:
    linear-gradient(145deg, rgba(255,255,255,.96), rgba(244,248,252,.92)),
    #f8fafc;
  color: #223044;
  box-shadow: 0 14px 34px rgba(15,37,63,.06);
  transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease, background .22s ease;
}
.diff-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg, transparent 0 40%, rgba(45,132,255,.08) 50%, transparent 60% 100%);
  transform: translateX(-48%);
  opacity: 0;
  pointer-events: none;
}
.diff-card:hover {
  transform: translateY(-5px);
  border-color: rgba(45,132,255,.48);
  box-shadow: 0 22px 46px rgba(15,37,63,.11);
  background: linear-gradient(145deg, #fff, #eef6ff);
}
.diff-card:hover::after { animation: panelSweep 2.8s ease-in-out 1; }
.diff-card h3 {
  margin: 18px 0 8px;
  font-size: 18px;
  line-height: 1.2;
}
.diff-card p {
  margin: 0;
  color: #526176;
  font-size: 13px;
  line-height: 1.5;
}
.diff-visual {
  width: 100%;
  height: 86px;
  position: relative;
  display: block;
  border: 1px solid rgba(45,132,255,.16);
  border-radius: 8px;
  background:
    linear-gradient(90deg, rgba(45,132,255,.08) 1px, transparent 1px),
    linear-gradient(180deg, rgba(0,174,239,.08) 1px, transparent 1px),
    linear-gradient(145deg, #061322, #10243a);
  background-size: 26px 26px, 26px 26px, auto;
  box-shadow: inset 0 0 26px rgba(45,132,255,.12);
  overflow: hidden;
}
.diff-visual i,
.diff-visual b {
  position: absolute;
  display: block;
  pointer-events: none;
}
.integrate .diff-visual i {
  width: 32px;
  height: 24px;
  border: 1px solid rgba(120,190,255,.7);
  border-radius: 6px;
  background: rgba(45,132,255,.16);
  animation: modulePulse 2.4s ease-in-out infinite;
}
.integrate .diff-visual i:nth-child(1) { left: 18px; top: 18px; }
.integrate .diff-visual i:nth-child(2) { left: 50%; top: 30px; transform: translateX(-50%); animation-delay: .4s; }
.integrate .diff-visual i:nth-child(3) { right: 18px; top: 18px; animation-delay: .8s; }
.integrate .diff-visual b {
  left: 50px;
  right: 50px;
  top: 42px;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(0,206,255,.85), transparent);
  animation: routeFlow 2s linear infinite;
}
.realtime .diff-visual i {
  bottom: 18px;
  width: 12px;
  border-radius: 6px 6px 0 0;
  background: linear-gradient(180deg, #2d84ff, #00ceff);
  animation: barLive 1.6s ease-in-out infinite;
}
.realtime .diff-visual i:nth-child(1) { left: 26px; height: 28px; }
.realtime .diff-visual i:nth-child(2) { left: 58px; height: 46px; animation-delay: .2s; }
.realtime .diff-visual i:nth-child(3) { left: 90px; height: 34px; animation-delay: .4s; }
.realtime .diff-visual b {
  left: 132px;
  right: 24px;
  top: 43px;
  height: 2px;
  background: repeating-linear-gradient(90deg, transparent 0 9px, rgba(35,209,139,.9) 10px 12px, transparent 13px 20px);
  animation: telemetryFlow 1.8s linear infinite;
}
.trace .diff-visual i {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 2px solid rgba(45,132,255,.75);
  background: rgba(45,132,255,.15);
  animation: nodePulse 2.2s ease-in-out infinite;
}
.trace .diff-visual i:nth-child(1) { left: 24px; top: 18px; }
.trace .diff-visual i:nth-child(2) { left: 50%; top: 28px; transform: translateX(-50%); animation-delay: .35s; border-color: rgba(35,209,139,.75); }
.trace .diff-visual i:nth-child(3) { right: 24px; top: 18px; animation-delay: .7s; border-color: rgba(255,188,66,.75); }
.trace .diff-visual b {
  left: 46px;
  right: 46px;
  top: 48px;
  height: 2px;
  background: linear-gradient(90deg, rgba(45,132,255,.2), rgba(35,209,139,.8), rgba(255,188,66,.2));
  animation: routeFlow 2.6s linear infinite;
}
.scale .diff-visual i {
  width: 30px;
  height: 20px;
  border-radius: 5px;
  border: 1px solid rgba(120,190,255,.65);
  background: rgba(45,132,255,.14);
  animation: stackRise 2.6s ease-in-out infinite;
}
.scale .diff-visual i:nth-child(1) { left: 28px; bottom: 20px; }
.scale .diff-visual i:nth-child(2) { left: 72px; bottom: 32px; animation-delay: .25s; }
.scale .diff-visual i:nth-child(3) { left: 116px; bottom: 44px; animation-delay: .5s; }
.scale .diff-visual b {
  right: 28px;
  top: 23px;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: 1px solid rgba(35,209,139,.6);
  box-shadow: 0 0 0 10px rgba(35,209,139,.08);
  animation: mapPulse 2.6s ease-in-out infinite;
}
.devices .diff-visual i:nth-child(1) {
  left: 28px;
  top: 18px;
  width: 72px;
  height: 46px;
  border: 1px solid rgba(120,190,255,.7);
  border-radius: 6px;
  background: rgba(45,132,255,.12);
}
.devices .diff-visual i:nth-child(2) {
  right: 50px;
  top: 14px;
  width: 32px;
  height: 58px;
  border: 1px solid rgba(120,190,255,.7);
  border-radius: 8px;
  background: rgba(0,206,255,.12);
  animation: deviceGlow 2.2s ease-in-out infinite;
}
.devices .diff-visual i:nth-child(3) {
  left: 42px;
  top: 34px;
  width: 46px;
  height: 2px;
  background: rgba(0,206,255,.85);
  animation: telemetryFlow 1.9s linear infinite;
}
.devices .diff-visual b {
  right: 61px;
  bottom: 22px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #23d18b;
  box-shadow: 0 0 18px rgba(35,209,139,.75);
  animation: nodePulse 1.9s ease-in-out infinite;
}
.analytics .diff-visual i {
  width: 12px;
  border-radius: 8px 8px 0 0;
  bottom: 18px;
  background: linear-gradient(180deg, #23d18b, #2d84ff);
  animation: barLive 1.7s ease-in-out infinite;
}
.analytics .diff-visual i:nth-child(1) { left: 32px; height: 24px; }
.analytics .diff-visual i:nth-child(2) { left: 64px; height: 42px; animation-delay: .2s; }
.analytics .diff-visual i:nth-child(3) { left: 96px; height: 60px; animation-delay: .4s; }
.analytics .diff-visual b {
  right: 30px;
  top: 22px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: conic-gradient(from 70deg, #2d84ff 0 38%, rgba(45,132,255,.14) 39% 62%, #23d18b 63% 100%);
  animation: rotateDial 5s linear infinite;
}
.architecture {
  padding: 0;
  overflow: hidden;
}
.architecture-video {
  position: relative;
  min-height: clamp(390px, 45vw, 560px);
  display: grid;
  align-items: center;
  overflow: hidden;
  background: #041121;
  border-top: 1px solid rgba(145,190,255,.16);
  border-bottom: 1px solid rgba(145,190,255,.16);
}
.architecture-video video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .78;
  filter: saturate(1.06) contrast(1.05);
}
.architecture-video::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(90deg, rgba(2,12,24,.92) 0%, rgba(2,12,24,.62) 42%, rgba(2,12,24,.2) 100%),
    radial-gradient(circle at 72% 24%, rgba(0,174,239,.16), transparent 32%);
}
.architecture-video::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(110deg, transparent 0 42%, rgba(255,255,255,.1) 50%, transparent 58% 100%);
  animation: panelSweep 7s ease-in-out infinite;
  pointer-events: none;
}
.architecture-overlay {
  position: relative;
  z-index: 3;
  max-width: 860px;
  padding: clamp(64px, 8vw, 110px) clamp(22px, 6vw, 88px);
}
.architecture-overlay h2 {
  max-width: 780px;
  margin-bottom: 18px;
  color: #fff;
  font-size: clamp(36px, 4.2vw, 64px);
  line-height: 1.02;
}
.architecture-overlay p:not(.eyebrow) {
  max-width: 620px;
  color: rgba(236,246,255,.82);
  font-size: 17px;
  line-height: 1.55;
}
.contact-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  padding: 24px;
  border: 1px solid rgba(148, 190, 255, .28);
  border-radius: 8px;
  background: rgba(8, 28, 49, .78);
  backdrop-filter: blur(12px);
}
.contact-form label { display: grid; gap: 8px; color: rgba(255,255,255,.82); font-size: 13px; font-weight: 700; }
.contact-form .full { grid-column: 1 / -1; }
.hidden-field { position: absolute; left: -9999px; opacity: 0; pointer-events: none; }
.contact-form input, .contact-form textarea {
  width: 100%;
  border: 1px solid rgba(148, 190, 255, .28);
  border-radius: 5px;
  background: rgba(255,255,255,.06);
  color: #fff;
  padding: 12px 13px;
  font: inherit;
}
.contact-form button { width: fit-content; }
.form-status { margin: 12px 0 0; color: #8bc5ff; }
.contact-links { display: grid; gap: 10px; margin-top: 22px; color: #fff; font-weight: 800; }
footer {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 30px;
  align-items: center;
  padding: 38px clamp(18px, 6vw, 88px);
  color: rgba(255,255,255,.72);
  background: #020b14;
}
footer img { width: 170px; margin-bottom: 12px; }
footer p { max-width: 520px; margin: 0; line-height: 1.5; }
footer nav { display: flex; gap: 20px; color: #fff; font-weight: 700; }

.reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }
@keyframes glowLine { 0%,100% { opacity:.35; } 50% { opacity:1; } }
@keyframes panelSweep { 0%, 62%, 100% { transform: translateX(-42%); opacity: 0; } 72% { opacity: .8; } 86% { transform: translateX(44%); opacity: 0; } }
@keyframes detailSwitch { 0% { opacity: .4; transform: translateY(8px); } 100% { opacity: 1; transform: translateY(0); } }
@keyframes nodePulse { 0%, 100% { transform: scale(.92); } 50% { transform: scale(1.12); } }
@keyframes flowLine { 0% { opacity: .25; filter: hue-rotate(0deg); } 50% { opacity: .95; } 100% { opacity: .25; filter: hue-rotate(30deg); } }
@keyframes imageDrift { 0% { transform: scale(1.015) translate3d(-4px, 0, 0); } 100% { transform: scale(1.04) translate3d(8px, -4px, 0); } }
@keyframes scanTravel { 0%, 100% { transform: translateY(-62px); opacity: 0; } 16%, 76% { opacity: .8; } 50% { transform: translateY(72px); opacity: .95; } }
@keyframes cameraFocus { 0%, 100% { transform: scale(.98); opacity: .48; } 50% { transform: scale(1.03); opacity: .92; } }
@keyframes mapPulse { 0%, 100% { transform: scale(.84); box-shadow: 0 0 0 0 rgba(69,160,255,.5), 0 0 14px rgba(69,160,255,.72); } 50% { transform: scale(1.16); box-shadow: 0 0 0 12px rgba(69,160,255,0), 0 0 24px rgba(69,160,255,.92); } }
@keyframes routeFlow { 0%, 100% { opacity: .18; filter: saturate(1); } 50% { opacity: .95; filter: saturate(1.3); } }
@keyframes monitorBlink { 0%, 100% { opacity: .18; transform: scale(.98); } 46% { opacity: .68; transform: scale(1.02); } }
@keyframes mediaDrift { 0% { transform: scale(1.012) translate3d(-5px, 0, 0); } 100% { transform: scale(1.045) translate3d(7px, -4px, 0); } }
@keyframes modulePulse { 0%,100% { opacity: .68; box-shadow: 0 0 0 rgba(45,132,255,0); } 50% { opacity: 1; box-shadow: 0 0 20px rgba(45,132,255,.28); } }
@keyframes barLive { 0%,100% { transform: scaleY(.62); opacity: .72; } 50% { transform: scaleY(1); opacity: 1; } }
@keyframes telemetryFlow { 0% { background-position: 0 0; opacity: .45; } 50% { opacity: 1; } 100% { background-position: 48px 0; opacity: .45; } }
@keyframes stackRise { 0%,100% { transform: translateY(0); opacity: .72; } 50% { transform: translateY(-6px); opacity: 1; } }
@keyframes deviceGlow { 0%,100% { box-shadow: inset 0 0 0 rgba(0,206,255,0); } 50% { box-shadow: inset 0 0 22px rgba(0,206,255,.24), 0 0 18px rgba(0,206,255,.18); } }
@keyframes rotateDial { to { transform: rotate(360deg); } }
@keyframes sectorScan { 0%, 100% { transform: translateY(0); opacity: .28; } 50% { transform: translateY(92px); opacity: .85; } }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
  .parallax-layer { transform: none !important; }
}

@media (max-width: 1180px) {
  .site-header { grid-template-columns: 180px 1fr 0; }
  .header-contact { display: none; }
  .hero-shell { grid-template-columns: 1fr; padding-top: 54px; }
  .ops-visual { min-height: 420px; margin: 0; border: 1px solid rgba(120,180,255,.16); border-radius: 8px; }
  .platform-list { grid-template-columns: repeat(2, 1fr); }
  .platform-tabs { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .platform-shell { grid-template-columns: 1fr; }
  .platform-visual { min-height: 270px; }
  .solution-console { grid-template-columns: 1fr; }
  .solution-tabs { grid-template-columns: repeat(4, minmax(0, 1fr)); border-right: 0; border-bottom: 1px solid rgba(148, 190, 255, .18); }
  .solution-detail { grid-template-columns: 1fr auto; }
  .solution-detail-top { grid-column: 1 / -1; grid-row: auto; flex-direction: row; justify-content: space-between; }
  .solution-detail h3,
  .solution-detail p,
  .solution-detail ul { grid-column: 1; grid-row: auto; }
  .solution-detail .solution-link { grid-column: 2; grid-row: 2 / span 3; }
  .unified-showcase .section-grid { grid-template-columns: 1fr; }
  .solution-showcase { grid-template-columns: 1fr; }
  .unified-showcase .solution-detail { border-right: 0; border-bottom: 1px solid rgba(145,190,255,.16); }
  .unified-showcase .solution-detail .solution-link { grid-column: 1; grid-row: auto; }
  .section-grid { grid-template-columns: 1fr; }
  .flow, .diff-grid { grid-template-columns: repeat(3, 1fr); }
  .sector-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 760px) {
  .site-header { height: 66px; grid-template-columns: 160px 1fr; padding: 0 18px; }
  .brand img { width: 158px; }
  .menu-toggle { justify-self: end; display: grid; gap: 5px; width: 42px; height: 42px; border: 1px solid rgba(255,255,255,.18); border-radius: 6px; background: transparent; padding: 11px; }
  .menu-toggle span { display: block; height: 2px; background: #fff; }
  .main-nav {
    position: absolute;
    top: 66px;
    left: 0;
    right: 0;
    display: none;
    padding: 18px;
    background: rgba(4,15,28,.98);
  }
  .main-nav.open { display: grid; justify-content: stretch; gap: 4px; }
  .main-nav a { padding: 14px 0; }
  .hero-shell { min-height: auto; padding: 46px 18px 34px; }
  h1 { font-size: 34px; line-height: 1.1; }
  .hero-actions { display: grid; }
  .capability-row { grid-template-columns: 1fr 1fr; }
  .capability-row span { padding: 12px; }
  .ops-visual { min-height: 300px; }
  section { padding: 54px 18px; }
  .platform-list, .diff-grid, .flow { grid-template-columns: 1fr; }
  .sector-grid { grid-template-columns: 1fr; }
  .sector-card,
  .sector-card:nth-child(4),
  .sector-card:nth-child(8),
  .sector-card:nth-child(11) { min-height: 210px; }
  .platform-tabs { grid-template-columns: 1fr 1fr; }
  .platform-tab { min-height: 44px; }
  .platform-detail { padding: 24px; }
  .platform-visual { min-height: 240px; }
  .solution-tabs { grid-template-columns: 1fr 1fr; }
  .solution-tab { min-height: 44px; font-size: 12px; }
  .solution-detail { min-height: 0; grid-template-columns: 1fr; padding: 20px; }
  .solution-detail .solution-link { grid-column: 1; grid-row: auto; }
  .unified-showcase .solution-detail h3 { font-size: 30px; }
  .unified-showcase .solution-detail p { font-size: 14px; }
  .solution-media,
  .solution-media img { min-height: 260px; }
  .platform-card { grid-template-columns: 1fr; }
  .platform-card.wide-card { grid-column: auto; grid-template-columns: 1fr; }
  .contact-form { grid-template-columns: 1fr; }
  footer { grid-template-columns: 1fr; }
  footer nav { flex-wrap: wrap; }
}
