:root {
  --void: #071321;
  --navy: #0B1E33;
  --navy-soft: #102A46;
  --cyan: #3DB7E8;
  --cyan-hot: #7DE8FF;
  --paper: #F4F7FA;
  --muted: #8AA0B4;
  --orange: #FF8B4A;
  --green: #34D884;
  --red: #FF6262;
  --glass: rgba(244, 247, 250, .08);
  --glass-strong: rgba(244, 247, 250, .13);
  --line: rgba(125, 232, 255, .18);
  --line-soft: rgba(244, 247, 250, .1);
  --shadow: 0 24px 70px rgba(0, 0, 0, .34);
  --radius: 24px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  background:
    radial-gradient(circle at 15% 10%, rgba(61, 183, 232, .18), transparent 28%),
    radial-gradient(circle at 92% 14%, rgba(255, 139, 74, .12), transparent 24%),
    linear-gradient(135deg, var(--void), var(--navy) 54%, #081827);
  color: var(--paper);
  font-family: Inter, "Segoe UI", Arial, sans-serif;
  margin: 0;
  min-height: 100vh;
}
body::before {
  background:
    linear-gradient(rgba(125,232,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(125,232,255,.03) 1px, transparent 1px);
  background-size: 74px 74px;
  content: "";
  inset: 0;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.8), transparent 78%);
  pointer-events: none;
  position: fixed;
  z-index: -2;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }

.btn, button {
  align-items: center;
  background: linear-gradient(135deg, rgba(61,183,232,.22), rgba(125,232,255,.1));
  border: 1px solid rgba(125,232,255,.25);
  border-radius: 999px;
  color: var(--paper);
  cursor: pointer;
  display: inline-flex;
  font: inherit;
  font-weight: 900;
  gap: 8px;
  justify-content: center;
  min-height: 44px;
  padding: 11px 18px;
  transition: transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
}
.btn:hover, button:hover {
  border-color: rgba(125,232,255,.55);
  box-shadow: 0 14px 34px rgba(61,183,232,.16);
  transform: translateY(-1px);
}
.btn.primary, button.primary, .hero-purple {
  background: linear-gradient(135deg, var(--cyan), #167DB2);
  border-color: rgba(125,232,255,.45);
  box-shadow: 0 18px 42px rgba(61,183,232,.24);
  color: #04101d;
}
.btn.ghost, .hero-white {
  background: rgba(244,247,250,.1);
  border-color: rgba(244,247,250,.2);
  color: var(--paper);
}
.btn.light { background: var(--paper); color: var(--navy); }
.btn.small, button.small { font-size: 13px; min-height: 34px; padding: 7px 12px; }
.btn.danger, button.danger {
  background: rgba(255,98,98,.14);
  border-color: rgba(255,98,98,.34);
  color: #ffd3d3;
}
.btn.full { width: 100%; }

/* Public site */
.public-nav {
  align-items: center;
  backdrop-filter: blur(22px);
  background: rgba(7,19,33,.74);
  border: 1px solid rgba(125,232,255,.12);
  border-radius: 0 0 28px 28px;
  box-shadow: 0 18px 45px rgba(0,0,0,.22);
  display: flex;
  justify-content: space-between;
  left: 3vw;
  padding: 16px 22px;
  position: fixed;
  right: 3vw;
  top: 14px;
  z-index: 20;
}
.brand-inline, .brand {
  align-items: center;
  display: flex;
  gap: 13px;
  font-weight: 1000;
}
.brand-inline img, .brand img {
  background: transparent;
  border-radius: 0;
  height: 60px;
  object-fit: contain;
  padding: 0;
  width: 92px;
}
.brand-inline span, .brand span { display: grid; gap: 1px; }
.brand-inline b { color: #fff; font-size: 22px; letter-spacing: 0; }
.brand-inline small, .brand small {
  color: var(--cyan-hot);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 1.4px;
  text-transform: uppercase;
}
.public-nav nav {
  align-items: center;
  display: flex;
  gap: 8px;
}
.public-nav nav a {
  border-radius: 999px;
  color: rgba(244,247,250,.78);
  font-size: 14px;
  font-weight: 850;
  padding: 10px 12px;
}
.public-nav nav a:hover {
  background: rgba(125,232,255,.09);
  color: #fff;
}
.support-btn {
  background: linear-gradient(135deg, rgba(255,139,74,.96), rgba(61,183,232,.9));
  border: 0;
  color: #071321 !important;
  margin-left: 8px;
  padding-inline: 20px !important;
}

.tech-public {
  background:
    radial-gradient(circle at 82% 7%, rgba(255,139,74,.17), transparent 26%),
    radial-gradient(circle at 8% 30%, rgba(61,183,232,.16), transparent 28%),
    linear-gradient(180deg, #071321 0%, #0B1E33 48%, #081827 100%);
  color: var(--paper);
  overflow: hidden;
}
.tech-hero {
  align-items: center;
  display: grid;
  gap: 52px;
  grid-template-columns: minmax(0, .95fr) minmax(440px, 1.05fr);
  min-height: 830px;
  padding: 170px 7vw 120px;
  position: relative;
}
.tech-hero::before {
  background:
    radial-gradient(circle, rgba(125,232,255,.7) 0 3px, transparent 4px) 10% 45% / 190px 190px,
    radial-gradient(circle, rgba(244,247,250,.44) 0 2px, transparent 3px) 80% 30% / 260px 240px,
    linear-gradient(32deg, transparent 0 48%, rgba(125,232,255,.12) 49%, transparent 50%) 0 0 / 320px 220px;
  content: "";
  inset: 0;
  opacity: .58;
  position: absolute;
}
.tech-hero::after {
  background: linear-gradient(90deg, transparent, rgba(125,232,255,.55), rgba(255,139,74,.24), transparent);
  bottom: 94px;
  content: "";
  height: 1px;
  left: 7vw;
  position: absolute;
  right: 7vw;
}
.hero-wave {
  background: rgba(244,247,250,.06);
  border: 1px solid rgba(125,232,255,.12);
  border-radius: 56% 44% 0 0 / 100% 100% 0 0;
  bottom: -128px;
  height: 270px;
  position: absolute;
  right: -7vw;
  transform: rotate(-2deg);
  width: 58vw;
}
.constellation span {
  background: rgba(125,232,255,.52);
  border-radius: 50%;
  box-shadow: 0 0 22px rgba(125,232,255,.55);
  height: 7px;
  position: absolute;
  width: 7px;
  z-index: 1;
}
.constellation span:nth-child(1) { left: 11%; top: 38%; }
.constellation span:nth-child(2) { left: 23%; top: 56%; height: 11px; width: 11px; }
.constellation span:nth-child(3) { right: 24%; top: 18%; height: 10px; width: 10px; }
.constellation span:nth-child(4) { right: 9%; top: 43%; height: 11px; width: 11px; }
.constellation span:nth-child(5) { left: 47%; top: 39%; height: 10px; width: 10px; }
.constellation span:nth-child(6) { right: 16%; top: 62%; height: 12px; width: 12px; }
.tech-hero-copy {
  max-width: 720px;
  position: relative;
  z-index: 2;
}
.social-row {
  display: flex;
  gap: 12px;
  margin-bottom: 32px;
}
.social-row a {
  align-items: center;
  background: rgba(244,247,250,.08);
  border: 1px solid rgba(125,232,255,.16);
  border-radius: 15px;
  color: var(--cyan-hot);
  display: grid;
  font-weight: 1000;
  height: 42px;
  place-items: center;
  width: 42px;
}
.tech-eyebrow, .clean-intro span, .clean-head span, .split-showcase span, .eldora-cta span {
  color: var(--cyan-hot);
  display: inline-block;
  font-size: 12px;
  font-weight: 1000;
  letter-spacing: 2.6px;
  text-transform: uppercase;
}
.tech-hero h1 {
  color: #fff;
  font-size: clamp(46px, 6.8vw, 104px);
  letter-spacing: 0;
  line-height: .92;
  margin: 16px 0 24px;
  text-shadow: 0 18px 60px rgba(0,0,0,.34);
}
.tech-hero p {
  color: rgba(244,247,250,.82);
  font-size: clamp(17px, 1.7vw, 22px);
  line-height: 1.75;
  margin: 0;
}
.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 34px;
}
.hero-white, .hero-purple {
  border-radius: 999px;
  min-height: 54px;
  padding: 14px 28px;
}

.aero-illustration {
  align-self: center;
  height: 540px;
  position: relative;
  z-index: 2;
}
.glass-panel {
  background:
    linear-gradient(145deg, rgba(244,247,250,.28), rgba(125,232,255,.08)),
    rgba(244,247,250,.06);
  backdrop-filter: blur(18px);
  border: 1px solid rgba(244,247,250,.22);
  box-shadow: var(--shadow);
  position: absolute;
}
.main-panel {
  border-radius: 34px 20px 42px 24px;
  height: 392px;
  left: 82px;
  top: 42px;
  transform: perspective(740px) rotateY(-18deg) rotateZ(-8deg);
  width: 260px;
}
.side-panel {
  border-radius: 28px 46px 24px 34px;
  height: 238px;
  right: 32px;
  top: 80px;
  transform: perspective(740px) rotateY(24deg) rotateZ(10deg);
  width: 292px;
}
.main-panel::before, .side-panel::before {
  border: 1px solid rgba(125,232,255,.18);
  border-radius: inherit;
  content: "";
  inset: 12px;
  position: absolute;
}
.panel-top {
  background: linear-gradient(90deg, var(--cyan), rgba(125,232,255,.26));
  border-radius: 999px;
  height: 16px;
  left: 32px;
  position: absolute;
  right: 32px;
  top: 42px;
}
.chart-line {
  background: conic-gradient(from 20deg, var(--orange) 0 20%, var(--cyan) 0 66%, rgba(244,247,250,.16) 0);
  border-radius: 50%;
  box-shadow: 0 0 35px rgba(61,183,232,.18);
  height: 86px;
  left: 42px;
  position: absolute;
  top: 106px;
  width: 86px;
}
.cockpit-card {
  background: rgba(7,19,33,.46);
  border: 1px solid rgba(125,232,255,.18);
  border-radius: 22px;
  display: grid;
  gap: 10px;
  padding: 16px;
  position: absolute;
  right: 28px;
  top: 106px;
  width: 92px;
}
.cockpit-card div {
  background: rgba(125,232,255,.72);
  border-radius: 999px;
  height: 8px;
}
.mini-bars {
  bottom: 50px;
  display: grid;
  gap: 12px;
  left: 34px;
  position: absolute;
  right: 34px;
}
.mini-bars span {
  background: rgba(244,247,250,.26);
  border-radius: 999px;
  height: 10px;
}
.mini-bars span:nth-child(2) { width: 72%; }
.mini-bars span:nth-child(3) { width: 54%; }
.runway {
  bottom: 66px;
  display: grid;
  gap: 13px;
  left: 300px;
  position: absolute;
  transform: rotate(-25deg);
  width: 186px;
}
.runway span {
  background: rgba(244,247,250,.9);
  border-radius: 999px;
  box-shadow: 0 20px 40px rgba(0,0,0,.18);
  height: 28px;
}
.runway span:nth-child(1) { width: 78px; }
.runway span:nth-child(2) { width: 120px; }
.runway span:nth-child(3) { width: 160px; }
.runway span:nth-child(4) { width: 104px; }
.tower-block {
  background: linear-gradient(180deg, rgba(244,247,250,.95), rgba(125,232,255,.42));
  border-radius: 22px 22px 14px 14px;
  box-shadow: 0 24px 60px rgba(0,0,0,.25);
  height: 160px;
  left: 315px;
  position: absolute;
  top: 192px;
  width: 78px;
}
.pilot-dot {
  background: linear-gradient(180deg, #fff, #cdefff);
  border-radius: 999px 999px 22px 22px;
  box-shadow: 0 20px 40px rgba(0,0,0,.18);
  height: 58px;
  position: absolute;
  width: 30px;
}
.pilot-dot::before {
  background: var(--orange);
  border-radius: 50%;
  content: "";
  height: 22px;
  left: 4px;
  position: absolute;
  top: -13px;
  width: 22px;
}
.pilot-dot.one { left: 246px; top: 264px; }
.pilot-dot.two { bottom: 82px; right: 116px; }
.paper-stack {
  background: repeating-linear-gradient(180deg, rgba(244,247,250,.94) 0 12px, rgba(61,183,232,.22) 13px 15px);
  border-radius: 18px;
  bottom: 96px;
  box-shadow: 16px 12px 0 rgba(244,247,250,.32), 0 20px 45px rgba(0,0,0,.22);
  height: 78px;
  position: absolute;
  right: 46px;
  transform: rotate(22deg);
  width: 140px;
}
.plane-mark {
  align-items: center;
  background: rgba(244,247,250,.09);
  border: 1px solid rgba(125,232,255,.18);
  border-radius: 18px;
  bottom: 24px;
  color: var(--cyan-hot);
  display: grid;
  font-weight: 1000;
  height: 112px;
  left: 430px;
  place-items: center;
  position: absolute;
  width: 48px;
}

.clean-intro, .clean-section, .split-showcase, .eldora-cta {
  padding-left: 7vw;
  padding-right: 7vw;
}
.clean-intro {
  background:
    radial-gradient(circle at 12% 18%, rgba(61,183,232,.14), transparent 24%),
    linear-gradient(180deg, #0B1E33, #071321);
  color: var(--paper);
  padding-bottom: 90px;
  padding-top: 100px;
  text-align: center;
}
.clean-intro h2, .clean-head h2, .split-showcase h2, .eldora-cta h2 {
  color: #fff;
  font-size: clamp(32px, 4vw, 58px);
  letter-spacing: 0;
  line-height: 1.05;
  margin: 14px auto 18px;
  max-width: 920px;
}
.clean-intro p, .split-showcase p, .eldora-cta p {
  color: rgba(244,247,250,.72);
  font-size: 18px;
  line-height: 1.8;
  margin: 0 auto;
  max-width: 930px;
}
.clean-section {
  background:
    radial-gradient(circle at 86% 12%, rgba(255,139,74,.09), transparent 25%),
    linear-gradient(180deg, #071321, #0B1E33);
  padding-bottom: 96px;
  padding-top: 94px;
}
.clean-head {
  margin-bottom: 36px;
  text-align: center;
}
.service-grid, .fleet-grid, .news-grid {
  display: grid;
  gap: 22px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.service-grid article, .fleet-grid article, .news-grid article {
  background: linear-gradient(155deg, rgba(244,247,250,.13), rgba(244,247,250,.045));
  backdrop-filter: blur(18px);
  border: 1px solid var(--line);
  border-radius: 28px 18px 34px 18px;
  box-shadow: 0 22px 54px rgba(0,0,0,.18);
  min-height: 250px;
  padding: 28px;
  position: relative;
  overflow: hidden;
}
.service-grid article::after, .fleet-grid article::after, .news-grid article::after {
  background: linear-gradient(90deg, var(--cyan), var(--orange));
  border-radius: 999px;
  content: "";
  height: 3px;
  left: 28px;
  opacity: .75;
  position: absolute;
  right: 46%;
  top: 0;
}
.service-grid i {
  background: linear-gradient(135deg, var(--cyan), var(--orange));
  border-radius: 18px;
  color: #071321;
  display: grid;
  font-style: normal;
  font-weight: 1000;
  height: 54px;
  place-items: center;
  width: 54px;
}
.service-grid h3, .fleet-grid h3, .news-grid h3 {
  color: #fff;
  font-size: 24px;
  margin: 26px 0 12px;
}
.service-grid p, .fleet-grid p, .news-grid p {
  color: rgba(244,247,250,.68);
  line-height: 1.7;
}
.split-showcase {
  align-items: center;
  background:
    radial-gradient(circle at 75% 28%, rgba(61,183,232,.14), transparent 29%),
    linear-gradient(135deg, #071321, #102A46);
  display: grid;
  gap: 54px;
  grid-template-columns: .95fr 1.05fr;
  padding-bottom: 98px;
  padding-top: 98px;
}
.split-showcase h2, .eldora-cta h2 { margin-left: 0; }
.mission-board {
  background: linear-gradient(135deg, rgba(125,232,255,.16), rgba(255,139,74,.08));
  border: 1px solid rgba(125,232,255,.22);
  border-radius: 34px 18px 34px 18px;
  box-shadow: var(--shadow);
  display: grid;
  gap: 1px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  overflow: hidden;
}
.mission-board div {
  background: rgba(7,19,33,.55);
  min-height: 150px;
  padding: 28px;
}
.mission-board small {
  color: var(--cyan-hot);
  font-weight: 1000;
  letter-spacing: 1.8px;
  text-transform: uppercase;
}
.mission-board b {
  color: #fff;
  display: block;
  font-size: 34px;
  margin-top: 22px;
}
.fleet-clean .fleet-grid, .news-clean .news-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.eldora-cta {
  align-items: center;
  background:
    radial-gradient(circle at 92% 20%, rgba(255,139,74,.22), transparent 24%),
    linear-gradient(135deg, #0B1E33, #071321);
  border-top: 1px solid var(--line-soft);
  display: flex;
  gap: 28px;
  justify-content: space-between;
  padding-bottom: 76px;
  padding-top: 76px;
}
.eldora-cta div { max-width: 760px; }
.clean-footer {
  align-items: center;
  background: #050D17;
  border-top: 1px solid rgba(125,232,255,.12);
  color: #fff;
  display: flex;
  gap: 18px;
  padding: 28px 7vw;
}
.clean-footer img {
  background: transparent;
  border-radius: 0;
  height: 60px;
  object-fit: contain;
  padding: 0;
  width: 92px;
}
.clean-footer div { display: grid; gap: 5px; }
.clean-footer span { color: rgba(244,247,250,.58); line-height: 1.5; }

/* Auth */
.auth-page {
  align-items: center;
  display: grid;
  min-height: 100vh;
  padding: 32px;
  place-items: center;
}
.auth-box {
  background: linear-gradient(155deg, rgba(244,247,250,.14), rgba(244,247,250,.055));
  backdrop-filter: blur(24px);
  border: 1px solid var(--line);
  border-radius: 34px 18px 34px 18px;
  box-shadow: var(--shadow);
  max-width: 480px;
  padding: 36px;
  width: 100%;
}
.auth-logo {
  background: rgba(244,247,250,.95);
  border-radius: 20px;
  height: 78px;
  margin-bottom: 18px;
  object-fit: contain;
  padding: 8px;
  width: 126px;
}
.auth-box h1 { color: #fff; margin: 0 0 8px; }
.auth-box p { color: rgba(244,247,250,.68); line-height: 1.6; }
.text-link { color: var(--cyan-hot); display: inline-block; font-weight: 900; margin-top: 16px; }

/* Internal cockpit layout */
.side {
  background:
    radial-gradient(circle at 22% 10%, rgba(61,183,232,.16), transparent 28%),
    linear-gradient(180deg, rgba(11,30,51,.96), rgba(7,19,33,.98));
  border-right: 1px solid rgba(125,232,255,.12);
  bottom: 0;
  color: var(--paper);
  display: flex;
  flex-direction: column;
  gap: 18px;
  left: 0;
  padding: 22px;
  position: fixed;
  top: 0;
  overflow: hidden;
  width: 300px;
}
.brand { flex: 0 0 auto; }
.brand img {
  background: transparent;
  border-radius: 0;
  height: 62px;
  object-fit: contain;
  padding: 0;
  width: 96px;
}
.brand b { color: #fff; font-size: 19px; }
.side nav {
  display: grid;
  flex: 1 1 auto;
  gap: 9px;
  margin-top: 8px;
  min-height: 0;
  overflow-y: auto;
  padding-right: 4px;
  scrollbar-color: rgba(125,232,255,.38) transparent;
  scrollbar-width: thin;
}
.side nav::-webkit-scrollbar {
  width: 6px;
}
.side nav::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, rgba(125,232,255,.58), rgba(255,139,74,.34));
  border-radius: 999px;
}
.side nav::-webkit-scrollbar-track {
  background: transparent;
}
.nav {
  background: rgba(244,247,250,.045);
  border: 1px solid rgba(125,232,255,.1);
  border-radius: 18px 12px 18px 12px;
  color: rgba(244,247,250,.72);
  font-weight: 850;
  padding: 13px 14px;
  transition: .18s ease;
}
.nav-group {
  color: var(--cyan-hot);
  font-size: 11px;
  font-weight: 1000;
  letter-spacing: 1.7px;
  margin: 12px 4px 2px;
  opacity: .82;
  text-transform: uppercase;
}
.nav.active, .nav:hover {
  background: linear-gradient(135deg, rgba(61,183,232,.22), rgba(255,139,74,.1));
  border-color: rgba(125,232,255,.28);
  color: #fff;
}
.operator {
  background: rgba(244,247,250,.055);
  border: 1px solid rgba(125,232,255,.12);
  border-radius: 22px;
  display: grid;
  gap: 6px;
  flex: 0 0 auto;
  margin-top: auto;
  padding: 16px;
}
.operator small { color: var(--cyan-hot); font-weight: 1000; letter-spacing: 1px; }
.operator a { color: #fff; font-weight: 900; }
.workspace {
  margin-left: 300px;
  min-height: 100vh;
  padding: 0 32px 44px;
  position: relative;
}
.workspace::before {
  background:
    radial-gradient(circle at 84% 10%, rgba(255,139,74,.13), transparent 26%),
    radial-gradient(circle at 34% 0%, rgba(61,183,232,.12), transparent 24%);
  content: "";
  height: 360px;
  left: 0;
  pointer-events: none;
  position: absolute;
  right: 0;
  top: 0;
  z-index: -1;
}
.topbar {
  align-items: center;
  display: flex;
  justify-content: space-between;
  min-height: 108px;
}
.topbar h1 {
  color: #fff;
  font-size: clamp(28px, 3vw, 42px);
  letter-spacing: 0;
  margin: 0;
}
.topbar p { color: var(--muted); margin: 6px 0 0; }
.metrics {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-bottom: 20px;
}
.dashboard-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-bottom: 18px;
}
.dash-card {
  min-height: 220px;
}
.dash-card h2 {
  margin-bottom: 10px;
}
@media (max-width: 1180px) {
  .dashboard-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 720px) {
  .dashboard-grid {
    grid-template-columns: 1fr;
  }
}
.metrics article, .panel {
  background: linear-gradient(155deg, rgba(244,247,250,.12), rgba(244,247,250,.045));
  backdrop-filter: blur(20px);
  border: 1px solid rgba(125,232,255,.14);
  border-radius: 28px 18px 28px 18px;
  box-shadow: 0 20px 55px rgba(0,0,0,.2);
  padding: 24px;
}
.metrics small {
  color: var(--muted);
  display: block;
  font-size: 12px;
  font-weight: 1000;
  letter-spacing: 1.6px;
  margin-bottom: 9px;
  text-transform: uppercase;
}
.metrics b {
  color: #fff;
  display: block;
  font-size: clamp(24px, 2.6vw, 34px);
  overflow-wrap: anywhere;
}
.grid-2 {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-bottom: 18px;
}
.grid-2.compact { gap: 12px; margin-bottom: 0; }
.stack { display: grid; gap: 15px; }
.panel h2 {
  color: #fff;
  font-size: 24px;
  margin: 0 0 15px;
}
.panel p { color: rgba(244,247,250,.68); line-height: 1.7; }
.quick-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}
label {
  color: rgba(244,247,250,.84);
  display: grid;
  font-weight: 850;
  gap: 8px;
}
input, select, textarea {
  background: rgba(7,19,33,.62);
  border: 1px solid rgba(125,232,255,.18);
  border-radius: 16px;
  color: #fff;
  font: inherit;
  min-height: 46px;
  outline: none;
  padding: 11px 13px;
  width: 100%;
}
textarea { min-height: 96px; resize: vertical; }
input:focus, select:focus, textarea:focus {
  border-color: rgba(125,232,255,.55);
  box-shadow: 0 0 0 4px rgba(61,183,232,.1);
}
select option { background: var(--navy); color: #fff; }

.data-table {
  display: grid;
  gap: 8px;
  overflow-x: auto;
}
.data-table > div {
  align-items: center;
  background: rgba(7,19,33,.48);
  border: 1px solid rgba(125,232,255,.1);
  border-radius: 18px;
  display: grid;
  gap: 12px;
  grid-template-columns: 1.4fr 1fr 1fr .8fr .9fr;
  min-width: 820px;
  padding: 13px 14px;
}
.data-table .thead {
  background: rgba(61,183,232,.12);
  color: var(--cyan-hot);
  font-size: 12px;
  font-weight: 1000;
  letter-spacing: 1.4px;
  text-transform: uppercase;
}
.data-table small { color: var(--muted); display: block; margin-top: 4px; }
.table-lite {
  display: grid;
  gap: 10px;
}
.table-lite div {
  background: rgba(7,19,33,.5);
  border: 1px solid rgba(125,232,255,.12);
  border-radius: 18px;
  display: grid;
  gap: 4px;
  padding: 13px;
}
.table-lite b, .data-table b { color: #fff; }
.table-lite span { color: var(--muted); }
.inline-actions { display: flex; flex-wrap: wrap; gap: 8px; }
.rules { display: grid; gap: 10px; }
.muted { color: var(--muted); }
.alert {
  border-radius: 18px;
  font-weight: 850;
  padding: 13px 14px;
}
.alert.ok, .toast.ok {
  background: rgba(52,216,132,.16);
  border: 1px solid rgba(52,216,132,.28);
  color: #a9ffd0;
}
.alert.bad, .toast.bad {
  background: rgba(255,98,98,.14);
  border: 1px solid rgba(255,98,98,.3);
  color: #ffd1d1;
}
.toast {
  background: rgba(7,19,33,.88);
  backdrop-filter: blur(18px);
  border: 1px solid rgba(125,232,255,.18);
  border-radius: 18px;
  bottom: 20px;
  box-shadow: var(--shadow);
  color: #fff;
  font-weight: 850;
  padding: 14px 18px;
  position: fixed;
  right: 20px;
  transition: .25s ease;
  z-index: 50;
}
.logo-admin-row {
  align-items: center;
  background: rgba(7,19,33,.45);
  border: 1px solid rgba(125,232,255,.12);
  border-radius: 22px;
  display: grid;
  gap: 16px;
  grid-template-columns: 120px 1fr;
  padding: 14px;
}
.logo-admin-row img {
  background: rgba(244,247,250,.95);
  border-radius: 18px;
  height: 78px;
  object-fit: contain;
  padding: 8px;
  width: 110px;
}
.profile-preview {
  background: rgba(244,247,250,.9);
  border-radius: 18px;
  max-height: 160px;
  object-fit: contain;
  padding: 12px;
  width: 100%;
}

.passage-form {
  margin-bottom: 20px;
}
.training-block {
  background: rgba(7,19,33,.32);
  border: 1px solid rgba(125,232,255,.1);
  border-radius: 24px;
  padding: 18px;
}
.question-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.question-card {
  background: rgba(7,19,33,.5);
  border: 1px solid rgba(125,232,255,.12);
  border-radius: 20px;
  padding: 16px;
}
.question-card h3 {
  color: #fff;
  font-size: 16px;
  line-height: 1.4;
  margin: 0 0 12px;
}
.answer-grid {
  display: grid;
  gap: 8px;
}
.answer-grid label,
.practice-line label {
  background: rgba(244,247,250,.045);
  border: 1px solid rgba(125,232,255,.08);
  border-radius: 14px;
  display: block;
  padding: 9px 10px;
}
.practice-grid {
  display: grid;
  gap: 10px;
}
.practice-line {
  align-items: center;
  background: rgba(7,19,33,.48);
  border: 1px solid rgba(125,232,255,.1);
  border-radius: 18px;
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(180px, 1fr) repeat(4, minmax(110px, .5fr));
  padding: 12px;
}
.practice-line span {
  color: #fff;
  font-weight: 900;
}
.checks.two {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (max-width: 980px) {
  .question-grid,
  .practice-line,
  .checks.two {
    grid-template-columns: 1fr;
  }
}

.certificate-page {
  min-height: 100vh;
  padding: 36px;
}
.certificate-actions {
  display: flex;
  gap: 12px;
  justify-content: center;
  margin-bottom: 22px;
}
.certificate {
  background:
    radial-gradient(circle at 85% 18%, rgba(255,139,74,.16), transparent 28%),
    linear-gradient(135deg, rgba(244,247,250,.97), rgba(222,242,251,.94));
  border: 2px solid #0B1E33;
  border-radius: 34px;
  box-shadow: 0 30px 90px rgba(0,0,0,.32);
  color: #071321;
  margin: 0 auto;
  max-width: 1080px;
  overflow: hidden;
  padding: 0;
  position: relative;
}
.certificate-bg {
  color: rgba(11,30,51,.055);
  font-size: 128px;
  font-weight: 1000;
  letter-spacing: 10px;
  position: absolute;
  right: -20px;
  top: 260px;
  transform: rotate(-10deg);
}
.certificate header {
  align-items: center;
  background: linear-gradient(135deg, #071321, #0B1E33);
  color: #fff;
  display: flex;
  gap: 24px;
  padding: 34px 42px;
}
.certificate header img {
  height: 92px;
  object-fit: contain;
  width: 150px;
}
.certificate header span,
.certificate-body small,
.certificate-grid small,
.certificate footer span {
  color: #3DB7E8;
  font-size: 12px;
  font-weight: 1000;
  letter-spacing: 2px;
  text-transform: uppercase;
}
.certificate header h1 {
  font-size: 38px;
  letter-spacing: 0;
  margin: 8px 0;
}
.certificate header p {
  color: rgba(244,247,250,.72);
  margin: 0;
}
.certificate-body {
  padding: 58px 54px 28px;
  position: relative;
  text-align: center;
  z-index: 1;
}
.certificate-body h2 {
  color: #071321;
  font-size: clamp(40px, 6vw, 72px);
  letter-spacing: 0;
  margin: 10px 0 14px;
}
.certificate-body p {
  color: #31465c;
  font-size: 18px;
}
.certificate-body strong {
  background: linear-gradient(135deg, #3DB7E8, #FF8B4A);
  border-radius: 999px;
  color: #071321;
  display: inline-flex;
  font-weight: 1000;
  padding: 13px 24px;
}
.certificate-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  padding: 24px 42px 38px;
  position: relative;
  z-index: 1;
}
.certificate-grid div {
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(11,30,51,.12);
  border-radius: 18px;
  padding: 14px;
}
.certificate-grid b {
  color: #071321;
  display: block;
  margin-top: 6px;
}
.certificate footer {
  display: grid;
  gap: 24px;
  grid-template-columns: 1fr 1fr;
  padding: 0 42px 38px;
  position: relative;
  z-index: 1;
}
.certificate footer div {
  border-top: 2px solid #0B1E33;
  padding-top: 12px;
}
.certificate footer b {
  color: #071321;
}

@media print {
  body {
    background: #fff !important;
  }
  body::before,
  .certificate-actions,
  .toast {
    display: none !important;
  }
  .certificate-page {
    padding: 0;
  }
  .certificate {
    border-radius: 0;
    box-shadow: none;
    max-width: none;
    min-height: 100vh;
  }
}

@media (max-width: 760px) {
  .certificate-page {
    padding: 18px;
  }
  .certificate header,
  .certificate footer {
    grid-template-columns: 1fr;
  }
  .certificate header {
    align-items: flex-start;
    flex-direction: column;
  }
  .certificate-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1180px) {
  .public-nav {
    align-items: flex-start;
    flex-direction: column;
    left: 18px;
    right: 18px;
  }
  .public-nav nav {
    flex-wrap: wrap;
    width: 100%;
  }
  .tech-hero {
    grid-template-columns: 1fr;
    padding-top: 190px;
  }
  .aero-illustration {
    height: 460px;
    max-width: 690px;
  }
  .service-grid, .metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  body::before { background-size: 52px 52px; }
  .public-nav {
    border-radius: 0 0 22px 22px;
    padding: 14px;
    position: absolute;
    top: 0;
  }
  .public-nav nav a { padding: 8px 10px; }
  .support-btn { margin-left: 0; width: 100%; }
  .tech-hero {
    min-height: auto;
    padding: 210px 24px 86px;
  }
  .tech-hero h1 { font-size: 44px; }
  .aero-illustration { display: none; }
  .hero-wave { width: 120vw; }
  .clean-intro, .clean-section, .split-showcase, .eldora-cta, .clean-footer {
    padding-left: 24px;
    padding-right: 24px;
  }
  .service-grid, .fleet-clean .fleet-grid, .news-clean .news-grid, .split-showcase, .grid-2, .metrics {
    grid-template-columns: 1fr;
  }
  .mission-board { grid-template-columns: 1fr; }
  .eldora-cta, .clean-footer {
    align-items: flex-start;
    flex-direction: column;
  }
  .side {
    position: static;
    width: 100%;
  }
  .workspace {
    margin-left: 0;
    padding: 0 18px 34px;
  }
  .topbar {
    align-items: flex-start;
    flex-direction: column;
    gap: 12px;
    padding: 18px 0;
  }
  .logo-admin-row { grid-template-columns: 1fr; }
}

@media (max-width: 520px) {
  .brand-inline img, .brand img { height: 50px; width: 78px; }
  .brand-inline b { font-size: 19px; }
  .tech-hero h1 { font-size: 38px; }
  .hero-actions, .quick-actions, .inline-actions {
    align-items: stretch;
    flex-direction: column;
  }
  .hero-actions .btn, .quick-actions .btn, .inline-actions .btn, .inline-actions button {
    width: 100%;
  }
  .service-grid article, .fleet-grid article, .news-grid article, .panel, .metrics article {
    border-radius: 22px;
    padding: 22px;
  }
}

/* Prototype public site - final override */
.noise {
  background-image: radial-gradient(rgba(255,255,255,.08) 1px, transparent 1px);
  background-size: 4px 4px;
  inset: 0;
  opacity: .18;
  pointer-events: none;
  position: fixed;
  z-index: -1;
}
.orb {
  border-radius: 999px;
  filter: blur(48px);
  opacity: .55;
  pointer-events: none;
  position: fixed;
  z-index: -1;
}
.orb-a {
  background: rgba(61,183,232,.45);
  height: 360px;
  left: -120px;
  top: 120px;
  width: 360px;
}
.orb-b {
  background: rgba(255,139,74,.28);
  bottom: 40px;
  height: 300px;
  right: -100px;
  width: 300px;
}
header.nav {
  align-items: center;
  background: rgba(7,19,33,.58);
  backdrop-filter: blur(22px);
  border: 1px solid rgba(125,232,255,.13);
  border-radius: 0 0 26px 26px;
  box-shadow: 0 24px 70px rgba(0,0,0,.28);
  display: flex;
  justify-content: space-between;
  left: 50%;
  max-width: 1180px;
  min-height: 82px;
  padding: 8px 18px;
  position: absolute;
  right: auto;
  top: 12px;
  transform: translateX(-50%);
  width: calc(100% - 48px);
  z-index: 40;
}
header.nav > img {
  background: transparent;
  border-radius: 0;
  height: 72px;
  object-fit: contain;
  padding: 0;
  width: 150px;
}
header.nav nav {
  align-items: center;
  display: flex;
  gap: 18px;
}
header.nav nav a {
  color: rgba(244,247,250,.76);
  font-weight: 900;
}
header.nav nav a:hover { color: #fff; }
.nav-cta {
  background: linear-gradient(135deg, var(--cyan), var(--orange));
  border-radius: 999px;
  color: #071321;
  font-weight: 1000;
  padding: 13px 20px;
}
body > main:not(.workspace) {
  overflow: hidden;
}
.hero {
  align-items: center;
  display: grid;
  gap: 70px;
  grid-template-columns: minmax(0, .95fr) minmax(460px, 1.05fr);
  min-height: 920px;
  padding: 170px 7vw 100px;
  position: relative;
}
.hero::before {
  background:
    linear-gradient(110deg, transparent 0 45%, rgba(125,232,255,.12) 46%, transparent 47%) 0 0 / 320px 230px,
    radial-gradient(circle, rgba(125,232,255,.55) 0 3px, transparent 4px) 12% 52% / 220px 220px;
  content: "";
  inset: 0;
  opacity: .62;
  position: absolute;
}
.hero-copy {
  position: relative;
  z-index: 2;
}
.kicker {
  align-items: center;
  color: var(--cyan-hot);
  display: inline-flex;
  font-size: 13px;
  font-weight: 1000;
  gap: 10px;
  letter-spacing: 2.4px;
  text-transform: uppercase;
}
.kicker span {
  background: var(--orange);
  border-radius: 999px;
  box-shadow: 0 0 26px rgba(255,139,74,.75);
  height: 9px;
  width: 9px;
}
.hero h1 {
  color: #fff;
  font-size: clamp(48px, 7vw, 104px);
  letter-spacing: 0;
  line-height: .9;
  margin: 22px 0 26px;
  max-width: 950px;
}
.hero p {
  color: rgba(244,247,250,.76);
  font-size: 19px;
  line-height: 1.8;
  max-width: 720px;
}
.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 34px;
}
.stats {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 38px;
  max-width: 650px;
}
.stats div {
  background: linear-gradient(155deg, rgba(244,247,250,.13), rgba(244,247,250,.045));
  border: 1px solid var(--line);
  border-radius: 24px 14px 28px 14px;
  padding: 18px;
}
.stats strong {
  color: #fff;
  display: block;
  font-size: 34px;
}
.stats span {
  color: var(--muted);
  font-weight: 850;
}
.hero-visual {
  min-height: 590px;
  position: relative;
  z-index: 2;
}
.flight-card {
  background: linear-gradient(155deg, rgba(244,247,250,.16), rgba(244,247,250,.055));
  backdrop-filter: blur(24px);
  border: 1px solid rgba(125,232,255,.2);
  border-radius: 34px 18px 36px 18px;
  box-shadow: var(--shadow);
  left: 50px;
  padding: 28px;
  position: absolute;
  top: 70px;
  width: 330px;
  z-index: 4;
}
.flight-card span {
  color: var(--cyan-hot);
  font-size: 12px;
  font-weight: 1000;
  letter-spacing: 2px;
}
.flight-card strong {
  color: #fff;
  display: block;
  font-size: 28px;
  margin: 12px 0 8px;
}
.flight-card small { color: var(--muted); }
.aircraft {
  height: 270px;
  left: 245px;
  position: absolute;
  top: 205px;
  transform: rotate(-18deg);
  width: 330px;
  z-index: 5;
}
.aircraft .body {
  background: linear-gradient(90deg, #fff, #d7f6ff 70%, var(--cyan));
  border-radius: 999px;
  height: 46px;
  left: 34px;
  position: absolute;
  top: 112px;
  width: 260px;
}
.aircraft .body::after {
  border-bottom: 18px solid transparent;
  border-left: 42px solid var(--orange);
  border-top: 18px solid transparent;
  content: "";
  position: absolute;
  right: -34px;
  top: 5px;
}
.wing {
  background: linear-gradient(135deg, var(--cyan-hot), rgba(244,247,250,.96));
  border-radius: 999px 999px 28px 28px;
  height: 150px;
  left: 120px;
  position: absolute;
  top: 42px;
  transform-origin: bottom center;
  width: 48px;
}
.wing.right {
  top: 118px;
  transform: rotate(180deg);
}
.tail {
  background: var(--orange);
  border-radius: 12px;
  height: 70px;
  left: 34px;
  position: absolute;
  top: 78px;
  transform: rotate(-22deg);
  width: 32px;
}
.ring {
  border: 1px solid rgba(125,232,255,.2);
  border-radius: 50%;
  position: absolute;
}
.r1 {
  height: 410px;
  right: 28px;
  top: 54px;
  width: 410px;
}
.r2 {
  height: 260px;
  right: 104px;
  top: 130px;
  width: 260px;
}
.route {
  border: 2px dashed rgba(125,232,255,.38);
  border-left: 0;
  border-radius: 0 999px 999px 0;
  height: 220px;
  position: absolute;
  right: 110px;
  top: 238px;
  transform: rotate(-18deg);
  width: 360px;
}
.wp {
  background: var(--orange);
  border-radius: 50%;
  box-shadow: 0 0 25px rgba(255,139,74,.7);
  height: 12px;
  position: absolute;
  width: 12px;
}
.wp.a { left: 110px; top: 455px; }
.wp.b { right: 240px; top: 255px; }
.wp.c { right: 96px; top: 404px; }
.section {
  padding: 92px 7vw;
  position: relative;
}
.section-title {
  margin: 0 auto 38px;
  max-width: 980px;
  text-align: center;
}
.section-title span, .eyebrow, .join span {
  color: var(--cyan-hot);
  display: inline-block;
  font-size: 12px;
  font-weight: 1000;
  letter-spacing: 2.4px;
  text-transform: uppercase;
}
.section-title h2, .academy-panel h2, .join h2 {
  color: #fff;
  font-size: clamp(32px, 4.2vw, 64px);
  letter-spacing: 0;
  line-height: 1.05;
  margin: 14px 0 0;
}
.intro-grid {
  display: grid;
  gap: 22px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.tilt, .exp, .fleet-card, .event, .join, .academy-panel {
  background: linear-gradient(155deg, rgba(244,247,250,.13), rgba(244,247,250,.045));
  backdrop-filter: blur(22px);
  border: 1px solid rgba(125,232,255,.16);
  box-shadow: 0 22px 60px rgba(0,0,0,.2);
}
.tilt {
  border-radius: 34px 18px 34px 18px;
  min-height: 255px;
  padding: 30px;
}
.tilt span {
  color: var(--orange);
  font-weight: 1000;
  letter-spacing: 2px;
}
.tilt h3, .exp h3, .fleet-card h3, .event h3 {
  color: #fff;
  font-size: 27px;
  margin: 26px 0 12px;
}
.tilt p, .exp p, .fleet-card p, .event p, .academy-panel p, .join p {
  color: rgba(244,247,250,.68);
  line-height: 1.72;
}
.academy-panel {
  align-items: center;
  border-radius: 42px 22px 42px 22px;
  display: grid;
  gap: 42px;
  grid-template-columns: minmax(0, 1fr) minmax(360px, .85fr);
  padding: 44px;
}
.academy-panel ul {
  color: rgba(244,247,250,.78);
  display: grid;
  gap: 12px;
  margin: 26px 0 0;
  padding-left: 20px;
}
.terminal {
  background: rgba(7,19,33,.78);
  border: 1px solid rgba(125,232,255,.17);
  border-radius: 28px;
  box-shadow: inset 0 0 44px rgba(61,183,232,.06);
  overflow: hidden;
}
.dots {
  background: rgba(244,247,250,.06);
  display: flex;
  gap: 8px;
  padding: 16px;
}
.dots span {
  background: var(--orange);
  border-radius: 50%;
  height: 10px;
  width: 10px;
}
.dots span:nth-child(2) { background: var(--cyan); }
.dots span:nth-child(3) { background: var(--green); }
.terminal pre {
  background: transparent;
  color: var(--cyan-hot);
  font: 850 15px/1.75 Consolas, Monaco, monospace;
  margin: 0;
  padding: 24px;
  white-space: pre-wrap;
}
.experience-grid {
  display: grid;
  gap: 22px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.exp {
  border-radius: 30px;
  min-height: 270px;
  padding: 28px;
}
.exp.large {
  grid-column: span 2;
}
.chip {
  background: rgba(255,139,74,.15);
  border: 1px solid rgba(255,139,74,.28);
  border-radius: 999px;
  color: #ffd6bd;
  display: inline-flex;
  font-size: 12px;
  font-weight: 1000;
  padding: 8px 12px;
}
.fleet {
  display: grid;
  gap: 22px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.fleet-card {
  border-radius: 34px;
  min-height: 245px;
  padding: 30px;
}
.fleet-card.active {
  background:
    radial-gradient(circle at 88% 18%, rgba(255,139,74,.2), transparent 28%),
    linear-gradient(155deg, rgba(61,183,232,.2), rgba(244,247,250,.06));
}
.fleet-card small {
  color: var(--cyan-hot);
  font-weight: 1000;
  letter-spacing: 1.8px;
  text-transform: uppercase;
}
.timeline {
  display: grid;
  gap: 18px;
  margin: 0 auto;
  max-width: 980px;
}
.event {
  align-items: flex-start;
  border-radius: 28px 18px 28px 18px;
  display: grid;
  gap: 20px;
  grid-template-columns: 78px 1fr;
  padding: 24px;
}
.event > span {
  align-items: center;
  background: linear-gradient(135deg, var(--cyan), var(--orange));
  border-radius: 22px;
  color: #071321;
  display: grid;
  font-weight: 1000;
  height: 58px;
  place-items: center;
  width: 58px;
}
.event h3 { margin-top: 0; }
.join {
  align-items: center;
  border-radius: 44px 24px 44px 24px;
  display: grid;
  gap: 34px;
  grid-template-columns: .9fr 1.1fr;
  padding: 44px;
}
.join form {
  display: grid;
  gap: 14px;
}
.join-notice {
  background:
    radial-gradient(circle at 92% 12%, rgba(255,139,74,.18), transparent 34%),
    linear-gradient(135deg, rgba(244,247,250,.1), rgba(61,183,232,.06));
  border: 1px solid rgba(125,232,255,.18);
  border-radius: 32px 18px 32px 18px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 28px 70px rgba(0,0,0,.2);
  display: grid;
  gap: 16px;
  overflow: hidden;
  padding: 30px;
  position: relative;
}
.join-notice::before {
  background:
    linear-gradient(90deg, transparent, rgba(125,232,255,.42), transparent),
    linear-gradient(180deg, transparent, rgba(125,232,255,.12));
  content: "";
  height: 1px;
  left: 8%;
  position: absolute;
  top: 24%;
  transform: rotate(-8deg);
  width: 86%;
}
.join-notice h3 {
  color: #fff;
  font-family: "Space Grotesk", sans-serif;
  font-size: clamp(25px, 3vw, 42px);
  letter-spacing: 0;
  line-height: 1.02;
  margin: 0;
  max-width: 720px;
  position: relative;
}
.join-notice p {
  max-width: 760px;
  position: relative;
}
.join-notice .quick-actions {
  position: relative;
}
body > footer {
  align-items: center;
  border-top: 1px solid rgba(125,232,255,.12);
  color: rgba(244,247,250,.62);
  display: flex;
  gap: 16px;
  justify-content: center;
  padding: 32px 7vw;
}
body > footer img {
  background: transparent;
  height: 56px;
  object-fit: contain;
  padding: 0;
  width: 100px;
}
body > footer p { margin: 0; }

header.nav > img,
.public-nav img,
.brand-inline img,
.brand img,
.clean-footer img,
body > footer img {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

@media (max-width: 1100px) {
  header.nav {
    align-items: flex-start;
    flex-direction: column;
    left: 18px;
    right: 18px;
    transform: none;
    width: auto;
  }
  header.nav nav {
    flex-wrap: wrap;
  }
  .hero, .academy-panel, .join {
    grid-template-columns: 1fr;
  }
  .hero {
    padding-top: 245px;
  }
  .hero-visual {
    min-height: 520px;
  }
  .intro-grid, .fleet {
    grid-template-columns: 1fr;
  }
  .experience-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  header.nav {
    padding: 16px;
  }
  header.nav > img {
    height: 68px;
    width: 136px;
  }
  header.nav nav {
    gap: 6px;
  }
  header.nav nav a {
    font-size: 13px;
  }
  .nav-cta {
    text-align: center;
    width: 100%;
  }
  .hero {
    min-height: auto;
    padding: 300px 24px 64px;
  }
  .hero h1 {
    font-size: 42px;
  }
  .stats, .experience-grid, .exp.large, .event, .join {
    grid-template-columns: 1fr;
  }
  .exp.large {
    grid-column: auto;
  }
  .hero-visual {
    display: none;
  }
  .section {
    padding: 64px 24px;
  }
  .academy-panel, .join {
    border-radius: 28px;
    padding: 24px;
  }
}

/* Global public scale refinement */
header.nav {
  max-width: 1080px;
  min-height: 72px;
  padding: 8px 18px;
}
header.nav > img {
  height: 60px;
  width: 126px;
}
header.nav nav {
  gap: 14px;
}
header.nav nav a {
  font-size: 14px;
  font-weight: 850;
}
.nav-cta {
  padding: 11px 18px;
}
.hero {
  gap: 46px;
  grid-template-columns: minmax(0, .95fr) minmax(380px, .9fr);
  margin: 0 auto;
  max-width: 1180px;
  min-height: 760px;
  padding: 138px 28px 72px;
}
.hero h1 {
  font-size: clamp(40px, 5.2vw, 72px);
  line-height: .96;
  margin: 18px 0 22px;
  max-width: 760px;
}
.hero p {
  font-size: 17px;
  line-height: 1.7;
  max-width: 650px;
}
.hero-actions {
  margin-top: 28px;
}
.stats {
  gap: 12px;
  margin-top: 28px;
  max-width: 560px;
}
.stats div {
  padding: 15px;
}
.stats strong {
  font-size: 28px;
}
.hero-visual {
  min-height: 460px;
  transform: scale(.82);
  transform-origin: center;
}
.section {
  margin: 0 auto;
  max-width: 1180px;
  padding: 72px 28px;
}
.section-title {
  margin-bottom: 30px;
  max-width: 820px;
}
.section-title h2,
.academy-panel h2,
.join h2 {
  font-size: clamp(28px, 3.5vw, 48px);
}
.intro-grid,
.experience-grid,
.fleet {
  gap: 18px;
}
.tilt {
  min-height: 220px;
  padding: 24px;
}
.tilt h3,
.exp h3,
.fleet-card h3,
.event h3 {
  font-size: 23px;
  margin: 20px 0 10px;
}
.academy-panel {
  gap: 32px;
  padding: 34px;
}
.exp {
  min-height: 230px;
  padding: 24px;
}
.fleet-card {
  min-height: 210px;
  padding: 24px;
}
.event {
  gap: 16px;
  padding: 20px;
}
.join {
  gap: 28px;
  padding: 34px;
}
body > footer {
  padding: 28px;
}

@media (max-width: 1100px) {
  .hero {
    max-width: 860px;
    padding-top: 220px;
  }
  .hero-visual {
    min-height: 420px;
  }
}

@media (max-width: 720px) {
  header.nav > img {
    height: 56px;
    width: 116px;
  }
  .hero {
    padding: 270px 22px 58px;
  }
  .hero h1 {
    font-size: 38px;
  }
  .section {
    padding: 58px 22px;
  }
}
