@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=DM+Mono:wght@400;500&display=swap');

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:root {
  --orange: #355872;
  --orange-dark: #243c4f;
  --orange-glow: rgba(53, 88, 114, 0.25);
  --green: #7AAACE;
  --green-dark: #5883a4;
  --green-light: #7AAACE;
  --green-glow: rgba(122, 170, 206, 0.2);
  --dark: #ffffff;
  --dark2: #ffffff;
  --dark3: #ffffff;
  --dark4: #e5e8d5;
  --border: rgba(53, 88, 114, 0.12);
  --border-orange: rgba(122, 170, 206, 0.25);
  --text: #2a4457;
  --text-muted: #526f84;
  --text-dim: #728ea2;
  --container: 1200px;
  --radius: 14px;
  --radius-sm: 8px;
  --radius-lg: 20px;
}

html {
  scroll-behavior: smooth;
  font-size: 16px;
}

body {
  font-family: 'Outfit', sans-serif;
  color: var(--text);
  background: var(--dark);
  overflow-x: hidden;
  line-height: 1.65;
}

h1,
h2,
h3,
h4,
h5 {
  line-height: 1.15;
  letter-spacing: -0.3px;
}

::-webkit-scrollbar {
  width: 5px;
}

::-webkit-scrollbar-track {
  background: var(--dark);
}

::-webkit-scrollbar-thumb {
  background: var(--green);
  border-radius: 3px;
}

/* ─── REUSABLE LIQUID GLASS EFFECT (APPLE OS STYLE) ─── */
.liquid-glass {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.4) 0%, rgba(255, 255, 255, 0.1) 100%);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-top: 1px solid rgba(255, 255, 255, 0.8);
  border-left: 1px solid rgba(255, 255, 255, 0.6);
  box-shadow: 
    0 16px 32px rgba(0, 0, 0, 0.04),
    inset 0 4px 6px rgba(255, 255, 255, 0.9),
    inset 4px 0 6px rgba(255, 255, 255, 0.7),
    inset -2px -2px 8px rgba(0, 0, 0, 0.04),
    inset 0 -4px 6px rgba(255, 255, 255, 0.2);
}

/* ─── LAYOUT ─── */
.container {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 48px;
}

.section {
  padding: 96px 0;
}

.section-alt {
  background: var(--dark2);
}

.row {
  display: grid;
  gap: 60px;
  align-items: center;
}

.row-2 {
  grid-template-columns: 1fr 1fr;
}

.row-3 {
  grid-template-columns: 1fr 1fr 1fr;
}

.row-4 {
  grid-template-columns: repeat(4, 1fr);
}

/* ─── LABEL / HEADING ─── */
.label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--orange);
  margin-bottom: 14px;
}

.label::before {
  content: '';
  width: 20px;
  height: 2px;
  background: var(--orange);
  border-radius: 1px;
}

.h1 {
  font-size: clamp(42px, 6vw, 80px);
  font-weight: 900;
}

.h2 {
  font-size: clamp(28px, 3.5vw, 48px);
  font-weight: 800;
}

.h3 {
  font-size: clamp(20px, 2vw, 28px);
  font-weight: 700;
}

.lead {
  font-size: 18px;
  color: var(--text-muted);
  font-weight: 300;
  line-height: 1.75;
  max-width: 600px;
}

.sub {
  font-size: 15px;
  color: var(--text-muted);
  line-height: 1.8;
}

/* ─── BUTTONS ─── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 32px;
  border-radius: var(--radius-sm);
  font-size: 14px;
  font-weight: 600;
  font-family: 'Outfit', sans-serif;
  cursor: pointer;
  border: none;
  transition: all 0.2s;
  letter-spacing: 0.2px;
}

.btn-primary {
  background: var(--orange);
  color: #fff;
  box-shadow: 0 4px 24px var(--orange-glow);
}

.btn-primary:hover {
  background: var(--orange-dark);
  transform: translateY(-2px);
  box-shadow: 0 8px 32px var(--orange-glow);
}

.btn-green {
  background: var(--green);
  color: #fff;
  box-shadow: 0 4px 24px var(--green-glow);
}

.btn-green:hover {
  background: var(--green-dark);
  transform: translateY(-2px);
}

.btn-outline {
  background: transparent;
  color: var(--text);
  border: 1px solid var(--border);
}

.btn-outline:hover {
  border-color: var(--green-light);
  color: var(--green-light);
  transform: translateY(-2px);
}

.btn-ghost {
  background: rgba(255, 255, 255, 0.05);
  color: var(--text-muted);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.btn-ghost:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--text);
}

.btn-lg {
  padding: 17px 40px;
  font-size: 16px;
}

.btn-sm {
  padding: 9px 20px;
  font-size: 13px;
}

/* ─── CARDS ─── */
.card {
  background: var(--dark3);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 36px;
  transition: all 0.25s;
}

.card:hover {
  border-color: var(--border-orange);
  transform: translateY(-5px);
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.4);
}

.card-icon {
  width: 52px;
  height: 52px;
  border-radius: 12px;
  background: rgba(90, 171, 0, 0.1);
  border: 1px solid rgba(90, 171, 0, 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  margin-bottom: 22px;
}

/* ─── BADGE ─── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 14px;
  border-radius: 30px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1.5px;
}

.badge-green {
  background: rgba(90, 171, 0, 0.1);
  border: 1px solid rgba(90, 171, 0, 0.3);
  color: var(--green-light);
}

.badge-orange {
  background: rgba(244, 124, 32, 0.1);
  border: 1px solid rgba(244, 124, 32, 0.3);
  color: var(--orange);
}

.badge-dot::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  animation: pulse 2s infinite;
}

@keyframes pulse {

  0%,
  100% {
    opacity: 1
  }

  50% {
    opacity: 0.3
  }
}

/* ─── DIVIDER ─── */
.divider {
  height: 1px;
  background: var(--border);
  margin: 48px 0;
}

/* ─── NAV ─── */
.nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 9999;
  background: rgba(255, 255, 255, 0.94);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border);
  transition: box-shadow 0.3s;
}

.nav.scrolled {
  box-shadow: 0 4px 20px rgba(53, 88, 114, 0.08);
}

.nav-inner {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 48px;
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.nav-logo {
  display: flex;
  flex-direction: column;
  cursor: pointer;
  text-decoration: none;
}

.nav-logo-main {
  font-size: 26px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: -1px;
}

.nav-logo-main .n {
  color: var(--orange);
}

.nav-logo-main .r {
  color: var(--green-light);
}

.nav-logo-sub {
  font-size: 8.5px;
  color: rgba(53, 88, 114, 0.6);
  letter-spacing: 2.5px;
  text-transform: uppercase;
  margin-top: 1px;
  font-family: 'DM Mono', monospace;
}

.nav-menu {
  display: flex;
  gap: 4px;
  list-style: none;
  align-items: center;
}

.nav-item {
  position: relative;
}

.nav-link {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 8px 14px;
  border-radius: var(--radius-sm);
  font-size: 13.5px;
  font-weight: 500;
  color: var(--text-muted);
  cursor: pointer;
  transition: all 0.2s;
  text-decoration: none;
}

.nav-link:hover {
  color: var(--orange);
  background: rgba(53, 88, 114, 0.05);
}

.nav-link.active {
  color: var(--green-light);
}

.nav-link .chevron {
  font-size: 10px;
  transition: transform 0.2s;
}

.nav-item:hover .chevron {
  transform: rotate(180deg);
}

.nav-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) translateY(-3px);
  background: var(--dark3);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 8px;
  min-width: 180px;
  opacity: 0;
  pointer-events: none;
  transition: all 0.2s;
  box-shadow: 0 10px 40px rgba(53, 88, 114, 0.12);
}

.nav-dropdown::before {
  content: '';
  position: absolute;
  top: -24px;
  left: 0;
  right: 0;
  height: 24px;
  background: transparent;
}

.nav-item:hover .nav-dropdown {
  opacity: 1;
  pointer-events: all;
  transform: translateX(-50%) translateY(0);
}

.nav-dropdown a {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  font-size: 13px;
  color: var(--text-muted);
  text-decoration: none;
  transition: all 0.15s;
}

.nav-dropdown a:hover {
  color: var(--orange);
  background: rgba(53, 88, 114, 0.05);
  padding-left: 18px;
}

.nav-dropdown a .dd-icon {
  font-size: 15px;
}

/* Remove icons from Verticals dropdown links only */
.nav-dropdown a[href*="defence.html"] .dd-icon,
.nav-dropdown a[href*="oem-odm.html"] .dd-icon,
.nav-dropdown a[href*="government.html"] .dd-icon,
.nav-dropdown a[href*="consumer.html"] .dd-icon,
.nav-dropdown a[href*="telecom.html"] .dd-icon {
  display: none;
}

.nav-cta {
  background: var(--orange) !important;
  color: #fff !important;
  font-weight: 600 !important;
  box-shadow: 0 4px 20px var(--orange-glow);
  margin-left: 8px;
}

.nav-cta:hover {
  background: var(--orange-dark) !important;
}

/* ─── PAGE HERO ─── */
.page-hero {
  background: var(--dark2);
  padding: 72px 0 64px;
  border-bottom: 1px solid var(--border);
  position: relative;
  overflow: hidden;
}

.page-hero::after {
  content: '';
  position: absolute;
  right: -200px;
  top: -200px;
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, var(--green-glow) 0%, transparent 65%);
  border-radius: 50%;
  pointer-events: none;
}

.page-hero .label {
  color: var(--green-light);
}

.page-hero .label::before {
  background: var(--green-light);
}

/* ─── FOOTER ─── */
footer {
  background: var(--dark2);
  border-top: 1px solid var(--border);
  padding: 64px 0 36px;
}

.footer-grid {
  display: grid;
  grid-template-columns: 2.2fr 1fr 1fr 1fr;
  gap: 64px;
  margin-bottom: 56px;
}

.footer-brand-desc {
  font-size: 14px;
  color: var(--text-muted);
  margin-top: 14px;
  line-height: 1.7;
  max-width: 300px;
}

.footer-col h5 {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2.5px;
  color: var(--text-dim);
  margin-bottom: 20px;
  font-family: 'DM Mono', monospace;
}

.footer-col ul {
  list-style: none;
}

.footer-col li {
  margin-bottom: 11px;
}

.footer-col a {
  font-size: 14px;
  color: var(--text-muted);
  text-decoration: none;
  transition: color 0.2s;
}

.footer-col a:hover {
  color: var(--orange-light, var(--orange));
}

.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 28px;
  border-top: 1px solid var(--border);
}

.footer-bottom p {
  font-size: 12px;
  color: var(--text-dim);
  font-family: 'DM Mono', monospace;
}

/* ─── UTILITY ─── */
.text-orange {
  color: var(--orange);
}

.text-green {
  color: var(--green-light);
}

.text-muted {
  color: var(--text-muted);
}

.mt-8 {
  margin-top: 8px;
}

.mt-16 {
  margin-top: 16px;
}

.mt-24 {
  margin-top: 24px;
}

.mt-32 {
  margin-top: 32px;
}

.mt-48 {
  margin-top: 48px;
}

.mt-64 {
  margin-top: 64px;
}

.mb-8 {
  margin-bottom: 8px;
}

.mb-16 {
  margin-bottom: 16px;
}

.mb-24 {
  margin-bottom: 24px;
}

.mb-32 {
  margin-bottom: 32px;
}

.mb-48 {
  margin-bottom: 48px;
}

.flex {
  display: flex;
}

.flex-center {
  display: flex;
  align-items: center;
}

.gap-12 {
  gap: 12px;
}

.gap-16 {
  gap: 16px;
}

.gap-24 {
  gap: 24px;
}

.gap-32 {
  gap: 32px;
}

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

.grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.grid-4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

.grid-5 {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 20px;
}

/* ─── ANIMATIONS ─── */
@keyframes rotate3d {
  0% { transform: perspective(1000px) rotateY(0deg); }
  100% { transform: perspective(1000px) rotateY(360deg); }
}

.auto-rotate-3d {
  animation: rotate3d 12s linear infinite;
  transform-style: preserve-3d;
}

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(24px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

@keyframes fadeIn {
  from {
    opacity: 0
  }

  to {
    opacity: 1
  }
}

@keyframes float {

  0%,
  100% {
    transform: translateY(0)
  }

  50% {
    transform: translateY(-14px)
  }
}

@keyframes spin {
  to {
    transform: rotate(360deg)
  }
}

.animate {
  animation: fadeUp 0.7s ease both;
}

.delay-1 {
  animation-delay: 0.1s;
}

.delay-2 {
  animation-delay: 0.2s;
}

.delay-3 {
  animation-delay: 0.3s;
}

.delay-4 {
  animation-delay: 0.4s;
}

/* ─── MEMBERS ─── */
.members-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
  justify-content: center;
  align-items: center;
}

.member-logo {
  padding: 24px 32px;
  border-radius: var(--radius);
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 180px;
}

.member-logo img {
  max-width: 160px;
  max-height: 60px;
  object-fit: contain;
  opacity: 0.6;
  filter: grayscale(100%);
  transition: all 0.3s ease;
}

.member-logo:hover img {
  opacity: 1;
  filter: grayscale(0%);
}

/* ─── FAQ ─── */
.faq-item {
  border-radius: var(--radius);
  overflow: hidden;
  margin-bottom: 12px;
  transition: border-color 0.2s;
}

.faq-item.open {
  border-color: var(--border-orange);
}

.faq-q {
  padding: 20px 26px;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  transition: color 0.2s;
}

.faq-q:hover {
  color: var(--green-light);
}

.faq-icon {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  color: var(--orange);
  flex-shrink: 0;
  transition: transform 0.25s;
}

.faq-item.open .faq-icon {
  transform: rotate(45deg);
}

.faq-body {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.35s ease;
}

.faq-item.open .faq-body {
  max-height: 300px;
}

.faq-body p {
  padding: 0 26px 22px;
  font-size: 14px;
  color: var(--text-muted);
  line-height: 1.8;
  border-top: 1px solid var(--border);
  padding-top: 18px;
  margin: 0 26px;
}

/* ─── STATS ─── */
.stats-strip {
  border-radius: var(--radius-lg);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}

.stat-cell {
  padding: 36px 40px;
  border-right: 1px solid var(--border);
}

.stat-cell:last-child {
  border-right: none;
}

.stat-val {
  font-size: 52px;
  font-weight: 900;
  line-height: 1;
  color: var(--text);
}

.stat-val .unit {
  font-size: 26px;
  color: var(--orange);
}

.stat-desc {
  font-size: 12px;
  color: var(--text-dim);
  margin-top: 6px;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-family: 'DM Mono', monospace;
}

/* ─── ABOUT MISSION GRID ─── */
.about-mission-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
}

/* ─── RESPONSIVE ─── */
@media (max-width: 1024px) {
  .container {
    padding: 0 32px;
  }

  .row-2 {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  /* Grid collapses for tablet */
  .hero-inner,
  .about-hero-inner,
  .vert-hero-inner,
  .prod-hero-inner,
  .contact-grid,
  .about-mission-grid {
    grid-template-columns: 1fr !important;
    gap: 48px;
  }

  .verts-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 16px;
  }

  .hero-visual,
  .orb-container,
  .prod-visual-box,
  .vert-visual {
    margin: 0 auto;
    max-width: 100%;
  }

  .info-card {
    position: static !important;
    width: 100% !important;
  }

  .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 40px;
  }

  /* Collapse product showcase */
  .prod-showcase {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
}

@media (max-width: 768px) {
  .container {
    padding: 0 24px;
  }

  .section {
    padding: 64px 0;
  }

  .grid-3,
  .grid-4,
  .grid-5 {
    grid-template-columns: 1fr;
  }

  .grid-2 {
    grid-template-columns: 1fr;
  }

  /* Grid collapses for mobile overrides */
  .tech-cards,
  .feat-grid,
  .branch-grid,
  .spec-row,
  .uc-grid,
  .versions-grid,
  .form-row,
  .verts-grid {
    grid-template-columns: 1fr !important;
    gap: 20px;
  }

  /* Stat and CTA adjustments */
  .orb-stat {
    display: none !important;
    /* Hide absolutely positioned stats to prevent horizontal overflow on small screens */
  }

  .cta-block,
  .cta-strip {
    flex-direction: column !important;
    text-align: center !important;
    padding: 48px 32px !important;
  }

  .cta-block h2,
  .cta-strip h2 {
    max-width: 100% !important;
    margin-bottom: 24px !important;
  }

  .cta-btns {
    flex-direction: column !important;
    width: 100% !important;
    gap: 12px !important;
  }

  .cta-btns .btn {
    width: 100% !important;
    justify-content: center !important;
  }

  .stats-strip {
    grid-template-columns: 1fr !important;
  }

  .stat-cell {
    border-right: none;
    border-bottom: 1px solid var(--border);
    text-align: center;
  }

  .stat-cell:last-child {
    border-bottom: none;
  }

  .nav-menu {
    display: none;
  }

  .footer-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  /* Flagship product specs responsive wrap to avoid cut-off */
  .prod-specs {
    flex-wrap: wrap !important;
    gap: 14px 18px !important;
    justify-content: flex-start;
  }

  .ps {
    flex: 1 1 calc(50% - 10px);
    min-width: 100px;
  }

  .ps strong {
    font-size: 20px !important;
  }
}

/* ─── MOBILE HAMBURGER & DRAWER ─── */

/* Hamburger button — hidden on desktop */
.nav-hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  padding: 8px;
  transition: background 0.2s;
  z-index: 10001;
  flex-shrink: 0;
}

.nav-hamburger:hover {
  background: rgba(53, 88, 114, 0.06);
}

.nav-hamburger span {
  display: block;
  width: 100%;
  height: 2px;
  background: var(--text);
  border-radius: 2px;
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  transform-origin: center;
}

/* Animate into X when open */
.nav-hamburger.open span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.nav-hamburger.open span:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}

.nav-hamburger.open span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* Full-screen overlay backdrop */
.mobile-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(42, 68, 87, 0.35);
  backdrop-filter: blur(3px);
  z-index: 9998;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.mobile-overlay.open {
  opacity: 1;
}

/* Mobile drawer panel sliding in from the right */
.mobile-menu {
  position: fixed;
  top: 0;
  right: 0;
  width: min(320px, 88vw);
  height: 100dvh;
  background: #ffffff;
  box-shadow: -8px 0 40px rgba(53, 88, 114, 0.14);
  z-index: 9999;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1);
  overflow-y: auto;
}

.mobile-menu.open {
  transform: translateX(0);
}

/* Drawer header */
.mobile-menu-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 24px;
  height: 72px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.mobile-menu-logo {
  font-size: 22px;
  font-weight: 900;
  letter-spacing: -1px;
  text-decoration: none;
  color: var(--text);
}

.mobile-menu-logo .n {
  color: var(--orange);
}

.mobile-menu-logo .r {
  color: var(--green-light);
}

.mobile-menu-close {
  width: 36px;
  height: 36px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: transparent;
  cursor: pointer;
  font-size: 18px;
  color: var(--text-muted);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}

.mobile-menu-close:hover {
  background: rgba(53, 88, 114, 0.06);
  color: var(--text);
}

/* Nav links in the drawer */
.mobile-nav {
  display: flex;
  flex-direction: column;
  padding: 16px 0;
  flex: 1;
}

.mobile-nav a {
  display: block;
  padding: 13px 24px;
  font-size: 15px;
  font-weight: 500;
  color: var(--text);
  text-decoration: none;
  transition: background 0.15s, color 0.15s;
  border-radius: 0;
}

.mobile-nav a:hover {
  background: rgba(53, 88, 114, 0.05);
  color: var(--orange);
}

.mobile-nav a.active {
  color: var(--orange);
  font-weight: 600;
}

/* Section label inside drawer */
.mobile-nav-section {
  padding: 16px 24px 6px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--text-dim);
  font-family: 'DM Mono', monospace;
}

.mobile-nav-divider {
  height: 1px;
  background: var(--border);
  margin: 8px 24px;
}

/* CTA button at the bottom of the drawer */
.mobile-nav-cta {
  padding: 20px 24px;
  border-top: 1px solid var(--border);
  flex-shrink: 0;
}

.mobile-nav-cta .btn {
  width: 100%;
  justify-content: center;
}

/* Show hamburger only on mobile */
@media (max-width: 768px) {
  .nav-hamburger {
    display: flex;
  }
}
/* ─── NEWS ROOM ─── */
.news-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
@media (max-width: 900px) {
  .news-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 600px) {
  .news-grid {
    grid-template-columns: 1fr;
  }
}
.news-card {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  padding: 0;
  transition: all 0.3s ease;
  height: max-content;
  border-radius: 24px;
}
.news-card:hover {
  transform: translateY(-5px);
  border-color: var(--border-orange);
}
.news-image {
  width: 100%;
  height: 200px;
  overflow: hidden;
  border-bottom: 1px solid var(--border);
}
.news-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.news-card:hover .news-image img {
  transform: scale(1.05);
}
.news-content {
  padding: 24px;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}
.news-title {
  font-size: 20px;
  margin-bottom: 12px;
  color: #fff;
}
.news-excerpt {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  color: var(--text-muted);
  margin-bottom: 24px;
  line-height: 1.6;
}
.news-body {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height 0.4s ease, opacity 0.4s ease, margin-top 0.4s ease;
  color: var(--text-muted);
}
.news-card.open .news-body {
  max-height: 1500px;
  opacity: 1;
  margin-bottom: 24px;
}
.news-card.open .news-excerpt {
  display: none;
}


/* --- PAGE SPECIFIC STYLES --- */

/* Extracted from oem-odm.html */
.vert-hero {
      padding-top: 72px;
      min-height: 55vh;
      display: flex;
      align-items: center;
      position: relative;
      overflow: hidden;
      background: var(--dark2);
    }

    .vert-hero-grid {
      position: absolute;
      inset: 0;
      background-image: linear-gradient(var(--border) 1px, transparent 1px), linear-gradient(90deg, var(--border) 1px, transparent 1px);
      background-size: 72px 72px;
      opacity: 0.4;
    }

    .vert-hero-glow {
      position: absolute;
      right: -5%;
      top: 50%;
      transform: translateY(-50%);
      width: 55vw;
      height: 55vw;
      background: radial-gradient(circle, rgba(156, 213, 255, 0.2) 0%, transparent 60%);
      border-radius: 50%;
    }

    .feat-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 24px;
    }

    .feat-card {
      background: var(--dark3);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 36px;
      transition: all 0.25s;
    }

    .feat-card:hover {
      border-color: var(--border-orange);
      transform: translateY(-5px);
    }

    .feat-card h3 {
      font-size: 20px;
      margin-bottom: 12px;
    }

    .feat-card p {
      font-size: 14px;
      color: var(--text-muted);
      line-height: 1.8;
    }

/* Extracted from newsroom.html */
.news-hero {
      padding-top: 72px;
      min-height: 40vh;
      display: flex;
      align-items: center;
      position: relative;
      overflow: hidden;
      background: var(--dark2);
    }
    .news-hero-grid {
      position: absolute;
      inset: 0;
      background-image: linear-gradient(var(--border) 1px, transparent 1px), linear-gradient(90deg, var(--border) 1px, transparent 1px);
      background-size: 72px 72px;
      opacity: 0.4;
    }
    .news-hero-glow {
      position: absolute;
      left: 50%;
      top: 50%;
      transform: translate(-50%, -50%);
      width: 60vw;
      height: 60vw;
      background: radial-gradient(circle, rgba(122, 170, 206, 0.15) 0%, transparent 60%);
      border-radius: 50%;
      pointer-events: none;
    }

/* Extracted from index.html */
/* ── HOME SPECIFIC ── */

    .hero {
      width: 100%;
      aspect-ratio: 16 / 9;
      display: flex;
      align-items: center;
      position: relative;
      overflow: hidden;
      padding-top: 72px;
      /* push content down behind transparent navbar */
      padding-bottom: 80px;
      /* wave offset */
    }

    @media (max-width: 768px) {
      .hero {
        margin-top: 72px;
        /* pull out from under navbar so video is 100% visible */
        padding-top: 0;
      }
    }

    /* ── VIDEO BACKGROUND ── */
    .hero-video-bg {
      position: absolute;
      inset: 0;
      z-index: 0;
      pointer-events: none;
    }

    .hero-video-bg video {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center;
      display: block;
    }



    .hero-wave {
      position: absolute;
      bottom: -2px;
      left: 0;
      width: 100%;
      line-height: 0;
      pointer-events: none;
      z-index: 2;
    }

    .hero-wave svg {
      display: block;
      width: 100%;
      height: 90px;
    }

    .hero-bg {
      position: absolute;
      inset: 0;
      pointer-events: none;
    }

    /* ── CREATIVE FLAGSHIP LAYOUT ── */
    .creative-flagships {
      display: flex;
      flex-direction: column;
      gap: 160px;
      margin-top: 80px;
    }

    .flagship-item {
      display: grid;
      grid-template-columns: repeat(12, 1fr);
      align-items: center;
      position: relative;
    }

    .flagship-item-image {
      grid-column: 1 / 8;
      position: relative;
      border-radius: 32px;
      aspect-ratio: 4 / 3;
      box-shadow: 0 40px 80px rgba(0, 0, 0, 0.06);
      z-index: 1;
      display: flex;
      align-items: center;
      justify-content: center;
      overflow: hidden;
      border: 1px solid var(--border);
    }

    .flagship-item-image img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }

    .placeholder-badge {
      font-family: 'DM Mono', monospace;
      font-size: 14px;
      color: var(--text-dim);
      border: 1px dashed var(--text-dim);
      padding: 12px 24px;
      border-radius: 100px;
      text-transform: uppercase;
      letter-spacing: 1.5px;
      font-weight: 600;
    }

    .flagship-item-content {
      grid-column: 7 / 13;
      position: relative;
      z-index: 2;
      padding: 56px;
      border-radius: 24px;
      margin-left: -40px;
    }

    .flagship-item.reverse .flagship-item-image {
      grid-column: 6 / 13;
    }

    .flagship-item.reverse .flagship-item-content {
      grid-column: 1 / 7;
      margin-left: 0;
      margin-right: -40px;
    }

    .flagship-item::before {
      content: "";
      position: absolute;
      top: 50%;
      left: 30%;
      width: 50vw;
      height: 50vw;
      background: var(--green-glow);
      border-radius: 50%;
      filter: blur(80px);
      transform: translate(-50%, -50%);
      z-index: 0;
      pointer-events: none;
    }

    .flagship-item.reverse::before {
      left: 70%;
      background: var(--orange-glow);
    }

    .full-width-banner {
      width: 100vw;
      height: 50vh;
      min-height: 300px;
      position: relative;
      left: 50%;
      right: 50%;
      margin-left: -50vw;
      margin-right: -50vw;
      background-position: center;
      background-size: cover;
      background-repeat: no-repeat;
    }

    @media (max-width: 991px) {
      .creative-flagships {
        gap: 80px;
      }

      .flagship-item,
      .flagship-item.reverse {
        display: flex;
        flex-direction: column;
      }

      .flagship-item-image,
      .flagship-item.reverse .flagship-item-image {
        width: 100%;
        margin: 0;
      }

      .flagship-item-content,
      .flagship-item.reverse .flagship-item-content {
        width: 90%;
        margin: -40px auto 0;
        padding: 32px;
      }
    }

    .hero-grid {
      position: absolute;
      inset: 0;
      background-image: linear-gradient(var(--border) 1px, transparent 1px), linear-gradient(90deg, var(--border) 1px, transparent 1px);
      background-size: 72px 72px;
      opacity: 0.5;
    }

    .hero-glow {
      position: absolute;
    }

    .hero-glow-1 {
      right: -10%;
      top: -10%;
      width: 65vw;
      height: 65vw;
      background: radial-gradient(circle, rgba(122, 170, 206, 0.15) 0%, transparent 60%);
      border-radius: 50%;
    }

    .hero-glow-2 {
      left: -15%;
      bottom: -20%;
      width: 50vw;
      height: 50vw;
      background: radial-gradient(circle, rgba(156, 213, 255, 0.2) 0%, transparent 60%);
      border-radius: 50%;
    }

    .hero-inner {
      position: relative;
      z-index: 1;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: center;
    }

    .hero-eyebrow {
      margin-bottom: 24px;
    }

    .hero-h1 {
      font-size: clamp(44px, 6vw, 82px);
      font-weight: 900;
      line-height: 1.02;
      margin-bottom: 24px;
    }

    .hero-h1 .line2 {
      display: block;
      color: var(--orange);
    }

    .hero-h1 .line3 {
      display: block;
      color: var(--green-light);
    }

    .hero-lead {
      font-size: 18px;
      color: var(--text-muted);
      font-weight: 300;
      line-height: 1.75;
      max-width: 480px;
      margin-bottom: 40px;
    }

    .hero-chips {
      display: flex;
      gap: 10px;
      flex-wrap: wrap;
      margin-top: 40px;
    }

    .chip {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 6px 14px;
      border-radius: 30px;
      font-size: 12px;
      font-weight: 500;
      border: 1px solid var(--border);
      background: var(--dark3);
      color: var(--text-muted);
    }

    .chip-dot {
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: var(--green-light);
    }

    .chip-dot.o {
      background: var(--orange);
    }

    /* ORB */
    .hero-visual {
      display: flex;
      align-items: center;
      justify-content: center;
      position: relative;
    }

    .orb {
      width: 400px;
      height: 400px;
      border-radius: 50%;
      background: radial-gradient(circle at 35% 35%, rgba(156, 213, 255, 0.45), var(--dark3));
      border: 1px solid rgba(122, 170, 206, 0.25);
      display: flex;
      align-items: center;
      justify-content: center;
      position: relative;
      animation: float 7s ease-in-out infinite;
    }

    .orb::before {
      content: '';
      position: absolute;
      inset: -24px;
      border-radius: 50%;
      border: 1px solid rgba(122, 170, 206, 0.12);
    }

    .orb::after {
      content: '';
      position: absolute;
      inset: -48px;
      border-radius: 50%;
      border: 1px dashed rgba(122, 170, 206, 0.1);
      animation: spin 40s linear infinite;
    }

    @keyframes float {

      0%,
      100% {
        transform: translateY(0)
      }

      50% {
        transform: translateY(-18px)
      }
    }

    @keyframes spin {
      to {
        transform: rotate(360deg)
      }
    }

    .orb-text {
      text-align: center;
    }

    .orb-icon {
      font-size: 64px;
      display: block;
      margin-bottom: 14px;
      opacity: 0.6;
    }

    .orb-label {
      font-size: 12px;
      font-weight: 700;
      color: var(--green-light);
      letter-spacing: 4px;
      text-transform: uppercase;
      font-family: 'DM Mono', monospace;
    }

    .orb-stat {
      position: absolute;
      background: rgba(255, 255, 255, 0.92);
      border: 1px solid var(--border);
      border-radius: 12px;
      padding: 14px 18px;
      backdrop-filter: blur(10px);
      box-shadow: 0 8px 32px rgba(53, 88, 114, 0.08);
    }

    .orb-stat .sv {
      font-size: 24px;
      font-weight: 900;
      color: var(--orange);
      font-family: 'Outfit', sans-serif;
      line-height: 1;
    }

    .orb-stat .sl {
      font-size: 11px;
      color: var(--text-muted);
      margin-top: 3px;
      font-family: 'DM Mono', monospace;
    }

    .orb-stat-1 {
      top: 10px;
      right: -50px;
    }

    .orb-stat-2 {
      bottom: 60px;
      right: -70px;
    }

    .orb-stat-3 {
      bottom: 10px;
      left: -50px;
    }

    /* SECTIONS */
    .tech-cards {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;
    }

    .tech-card {
      border-radius: var(--radius);
      padding: 36px;
      transition: all 0.25s;
    }

    .tech-card:hover {
      border-color: var(--border-orange);
      transform: translateY(-5px);
    }

    .tc-icon {
      width: 52px;
      height: 52px;
      border-radius: 12px;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 24px;
      margin-bottom: 22px;
    }

    .tc-icon.green {
      background: rgba(122, 170, 206, 0.12);
      border: 1px solid rgba(122, 170, 206, 0.25);
    }

    .tc-icon.orange {
      background: rgba(156, 213, 255, 0.15);
      border: 1px solid rgba(156, 213, 255, 0.3);
    }

    .tech-card h3 {
      font-size: 20px;
      margin-bottom: 10px;
    }

    .tech-card p {
      font-size: 14px;
      color: var(--text-muted);
      line-height: 1.75;
    }

    .verts-grid {
      display: grid;
      grid-template-columns: repeat(5, 1fr);
      gap: 16px;
    }

    .vert-card {
      border-radius: var(--radius);
      padding: 32px 20px;
      text-align: center;
      transition: all 0.25s;
      text-decoration: none;
      display: block;
    }

    .vert-card:hover {
      border-color: var(--border-orange);
      transform: translateY(-6px);
      background: rgba(122, 170, 206, 0.05);
    }

    .vert-icon {
      font-size: 34px;
      margin-bottom: 14px;
    }

    .vert-card h4 {
      font-size: 14px;
      font-weight: 700;
      color: var(--text);
    }

    .vert-card p {
      font-size: 12px;
      color: var(--text-muted);
      margin-top: 5px;
    }

    .prod-showcase {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 28px;
    }

    .prod-card {
      background: var(--dark3);
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      overflow: hidden;
      text-decoration: none;
      display: block;
      transition: all 0.25s;
    }

    .prod-card:hover {
      border-color: var(--green);
      transform: translateY(-6px);
      box-shadow: 0 24px 60px rgba(53, 88, 114, 0.08);
    }

    .prod-thumb {
      height: 230px;
      display: flex;
      align-items: center;
      justify-content: center;
      position: relative;
      overflow: hidden;
    }

    .prod-thumb::before {
      content: '';
      position: absolute;
      inset: 0;
      background: repeating-linear-gradient(45deg, transparent, transparent 19px, rgba(53, 88, 114, 0.02) 19px, rgba(53, 88, 114, 0.02) 20px);
    }

    .prod-body {
      padding: 32px 36px;
    }

    .prod-tag {
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 2.5px;
      text-transform: uppercase;
      color: var(--green-light);
      margin-bottom: 10px;
      display: block;
      font-family: 'DM Mono', monospace;
    }

    .prod-body h3 {
      font-size: 26px;
      margin-bottom: 12px;
    }

    .prod-body p {
      font-size: 14px;
      color: var(--text-muted);
      line-height: 1.75;
      margin-bottom: 22px;
    }

    .prod-specs {
      display: flex;
      gap: 24px;
      padding-top: 18px;
      border-top: 1px solid var(--border);
    }

    .ps {
      font-size: 12px;
      color: var(--text-muted);
    }

    .ps strong {
      color: var(--orange);
      font-size: 22px;
      font-weight: 900;
      display: block;
      line-height: 1;
      margin-bottom: 3px;
    }

    .cta-block {
      background: linear-gradient(135deg, #355872, #7AAACE 60%, #9CD5FF);
      border: 1px solid rgba(122, 170, 206, 0.3);
      border-radius: 24px;
      padding: 84px 72px;
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 48px;
      position: relative;
      overflow: hidden;
      color: #fff;
    }

    .cta-block::after {
      content: '';
      position: absolute;
      right: -80px;
      top: -80px;
      width: 360px;
      height: 360px;
      background: radial-gradient(circle, rgba(156, 213, 255, 0.25) 0%, transparent 70%);
      border-radius: 50%;
      pointer-events: none;
    }

    .cta-block h2 {
      font-size: clamp(28px, 3vw, 44px);
      max-width: 520px;
      position: relative;
      z-index: 1;
      color: #fff;
    }

    .cta-block h2 span {
      color: #9CD5FF;
    }

    .cta-block .btn-primary {
      background: #ffffff;
      color: #355872;
      box-shadow: 0 4px 24px rgba(255, 255, 255, 0.15);
    }

    .cta-block .btn-primary:hover {
      background: #f0f4f8;
      transform: translateY(-2px);
    }

    .cta-block .btn-outline {
      border-color: rgba(255, 255, 255, 0.4);
      color: #ffffff;
    }

    .cta-block .btn-outline:hover {
      border-color: #ffffff;
      background: rgba(255, 255, 255, 0.1);
      color: #ffffff;
    }

    .cta-btns {
      display: flex;
      gap: 14px;
      position: relative;
      z-index: 1;
      flex-shrink: 0;
    }

    /* Specs Box Visual for Slides */
    .specs-box {
      background: rgba(255, 255, 255, 0.72);
      backdrop-filter: blur(16px);
      -webkit-backdrop-filter: blur(16px);
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      padding: 36px;
      width: 100%;
      max-width: 440px;
      box-shadow: 0 20px 48px rgba(53, 88, 114, 0.06);
      position: relative;
      z-index: 1;
    }

    .specs-box-title {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: var(--green-light);
      margin-bottom: 24px;
      font-family: 'DM Mono', monospace;
      display: flex;
      align-items: center;
      gap: 8px;
    }

    .specs-box-title::after {
      content: '';
      flex: 1;
      height: 1px;
      background: var(--border);
    }

    .specs-box-grid {
      display: grid;
      gap: 18px;
    }

    .specs-box-item {
      display: flex;
      align-items: center;
      gap: 20px;
      padding-bottom: 14px;
      border-bottom: 1px solid rgba(53, 88, 114, 0.08);
    }

    .specs-box-item:last-child {
      border-bottom: none;
      padding-bottom: 0;
    }

    .specs-box-num {
      font-size: 32px;
      font-weight: 900;
      color: var(--orange);
      line-height: 1;
      min-width: 90px;
    }

    .specs-box-num .unit {
      font-size: 14px;
      font-weight: 600;
    }

    .specs-box-desc {
      font-size: 13.5px;
      color: var(--text-muted);
      line-height: 1.45;
    }

    .specs-box-desc strong {
      color: var(--text);
      display: block;
      font-size: 14px;
      margin-bottom: 2px;
    }

/* Extracted from government.html */
.vert-hero{padding-top:72px;min-height:55vh;display:flex;align-items:center;position:relative;overflow:hidden;background:var(--dark2);}
.vert-hero-grid{position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:72px 72px;opacity:0.4;}
.vert-hero-glow{position:absolute;right:-5%;top:50%;transform:translateY(-50%);width:55vw;height:55vw;background:radial-gradient(circle,rgba(156,213,255,0.2) 0%,transparent 60%);border-radius:50%;}
.feat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.feat-card{background:var(--dark3);border:1px solid var(--border);border-radius:var(--radius);padding:36px;transition:all 0.25s;}
.feat-card:hover{border-color:var(--border-orange);transform:translateY(-5px);}
.feat-card h3{font-size:20px;margin-bottom:12px;}
.feat-card p{font-size:14px;color:var(--text-muted);line-height:1.8;}

/* Extracted from about.html */
.about-hero{padding-top:72px;min-height:60vh;display:flex;align-items:center;position:relative;overflow:hidden;background:var(--dark2);}
.about-hero-grid{position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:72px 72px;opacity:0.4;}
.about-hero-glow{position:absolute;right:-5%;top:50%;transform:translateY(-50%);width:55vw;height:55vw;background:radial-gradient(circle,rgba(122,170,206,0.18) 0%,transparent 60%);border-radius:50%;}
.about-hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.about-visual{border-radius:24px;height:440px;background:linear-gradient(135deg,var(--orange) 0%,var(--green-dark) 100%);border:1px solid var(--border);position:relative;overflow:hidden;display:flex;align-items:flex-end;}
.about-visual::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 29px,rgba(255,255,255,0.03) 29px,rgba(255,255,255,0.03) 30px);}
.about-visual-big{position:absolute;top:50%;left:50%;transform:translate(-50%,-60%);font-size:110px;font-weight:900;color:rgba(255,255,255,0.06);line-height:1;white-space:nowrap;pointer-events:none;}
.about-visual-content{position:relative;z-index:1;padding:36px;width:100%;}
.about-visual-content h3{font-size:26px;color:#fff;}
.about-visual-content p{color:rgba(255,255,255,0.65);font-size:13px;margin-top:6px;font-family:'DM Mono',monospace;}
.mission-values{display:flex;flex-direction:column;gap:22px;margin-top:36px;}
.mv-row{display:flex;gap:18px;align-items:flex-start;}
.mv-num{font-family:'DM Mono',monospace;font-size:12px;font-weight:700;color:var(--orange);min-width:30px;margin-top:3px;}
.mv-row h4{font-size:16px;margin-bottom:5px;}
.mv-row p{font-size:13px;color:var(--text-muted);line-height:1.7;}
.ideas-cloud{display:flex;flex-wrap:wrap;gap:12px;margin-top:48px;}
.idea-pill{background:rgba(122,170,206,0.12);border:1px solid rgba(122,170,206,0.25);color:var(--text);font-size:13px;padding:9px 20px;border-radius:40px;transition:all 0.2s;font-weight:500;}
.idea-pill:hover{background:rgba(122,170,206,0.2);color:var(--orange-dark);}

/* Extracted from contact.html */
.contact-hero{padding-top:72px;min-height:45vh;display:flex;align-items:center;position:relative;overflow:hidden;background:var(--dark2);}
.contact-hero-grid{position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:72px 72px;opacity:0.4;}
.contact-hero-glow{position:absolute;right:-5%;top:50%;transform:translateY(-50%);width:55vw;height:55vw;background:radial-gradient(circle,rgba(156,213,255,0.2) 0%,transparent 60%);border-radius:50%;}
.contact-grid{display:grid;grid-template-columns:1fr 1.8fr;gap:72px;align-items:start;}
.info-card{background:var(--dark3);border:1px solid var(--border);border-radius:var(--radius);padding:48px;position:sticky;top:96px;}
.info-card h3{font-size:22px;margin-bottom:32px;}
.ci-item{display:flex;gap:16px;margin-bottom:28px;align-items:flex-start;}
.ci-icon{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.ci-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--orange);margin-bottom:5px;font-family:'DM Mono',monospace;}
.ci-val{font-size:14px;color:var(--text);line-height:1.6;}
.av-badge{display:flex;align-items:center;gap:10px;background:rgba(122,170,206,0.12);border:1px solid rgba(122,170,206,0.25);border-radius:10px;padding:14px 18px;margin-top:32px;}
.av-dot{width:8px;height:8px;border-radius:50%;background:var(--green);animation:pulse 2s infinite;flex-shrink:0;}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.3}}
.av-badge p{font-size:13px;color:var(--text-muted);}
.form-card{background:var(--dark3);border:1px solid var(--border);border-radius:var(--radius);padding:56px;}
.form-card h3{font-size:26px;margin-bottom:32px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.form-group{margin-bottom:22px;}
.form-group label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:9px;color:var(--text-muted);font-family:'DM Mono',monospace;}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:13px 18px;background:var(--dark);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;color:var(--text);font-family:'Outfit',sans-serif;outline:none;transition:border-color 0.2s;resize:vertical;}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(122,170,206,0.2);}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-dim);}
.form-group select option{background:var(--dark3);color:var(--text);}
.form-group textarea{min-height:130px;}
.submit-btn{width:100%;padding:16px;background:var(--orange);color:#fff;border:none;border-radius:var(--radius-sm);font-size:16px;font-weight:700;font-family:'Outfit',sans-serif;cursor:pointer;transition:background 0.2s;letter-spacing:0.3px;}
.submit-btn:hover{background:var(--orange-dark);}
.success-msg{display:none;background:rgba(122,170,206,0.12);border:1px solid rgba(122,170,206,0.35);border-radius:var(--radius-sm);padding:15px 20px;color:var(--text);font-size:14px;margin-bottom:24px;text-align:center;}

/* Extracted from navocular.html */
.prod-hero { min-height: 70vh; display: flex; align-items: center; padding-top: 72px; position: relative; overflow: hidden; background: var(--dark2); }
.prod-hero-grid { position:absolute;inset:0; background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px); background-size:72px 72px; opacity:0.4; }
.prod-hero-glow { position:absolute; right:-10%; top:50%; transform:translateY(-50%); width:60vw; height:60vw; background:radial-gradient(circle,rgba(156,213,255,0.2) 0%,transparent 60%); border-radius:50%; pointer-events:none; }
.prod-hero-inner { position:relative; z-index:1; display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.prod-visual-box { border-radius:24px; height:400px; display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; border:1px solid var(--border); background:linear-gradient(135deg,var(--orange) 0%,var(--green-dark) 80%); }
.prod-visual-box::before { content:''; position:absolute; inset:0; background:repeating-linear-gradient(45deg,transparent,transparent 19px,rgba(255,255,255,0.06) 19px,rgba(255,255,255,0.06) 20px); }
.spec-row { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.spec-box { background:var(--dark3); border:1px solid var(--border); border-radius:var(--radius); padding:32px 24px; text-align:center; }
.spec-val { font-size:48px; font-weight:900; color:var(--orange); line-height:1; }
.spec-unit { font-size:11px; color:var(--text-muted); margin-top:6px; text-transform:uppercase; letter-spacing:1px; font-family:'DM Mono',monospace; }
.spec-desc { font-size:13px; color:var(--text-muted); margin-top:8px; }
.uc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.uc-card { background:var(--dark3); border:1px solid var(--border); border-radius:var(--radius); padding:30px 28px; transition:all 0.25s; }
.uc-card:hover { border-color:var(--border-orange); transform:translateY(-4px); }
.uc-tag { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--green-light); margin-bottom:10px; display:block; font-family:'DM Mono',monospace; }
.uc-card h4 { font-size:18px; margin-bottom:10px; }
.uc-card p { font-size:14px; color:var(--text-muted); line-height:1.75; }

/* Extracted from defence.html */
.vert-hero { padding-top:72px; min-height:60vh; display:flex; align-items:center; position:relative; overflow:hidden; background:var(--dark2); }
.vert-hero-grid { position:absolute;inset:0; background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px); background-size:72px 72px; opacity:0.4; }
.vert-hero-glow { position:absolute; right:-5%; top:50%; transform:translateY(-50%); width:55vw; height:55vw; background:radial-gradient(circle,rgba(156,213,255,0.2) 0%,transparent 60%); border-radius:50%; }
.vert-hero-inner { position:relative; z-index:1; display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.vert-visual { border-radius:24px; height:380px; display:flex; align-items:center; justify-content:center; border:1px solid var(--border); background:linear-gradient(135deg,var(--orange),var(--green-dark)); position:relative; overflow:hidden; }
.vert-visual::before { content:''; position:absolute; inset:0; background:repeating-linear-gradient(45deg,transparent,transparent 19px,rgba(255,255,255,0.06) 19px,rgba(255,255,255,0.06) 20px); }
.branch-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.branch-card { background:var(--dark3); border:1px solid var(--border); border-radius:var(--radius); padding:32px 28px; transition:all 0.25s; }
.branch-card:hover { border-color:var(--border-orange); transform:translateY(-5px); }
.branch-card h3 { font-size:20px; margin-bottom:16px; padding-bottom:14px; border-bottom:1px solid var(--border); display:flex; align-items:center; gap:10px; }
.sub-item { margin-top:18px; }
.sub-item h5 { font-size:11px; font-weight:700; color:var(--orange); text-transform:uppercase; letter-spacing:1.5px; margin-bottom:7px; font-family:'DM Mono',monospace; }
.sub-item p { font-size:13px; color:var(--text-muted); line-height:1.75; }
.cta-strip { background:linear-gradient(135deg, #355872, #7AAACE 60%, #9CD5FF); border:1px solid rgba(122,170,206,0.3); border-radius:20px; padding:60px 64px; display:flex; justify-content:space-between; align-items:center; gap:32px; color: #fff; }
.cta-strip h2 { font-size:32px; max-width:500px; color: #fff; }
.cta-strip h2 span { color:#9CD5FF; }
.cta-strip .btn-primary { background: #ffffff; color: #355872; box-shadow: 0 4px 24px rgba(255, 255, 255, 0.15); }
.cta-strip .btn-primary:hover { background: #f0f4f8; transform: translateY(-2px); }

/* Extracted from consumer.html */
.vert-hero{padding-top:72px;min-height:55vh;display:flex;align-items:center;position:relative;overflow:hidden;background:var(--dark2);}
.vert-hero-grid{position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:72px 72px;opacity:0.4;}
.vert-hero-glow{position:absolute;left:-5%;top:50%;transform:translateY(-50%);width:55vw;height:55vw;background:radial-gradient(circle,rgba(156,213,255,0.2) 0%,transparent 60%);border-radius:50%;}
.feat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.feat-card{background:var(--dark3);border:1px solid var(--border);border-radius:var(--radius);padding:36px;transition:all 0.25s;}
.feat-card:hover{border-color:var(--border-orange);transform:translateY(-5px);}
.feat-card h3{font-size:20px;margin-bottom:12px;}
.feat-card p{font-size:14px;color:var(--text-muted);line-height:1.8;}

/* Extracted from opticspectra.html */
.prod-hero { min-height:70vh; display:flex; align-items:center; padding-top:72px; position:relative; overflow:hidden; background:var(--dark2); }
.prod-hero-grid { position:absolute;inset:0; background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px); background-size:72px 72px; opacity:0.4; }
.prod-hero-glow { position:absolute; right:-10%; top:50%; transform:translateY(-50%); width:60vw; height:60vw; background:radial-gradient(circle,rgba(156,213,255,0.2) 0%,transparent 60%); border-radius:50%; pointer-events:none; }
.prod-hero-inner { position:relative; z-index:1; display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.prod-visual-box { border-radius:24px; height:400px; display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; border:1px solid rgba(122,170,206,0.3); background:linear-gradient(135deg,var(--dark3),var(--dark2)); }
.prod-visual-box::before { content:''; position:absolute; inset:0; background:repeating-linear-gradient(45deg,transparent,transparent 19px,rgba(122,170,206,0.05) 19px,rgba(122,170,206,0.05) 20px); }
.versions-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.version-card { background:var(--dark3); border:1px solid var(--border); border-radius:var(--radius); padding:36px; position:relative; overflow:hidden; transition:all 0.25s; }
.version-card:hover { transform:translateY(-5px); }
.version-card.featured { border-color:rgba(122,170,206,0.4); }
.version-card.featured::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--orange),var(--orange-dark)); }
.cert { display:inline-flex; align-items:center; gap:6px; background:rgba(122,170,206,0.1); border:1px solid rgba(122,170,206,0.25); color:var(--orange); font-size:10px; font-weight:700; letter-spacing:1.5px; padding:5px 12px; border-radius:20px; margin-bottom:16px; text-transform:uppercase; font-family:'DM Mono',monospace; }
.version-card h3 { font-size:24px; margin-bottom:6px; }
.version-card .sub { font-size:13px; color:var(--text-muted); margin-bottom:24px; }
.vspec-row { display:flex; gap:28px; padding-top:16px; border-top:1px solid var(--border); }
.vspec { font-size:12px; color:var(--text-muted); }
.vspec strong { font-size:22px; font-weight:900; color:var(--text); display:block; font-family:'Outfit',sans-serif; line-height:1; margin-bottom:3px; }
.uc-grid { display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.uc-card { background:var(--dark3); border:1px solid var(--border); border-radius:var(--radius); padding:30px; transition:all 0.25s; }
.uc-card:hover { border-color:var(--border-orange); transform:translateY(-4px); }
.uc-tag { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--green-light); margin-bottom:10px; display:block; font-family:'DM Mono',monospace; }
.uc-card h4 { font-size:18px; margin-bottom:10px; }
.uc-card p { font-size:14px; color:var(--text-muted); line-height:1.75; }