@font-face {
  font-family: "Archivo";
  src: url("/assets/fonts/archivo.woff2") format("woff2");
  font-weight: 100 900;
  font-display: swap;
}

:root {
  --navy-950: #04101f;
  --navy-900: #07172b;
  --navy-800: #003566;
  --navy-700: #004b87;
  --cyan: #00aeef;
  --green: #00a335;
  --green-dark: #007a28;
  --ink: #0f172b;
  --slate: #45556c;
  --mist: #e2e8f0;
  --paper: #f8fafc;
  --white: #fff;
  --shell: min(1160px, calc(100vw - 48px));
  --ease: cubic-bezier(.22, 1, .36, 1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
html.lenis, html.lenis body { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }
body {
  margin: 0;
  overflow-x: clip;
  color: var(--ink);
  background: var(--white);
  font-family: "Archivo", Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
}
body.menu-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; height: auto; }
button { font: inherit; }
h1, h2, h3, p { margin-top: 0; }
h1, h2, h3 { text-wrap: balance; }
p { text-wrap: pretty; }
.shell { width: var(--shell); margin-inline: auto; }
.section-light { background: var(--white); }
.section-dark { color: var(--white); background: var(--navy-950); }
.skip-link {
  position: fixed; top: 12px; left: 12px; z-index: 1000;
  transform: translateY(-150%); padding: 12px 16px; border-radius: 6px;
  color: white; background: var(--green);
}
.skip-link:focus { transform: none; }
.grain {
  position: fixed; inset: 0; z-index: 90; pointer-events: none; opacity: .035;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.page-wipe {
  position: fixed; inset: 0; z-index: 200; pointer-events: none;
  transform: translateY(-100%); background: var(--navy-950);
}
.cursor-dot {
  position: fixed; top: 0; left: 0; z-index: 150; width: 16px; height: 16px;
  pointer-events: none; border: 1px solid rgba(255,255,255,.7); border-radius: 50%;
  background: rgba(0,174,239,.22); backdrop-filter: blur(3px);
  transform: translate(-50%, -50%); opacity: 0; transition: width .35s var(--ease), height .35s var(--ease), background .35s;
}
.cursor-dot.active { width: 48px; height: 48px; background: rgba(0,163,53,.16); }

.site-header {
  position: fixed; inset: 0 0 auto; z-index: 80; color: var(--white);
  border-bottom: 1px solid transparent; transition: background .35s, border-color .35s;
}
.site-header.scrolled {
  background: rgba(4,16,31,.82); border-color: rgba(255,255,255,.09);
  backdrop-filter: blur(18px) saturate(130%);
}
.nav { height: 80px; display: flex; align-items: center; justify-content: space-between; }
.brand img, .footer-brand img { width: 150px; max-height: 48px; object-fit: contain; object-position: left center; }
.nav-links { display: flex; gap: 34px; margin-left: auto; margin-right: 34px; }
.nav-links a { font-size: .86rem; font-weight: 600; color: rgba(255,255,255,.75); transition: color .25s; }
.nav-links a:hover { color: white; }
.button {
  display: inline-flex; align-items: center; justify-content: center; gap: 14px;
  min-height: 52px; padding: 0 24px; border: 1px solid transparent; border-radius: 7px;
  color: var(--white); background: var(--green); font-size: .89rem; font-weight: 700;
  box-shadow: 0 18px 45px rgba(0,163,53,.16), inset 0 1px rgba(255,255,255,.2);
  transition: transform .4s var(--ease), background .3s, box-shadow .3s;
}
.button:hover { background: var(--green-dark); box-shadow: 0 22px 55px rgba(0,163,53,.25); }
.button-small { min-height: 42px; padding-inline: 18px; font-size: .8rem; }
.menu-toggle { display: none; width: 44px; height: 44px; padding: 12px; border: 0; background: transparent; }
.menu-toggle span { display: block; width: 100%; height: 1px; margin: 6px 0; background: white; transition: transform .3s; }
.mobile-menu { display: none; }

.hero {
  position: relative; min-height: 100svh; display: flex; align-items: center;
  overflow: hidden; color: var(--white); background: var(--navy-950);
}
.hero-grid, .cta-grid {
  position: absolute; inset: 0; opacity: .065;
  background-image: linear-gradient(to right, var(--cyan) 1px, transparent 1px), linear-gradient(to bottom, var(--cyan) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: linear-gradient(to right, black, transparent 85%);
}
.hero-glow { position: absolute; border-radius: 50%; filter: blur(10px); pointer-events: none; }
.hero-glow-one { width: 750px; height: 750px; right: -170px; top: 5%; background: radial-gradient(circle, rgba(0,75,135,.28), transparent 67%); }
.hero-glow-two { width: 460px; height: 460px; left: 15%; bottom: -30%; background: radial-gradient(circle, rgba(0,163,53,.12), transparent 68%); }
.hero-layout { position: relative; z-index: 2; display: grid; grid-template-columns: 1.04fr .96fr; align-items: center; padding: 138px 0 90px; }
.hero-copy { position: relative; z-index: 3; }
.eyebrow {
  margin-bottom: 24px; color: #6dd6ff; text-transform: uppercase;
  letter-spacing: .18em; font-size: .71rem; font-weight: 750;
}
.eyebrow::before { content: ""; display: inline-block; width: 30px; height: 1px; margin: 0 12px 3px 0; background: var(--green); }
.hero-title {
  max-width: 13ch; margin-bottom: 28px;
  font-size: clamp(2.75rem, 5.8vw, 5.45rem); line-height: .98; letter-spacing: -.052em;
  font-weight: 780; font-stretch: 115%;
}
.hero-title em { color: #72dbff; font-style: normal; }
.title-line { display: block; overflow: hidden; padding-bottom: .04em; }
.title-line > span { display: block; will-change: transform; }
.hero-lead { max-width: 55ch; margin-bottom: 34px; color: #b9c8d9; font-size: clamp(1rem, 1.2vw, 1.12rem); line-height: 1.75; }
.hero-actions { display: flex; align-items: center; gap: 26px; }
.text-link { display: inline-flex; gap: 10px; align-items: center; font-size: .87rem; font-weight: 650; color: rgba(255,255,255,.82); }
.text-link span { transition: transform .3s var(--ease); }
.text-link:hover span { transform: translateX(5px); }
.hero-proof { display: flex; flex-wrap: wrap; gap: 20px 28px; padding: 0; margin: 42px 0 0; list-style: none; color: #8193a8; font-size: .74rem; font-weight: 600; }
.hero-proof li { display: flex; align-items: center; gap: 9px; }
.hero-proof span { width: 5px; height: 5px; border-radius: 50%; background: var(--green); box-shadow: 0 0 14px var(--green); }
.hero-visual { position: relative; margin-right: -12vw; }
.hero-visual img { position: relative; z-index: 1; width: min(900px, 67vw); filter: drop-shadow(0 34px 60px rgba(0,0,0,.25)); }
.interactive-3d {
  --tilt-x: 0deg;
  --tilt-y: 0deg;
  --glow-x: 50%;
  --glow-y: 50%;
  position: relative;
  perspective: 1100px;
  transform-style: preserve-3d;
}
.interactive-3d::before {
  content: "";
  position: absolute;
  inset: -8%;
  z-index: 0;
  pointer-events: none;
  opacity: .55;
  background: radial-gradient(circle at var(--glow-x) var(--glow-y), rgba(114,219,255,.22), transparent 36%);
  filter: blur(18px);
  transition: opacity .35s var(--ease);
}
.hero-visual.interactive-3d img,
.security-visual.interactive-3d img {
  transform: rotateX(var(--tilt-y)) rotateY(var(--tilt-x)) translateZ(34px);
  transform-style: preserve-3d;
  transition: transform .45s var(--ease), filter .45s var(--ease);
}
.image-3d-plane {
  position: relative;
  z-index: 1;
  transform: rotateX(var(--tilt-y)) rotateY(var(--tilt-x)) translateZ(24px);
  transform-style: preserve-3d;
  transition: transform .45s var(--ease);
}
.visual-halo { position: absolute; z-index: 0; width: 75%; aspect-ratio: 1; right: 12%; top: 12%; border-radius: 50%; background: rgba(0,174,239,.08); filter: blur(50px); }
.glass {
  border: 1px solid rgba(255,255,255,.14);
  background: linear-gradient(135deg, rgba(255,255,255,.13), rgba(255,255,255,.035));
  box-shadow: 0 24px 60px rgba(0,0,0,.23), inset 0 1px rgba(255,255,255,.14);
  backdrop-filter: blur(18px) saturate(125%);
}
.float-card { position: absolute; z-index: 3; display: flex; align-items: center; gap: 12px; min-width: 180px; padding: 14px 16px; border-radius: 12px; }
.float-card small, .float-card strong { display: block; }
.float-card small { color: #9fb0c2; font-size: .63rem; margin-bottom: 3px; }
.float-card strong { font-size: .76rem; }
.float-card-a { left: 9%; bottom: 15%; }
.pulse { position: relative; width: 9px; height: 9px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 7px rgba(0,163,53,.13); }
.scroll-cue { position: absolute; z-index: 4; bottom: 24px; left: 50%; display: flex; align-items: center; gap: 10px; color: #6f8298; font-size: .65rem; text-transform: uppercase; letter-spacing: .17em; }
.scroll-cue span { width: 1px; height: 27px; background: linear-gradient(var(--cyan), transparent); }

.manifesto { position: relative; overflow: hidden; padding: clamp(7rem, 15vw, 12rem) 0; }
.manifesto::before {
  content: "";
  position: absolute;
  right: -18%;
  top: 4%;
  width: 560px;
  height: 560px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(0,174,239,.1), transparent 68%);
  pointer-events: none;
}
.manifesto-grid { position: relative; display: grid; grid-template-columns: .55fr 1.42fr .98fr; gap: clamp(40px, 6vw, 86px); align-items: center; }
.section-index { color: var(--green); font-size: .7rem; font-weight: 750; letter-spacing: .15em; text-transform: uppercase; }
.manifesto h2 {
  max-width: 23ch; margin-bottom: 40px; color: var(--navy-800);
  font-size: clamp(2rem, 4.3vw, 3.8rem); line-height: 1.08; letter-spacing: -.04em; font-weight: 760;
}
.word-reveal span { display: inline-block; }
.manifesto-copy { max-width: 60ch; color: var(--slate); font-size: 1.03rem; line-height: 1.8; }
.manifesto-visual { min-height: 380px; display: grid; place-items: center; }
.purpose-object {
  position: relative;
  width: min(360px, 86vw);
  aspect-ratio: 1;
  border-radius: 34px;
  background:
    radial-gradient(circle at 35% 25%, rgba(255,255,255,.92), rgba(255,255,255,.25) 13%, transparent 32%),
    linear-gradient(135deg, rgba(0,75,135,.98), rgba(0,174,239,.72));
  box-shadow: 0 38px 90px rgba(0,53,102,.25), inset 0 1px rgba(255,255,255,.42);
  transform: rotateX(var(--tilt-y)) rotateY(var(--tilt-x)) translateZ(32px);
  transform-style: preserve-3d;
  transition: transform .45s var(--ease);
  animation: float-3d 7.5s ease-in-out infinite;
}
.purpose-object::before {
  content: "";
  position: absolute;
  inset: 12%;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.32);
  box-shadow: inset 0 0 42px rgba(255,255,255,.13);
  transform: translateZ(36px);
}
.purpose-ring, .purpose-core, .purpose-node, .purpose-panel {
  position: absolute;
  display: block;
  transform-style: preserve-3d;
}
.purpose-ring {
  inset: 19%;
  border: 1px solid rgba(255,255,255,.55);
  border-radius: 50%;
  transform: rotateX(62deg) rotateZ(22deg) translateZ(58px);
}
.purpose-ring-two { inset: 28%; transform: rotateX(62deg) rotateZ(-38deg) translateZ(62px); border-color: rgba(0,255,122,.65); }
.purpose-ring-three { inset: 36%; transform: rotateX(62deg) rotateZ(84deg) translateZ(66px); border-color: rgba(114,219,255,.72); }
.purpose-core {
  inset: 38%;
  border-radius: 22px;
  background: linear-gradient(135deg, #00ff45, #72dbff);
  box-shadow: 0 20px 46px rgba(0,163,53,.36), inset 0 1px rgba(255,255,255,.5);
  transform: translateZ(88px) rotate(45deg);
}
.purpose-node {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 24px rgba(0,163,53,.7);
  transform: translateZ(96px);
}
.purpose-node-one { top: 21%; left: 33%; }
.purpose-node-two { right: 22%; top: 45%; background: var(--cyan); box-shadow: 0 0 24px rgba(0,174,239,.68); }
.purpose-node-three { left: 27%; bottom: 22%; background: white; box-shadow: 0 0 24px rgba(255,255,255,.7); }
.purpose-panel {
  width: 104px;
  height: 46px;
  border: 1px solid rgba(255,255,255,.24);
  border-radius: 14px;
  background: rgba(4,16,31,.28);
  backdrop-filter: blur(14px);
  box-shadow: 0 18px 42px rgba(0,0,0,.16);
  transform: translateZ(72px);
}
.purpose-panel-one { top: 17%; right: -7%; }
.purpose-panel-two { left: -8%; bottom: 18%; }

.journey { padding: clamp(6rem, 12vw, 10rem) 0; overflow: hidden; }
.section-heading { display: grid; grid-template-columns: 1.55fr .7fr; align-items: end; gap: 80px; margin-bottom: 70px; }
.section-heading h2, .security h2 {
  max-width: 18ch; margin: 0; font-size: clamp(2.2rem, 4.6vw, 4.1rem);
  line-height: 1.04; letter-spacing: -.045em; font-weight: 760;
}
.section-heading > p { margin: 0 0 6px; color: #95a7ba; line-height: 1.75; }
.journey-stage { position: relative; overflow: hidden; border: 1px solid rgba(255,255,255,.1); border-radius: 24px; background: #06152a; box-shadow: 0 45px 100px rgba(0,0,0,.3); }
.journey-stage::after { content: ""; position: absolute; inset: 0; box-shadow: inset 0 0 100px rgba(4,16,31,.38); pointer-events: none; }
.journey-stage.interactive-3d::before { inset: 0; z-index: 2; opacity: .36; }
.journey-stage img { width: 100%; aspect-ratio: 1.9; object-fit: cover; }
.journey-label { position: absolute; z-index: 2; display: flex; gap: 10px; align-items: center; padding: 12px 15px; border-radius: 10px; font-size: .72rem; }
.journey-label b { color: var(--green); }
.label-one { left: 5%; bottom: 9%; }
.label-two { left: 43%; bottom: 9%; }
.label-three { right: 5%; bottom: 9%; }

.capabilities { padding: clamp(6rem, 12vw, 10rem) 0; }
.dark-heading h2 { color: var(--navy-800); }
.dark-heading > p { color: var(--slate); }
.capability-grid { display: grid; grid-template-columns: repeat(2, 1fr); border-top: 1px solid var(--mist); border-left: 1px solid var(--mist); }
.capability-card { min-height: 360px; padding: clamp(28px, 4vw, 52px); border-right: 1px solid var(--mist); border-bottom: 1px solid var(--mist); transition: background .4s, transform .4s var(--ease); }
.capability-card:hover { position: relative; z-index: 2; background: var(--paper); transform: translateY(-4px); }
.card-number { display: block; margin-bottom: 68px; color: var(--green); font-size: .7rem; font-weight: 750; }
.capability-card h3 { margin: 30px 0 16px; color: var(--navy-800); font-size: clamp(1.45rem, 2vw, 2rem); letter-spacing: -.03em; }
.capability-card p { max-width: 43ch; margin-bottom: 0; color: var(--slate); line-height: 1.75; font-size: .93rem; }
.line-icon { position: relative; width: 82px; height: 58px; }
.line-icon i { position: absolute; bottom: 0; width: 16px; border: 1px solid var(--navy-700); border-radius: 8px 8px 2px 2px; background: linear-gradient(#fff, #eaf6ff); }
.line-icon i:nth-child(1) { left: 3px; height: 28px; }
.line-icon i:nth-child(2) { left: 31px; height: 52px; }
.line-icon i:nth-child(3) { left: 59px; height: 39px; border-color: var(--green); }
.citizen-icon i:first-child { left: 24px; top: 0; width: 26px; height: 26px; border-radius: 50%; }
.citizen-icon i:last-child { left: 10px; bottom: 0; width: 54px; height: 28px; border-radius: 30px 30px 5px 5px; }
.transparency-icon i { bottom: 4px; width: 42px; height: 42px; border-radius: 50%; background: transparent; }
.transparency-icon i:nth-child(1) { left: 0; }
.transparency-icon i:nth-child(2) { left: 20px; border-color: var(--green); }
.transparency-icon i:nth-child(3) { left: 40px; }
.team-icon i { width: 28px; height: 28px; border-radius: 50%; }
.team-icon i:nth-child(1) { left: 0; bottom: 2px; }
.team-icon i:nth-child(2) { left: 26px; bottom: 24px; border-color: var(--green); }
.team-icon i:nth-child(3) { left: 52px; bottom: 2px; }
.capability-wide { grid-column: 1 / -1; min-height: 310px; display: grid; grid-template-columns: 1fr 1fr; align-items: center; background: var(--paper); }
.capability-wide .card-number { margin-bottom: 42px; }
.orbit-object { position: relative; width: 230px; aspect-ratio: 1; justify-self: center; border: 1px solid #bad5e9; border-radius: 50%; transform: rotateX(var(--tilt-y)) rotateY(var(--tilt-x)) translateZ(28px); transition: transform .45s var(--ease); animation: float-3d 7.8s ease-in-out infinite; }
.orbit-object::before, .orbit-object::after { content: ""; position: absolute; inset: 17%; border: 1px solid #d3e3ee; border-radius: 50%; background: none; filter: none; opacity: 1; transform: rotate(55deg) scaleY(.45); }
.orbit-object::after { transform: rotate(-55deg) scaleY(.45); }
.orbit-object i { position: absolute; inset: 38%; border-radius: 24px; background: linear-gradient(135deg, var(--navy-700), var(--cyan)); box-shadow: 0 18px 40px rgba(0,75,135,.24); }
.orbit-object span { position: absolute; z-index: 2; width: 15px; height: 15px; border-radius: 50%; background: var(--green); box-shadow: 0 0 18px rgba(0,163,53,.5); }
.orbit-object span:nth-child(1) { top: 8%; left: 46%; }
.orbit-object span:nth-child(2) { right: 13%; bottom: 24%; background: var(--cyan); }
.orbit-object span:nth-child(3) { left: 12%; bottom: 28%; background: var(--navy-700); }

.security { position: relative; padding: clamp(6rem, 12vw, 10rem) 0; overflow: hidden; }
.security-glow { position: absolute; left: -10%; bottom: -30%; width: 780px; height: 780px; border-radius: 50%; background: radial-gradient(circle, rgba(0,75,135,.24), transparent 68%); }
.security-grid { position: relative; display: grid; grid-template-columns: .92fr 1.08fr; gap: clamp(50px, 8vw, 110px); align-items: center; }
.security-visual img { width: 100%; border-radius: 28px; mix-blend-mode: screen; filter: drop-shadow(0 35px 65px rgba(0,0,0,.35)); }
.security-copy > p:not(.eyebrow) { max-width: 58ch; color: #9eafc1; line-height: 1.8; }
.security h2 { margin-bottom: 28px; }
.security-list { margin-top: 42px; border-top: 1px solid rgba(255,255,255,.1); }
.security-item { display: grid; grid-template-columns: 42px 1fr; gap: 18px; padding: 23px 0; border-bottom: 1px solid rgba(255,255,255,.1); }
.security-item > span { color: var(--green); font-size: .68rem; font-weight: 750; }
.security-item h3 { margin: 0 0 7px; font-size: .97rem; }
.security-item p { margin: 0; color: #8396aa; font-size: .83rem; line-height: 1.6; }

.technology { padding: clamp(6rem, 12vw, 10rem) 0; }
.technology-layout { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(60px, 10vw, 140px); }
.technology-copy { position: sticky; top: 140px; align-self: start; }
.technology h2 { max-width: 15ch; margin: 28px 0; color: var(--navy-800); font-size: clamp(2.2rem, 4.5vw, 3.9rem); line-height: 1.05; letter-spacing: -.045em; }
.technology-copy > p:not(.section-index) { max-width: 50ch; color: var(--slate); line-height: 1.8; }
.text-link-dark { margin-top: 20px; color: var(--navy-800); }
.technology-stack { border-top: 1px solid var(--mist); }
.tech-row { display: grid; grid-template-columns: 42px 1fr 1.4fr; gap: 18px; align-items: center; padding: 29px 0; border-bottom: 1px solid var(--mist); }
.tech-row span { color: var(--green); font-size: .68rem; font-weight: 750; }
.tech-row strong { color: var(--navy-800); font-size: 1.05rem; }
.tech-row small { color: var(--slate); line-height: 1.5; }

.cta { position: relative; overflow: hidden; padding: clamp(7rem, 13vw, 11rem) 0; color: white; text-align: center; background: var(--navy-700); }
.cta-grid { opacity: .1; mask-image: radial-gradient(circle at center, black, transparent 72%); }
.cta::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 50% 100%, rgba(0,163,53,.22), transparent 43%); }
.cta-inner { position: relative; z-index: 2; display: flex; flex-direction: column; align-items: center; }
.cta h2 { max-width: 16ch; margin-bottom: 28px; font-size: clamp(2.35rem, 5vw, 4.5rem); line-height: 1.02; letter-spacing: -.05em; }
.cta p:not(.eyebrow) { max-width: 50ch; margin-bottom: 34px; color: #c3d5e7; line-height: 1.7; }
.button-light { color: var(--navy-800); background: white; box-shadow: 0 20px 55px rgba(0,0,0,.18); }
.button-light:hover { color: white; background: var(--green); }

.footer { padding: 75px 0 24px; color: white; background: var(--navy-950); }
.footer-grid { display: grid; grid-template-columns: 1.35fr .65fr .8fr 1fr; gap: 55px; }
.footer-brand p { max-width: 34ch; margin: 25px 0 14px; color: #8fa1b5; line-height: 1.7; font-size: .84rem; }
.footer-brand span { color: var(--green); font-size: .73rem; font-weight: 700; }
.footer strong { display: block; margin-bottom: 20px; font-size: .8rem; }
.footer-grid > div:not(.footer-brand) a { display: block; margin-bottom: 13px; color: #91a3b7; font-size: .8rem; transition: color .25s; }
.footer-grid a:hover { color: white !important; }
.footer address { color: #91a3b7; font-size: .8rem; font-style: normal; line-height: 1.8; }
.footer address strong { color: white; }
.footer-bottom { display: flex; justify-content: space-between; gap: 30px; margin-top: 65px; padding-top: 23px; border-top: 1px solid rgba(255,255,255,.09); color: #677b91; font-size: .68rem; }

@keyframes float-3d {
  0%, 100% { translate: 0 0; }
  50% { translate: 0 -14px; }
}

.js .reveal, .js .reveal-scale { opacity: 0; }

@media (max-width: 980px) {
  :root { --shell: min(100% - 36px, 720px); }
  .nav-links, .nav > .button { display: none; }
  .menu-toggle { display: block; cursor: pointer; }
  .mobile-menu {
    position: fixed; inset: 80px 0 0; z-index: 79; display: flex; flex-direction: column;
    padding: 48px 24px; visibility: hidden; opacity: 0; transform: translateY(-18px);
    color: white; background: rgba(4,16,31,.98); transition: .35s var(--ease);
  }
  .mobile-menu.open { visibility: visible; opacity: 1; transform: none; }
  .mobile-menu a { padding: 19px 0; border-bottom: 1px solid rgba(255,255,255,.1); font-size: 1.4rem; }
  .hero { min-height: auto; }
  .hero-layout { grid-template-columns: 1fr; padding-top: 145px; }
  .hero-copy { max-width: 680px; }
  .hero-title { font-size: clamp(3rem, 10vw, 5rem); }
  .hero-visual { margin: -20px -22vw -10px 5vw; }
  .hero-visual img { width: 100%; }
  .manifesto-grid { grid-template-columns: 1fr; gap: 28px; }
  .manifesto-visual { min-height: 330px; }
  .manifesto-copy { max-width: 62ch; }
  .section-heading { grid-template-columns: 1fr; gap: 28px; }
  .section-heading > p { max-width: 56ch; }
  .security-grid { grid-template-columns: 1fr; }
  .security-visual { max-width: 580px; margin-inline: auto; }
  .technology-layout { grid-template-columns: 1fr; }
  .technology-copy { position: static; }
  .footer-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
  :root { --shell: calc(100% - 32px); }
  .nav { height: 70px; }
  .brand img { width: 125px; }
  .mobile-menu { top: 70px; }
  .hero-layout { padding: 122px 0 70px; }
  .hero-title { font-size: clamp(2.65rem, 13vw, 4.2rem); }
  .hero-actions { align-items: flex-start; flex-direction: column; }
  .hero-proof { display: grid; gap: 12px; }
  .hero-visual { margin: 8px -36vw 0 -8vw; }
  .float-card { transform: scale(.82); }
  .float-card-a { left: 16%; bottom: 11%; }
  .scroll-cue { display: none; }
  .manifesto h2 { font-size: 2.2rem; }
  .manifesto-visual { min-height: 280px; }
  .purpose-object { width: min(270px, 82vw); border-radius: 28px; }
  .purpose-panel { width: 78px; height: 38px; }
  .purpose-panel-one { right: -2%; }
  .purpose-panel-two { left: -2%; }
  .journey-stage img { aspect-ratio: .86; object-position: center; }
  .journey-label { position: static; margin: 8px; }
  .capability-grid { grid-template-columns: 1fr; }
  .capability-card { min-height: 320px; }
  .capability-wide { grid-column: auto; grid-template-columns: 1fr; gap: 45px; }
  .orbit-object { width: 185px; }
  .security-visual { margin: 0 -8vw; }
  .tech-row { grid-template-columns: 30px 1fr; }
  .tech-row small { grid-column: 2; }
  .footer-grid { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; }
}

@media (pointer: coarse) {
  .cursor-dot { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; transition-duration: .01ms !important; }
  .js .reveal, .js .reveal-scale { opacity: 1; }
  .interactive-3d img, .image-3d-plane, .purpose-object, .orbit-object { transform: none !important; }
}
