:root {
  --bg: #05070d;
  --bg-2: #0b1020;
  --panel: rgba(11, 18, 32, 0.72);
  --panel-strong: rgba(13, 22, 40, 0.9);
  --line: rgba(203, 226, 255, 0.16);
  --text: #f5f7fb;
  --muted: #a9b6cc;
  --subtle: #6f7e96;
  --cyan: #66e4ff;
  --blue: #3b82f6;
  --orange: #ffb45c;
  --red: #ff6b7a;
  --green: #7cf7c9;
  --shadow: 0 30px 90px rgba(0, 0, 0, 0.48);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-height: 100vh;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at 18% 18%, rgba(56, 189, 248, 0.18), transparent 26rem),
    radial-gradient(circle at 80% 0%, rgba(99, 102, 241, 0.18), transparent 28rem),
    linear-gradient(135deg, #05070d 0%, #081224 46%, #05070d 100%);
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.032) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.028) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: radial-gradient(circle at center, black, transparent 78%);
}

.app-shell {
  width: min(1540px, calc(100vw - 32px));
  margin: 0 auto;
  padding: 20px 0 56px;
}

.topbar {
  position: sticky;
  top: 12px;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 24px;
  background: rgba(5, 9, 18, 0.72);
  backdrop-filter: blur(18px);
  box-shadow: 0 16px 54px rgba(0,0,0,0.32);
}

.brand {
  display: inline-flex;
  align-items: center;
  min-width: 0;
  color: var(--text);
  text-decoration: none;
}
.brand-logo-wrap {
  display: inline-flex;
  align-items: center;
  width: clamp(240px, 28vw, 390px);
  height: 62px;
  padding: 7px 12px;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(255,255,255,0.96), rgba(241,247,255,0.9));
  border: 1px solid rgba(255,255,255,0.78);
  box-shadow: 0 14px 44px rgba(0, 0, 0, 0.24), 0 0 34px rgba(59, 130, 246, 0.12);
}
.brand-logo {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: left center;
  display: block;
}

.navlinks { display: flex; align-items: center; gap: 4px; }
.navlinks a {
  color: var(--muted);
  text-decoration: none;
  padding: 10px 13px;
  border-radius: 999px;
  font-size: 0.86rem;
  transition: 180ms ease;
}
.navlinks a:hover { color: var(--text); background: rgba(255,255,255,0.08); }

.glass-panel {
  border: 1px solid var(--line);
  background: var(--panel);
  box-shadow: var(--shadow);
  backdrop-filter: blur(20px);
}

.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 420px;
  gap: 18px;
  padding: 42px 0 18px;
}
.hero-copy,
.hero-metrics { border-radius: 34px; }
.hero-copy { padding: clamp(28px, 4vw, 58px); min-height: 360px; display: flex; flex-direction: column; justify-content: center; overflow: hidden; position: relative; }
.hero-logo-plate {
  width: min(650px, 100%);
  margin-bottom: clamp(18px, 2.5vw, 28px);
  padding: clamp(12px, 1.5vw, 18px) clamp(14px, 2vw, 24px);
  border-radius: 28px;
  background: linear-gradient(135deg, rgba(255,255,255,0.97), rgba(241,247,255,0.9));
  border: 1px solid rgba(255,255,255,0.78);
  box-shadow: 0 24px 70px rgba(0,0,0,0.26), 0 0 44px rgba(59, 130, 246, 0.14);
  position: relative;
  z-index: 1;
}
.hero-logo-plate img {
  width: 100%;
  height: auto;
  display: block;
}

.hero-copy::after {
  content: "";
  position: absolute;
  inset: auto -15% -55% 45%;
  height: 420px;
  background: radial-gradient(circle, rgba(102,228,255,0.22), transparent 65%);
  pointer-events: none;
}
.eyebrow {
  margin: 0 0 12px;
  color: var(--cyan);
  text-transform: uppercase;
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  font-weight: 800;
}
h1, h2, h3, p { margin-top: 0; }
h1 {
  max-width: 880px;
  margin-bottom: 18px;
  font-size: clamp(2.6rem, 6.2vw, 6.6rem);
  line-height: 0.92;
  letter-spacing: -0.078em;
}
.lede {
  max-width: 770px;
  color: var(--muted);
  font-size: clamp(1rem, 1.45vw, 1.22rem);
  line-height: 1.7;
}
.hero-actions,
.button-row { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 22px; }
.button {
  appearance: none;
  border: 1px solid rgba(255,255,255,0.16);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 12px 16px;
  border-radius: 999px;
  font-weight: 800;
  letter-spacing: -0.01em;
  text-decoration: none;
  cursor: pointer;
  transition: transform 160ms ease, background 160ms ease, border-color 160ms ease;
}
.button:hover { transform: translateY(-1px); }
.button.primary { color: #03111d; background: linear-gradient(135deg, #8ff1ff, #f7fbff 52%, #ffd09a); border-color: transparent; }
.button.secondary { color: var(--text); background: rgba(255,255,255,0.06); }

.hero-metrics {
  padding: 22px;
  display: grid;
  gap: 12px;
  align-content: stretch;
}
.hero-metrics div {
  min-height: 98px;
  padding: 18px;
  border: 1px solid rgba(255,255,255,0.11);
  border-radius: 24px;
  background: rgba(255,255,255,0.045);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.metric-label { color: var(--subtle); font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.12em; font-weight: 800; }
.hero-metrics strong { font-size: 1.75rem; letter-spacing: -0.05em; }

.surface-grid {
  display: grid;
  grid-template-columns: minmax(680px, 1fr) minmax(360px, 440px);
  gap: 18px;
  align-items: stretch;
  padding: 18px 0;
}
.globe-card { border-radius: 34px; padding: 18px; min-height: 760px; position: relative; overflow: hidden; }
.globe-card::before {
  content: "";
  position: absolute;
  inset: 76px 18px 64px;
  border-radius: 32px;
  background: radial-gradient(circle at center, rgba(102,228,255,0.07), transparent 62%);
  pointer-events: none;
}
.globe-header { display: flex; justify-content: space-between; gap: 18px; align-items: start; margin-bottom: 12px; }
.globe-header h2,
.model-section h2 { font-size: clamp(1.35rem, 2vw, 2.3rem); letter-spacing: -0.04em; margin-bottom: 0; }
.status-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  border-radius: 999px;
  padding: 9px 12px;
  color: var(--muted);
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  font-size: 0.8rem;
  font-weight: 700;
}
.status-pill span {
  width: 8px; height: 8px; border-radius: 50%; background: var(--green); box-shadow: 0 0 18px rgba(124,247,201,0.7);
}
.home-globe-frame { position: relative; width: 100%; height: 626px; border-radius: 30px; overflow: hidden; background: radial-gradient(circle, rgba(16,31,58,0.86), rgba(3,7,14,0.94)); }
#globeViz { position: absolute; inset: 0; width: 100%; height: 100%; border-radius: 30px; overflow: hidden; }
#globeViz canvas { border-radius: 30px; }
.globe-legend {
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
  min-height: 42px;
  margin-top: 12px;
  color: var(--muted);
  font-size: 0.82rem;
}
.legend-dot { width: 9px; height: 9px; border-radius: 50%; display: inline-block; margin-right: 7px; }
.legend-dot.launch { background: #fff; box-shadow: 0 0 14px rgba(255,255,255,0.7); }
.legend-dot.lead { background: var(--orange); box-shadow: 0 0 14px rgba(255,180,92,0.7); }
.legend-dot.alt { background: var(--cyan); }
.legend-dot.ring { background: var(--red); }

.control-stack { display: grid; gap: 18px; }
.control-panel,
.analytics-panel { border-radius: 30px; padding: 20px; }
.panel-heading { margin-bottom: 18px; }
.panel-heading h3 { margin: 0; font-size: 1.18rem; letter-spacing: -0.035em; }
.panel-heading.inline { display: flex; align-items: center; justify-content: space-between; gap: 14px; }
#leadBadge {
  display: inline-flex; align-items: center; min-width: 72px; justify-content: center;
  border-radius: 999px; padding: 9px 12px;
  color: #07111d;
  background: linear-gradient(135deg, var(--cyan), #fff2d8);
}
.slider-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px 12px;
  padding: 13px 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  color: var(--muted);
  font-size: 0.9rem;
}
.slider-row output { color: var(--text); font-weight: 800; }
.slider-row input { grid-column: 1 / -1; width: 100%; accent-color: var(--cyan); }
.slider-row.compact { padding-bottom: 6px; }

.route-cards { display: grid; gap: 10px; }
.route-card {
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 22px;
  background: rgba(255,255,255,0.045);
  padding: 13px;
  cursor: pointer;
  transition: 160ms ease;
}
.route-card:hover,
.route-card.active { border-color: rgba(102,228,255,0.5); background: rgba(102,228,255,0.08); transform: translateY(-1px); }
.route-top { display: flex; justify-content: space-between; align-items: baseline; gap: 10px; margin-bottom: 9px; }
.route-title { font-weight: 900; letter-spacing: -0.02em; }
.route-prob { font-weight: 900; color: var(--text); }
.bar-track { height: 8px; border-radius: 999px; background: rgba(255,255,255,0.08); overflow: hidden; }
.bar-fill { height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--blue), var(--cyan), var(--orange)); }
.route-meta { display: flex; justify-content: space-between; gap: 8px; margin-top: 8px; color: var(--subtle); font-size: 0.76rem; }

.model-section { margin-top: 18px; border-radius: 34px; padding: clamp(24px, 4vw, 42px); }
.model-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; margin-top: 20px; }
.model-grid article { border: 1px solid rgba(255,255,255,0.1); border-radius: 26px; padding: 18px; background: rgba(255,255,255,0.045); min-height: 210px; }
.model-grid span { display: inline-flex; color: var(--cyan); font-weight: 900; margin-bottom: 22px; }
.model-grid h3 { margin-bottom: 10px; letter-spacing: -0.035em; }
.model-grid p { color: var(--muted); line-height: 1.6; font-size: 0.91rem; margin-bottom: 0; }

@media (max-width: 1180px) {
  .hero-grid,
  .surface-grid { grid-template-columns: 1fr; }
  .globe-card { min-height: auto; }
  .control-stack { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .model-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 760px) {
  .app-shell { width: min(100vw - 18px, 1540px); padding-top: 9px; }
  .topbar { position: relative; top: 0; align-items: flex-start; flex-direction: column; }
  .brand-logo-wrap { width: min(100%, 340px); height: 58px; }
  .hero-logo-plate { border-radius: 22px; }
  .navlinks { width: 100%; overflow-x: auto; }
  .hero-grid { padding-top: 16px; }
  .hero-copy { min-height: auto; }
  .control-stack,
  .model-grid { grid-template-columns: 1fr; }
  .home-globe-frame { height: 500px; }
  h1 { font-size: clamp(2.4rem, 15vw, 4.6rem); }
}

button, input, select { font: inherit; }
img { max-width: 100%; }
.navlinks a.active { color: var(--text); background: rgba(102, 228, 255, 0.12); border: 1px solid rgba(102, 228, 255, 0.18); }
.hero-data-panel { border-radius: 34px; padding: 22px; min-height: 360px; display: flex; flex-direction: column; gap: 14px; }
.mini-badge { display: inline-flex; align-items: center; justify-content: center; white-space: nowrap; min-width: 84px; border-radius: 999px; padding: 8px 11px; color: #06131f; background: linear-gradient(135deg, var(--cyan), #fff2d8); font-size: .78rem; }
.data-select-grid { display: grid; grid-template-columns: 1fr; gap: 10px; }
.field-control { display: grid; gap: 7px; color: var(--muted); font-weight: 800; font-size: .78rem; text-transform: uppercase; letter-spacing: .08em; }
.field-control input, .field-control select { width: 100%; min-height: 44px; border-radius: 15px; border: 1px solid rgba(203, 226, 255, 0.18); background: rgba(255,255,255,0.075); color: var(--text); padding: 0 12px; outline: none; text-transform: none; letter-spacing: 0; font-weight: 650; }
.field-control input::placeholder { color: rgba(169,182,204,.66); }
.field-control select option { color: #07111d; background: #f8fbff; }
.field-control input:focus, .field-control select:focus { border-color: rgba(102,228,255,.55); box-shadow: 0 0 0 4px rgba(102,228,255,.08); }
.mini-kpis { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 9px; }
.mini-kpis div { min-height: 74px; border-radius: 19px; border: 1px solid rgba(255,255,255,.10); background: rgba(255,255,255,.045); padding: 12px; display: grid; align-content: center; gap: 5px; }
.mini-kpis strong { font-size: clamp(1.05rem, 1.7vw, 1.46rem); letter-spacing: -.05em; }
.mini-kpis span { color: var(--subtle); font-size: .69rem; text-transform: uppercase; letter-spacing: .09em; font-weight: 850; }
.selected-summary { border: 1px solid rgba(255,255,255,.10); border-radius: 21px; background: rgba(255,255,255,.045); padding: 14px; }
.selected-summary strong { display: block; margin-bottom: 5px; letter-spacing: -.025em; }
.selected-summary p { color: var(--muted); line-height: 1.48; margin: 0; font-size: .88rem; }
.home-flip-card { width: min(100%, 210px); align-self: center; aspect-ratio: 493 / 688; border: 0; background: transparent; padding: 0; perspective: 1000px; cursor: pointer; }
.home-flip-inner { display: block; position: relative; width: 100%; height: 100%; transform-style: preserve-3d; transition: transform .65s cubic-bezier(.2,.75,.2,1); }
.home-flip-card.flipped .home-flip-inner { transform: rotateY(180deg); }
.home-flip-face { position: absolute; inset: 0; display: grid; place-items: center; backface-visibility: hidden; }
.home-flip-face img { width: 100%; height: 100%; object-fit: contain; border-radius: 18px; filter: drop-shadow(0 18px 38px rgba(0,0,0,.34)); }
.home-flip-back { transform: rotateY(180deg); }
.flip-hint { color: var(--subtle); font-size: .78rem; line-height: 1.45; margin: -4px 0 0; text-align: center; }
.compact-actions { margin-top: auto; }
.integration-section { margin-top: 18px; border-radius: 34px; padding: clamp(24px, 4vw, 42px); }
.section-title-row { display: flex; justify-content: space-between; gap: 18px; align-items: flex-start; margin-bottom: 18px; }
.integration-section h2, .data-hero h1 { font-size: clamp(2rem, 4vw, 4.4rem); line-height: .95; letter-spacing: -.07em; margin-bottom: 12px; }
.integration-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 14px; }
.integration-grid article { border: 1px solid rgba(255,255,255,0.1); border-radius: 26px; padding: 18px; background: rgba(255,255,255,0.045); min-height: 230px; }
.integration-grid span { display: inline-flex; color: var(--cyan); font-weight: 900; margin-bottom: 18px; }
.integration-grid h3 { letter-spacing: -.035em; margin-bottom: 10px; }
.integration-grid p { color: var(--muted); line-height: 1.6; font-size: .93rem; }
.integration-grid a { color: var(--cyan); text-decoration: none; font-weight: 900; }
.integration-grid.expanded { grid-template-columns: repeat(3, minmax(0,1fr)); }
.compact-lede { max-width: 940px; margin: 10px 0 0; font-size: .98rem; }
@media (max-width: 1180px) { .integration-grid.expanded { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 760px) { .integration-grid.expanded { grid-template-columns: 1fr; } }

.site-footer { margin-top: 18px; border-radius: 28px; padding: 18px 22px; display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.site-footer img { width: min(320px, 52vw); max-height: 58px; object-fit: contain; background: rgba(255,255,255,.94); border-radius: 16px; padding: 8px 12px; }
.site-footer p { color: var(--muted); margin: 0; text-align: right; }

/* Data page */
.data-app-shell { width: min(1760px, calc(100vw - 32px)); }
.data-hero { margin-top: 42px; border-radius: 34px; padding: clamp(24px, 4vw, 42px); }
.data-hero .lede { max-width: 940px; }
.data-caveat { max-width: 370px; border: 1px solid rgba(255,255,255,.12); border-radius: 22px; background: rgba(255,255,255,.055); color: var(--muted); line-height: 1.55; padding: 16px; }
.filters { display: grid; grid-template-columns: minmax(280px, 1.35fr) repeat(6, minmax(150px, 1fr)) auto; gap: 10px; align-items: end; }
.field-control.wide { min-width: 280px; }
.reset-filter-btn { min-height: 44px; margin-top: 19px; }
.data-summary-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 14px; margin-top: 18px; }
.data-charts-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 14px; margin-top: 14px; }
.data-card { border-radius: 28px; padding: 18px; min-height: 130px; }
.data-card > span { color: var(--subtle); text-transform: uppercase; font-size: .74rem; letter-spacing: .12em; font-weight: 850; }
.data-card > strong { display: block; margin-top: 14px; font-size: clamp(1.7rem, 4vw, 3.2rem); letter-spacing: -.065em; }
.bars { display: grid; gap: 10px; margin-top: 16px; }
.bar-row { display: grid; grid-template-columns: minmax(140px, .8fr) minmax(160px, 1.5fr) 52px; gap: 10px; align-items: center; color: var(--muted); font-size: .82rem; }
.bar-label { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bar-row strong { color: var(--text); text-align: right; }
.table-section { margin-top: 18px; border-radius: 34px; padding: 18px; }
.toolbar { display: flex; justify-content: space-between; align-items: center; gap: 14px; flex-wrap: wrap; margin-bottom: 14px; }
.bottom-toolbar { margin: 14px 0 0; justify-content: space-between; align-items: center; }
.pill, .badge { display: inline-flex; align-items: center; border-radius: 999px; border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.07); color: var(--muted); padding: 8px 11px; font-weight: 800; font-size: .74rem; }
.downloads { display: flex; gap: 8px; flex-wrap: nowrap; justify-content: flex-end; overflow-x: auto; scrollbar-width: thin; }
.table-wrap { width: 100%; overflow: auto; border: 1px solid rgba(255,255,255,.10); border-radius: 24px; background: rgba(2,8,17,.42); }
table { width: 100%; min-width: 1940px; border-collapse: collapse; font-size: .74rem; }
th { position: sticky; top: 0; z-index: 1; text-align: left; padding: 13px 12px; color: #dff7ff; background: rgba(8, 22, 41, .96); border-bottom: 1px solid rgba(255,255,255,.12); white-space: nowrap; }
td { vertical-align: top; padding: 11px 10px; border-bottom: 1px solid rgba(255,255,255,.08); color: var(--muted); line-height: 1.35; }
td strong { color: var(--text); }
td small { color: var(--subtle); }
td a { color: var(--cyan); font-weight: 800; text-decoration: none; }
tbody tr:hover { background: rgba(102,228,255,.055); }
.table-actions { display: flex; align-items: center; justify-content: flex-end; gap: 10px; min-width: 0; flex: 1 1 auto; }
.pager-group { display: inline-flex; gap: 8px; flex: 0 0 auto; }
.pager-group .button { white-space: nowrap; }
.top-table-toolbar .pageInfo, .bottom-toolbar .pageInfo { flex: 0 0 auto; }
.class-subclass-cell { min-width: 300px; white-space: nowrap; }
.nowrap-badge { white-space: nowrap; }
.subclass-line { display: block; margin-top: 7px; color: var(--subtle); font-size: .72rem; font-weight: 760; white-space: nowrap; }
td:nth-child(3), th:nth-child(3) { min-width: 300px; }
td:nth-child(11), th:nth-child(11) { white-space: nowrap; }

button:disabled { opacity: .45; cursor: not-allowed; transform: none !important; }

@media (max-width: 1420px) {
  .filters { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .reset-filter-btn { margin-top: 0; }
}
@media (max-width: 1180px) {
  .integration-grid { grid-template-columns: 1fr; }
  .data-summary-grid, .data-charts-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .section-title-row { flex-direction: column; }
  .site-footer { flex-direction: column; align-items: flex-start; }
  .site-footer p { text-align: left; }
}
@media (max-width: 760px) {
  .hero-data-panel { border-radius: 28px; }
  .mini-kpis, .data-summary-grid, .data-charts-grid, .filters { grid-template-columns: 1fr; }
  .home-flip-card { width: min(100%, 240px); }
  .downloads { justify-content: flex-start; }
  table { min-width: 1700px; }
}

/* Filter-driven trajectory context + single-row button polish */
.trajectory-context-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(180px, 1fr));
  gap: 10px;
  margin-top: 12px;
}
.trajectory-context-strip span {
  min-width: 0;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 18px;
  background: rgba(255,255,255,0.045);
  padding: 10px 12px;
}
.trajectory-context-strip strong {
  display: block;
  color: var(--text);
  font-size: .72rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-bottom: 4px;
}
.trajectory-context-strip em {
  display: block;
  color: var(--muted);
  font-size: .82rem;
  font-style: normal;
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.hero-actions,
.button-row,
.downloads,
.bottom-toolbar {
  flex-wrap: nowrap !important;
  overflow-x: auto;
  scrollbar-width: thin;
}
.button,
.downloads .button,
.hero-actions .button,
.button-row .button,
.bottom-toolbar .button {
  white-space: nowrap;
  flex: 0 0 auto;
}
.downloads { align-items: center; }
.toolbar { gap: 12px; }
@media (max-width: 980px) {
  .trajectory-context-strip { grid-template-columns: repeat(2, minmax(180px, 1fr)); overflow-x: auto; }
}
@media (max-width: 560px) {
  .trajectory-context-strip { display: flex; overflow-x: auto; }
  .trajectory-context-strip span { min-width: 220px; }
}

/* v8 navigation expansion */
.navlinks { margin-left: auto; justify-content: flex-end; flex-wrap: nowrap; min-width: max-content; }
.navlinks a { white-space: nowrap; }
.hero-actions { flex-wrap: nowrap; overflow-x: auto; }
.hero-actions .button { white-space: nowrap; }


/* v9 Globe.gl active controls */
.globe-tools{display:flex;align-items:center;justify-content:flex-end;gap:8px;margin:6px 0 12px;white-space:nowrap;overflow-x:auto;padding-bottom:2px;scrollbar-width:thin;position:relative;z-index:3}
.globe-tool{appearance:none;border:1px solid rgba(132,195,255,.28);background:rgba(5,20,42,.72);color:#dff6ff;border-radius:999px;padding:9px 12px;font-size:.78rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;box-shadow:inset 0 0 0 1px rgba(255,255,255,.04);transition:transform .18s ease,border-color .18s ease,background .18s ease,box-shadow .18s ease;flex:0 0 auto}
.globe-tool:hover{transform:translateY(-1px);border-color:rgba(102,228,255,.62);background:rgba(14,48,88,.86);box-shadow:0 0 22px rgba(64,151,255,.18),inset 0 0 0 1px rgba(255,255,255,.06)}
.globe-tool.primary{background:linear-gradient(135deg,rgba(0,119,255,.92),rgba(80,110,255,.78));border-color:rgba(102,228,255,.58);color:#fff}
.globe-modal{position:fixed;inset:0;z-index:9999;display:none;padding:26px;background:rgba(0,5,14,.84);backdrop-filter:blur(18px);align-items:center;justify-content:center}
.globe-modal.is-open{display:flex}
.globe-modal-shell{width:min(1680px,96vw);height:min(960px,92vh);border:1px solid rgba(102,228,255,.24);border-radius:30px;background:linear-gradient(180deg,rgba(2,15,34,.98),rgba(1,7,18,.96));box-shadow:0 34px 130px rgba(0,0,0,.72),0 0 90px rgba(0,122,255,.22);padding:14px;display:grid;grid-template-rows:auto minmax(0,1fr);gap:12px}
.globe-modal-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:4px 4px 0;color:#fff}
.globe-modal-bar strong{display:block;font-size:1rem;letter-spacing:.08em;text-transform:uppercase}.globe-modal-bar span{display:block;color:#8ba7c9;font-size:.82rem;margin-top:2px}
.globe-modal-mount{min-height:0;border-radius:26px;overflow:hidden;background:radial-gradient(circle,rgba(16,31,58,.86),rgba(3,7,14,.98));position:relative}
.globe-modal-mount .home-globe-frame{width:100%;height:100%;min-height:0;border-radius:26px;margin:0}
.globe-modal-mount #globeViz{width:100%;height:100%;border-radius:26px}
.globe-modal-mount #globeViz canvas{border-radius:26px}
@media(max-width:720px){.globe-tools{justify-content:flex-start}.globe-modal{padding:10px}.globe-modal-shell{width:100vw;height:94vh;border-radius:20px}.globe-modal-mount,.globe-modal-mount .home-globe-frame,.globe-modal-mount #globeViz{border-radius:16px}}

/* v15 single-row button hardening across integrated pages */
button,
.button,
.btn,
.globe-tool,
.navlinks a,
.pager button,
.pager-group .button,
.downloads .button,
.hero-actions .button,
.button-row .button,
.bottom-toolbar .button,
.actions .btn {
  white-space: nowrap !important;
}
.button-row,
.hero-actions,
.downloads,
.bottom-toolbar,
.actions,
.globe-tools,
.navlinks,
.pager,
.pager-group {
  flex-wrap: nowrap !important;
  overflow-x: auto;
  scrollbar-width: thin;
}
.button,
.btn,
.globe-tool,
.navlinks a,
.actions .btn,
.hero-actions .button,
.button-row .button,
.downloads .button,
.bottom-toolbar .button {
  flex: 0 0 auto;
}


/* v23: hero ADL graphic popup and tighter Data filter/table behavior */
.hero-logo-plate { max-width: min(650px, 100%); }
.hero-graphic-expand {
  width: 100%;
  display: block;
  position: relative;
  border: 0;
  background: transparent;
  padding: 0;
  cursor: zoom-in;
  border-radius: 20px;
  overflow: hidden;
}
.hero-graphic-expand img { width: 100%; height: auto; display: block; }
.hero-graphic-expand span {
  position: absolute;
  right: 10px;
  bottom: 10px;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.72);
  background: rgba(3, 7, 18, .72);
  color: #fff;
  padding: 7px 10px;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .02em;
  backdrop-filter: blur(10px);
}
.hero-graphic-modal {
  position: fixed;
  inset: 0;
  z-index: 999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: clamp(16px, 3vw, 40px);
}
.hero-graphic-modal.open { display: flex; }
.hero-graphic-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.72); backdrop-filter: blur(12px); }
.hero-graphic-dialog {
  position: relative;
  width: min(1180px, 94vw);
  max-height: 90vh;
  border-radius: 30px;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(6, 15, 30, .94);
  box-shadow: 0 40px 120px rgba(0,0,0,.55);
  padding: clamp(12px, 2vw, 20px);
  overflow: auto;
}
.hero-graphic-dialog img { display: block; width: 100%; height: auto; border-radius: 22px; object-fit: contain; }
.hero-graphic-close {
  position: sticky;
  top: 0;
  float: right;
  z-index: 2;
  width: 42px;
  height: 42px;
  margin: 0 0 8px 8px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.24);
  background: rgba(255,255,255,.12);
  color: #fff;
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
}
body.modal-open { overflow: hidden; }
.filters { grid-template-columns: minmax(210px, .82fr) repeat(6, minmax(122px, .86fr)) max-content; }
.field-control.wide { min-width: 210px; }
.reset-filter-btn { white-space: nowrap; padding-inline: 13px; }
.data-nowrap { white-space: nowrap !important; overflow-wrap: normal !important; word-break: normal !important; }
.muted-nowrap { display: inline-block; max-width: 260px; overflow: hidden; text-overflow: ellipsis; vertical-align: bottom; }
td:nth-child(1), th:nth-child(1) { min-width: 190px; }
td:nth-child(2), th:nth-child(2) { min-width: 260px; }
@media (max-width: 1600px) {
  .filters { grid-template-columns: minmax(200px, .8fr) repeat(3, minmax(130px, 1fr)) max-content; }
}
@media (max-width: 1180px) {
  .filters { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .reset-filter-btn { width: max-content; }
}
@media (max-width: 760px) {
  .filters { grid-template-columns: 1fr; }
  .reset-filter-btn { width: 100%; }
}

/* v28 home hero product + pitch deck actions outside the image container */
.hero-media-block{width:min(900px,100%);margin-bottom:clamp(18px,2.5vw,28px);position:relative;z-index:2}
.hero-media-block .hero-logo-plate{margin-bottom:0;flex:0 0 auto;width:min(650px,100%)}
.hero-product-row{display:flex;justify-content:flex-start;align-items:center;margin:0 0 10px;position:relative;z-index:2}
.hero-asset-row{display:grid;grid-template-columns:minmax(0,650px) minmax(170px,220px);gap:16px;align-items:center}
.pitch-deck-actions{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px;min-width:0}
.home-white-button,
.hero-product-row .product-button,
.pitch-deck-actions .button{background:#ffffff!important;border:1px solid rgba(255,255,255,.88)!important;color:#061225!important;box-shadow:0 12px 28px rgba(0,0,0,.22),0 0 0 1px rgba(0,102,204,.08) inset!important;text-shadow:none!important}
.home-white-button:hover,
.hero-product-row .product-button:hover,
.pitch-deck-actions .button:hover{background:#f4f8ff!important;color:#000!important;border-color:rgba(102,228,255,.55)!important}
.pitch-deck-actions .button{width:100%;justify-content:center;text-align:center;white-space:nowrap;padding-inline:12px}
@media(max-width:960px){.hero-asset-row{grid-template-columns:1fr}.pitch-deck-actions{align-items:flex-start;max-width:240px}.hero-media-block .hero-logo-plate{width:min(650px,100%)}}
@media(max-width:760px){.pitch-deck-actions{align-items:stretch;max-width:none}.hero-product-row .product-button{width:100%;justify-content:center;text-align:center;white-space:normal}.pitch-deck-actions .button{white-space:normal}}
