/* ALTBIM landing v2 — instrument panel meets editorial */

@import url('assets/colors_and_type.css');

/* ============================================================
   VALUE CHAIN — 5 stages, horizontal
   ============================================================ */
.chain {
  margin-top: 56px;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  position: relative;
  border-top: 1px solid var(--alt-border-weak);
  border-bottom: 1px solid var(--alt-border-weak);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.02), transparent 30%, transparent 70%, rgba(0,0,0,0.15)),
    var(--alt-surface-low);
}
.chain .stg {
  position: relative;
  padding: 22px 18px 24px;
  border-right: 1px solid var(--alt-border-weak);
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-width: 0;
}
.chain .stg:last-child { border-right: none; }
.chain .stg.core {
  background: linear-gradient(180deg, rgba(0,209,255,0.06), rgba(0,209,255,0.01));
  border-left: 1px solid rgba(0,209,255,0.22);
  border-right: 1px solid rgba(0,209,255,0.22);
}
.chain .stg-head {
  display: flex; align-items: center; gap: 10px;
}
.chain .stg-head .ix {
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--alt-cyan);
}
.chain .stg-head .lbl {
  font-family: var(--alt-font-label);
  font-size: 11px;
  letter-spacing: 0.18em;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--alt-text-primary);
}
.chain .stg-in,
.chain .stg-out {
  font-size: 10px;
  letter-spacing: 0.04em;
  color: var(--alt-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.14em;
}
.chain .stg-out { margin-top: auto; color: var(--alt-cyan); opacity: 0.85; }
.chain .stg.core .stg-out { color: var(--alt-cyan); }
.chain .stg-arrow {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--alt-border-medium), transparent);
  position: relative;
  margin: 2px 0 6px;
}
.chain .stg-arrow::after {
  content: '';
  position: absolute;
  right: -4px;
  top: 50%;
  transform: translateY(-50%);
  width: 0; height: 0;
  border-top: 4px solid transparent;
  border-bottom: 4px solid transparent;
  border-left: 5px solid var(--alt-border-medium);
}
.chain .stg-prods {
  display: flex; flex-direction: column; gap: 8px;
}
.chain .prod-chip {
  border: 1px solid var(--alt-border-weak);
  background: var(--alt-surface-mid);
  border-radius: 3px;
  padding: 12px 12px 10px;
  position: relative;
  display: grid;
  grid-template-columns: 28px 1fr;
  grid-template-rows: auto auto;
  column-gap: 10px;
  row-gap: 6px;
}
.chain .prod-chip .pi {
  grid-row: 1 / 2;
  width: 28px; height: 28px;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--alt-border-weak);
  border-radius: 2px;
  background: var(--alt-surface-low);
}
.chain .prod-chip .pi img {
  width: 16px;
  height: 16px;
  object-fit: contain;
}
.chain .prod-chip .pi svg { width: 16px; height: 16px; }
.chain .prod-chip .pn {
  grid-row: 1 / 2;
  font-family: var(--alt-font-label);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  align-self: center;
}
.chain .prod-chip .pd {
  grid-column: 1 / 3;
  font-size: 11px;
  line-height: 1.5;
  color: var(--alt-text-secondary);
}
.chain .prod-chip .b {
  position: absolute;
  top: 10px;
  right: 10px;
  font-family: var(--alt-font-mono);
  font-size: 8.5px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  padding: 2px 6px;
  border-radius: 2px;
  border: 1px solid var(--alt-border-weak);
}
.chain .prod-chip .b.live { color: var(--alt-teal); border-color: rgba(0,212,170,0.30); background: rgba(0,212,170,0.06); }
.chain .prod-chip .b.beta { color: var(--alt-amber); border-color: rgba(245,158,11,0.30); background: rgba(245,158,11,0.06); }
.chain .prod-chip .b.mvp { color: var(--alt-cyan); border-color: rgba(0,209,255,0.30); background: rgba(0,209,255,0.06); }
.chain .prod-chip .b.spec { color: #B18CFF; border-color: rgba(177,140,255,0.30); background: rgba(177,140,255,0.06); }
.chain .prod-chip.ids    .pi { color: var(--alt-cyan);  border-color: rgba(0,209,255,0.30); }
.chain .prod-chip.ids    .pn { color: var(--alt-cyan); }
.chain .prod-chip.forge  .pi { color: #FF5E3A;  border-color: rgba(255,94,58,0.30); }
.chain .prod-chip.forge  .pn { color: #FF5E3A; }
.chain .prod-chip.needle .pi { color: #B18CFF;  border-color: rgba(177,140,255,0.30); }
.chain .prod-chip.needle .pn { color: #B18CFF; }
.chain .prod-chip.spine  { border-color: rgba(0,209,255,0.35); background: linear-gradient(180deg, rgba(0,209,255,0.08), rgba(0,209,255,0.02)), var(--alt-surface-mid); }
.chain .prod-chip.spine  .pi { color: var(--alt-cyan);  border-color: rgba(0,209,255,0.45); }
.chain .prod-chip.spine  .pn { color: var(--alt-cyan); }
.chain .prod-chip.atlas  .pi { color: var(--alt-cyan);  border-color: rgba(0,209,255,0.30); }
.chain .prod-chip.atlas  .pn { color: var(--alt-cyan); }
.chain .prod-chip.bob    .pi { color: #00d4aa;  border-color: rgba(0,212,170,0.30); }
.chain .prod-chip.bob    .pn { color: #00d4aa; }
.chain .prod-chip.scout  .pi { color: #0099BE;  border-color: rgba(0,153,190,0.30); }
.chain .prod-chip.scout  .pn { color: #0099BE; }
.chain .prod-chip.beacon .pi { color: #B18CFF;  border-color: rgba(177,140,255,0.30); }
.chain .prod-chip.beacon .pn { color: #B18CFF; }

/* Hover popover — detailed info card */
.chain .prod-chip {
  cursor: pointer;
  transition: border-color 160ms cubic-bezier(0.16,1,0.3,1),
              background 160ms cubic-bezier(0.16,1,0.3,1),
              transform 200ms cubic-bezier(0.16,1,0.3,1);
}
.chain .prod-chip:hover {
  border-color: rgba(255,255,255,0.18);
  background: var(--alt-surface-high);
  z-index: 5;
}
.chain .prod-chip .pi {
  transition: transform 220ms cubic-bezier(0.16,1,0.3,1),
              box-shadow 220ms cubic-bezier(0.16,1,0.3,1);
}
.chain .prod-chip:hover .pi {
  transform: scale(1.08) rotate(-2deg);
}
.chain .prod-chip.ids:hover    .pi { box-shadow: 0 0 16px rgba(0,209,255,0.45); }
.chain .prod-chip.forge:hover  .pi { box-shadow: 0 0 16px rgba(255,94,58,0.45); }
.chain .prod-chip.needle:hover .pi { box-shadow: 0 0 16px rgba(177,140,255,0.45); }
.chain .prod-chip.spine:hover  .pi { box-shadow: 0 0 18px rgba(0,209,255,0.55); }
.chain .prod-chip.atlas:hover  .pi { box-shadow: 0 0 16px rgba(0,209,255,0.45); }
.chain .prod-chip.bob:hover    .pi { box-shadow: 0 0 16px rgba(0,212,170,0.45); }
.chain .prod-chip.scout:hover  .pi { box-shadow: 0 0 16px rgba(0,153,190,0.45); }
.chain .prod-chip.beacon:hover .pi { box-shadow: 0 0 16px rgba(177,140,255,0.45); }

.prod-pop {
  position: absolute;
  left: 50%;
  bottom: calc(100% + 14px);
  --pop-shift: 0px;
  transform: translate(calc(-50% + var(--pop-shift)), 8px);
  width: 248px;
  max-width: min(248px, 90vw);
  background: rgba(18,20,22,0.96);
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 4px;
  padding: 12px;
  box-shadow:
    0 24px 60px rgba(0,0,0,0.55),
    0 2px 0 rgba(255,255,255,0.04) inset,
    0 0 0 1px rgba(0,0,0,0.20);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  z-index: 50;
  transition:
    opacity 220ms cubic-bezier(0.16,1,0.3,1),
    transform 260ms cubic-bezier(0.16,1,0.3,1),
    visibility 0s linear 260ms;
}
.chain .prod-chip:hover .prod-pop {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translate(calc(-50% + var(--pop-shift)), 0);
  transition:
    opacity 220ms cubic-bezier(0.16,1,0.3,1),
    transform 260ms cubic-bezier(0.16,1,0.3,1),
    visibility 0s linear 0s;
}
.chain .prod-chip:focus-within .prod-pop,
.chain .prod-chip:focus .prod-pop {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translate(calc(-50% + var(--pop-shift)), 0);
  transition:
    opacity 220ms cubic-bezier(0.16,1,0.3,1),
    transform 260ms cubic-bezier(0.16,1,0.3,1),
    visibility 0s linear 0s;
}
.prod-pop.flip-down {
  bottom: auto;
  top: calc(100% + 12px);
}

/* Arrow on popover */
.prod-pop::after {
  content: '';
  position: absolute;
  bottom: -7px;
  left: 50%;
  transform: translateX(-50%) rotate(45deg);
  width: 12px; height: 12px;
  background: rgba(18,20,22,0.96);
  border-right: 1px solid rgba(255,255,255,0.10);
  border-bottom: 1px solid rgba(255,255,255,0.10);
}
.prod-pop.flip-down::after {
  bottom: auto;
  top: -7px;
  transform: translateX(-50%) rotate(225deg);
}

.prod-pop .pv-head {
  display: flex; align-items: center; gap: 10px;
  padding-bottom: 8px;
  margin-bottom: 8px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.prod-pop .pv-head .pn {
  font-family: var(--alt-font-label);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.prod-pop .pv-head .role {
  font-family: var(--alt-font-mono);
  font-size: 9px;
  letter-spacing: 0.14em;
  color: var(--alt-text-muted);
  text-transform: uppercase;
  margin-left: auto;
}
.prod-pop .pv-shot {
  display: block;
  text-decoration: none;
  border: 1px solid rgba(255,255,255,0.08);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.015)),
    var(--alt-surface-low);
  border-radius: 3px;
  padding: 9px;
  margin-bottom: 8px;
}
.prod-pop .pv-shot .pv-url {
  display: block;
  font-size: 8.5px;
  letter-spacing: 0.13em;
  color: var(--alt-text-muted);
  text-transform: uppercase;
  margin-bottom: 4px;
}
.prod-pop .pv-shot strong {
  display: block;
  font-size: 11px;
  line-height: 1.35;
  color: var(--alt-text-primary);
  margin-bottom: 3px;
}
.prod-pop .pv-shot span {
  display: block;
  font-size: 10px;
  line-height: 1.4;
  color: var(--alt-text-secondary);
}
.prod-pop .pv-points {
  list-style: none;
  padding: 0;
  margin: 0 0 8px;
  display: flex; flex-direction: column; gap: 6px;
}
.prod-pop .pv-points li {
  display: grid;
  grid-template-columns: 14px 1fr;
  gap: 6px;
  font-size: 10px;
  line-height: 1.4;
  color: var(--alt-text-secondary);
}
.prod-pop .pv-points li::before {
  content: '→';
  font-family: var(--alt-font-mono);
  color: var(--alt-cyan);
  font-size: 10px;
  line-height: 1.4;
}
.prod-pop .pv-link {
  display: inline-block;
  text-decoration: none;
  font-family: var(--alt-font-mono);
  font-size: 10px;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--alt-cyan);
}
.prod-pop .pv-link:hover { color: var(--alt-text-primary); }
.prod-pop.ids    { border-color: rgba(0,209,255,0.30); }
.prod-pop.forge  { border-color: rgba(255,94,58,0.30); }
.prod-pop.needle { border-color: rgba(177,140,255,0.30); }
.prod-pop.spine  { border-color: rgba(0,209,255,0.40); }
.prod-pop.atlas  { border-color: rgba(0,209,255,0.30); }
.prod-pop.bob    { border-color: rgba(0,212,170,0.30); }
.prod-pop.scout  { border-color: rgba(0,153,190,0.30); }
.prod-pop.beacon { border-color: rgba(177,140,255,0.30); }
.prod-pop.ids    .pv-head .pn,
.prod-pop.atlas  .pv-head .pn,
.prod-pop.spine  .pv-head .pn { color: var(--alt-cyan); }
.prod-pop.forge  .pv-head .pn { color: #FF5E3A; }
.prod-pop.needle .pv-head .pn,
.prod-pop.beacon .pv-head .pn { color: #B18CFF; }
.prod-pop.bob    .pv-head .pn { color: #00d4aa; }
.prod-pop.scout  .pv-head .pn { color: #0099BE; }
@media (max-width: 1100px) {
  .prod-pop {
    width: 220px;
    max-width: min(220px, 90vw);
  }
}

.chain .prod-chip.spine .ports {
  grid-column: 1 / 3;
  display: flex; flex-wrap: wrap; gap: 4px;
  margin-top: 2px;
}
.chain .prod-chip.spine .ports span {
  font-family: var(--alt-font-mono);
  font-size: 9px;
  letter-spacing: 0.04em;
  padding: 2px 5px;
  border-radius: 2px;
  background: rgba(0,209,255,0.08);
  color: var(--alt-cyan);
  border: 1px solid rgba(0,209,255,0.18);
}
@media (max-width: 1100px) {
  .chain { grid-template-columns: 1fr 1fr; }
  .chain .stg { border-right: 1px solid var(--alt-border-weak); border-bottom: 1px solid var(--alt-border-weak); }
}
@media (max-width: 700px) {
  .chain { grid-template-columns: 1fr; }
}


* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--alt-surface-base);
  background-image:
    linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px);
  background-size: 30px 30px;
  color: var(--alt-text-primary);
  font-family: var(--alt-font-body);
  font-size: 14px;
  line-height: 1.55;
  overflow-x: hidden;
}

/* ============================================================
   LAYOUT PRIMITIVES
   ============================================================ */
.lp-wrap { width: 100%; max-width: 1440px; margin: 0 auto; padding: 0 56px; }
@media (max-width: 900px) { .lp-wrap { padding: 0 24px; } }

.lp-rule { height: 1px; background: var(--alt-border-weak); width: 100%; }
.lp-rule-strong { height: 1px; background: var(--alt-border-medium); width: 100%; }

.lp-grid-bg {
  background-image:
    linear-gradient(rgba(255,255,255,0.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.022) 1px, transparent 1px);
  background-size: 26px 26px;
}

.kicker {
  font-family: var(--alt-font-label);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--alt-cyan);
}
.label {
  font-family: var(--alt-font-label);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--alt-text-muted);
}
.mono { font-family: var(--alt-font-mono); font-feature-settings: "ss01" on; }

/* ============================================================
   STATUS STRIP (very top, hair-thin)
   ============================================================ */
.status-strip {
  position: relative; z-index: 60;
  background: #0c0e10;
  border-bottom: 1px solid var(--alt-border-weak);
  font-family: var(--alt-font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--alt-text-muted);
}
.status-strip .lp-wrap {
  display: flex; align-items: center; gap: 28px;
  height: 28px; overflow: hidden;
}
.status-strip .item { display: inline-flex; align-items: center; gap: 8px; white-space: nowrap; }
.status-strip .item strong { color: var(--alt-text-secondary); font-weight: 500; }
.status-strip .item .v { color: var(--alt-cyan); }
.status-strip .item .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--alt-teal); box-shadow: 0 0 8px rgba(0,212,170,0.6); }
.status-strip .item .dot.pulse { animation: pulse 2s ease-in-out infinite; }
.status-strip .spacer { flex: 1; }
@keyframes pulse { 0%,100% { opacity: 0.45; } 50% { opacity: 1; } }

/* ============================================================
   TOP NAV
   ============================================================ */
.topnav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(18,20,22,0.85);
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--alt-border-weak);
  height: 64px;
  display: flex; align-items: center;
}
.topnav .lp-wrap { display: flex; align-items: center; gap: 32px; }
.topnav .brand { display: flex; align-items: center; gap: 12px; color: var(--alt-text-primary); }
.topnav .brand img { width: 20px; height: 20px; object-fit: contain; }
.topnav .brand .wordmark {
  font-family: var(--alt-font-display);
  font-weight: 900;
  font-size: 17px;
  letter-spacing: 0.04em;
}
.topnav .brand .tag {
  font-family: var(--alt-font-label);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.20em;
  color: var(--alt-text-muted);
  padding-left: 12px;
  border-left: 1px solid var(--alt-border-medium);
  margin-left: 4px;
}
.topnav nav { display: flex; gap: 32px; margin-left: 24px; }
.topnav nav a {
  font-family: var(--alt-font-label);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--alt-text-muted);
  transition: color 120ms var(--alt-ease-out);
  position: relative;
}
.topnav nav a:hover { color: var(--alt-text-primary); }
.topnav nav a.active { color: var(--alt-text-primary); }
.topnav nav a.active::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -22px;
  height: 2px; background: var(--alt-cyan); box-shadow: 0 0 12px rgba(0,209,255,0.45);
}
.topnav .right { margin-left: auto; display: flex; align-items: center; gap: 16px; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--alt-font-label);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 10px 16px;
  border-radius: 2px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all 120ms var(--alt-ease-out);
  text-decoration: none;
}
.btn-primary {
  background: var(--alt-cyan);
  color: var(--alt-cyan-text);
  box-shadow: 0 0 0 1px var(--alt-cyan), 0 0 24px rgba(0,209,255,0.30);
}
.btn-primary:hover { background: var(--alt-cyan-hover); box-shadow: 0 0 0 1px var(--alt-cyan-hover), 0 0 32px rgba(0,209,255,0.45); }
.btn-ghost {
  background: rgba(255,255,255,0.02);
  border-color: var(--alt-border-medium);
  color: var(--alt-text-secondary);
}
.btn-ghost:hover { border-color: var(--alt-border-strong); color: var(--alt-text-primary); background: rgba(255,255,255,0.04); }
.btn-link {
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--alt-cyan);
  font-family: var(--alt-font-label);
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  cursor: pointer;
}
.btn-link::after { content: "→"; transition: transform 120ms var(--alt-ease-out); }
.btn-link:hover::after { transform: translateX(3px); }

.btn-theme {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 104px;
  padding: 9px 12px;
  border-radius: 2px;
  border: 1px solid var(--alt-border-medium);
  background: rgba(255,255,255,0.03);
  color: var(--alt-text-secondary);
  font-family: var(--alt-font-label);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 160ms var(--alt-ease-out);
}
.btn-theme:hover {
  color: var(--alt-text-primary);
  border-color: var(--alt-border-strong);
  background: rgba(255,255,255,0.07);
}

/* ============================================================
   SECTION CHROME
   ============================================================ */
.section { position: relative; }
.section-marker {
  display: flex; align-items: center; gap: 16px;
  padding: 24px 0 12px;
}
.section-marker .idx {
  font-family: var(--alt-font-mono);
  font-size: 10px;
  color: var(--alt-text-muted);
  letter-spacing: 0.08em;
}
.section-marker .lbl {
  font-family: var(--alt-font-label);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--alt-cyan);
}
.section-marker .line { flex: 1; height: 1px; background: var(--alt-border-weak); }

h1, h2 { margin: 0; }
.disp {
  font-family: var(--alt-font-display);
  font-weight: 900;
  letter-spacing: -0.035em;
  line-height: 0.92;
}
.disp-xl { font-size: clamp(56px, 8.4vw, 124px); }
.disp-lg { font-size: clamp(40px, 5.4vw, 76px); }
.disp-md { font-size: clamp(32px, 3.8vw, 54px); }

.disp .accent { color: var(--alt-cyan); }
.disp .dim { color: var(--alt-text-muted); }

/* ============================================================
   HERO
   ============================================================ */
.hero { position: relative; padding: 56px 0 24px; }
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 15% 10%, rgba(0,209,255,0.08), transparent 46%);
  pointer-events: none;
}
.hero-grid { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr); gap: 56px; align-items: stretch; }
@media (max-width: 1100px) { .hero-grid { grid-template-columns: 1fr; gap: 40px; } }

.hero-meta { display: flex; align-items: center; gap: 14px; margin-bottom: 28px; }
.hero-meta .pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 10px;
  border: 1px solid var(--alt-border-medium);
  border-radius: 2px;
  background: rgba(0,209,255,0.04);
  font-family: var(--alt-font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  color: var(--alt-text-secondary);
}
.hero-meta .pill .dot { width: 5px; height: 5px; border-radius: 50%; background: var(--alt-cyan); box-shadow: 0 0 8px var(--alt-cyan); animation: pulse 2s ease-in-out infinite; }
.hero-meta .ver { font-family: var(--alt-font-mono); font-size: 10px; color: var(--alt-text-muted); letter-spacing: 0.06em; }

.hero h1 .l { display: block; }
.hero .lede {
  margin-top: 28px;
  font-family: var(--alt-font-body);
  font-size: 16px;
  line-height: 1.55;
  color: var(--alt-text-secondary);
  max-width: 520px;
}
.hero .cta-row { margin-top: 32px; display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.hero .signals {
  margin-top: 40px;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border-top: 1px solid var(--alt-border-weak);
  border-bottom: 1px solid var(--alt-border-weak);
}
.hero .signals .cell {
  padding: 14px 16px;
  border-right: 1px solid var(--alt-border-weak);
}
.hero .signals .cell:last-child { border-right: none; }
.hero .signals .cell .v {
  font-family: var(--alt-font-display);
  font-weight: 900;
  font-size: 22px;
  letter-spacing: -0.02em;
  color: var(--alt-text-primary);
}
.hero .signals .cell .v .unit { color: var(--alt-text-muted); font-weight: 400; font-size: 13px; margin-left: 4px; }
.hero .signals .cell .k {
  margin-top: 2px;
  font-family: var(--alt-font-label);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--alt-text-muted);
}

.hero-orb {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  mix-blend-mode: screen;
  filter: blur(0);
  animation: floatOrb 12s ease-in-out infinite;
}
.hero-orb.orb-a {
  width: 220px;
  height: 220px;
  top: 14px;
  right: 14%;
  background: radial-gradient(circle, rgba(0,209,255,0.22), rgba(0,209,255,0.02) 65%, transparent 75%);
}
.hero-orb.orb-b {
  width: 180px;
  height: 180px;
  bottom: 24px;
  right: 2%;
  background: radial-gradient(circle, rgba(177,140,255,0.18), rgba(177,140,255,0.02) 62%, transparent 74%);
  animation-delay: -4s;
}
@keyframes floatOrb {
  0%, 100% { transform: translate3d(0, 0, 0); }
  50% { transform: translate3d(0, -14px, 0); }
}

/* Hero panel — live instrument */
.hero-panel {
  position: relative;
  background: linear-gradient(180deg, rgba(255,255,255,0.09), rgba(255,255,255,0.01));
  border: 1px solid var(--alt-border-medium);
  border-radius: 4px;
  padding: 0;
  overflow: hidden;
  box-shadow: var(--alt-shadow-card);
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
  display: flex; flex-direction: column;
}
.hero-panel .hp-bar {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--alt-border-weak);
  background: var(--alt-surface-low);
  font-family: var(--alt-font-mono);
  font-size: 10px;
  color: var(--alt-text-muted);
}
.hero-panel .hp-bar .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--alt-teal); box-shadow: 0 0 6px var(--alt-teal); }
.hero-panel .hp-bar .crumb { color: var(--alt-text-secondary); }
.hero-panel .hp-bar .crumb .sep { color: var(--alt-text-muted); margin: 0 6px; }
.hero-panel .hp-bar .right { margin-left: auto; }

.hp-body { display: grid; grid-template-columns: 110px 1fr; flex: 1; }
.hp-nav { border-right: 1px solid var(--alt-border-weak); padding: 12px 0; background: var(--alt-surface-low); }
.hp-nav .item {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 12px;
  font-family: var(--alt-font-label);
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--alt-text-muted);
  border-left: 2px solid transparent;
}
.hp-nav .item.active { color: var(--alt-text-primary); border-left-color: var(--alt-cyan); background: rgba(0,209,255,0.06); }
.hp-nav .item .b {
  margin-left: auto;
  font-family: var(--alt-font-mono);
  color: var(--alt-text-muted);
  letter-spacing: 0;
}

.hp-content { padding: 16px; display: flex; flex-direction: column; gap: 16px; }
.hp-kpi-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.hp-kpi {
  background: var(--alt-surface-low);
  border: 1px solid var(--alt-border-weak);
  border-radius: 2px;
  padding: 10px 12px;
}
.hp-kpi .k {
  font-family: var(--alt-font-label);
  font-size: 8px; font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--alt-text-muted);
}
.hp-kpi .v {
  margin-top: 4px;
  font-family: var(--alt-font-display);
  font-weight: 900;
  font-size: 22px;
  letter-spacing: -0.02em;
}
.hp-kpi .v.tcy { color: var(--alt-cyan); }
.hp-kpi .v.tam { color: var(--alt-amber); }
.hp-kpi .v.tte { color: var(--alt-teal); }
.hp-kpi .d {
  margin-top: 2px;
  font-family: var(--alt-font-mono);
  font-size: 9px;
  color: var(--alt-text-muted);
}

.hp-chart {
  background: var(--alt-surface-low);
  border: 1px solid var(--alt-border-weak);
  border-radius: 2px;
  padding: 12px;
}
.hp-chart .ch-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.hp-chart .ch-head .t {
  font-family: var(--alt-font-label);
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--alt-text-muted);
}
.hp-chart .ch-head .x {
  font-family: var(--alt-font-mono);
  font-size: 10px;
  color: var(--alt-cyan);
}

.hp-list {
  background: var(--alt-surface-low);
  border: 1px solid var(--alt-border-weak);
  border-radius: 2px;
}
.hp-list .row {
  display: grid;
  grid-template-columns: 12px 1fr auto 80px;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  border-bottom: 1px solid var(--alt-border-weak);
  font-family: var(--alt-font-mono);
  font-size: 10px;
}
.hp-list .row:last-child { border-bottom: none; }
.hp-list .row .stat { width: 8px; height: 8px; border-radius: 1px; }
.hp-list .row .stat.open { background: var(--alt-amber); }
.hp-list .row .stat.work { background: var(--alt-cyan); }
.hp-list .row .stat.done { background: var(--alt-teal); }
.hp-list .row .id { color: var(--alt-text-muted); }
.hp-list .row .ti { color: var(--alt-text-primary); font-family: var(--alt-font-body); font-size: 11px; }
.hp-list .row .tx { color: var(--alt-text-muted); justify-self: end; }

/* ============================================================
   ARCHITECTURE / ECOSYSTEM
   ============================================================ */
.arch { padding: 64px 0 80px; }
.arch h2 { max-width: 760px; }
.arch .lede { color: var(--alt-text-secondary); max-width: 600px; margin-top: 16px; font-size: 15px; }

.arch-diagram {
  position: relative;
  margin-top: 56px;
  display: grid;
  grid-template-columns: 1fr 1.2fr 1fr;
  gap: 0;
  align-items: stretch;
  min-height: 380px;
}
.arch-col {
  display: flex; flex-direction: column; gap: 14px;
  padding: 8px 0;
  position: relative;
  z-index: 2;
}
.arch-col.c { z-index: 3; }
.arch-col-label {
  font-family: var(--alt-font-label);
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--alt-text-muted);
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--alt-border-weak);
}
.arch-col-label .ix {
  font-family: var(--alt-font-mono);
  margin-right: 8px;
  color: var(--alt-cyan);
}

.app-card {
  position: relative;
  background: var(--alt-surface-mid);
  border: 1px solid var(--alt-border-weak);
  border-radius: 3px;
  padding: 14px 16px;
  display: grid;
  grid-template-columns: 36px 1fr auto;
  gap: 12px;
  align-items: center;
  transition: all 160ms var(--alt-ease-out);
  cursor: pointer;
}
.app-card:hover {
  background: var(--alt-surface-high);
  border-color: var(--alt-border-medium);
  transform: translateX(4px);
}
.arch-col.r .app-card:hover { transform: translateX(-4px); }
.arch-col.c .app-card:hover { transform: none; }

.app-card .ico {
  width: 36px; height: 36px;
  border-radius: 3px;
  display: flex; align-items: center; justify-content: center;
  background: var(--alt-surface-low);
  border: 1px solid var(--alt-border-weak);
}
.app-card .ico svg { width: 22px; height: 22px; }
.app-card .nm { font-family: var(--alt-font-display); font-weight: 900; font-size: 14px; letter-spacing: 0.04em; }
.app-card .ro { font-family: var(--alt-font-body); font-size: 11px; color: var(--alt-text-muted); margin-top: 1px; }
.app-card .badge {
  font-family: var(--alt-font-label);
  font-size: 8px; font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 3px 6px;
  border-radius: 2px;
}
.app-card .badge.live  { background: rgba(0,212,170,0.10); color: var(--alt-teal); }
.app-card .badge.mvp   { background: rgba(0,209,255,0.10); color: var(--alt-cyan); }
.app-card .badge.beta  { background: rgba(245,158,11,0.10); color: var(--alt-amber); }
.app-card .badge.spec  { background: rgba(177,140,255,0.12); color: var(--alt-purple); }

.app-card.atlas  { border-left: 2px solid var(--alt-cyan); }
.app-card.forge  { border-left: 2px solid var(--alt-forge); }
.app-card.needle { border-left: 2px solid var(--alt-purple); }
.app-card.scout  { border-left: 2px solid var(--alt-scout); }
.app-card.beacon { border-left: 2px solid var(--alt-purple); }

.spine-core {
  background: linear-gradient(180deg, rgba(0,209,255,0.08), rgba(0,209,255,0.02)), var(--alt-surface-mid);
  border: 1px solid rgba(0,209,255,0.35);
  border-radius: 3px;
  padding: 24px 20px;
  display: flex; flex-direction: column; align-items: center; text-align: center;
  position: relative;
  box-shadow: 0 0 40px rgba(0,209,255,0.10), inset 0 1px 0 rgba(255,255,255,0.06);
  height: 100%;
  justify-content: center;
}
.spine-core .ko {
  font-family: var(--alt-font-label);
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.20em; text-transform: uppercase;
  color: var(--alt-cyan);
  margin-bottom: 12px;
}
.spine-core h3 {
  font-family: var(--alt-font-display);
  font-weight: 900;
  font-size: 40px;
  letter-spacing: -0.02em;
  color: var(--alt-text-primary);
  margin: 0;
}
.spine-core .sub {
  font-family: var(--alt-font-body);
  font-size: 12px;
  color: var(--alt-text-secondary);
  margin-top: 8px;
  max-width: 280px;
}
.spine-core .ports {
  margin-top: 18px;
  display: grid;
  grid-template-columns: repeat(2, auto);
  gap: 4px 18px;
  font-family: var(--alt-font-mono);
  font-size: 10px;
  color: var(--alt-text-muted);
}
.spine-core .ports span { display: inline-flex; align-items: center; gap: 6px; }
.spine-core .ports span::before { content: ""; width: 4px; height: 4px; background: var(--alt-cyan); border-radius: 50%; }

/* Connector overlay — sits behind the cards, terminates AT the spine edge */
.arch-connectors { position: absolute; inset: 0; pointer-events: none; z-index: 0; }
.arch-connectors svg { width: 100%; height: 100%; display: block; }
.arch-connectors .stub { stroke: rgba(0,209,255,0.20); stroke-width: 1; fill: none; }
.arch-connectors .stub.live { stroke: var(--alt-cyan); stroke-dasharray: 0; opacity: 0.55; }
.arch-connectors .stub.dashed { stroke-dasharray: 3 4; }
.arch-connectors .node { fill: var(--alt-cyan); }
.arch-connectors .bus { stroke: rgba(0,209,255,0.30); stroke-width: 1; fill: none; }

/* ============================================================
   PRODUCTS
   ============================================================ */
.products { padding: 64px 0 80px; border-top: 1px solid var(--alt-border-weak); }
.products .head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; margin-bottom: 40px; }
.products .head .lede { max-width: 460px; font-size: 14px; color: var(--alt-text-secondary); }
.products .product-links { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.products .product-links span {
  border: 1px solid var(--alt-border-weak);
  background: var(--alt-surface-mid);
  border-radius: 2px;
  padding: 5px 8px;
  font-family: var(--alt-font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.products .product-links a { color: var(--alt-text-secondary); text-decoration: none; }
.products .product-links a:hover { color: var(--alt-cyan); }

.prod-grid { display: grid; grid-template-columns: 1.8fr 1fr; gap: 16px; }
@media (max-width: 1000px) { .prod-grid { grid-template-columns: 1fr; } }

.prod-card {
  position: relative;
  background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.01));
  border: 1px solid var(--alt-border-weak);
  border-radius: 4px;
  overflow: hidden;
  display: flex; flex-direction: column;
  min-height: 360px;
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  transition: transform 220ms var(--alt-ease-out), border-color 220ms var(--alt-ease-out), box-shadow 220ms var(--alt-ease-out);
}
.prod-card:hover {
  transform: translateY(-4px);
  border-color: var(--alt-border-medium);
  box-shadow: 0 20px 44px rgba(0, 0, 0, 0.35);
}
.prod-card .meta {
  display: flex; align-items: center; gap: 12px;
  padding: 18px 20px 14px;
  border-bottom: 1px solid var(--alt-border-weak);
}
.prod-card .meta .ic {
  width: 30px; height: 30px;
  border-radius: 2px;
  background: var(--alt-surface-low);
  border: 1px solid var(--alt-border-weak);
  display: flex; align-items: center; justify-content: center;
}
.prod-card .meta .ic svg,
.prod-card .meta .ic img { width: 20px; height: 20px; object-fit: contain; }
.prod-card .meta .nm { font-family: var(--alt-font-display); font-weight: 900; font-size: 16px; letter-spacing: 0.04em; }
.prod-card .meta .ro { font-family: var(--alt-font-body); font-size: 11px; color: var(--alt-text-muted); }
.prod-card .meta .badge {
  margin-left: auto;
  font-family: var(--alt-font-label);
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  padding: 4px 8px; border-radius: 2px;
}
.prod-card .body {
  padding: 24px 20px;
  flex: 1;
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 24px;
  align-items: center;
}
.prod-card .body.solo { grid-template-columns: 1fr; }
.prod-card .body .txt h3 {
  font-family: var(--alt-font-display);
  font-weight: 900;
  font-size: 22px;
  letter-spacing: -0.015em;
  margin: 0 0 8px;
}
.prod-card .body .txt p {
  font-family: var(--alt-font-body);
  font-size: 13px;
  line-height: 1.5;
  color: var(--alt-text-secondary);
  margin: 0;
}
.prod-card .body .txt .feats {
  margin-top: 16px;
  display: flex; flex-direction: column; gap: 8px;
}
.prod-card .body .txt .feats span {
  font-family: var(--alt-font-mono);
  font-size: 10px;
  color: var(--alt-text-muted);
  display: inline-flex; align-items: center; gap: 8px;
}
.prod-card .body .txt .feats span::before { content: "→"; color: var(--alt-cyan); }

.prod-card .body .vis {
  position: relative;
  background: var(--alt-surface-low);
  border: 1px solid var(--alt-border-weak);
  border-radius: 3px;
  overflow: hidden;
  aspect-ratio: 16/10;
}

/* ============================================================
   MOCK UIs (Atlas/Forge/Scout/Beacon mini)
   ============================================================ */
.mock { width: 100%; height: 100%; display: flex; flex-direction: column; font-family: var(--alt-font-body); }

/* ATLAS mock — detailed */
.mock-atlas { background: var(--alt-surface-base); }
.mock-atlas .mt {
  height: 22px;
  background: #15171a;
  border-bottom: 1px solid var(--alt-border-weak);
  display: flex; align-items: center; gap: 6px; padding: 0 8px;
  font-family: var(--alt-font-mono);
  font-size: 8px;
  color: var(--alt-text-muted);
}
.mock-atlas .mt .dot { width: 5px; height: 5px; border-radius: 50%; background: var(--alt-teal); box-shadow: 0 0 4px var(--alt-teal); }
.mock-atlas .mt .crumb { color: var(--alt-text-secondary); }
.mock-atlas .mt .crumb .s { color: var(--alt-text-muted); margin: 0 4px; }
.mock-atlas .mt .rt { margin-left: auto; color: var(--alt-cyan); }
.mock-atlas .ms { flex: 1; display: grid; grid-template-columns: 78px 1fr; }
.mock-atlas .mn { border-right: 1px solid var(--alt-border-weak); background: #15171a; padding: 6px 0; display: flex; flex-direction: column; gap: 1px; }
.mock-atlas .mn .it {
  font-family: var(--alt-font-label);
  font-size: 7px;
  letter-spacing: 0.14em;
  font-weight: 700;
  color: var(--alt-text-muted);
  padding: 5px 8px;
  border-left: 2px solid transparent;
  display: flex; justify-content: space-between; align-items: center;
  text-transform: uppercase;
}
.mock-atlas .mn .it.active { color: var(--alt-text-primary); border-left-color: var(--alt-cyan); background: rgba(0,209,255,0.06); }
.mock-atlas .mn .it .b { font-family: var(--alt-font-mono); color: var(--alt-text-muted); letter-spacing: 0; font-size: 6.5px; }
.mock-atlas .mn .it.active .b { color: var(--alt-cyan); }
.mock-atlas .mn .sep { height: 1px; background: var(--alt-border-weak); margin: 4px 8px; }
.mock-atlas .mc { padding: 8px; display: flex; flex-direction: column; gap: 6px; overflow: hidden; }
.mock-atlas .mc .ttl { font-family: var(--alt-font-display); font-weight: 900; font-size: 11px; letter-spacing: -0.01em; display: flex; justify-content: space-between; align-items: center; }
.mock-atlas .mc .ttl .x { font-family: var(--alt-font-label); font-size: 6px; font-weight: 700; letter-spacing: 0.14em; color: var(--alt-cyan); }
.mock-atlas .mc .row4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 4px; }
.mock-atlas .mc .k {
  background: var(--alt-surface-mid);
  border: 1px solid var(--alt-border-weak);
  border-radius: 2px;
  padding: 5px 6px;
  position: relative;
}
.mock-atlas .mc .k .l { font-family: var(--alt-font-label); font-size: 5.5px; font-weight: 700; letter-spacing: 0.14em; color: var(--alt-text-muted); text-transform: uppercase; }
.mock-atlas .mc .k .v { font-family: var(--alt-font-display); font-weight: 900; font-size: 13px; line-height: 1.1; margin-top: 2px; }
.mock-atlas .mc .k .d { font-family: var(--alt-font-mono); font-size: 5.5px; color: var(--alt-text-muted); }
.mock-atlas .mc .k .v.cy { color: var(--alt-cyan); }
.mock-atlas .mc .k .v.am { color: var(--alt-amber); }
.mock-atlas .mc .k .v.te { color: var(--alt-teal); }
.mock-atlas .mc .k .v.rd { color: var(--alt-red); }
.mock-atlas .mc .grid2 { display: grid; grid-template-columns: 1.4fr 1fr; gap: 4px; flex: 1; min-height: 0; }
.mock-atlas .mc .ch {
  background: var(--alt-surface-mid);
  border: 1px solid var(--alt-border-weak);
  border-radius: 2px;
  padding: 5px;
  display: flex; flex-direction: column;
  min-height: 0;
}
.mock-atlas .mc .ch .lh { display: flex; justify-content: space-between; align-items: center; }
.mock-atlas .mc .ch .lh .h { font-family: var(--alt-font-label); font-size: 5.5px; font-weight: 700; letter-spacing: 0.14em; color: var(--alt-text-muted); text-transform: uppercase; }
.mock-atlas .mc .ch .lh .v { font-family: var(--alt-font-mono); font-size: 6.5px; color: var(--alt-cyan); }
.mock-atlas .mc .ch .gv { flex: 1; margin-top: 3px; min-height: 0; position: relative; }
.mock-atlas .mc .ch .gv svg { position: absolute; inset: 0; width: 100%; height: 100%; }
.mock-atlas .mc .iss {
  background: var(--alt-surface-mid);
  border: 1px solid var(--alt-border-weak);
  border-radius: 2px;
  padding: 4px 5px;
  display: flex; flex-direction: column;
  min-height: 0;
  overflow: hidden;
}
.mock-atlas .mc .iss .lh { display: flex; justify-content: space-between; }
.mock-atlas .mc .iss .lh .h { font-family: var(--alt-font-label); font-size: 5.5px; font-weight: 700; letter-spacing: 0.14em; color: var(--alt-text-muted); text-transform: uppercase; }
.mock-atlas .mc .iss .lh .ct { font-family: var(--alt-font-mono); font-size: 6.5px; color: var(--alt-amber); }
.mock-atlas .mc .iss ul { list-style: none; padding: 0; margin: 4px 0 0; display: flex; flex-direction: column; gap: 2px; flex: 1; }
.mock-atlas .mc .iss li { display: grid; grid-template-columns: 4px 1fr auto; gap: 4px; align-items: center; font-family: var(--alt-font-mono); font-size: 6px; color: var(--alt-text-secondary); }
.mock-atlas .mc .iss li .s { width: 4px; height: 4px; border-radius: 50%; }
.mock-atlas .mc .iss li .s.h { background: var(--alt-red); }
.mock-atlas .mc .iss li .s.m { background: var(--alt-amber); }
.mock-atlas .mc .iss li .s.l { background: var(--alt-cyan); }
.mock-atlas .mc .iss li .t { color: var(--alt-text-muted); }

/* Scout phone mock */
.mock-scout {
  align-items: center; justify-content: center;
  background: radial-gradient(circle at 50% 30%, rgba(0,153,190,0.12), transparent 60%);
}
.scout-phone {
  width: 130px; height: 240px;
  border-radius: 16px;
  background: #f5f7fa;
  border: 6px solid #1a1d20;
  overflow: hidden;
  position: relative;
  display: flex; flex-direction: column;
  font-family: var(--alt-font-body);
  color: #1a1d20;
  box-shadow: 0 20px 40px rgba(0,0,0,0.4);
}
.scout-phone .sb { height: 14px; display: flex; justify-content: space-between; align-items: center; padding: 0 10px; font-size: 6px; font-family: var(--alt-font-mono); }
.scout-phone .hd { padding: 6px 10px; border-bottom: 1px solid #e2e6ea; display: flex; justify-content: space-between; align-items: center; }
.scout-phone .hd .t { font-family: var(--alt-font-display); font-weight: 700; font-size: 9px; letter-spacing: 0.04em; }
.scout-phone .hd .a { width: 14px; height: 14px; border-radius: 2px; background: #0099BE; }
.scout-phone .lst { flex: 1; padding: 4px 8px; display: flex; flex-direction: column; gap: 4px; }
.scout-phone .ev { padding: 5px 6px; border-radius: 2px; background: #fff; border: 1px solid #e2e6ea; }
.scout-phone .ev .l1 { font-size: 7px; font-weight: 600; }
.scout-phone .ev .l2 { font-size: 6px; color: #859399; font-family: var(--alt-font-mono); margin-top: 1px; }
.scout-phone .ev.high { border-left: 2px solid #EF4444; }
.scout-phone .ev.med { border-left: 2px solid #F59E0B; }
.scout-phone .tb { height: 28px; border-top: 1px solid #e2e6ea; display: grid; grid-template-columns: repeat(4,1fr); align-items: center; }
.scout-phone .tb .t { display: flex; flex-direction: column; align-items: center; gap: 1px; font-size: 5px; font-weight: 700; letter-spacing: 0.12em; color: #859399; text-transform: uppercase; }
.scout-phone .tb .t::before { content:""; width: 8px; height: 8px; background: currentColor; mask: radial-gradient(circle, currentColor 40%, transparent 50%); }
.scout-phone .tb .t.a { color: #0099BE; }

/* Beacon kiosk mock */
.mock-beacon { background: linear-gradient(180deg, #0e0f12 0%, #14161a 100%); padding: 6px; }
.bk { width: 100%; height: 100%; display: grid; grid-template-rows: 14px 1fr 24px; gap: 4px; color: var(--alt-text-primary); }
.bk .tt { display: flex; align-items: center; justify-content: space-between; padding: 0 4px; font-family: var(--alt-font-mono); font-size: 6px; color: var(--alt-text-muted); }
.bk .tt .nm { color: var(--alt-purple); letter-spacing: 0.18em; font-weight: 700; font-family: var(--alt-font-label); }
.bk .gd { display: grid; grid-template-columns: 1.4fr 1fr; gap: 4px; }
.bk .pn { background: var(--alt-surface-mid); border: 1px solid rgba(177,140,255,0.18); border-radius: 2px; padding: 6px; display: flex; flex-direction: column; }
.bk .pn .lbl { font-family: var(--alt-font-label); font-size: 6px; font-weight: 700; letter-spacing: 0.16em; color: var(--alt-purple); text-transform: uppercase; }
.bk .pn .vv { font-family: var(--alt-font-display); font-weight: 900; font-size: 18px; line-height: 1; margin-top: 4px; }
.bk .pn .ll { display: flex; flex-direction: column; gap: 2px; margin-top: 4px; font-family: var(--alt-font-mono); font-size: 6px; color: var(--alt-text-secondary); }
.bk .bb { display: flex; justify-content: space-between; padding: 0 4px; align-items: center; font-family: var(--alt-font-mono); font-size: 6px; color: var(--alt-text-muted); }

/* Forge desktop mock */
.mock-forge .mt {
  height: 18px;
  display: flex; align-items: center; gap: 6px;
  background: #14161a;
  padding: 0 8px;
  border-bottom: 1px solid var(--alt-border-weak);
}
.mock-forge .mt .tl { display: flex; gap: 4px; }
.mock-forge .mt .tl span { width: 6px; height: 6px; border-radius: 50%; background: #444; }
.mock-forge .mt .tl span:nth-child(1) { background: #EF4444; }
.mock-forge .mt .tl span:nth-child(2) { background: #F59E0B; }
.mock-forge .mt .tl span:nth-child(3) { background: #00D4AA; }
.mock-forge .mt .pt { font-family: var(--alt-font-mono); font-size: 7px; color: var(--alt-text-muted); margin-left: auto; }
.mock-forge .mb { flex: 1; display: grid; grid-template-columns: 80px 1fr; }
.mock-forge .tree { border-right: 1px solid var(--alt-border-weak); background: #14161a; padding: 6px; font-family: var(--alt-font-mono); font-size: 7px; color: var(--alt-text-muted); display: flex; flex-direction: column; gap: 3px; }
.mock-forge .tree .l { display: flex; align-items: center; gap: 4px; }
.mock-forge .tree .l.ok::before { content:"✓"; color: var(--alt-teal); }
.mock-forge .tree .l.run::before { content:"●"; color: var(--alt-forge); }
.mock-forge .tree .l.pn::before { content:"○"; color: var(--alt-text-muted); }
.mock-forge .pp { padding: 8px; display: flex; flex-direction: column; gap: 6px; }
.mock-forge .pp .pl {
  background: var(--alt-surface-mid);
  border: 1px solid var(--alt-border-weak);
  border-radius: 2px;
  padding: 6px 8px;
}
.mock-forge .pp .pl .h { display: flex; justify-content: space-between; font-family: var(--alt-font-label); font-size: 7px; font-weight: 700; letter-spacing: 0.14em; color: var(--alt-text-muted); text-transform: uppercase; }
.mock-forge .pp .pl .h .x { color: var(--alt-forge); font-family: var(--alt-font-mono); letter-spacing: 0; }
.mock-forge .pp .pl .bar { margin-top: 4px; height: 4px; background: rgba(255,255,255,0.06); border-radius: 1px; overflow: hidden; }
.mock-forge .pp .pl .bar > div { height: 100%; background: var(--alt-forge); }

/* ============================================================
   PILLARS (Why)
   ============================================================ */
.pillars { padding: 64px 0 80px; border-top: 1px solid var(--alt-border-weak); }
.pillars .head { margin-bottom: 48px; max-width: 760px; }
.pillars .head .lede { color: var(--alt-text-secondary); font-size: 15px; max-width: 600px; margin-top: 16px; }
.pillar-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid var(--alt-border-medium); }
@media (max-width: 1000px) { .pillar-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .pillar-grid { grid-template-columns: 1fr; } }
.pillar {
  padding: 24px 24px 28px;
  border-right: 1px solid var(--alt-border-weak);
  border-bottom: 1px solid var(--alt-border-weak);
  position: relative;
}
.pillar:last-child { border-right: none; }
.pillar .ix { font-family: var(--alt-font-mono); font-size: 10px; color: var(--alt-cyan); letter-spacing: 0.08em; }
.pillar .ti { font-family: var(--alt-font-display); font-weight: 900; font-size: 18px; letter-spacing: -0.01em; margin-top: 16px; }
.pillar p { font-family: var(--alt-font-body); font-size: 13px; color: var(--alt-text-secondary); margin-top: 10px; line-height: 1.55; }
.pillar .ev {
  margin-top: 16px;
  font-family: var(--alt-font-mono);
  font-size: 10px;
  color: var(--alt-text-muted);
}
.pillar .ev .v { color: var(--alt-cyan); }

/* ============================================================
   ROADMAP
   ============================================================ */
.roadmap { padding: 64px 0 80px; border-top: 1px solid var(--alt-border-weak); }
.roadmap .head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; margin-bottom: 40px; }
.roadmap .head .lede { color: var(--alt-text-secondary); font-size: 14px; max-width: 460px; }

.phase {
  display: grid;
  grid-template-columns: 80px 200px 1fr 140px;
  gap: 24px;
  padding: 24px 0;
  border-top: 1px solid var(--alt-border-weak);
  align-items: start;
  transition: background 180ms var(--alt-ease-out);
}
.phase:hover { background: rgba(255,255,255,0.02); }
.phase:last-child { border-bottom: 1px solid var(--alt-border-weak); }
.phase .ph-num {
  font-family: var(--alt-font-mono);
  font-size: 10px;
  color: var(--alt-text-muted);
  letter-spacing: 0.12em;
}
.phase .ph-stat {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--alt-font-label);
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  padding: 6px 10px;
  border-radius: 2px;
  align-self: start;
}
.phase .ph-stat.done { background: rgba(0,212,170,0.10); color: var(--alt-teal); border: 1px solid rgba(0,212,170,0.30); }
.phase .ph-stat.live { background: rgba(0,209,255,0.10); color: var(--alt-cyan); border: 1px solid rgba(0,209,255,0.30); }
.phase .ph-stat.next { background: rgba(245,158,11,0.10); color: var(--alt-amber); border: 1px solid rgba(245,158,11,0.30); }
.phase .ph-stat.plan { background: rgba(133,147,153,0.10); color: var(--alt-text-muted); border: 1px solid var(--alt-border-medium); }
.phase .ph-stat .pd { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.phase .ph-stat .pd.pulse { animation: pulse 2s ease-in-out infinite; }
.phase .ph-ti { font-family: var(--alt-font-display); font-weight: 900; font-size: 22px; letter-spacing: -0.015em; }
.phase .ph-bd { font-family: var(--alt-font-body); font-size: 13px; color: var(--alt-text-secondary); margin-top: 8px; line-height: 1.55; max-width: 540px; }
.phase .ph-deli { margin-top: 14px; display: flex; flex-direction: column; gap: 6px; }
.phase .ph-deli span { font-family: var(--alt-font-mono); font-size: 11px; color: var(--alt-text-muted); display: inline-flex; align-items: center; gap: 8px; }
.phase .ph-deli span::before { content: "→"; color: var(--alt-cyan); }
.phase .ph-eta {
  font-family: var(--alt-font-mono);
  font-size: 11px;
  color: var(--alt-text-muted);
  text-align: right;
}
.phase .ph-eta .lb { font-family: var(--alt-font-label); font-size: 9px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; }
.phase .ph-eta .v { color: var(--alt-text-primary); margin-top: 4px; }

@media (max-width: 900px) {
  .phase { grid-template-columns: 1fr; gap: 12px; }
  .phase .ph-eta { text-align: left; }
}

/* ============================================================
   CTA
   ============================================================ */
.cta {
  border-top: 1px solid var(--alt-border-medium);
  background:
    radial-gradient(ellipse at 70% 100%, rgba(0,209,255,0.08), transparent 60%),
    linear-gradient(180deg, var(--alt-surface-base), #0c0e10);
  padding: 96px 0 96px;
}
.cta-inner {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 64px;
  align-items: center;
}
@media (max-width: 900px) { .cta-inner { grid-template-columns: 1fr; } }
.cta h2 { font-size: clamp(40px, 5.4vw, 76px); }
.cta .lede { color: var(--alt-text-secondary); font-size: 15px; margin-top: 24px; max-width: 480px; line-height: 1.55; }
.cta .row { margin-top: 32px; display: flex; gap: 12px; flex-wrap: wrap; }
.cta .side {
  background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.01));
  border: 1px solid var(--alt-border-medium);
  border-radius: 3px;
  padding: 24px;
  position: relative;
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
}
.cta .side .ko { font-family: var(--alt-font-label); font-size: 10px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: var(--alt-cyan); }
.cta .side h3 { font-family: var(--alt-font-display); font-weight: 900; font-size: 22px; letter-spacing: -0.015em; margin: 14px 0 0; }
.cta .side .feats { margin-top: 16px; display: flex; flex-direction: column; gap: 10px; }
.cta .side .feats span { font-family: var(--alt-font-mono); font-size: 12px; color: var(--alt-text-secondary); display: inline-flex; gap: 10px; }
.cta .side .feats span::before { content: "→"; color: var(--alt-cyan); }
.cta .side .term {
  margin-top: 20px;
  padding: 14px;
  background: #0a0b0d;
  border: 1px solid var(--alt-border-weak);
  border-radius: 2px;
  font-family: var(--alt-font-mono);
  font-size: 11px;
  line-height: 1.7;
}
.cta .side .term .p { color: var(--alt-cyan); }
.cta .side .term .c { color: var(--alt-text-primary); }
.cta .side .term .o { color: var(--alt-text-muted); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer {
  border-top: 1px solid var(--alt-border-weak);
  background: #0c0e10;
  padding: 48px 0 32px;
  font-family: var(--alt-font-body);
  font-size: 12px;
  color: var(--alt-text-muted);
}
.footer .grid { display: grid; grid-template-columns: 1.4fr repeat(4, 1fr); gap: 32px; }
@media (max-width: 900px) { .footer .grid { grid-template-columns: 1fr 1fr; } }
.footer .brand-col svg { width: 22px; height: 22px; color: var(--alt-cyan); }
.footer .brand-col .wm { font-family: var(--alt-font-display); font-weight: 900; font-size: 18px; letter-spacing: 0.04em; color: var(--alt-text-primary); margin-top: 14px; }
.footer .brand-col p { font-size: 12px; margin-top: 12px; max-width: 280px; }
.footer h4 {
  font-family: var(--alt-font-label);
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--alt-text-primary);
  margin: 0 0 14px;
}
.footer ul { margin: 0; padding: 0; list-style: none; display: flex; flex-direction: column; gap: 8px; }
.footer ul a { color: var(--alt-text-muted); }
.footer ul a:hover { color: var(--alt-text-primary); }
.footer .bottom {
  margin-top: 40px;
  padding-top: 20px;
  border-top: 1px solid var(--alt-border-weak);
  display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap;
  font-family: var(--alt-font-mono);
  font-size: 11px;
}

/* ============================================================
   APP-COLOR HELPERS
   ============================================================ */
.c-atlas  { color: var(--alt-cyan); }
.c-forge  { color: var(--alt-forge); }
.c-needle { color: var(--alt-purple); }
.c-scout  { color: var(--alt-scout); }
.c-beacon { color: var(--alt-purple); }
.c-spine  { color: var(--alt-text-primary); }

/* ============================================================
   MOTION REVEAL
   ============================================================ */
.js-enhanced .will-reveal {
  opacity: 0;
  transform: translate3d(0, 16px, 0);
  transition: opacity 420ms var(--alt-ease-out), transform 520ms var(--alt-ease-out);
}
.js-enhanced .will-reveal.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}
@media (prefers-reduced-motion: reduce) {
  .hero-orb { animation: none; }
  .js-enhanced .will-reveal,
  .js-enhanced .will-reveal.is-visible {
    transition: none;
    opacity: 1;
    transform: none;
  }
}

/* ============================================================
   LIGHT THEME
   ============================================================ */
html[data-theme="light"] {
  --alt-surface-base: #eef4fb;
  --alt-surface-low: #dde7f4;
  --alt-surface-mid: #ffffff;
  --alt-surface-high: #f3f8ff;
  --alt-surface-highest: #e8f0fc;
  --alt-text-primary: #0f1c2b;
  --alt-text-secondary: #20384f;
  --alt-text-muted: #49637c;
  --alt-text-disabled: #8fa4b7;
  --alt-border-weak: rgba(19, 32, 45, 0.14);
  --alt-border-medium: rgba(19, 32, 45, 0.22);
  --alt-border-strong: rgba(19, 32, 45, 0.30);
  --alt-cyan: #0d8cff;
  --alt-cyan-hover: #056fd1;
  --alt-cyan-text: #ffffff;
  --alt-teal: #008f74;
  --alt-amber: #c77f00;
  --alt-red: #c43131;
}

html[data-theme="light"] body {
  background: linear-gradient(180deg, #f4f8ff, #eaf2fc);
  background-image:
    linear-gradient(rgba(8, 22, 36, 0.028) 1px, transparent 1px),
    linear-gradient(90deg, rgba(8, 22, 36, 0.028) 1px, transparent 1px);
  background-size: 30px 30px;
}
html[data-theme="light"] .status-strip {
  background: rgba(255,255,255,0.96);
  border-bottom-color: var(--alt-border-medium);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
}
html[data-theme="light"] .status-strip .item,
html[data-theme="light"] .status-strip .item strong { color: var(--alt-text-secondary); }
html[data-theme="light"] .topnav {
  background: rgba(255,255,255,0.9);
  border-bottom-color: var(--alt-border-medium);
}
html[data-theme="light"] .hero::before {
  background: radial-gradient(ellipse at 15% 10%, rgba(13,140,255,0.08), transparent 50%);
}
html[data-theme="light"] .hero-orb.orb-a {
  background: radial-gradient(circle, rgba(13,140,255,0.14), rgba(13,140,255,0.02) 65%, transparent 76%);
}
html[data-theme="light"] .hero-orb.orb-b {
  background: radial-gradient(circle, rgba(177,140,255,0.14), rgba(177,140,255,0.02) 62%, transparent 74%);
}
html[data-theme="light"] .hero-panel,
html[data-theme="light"] .prod-card,
html[data-theme="light"] .cta .side {
  box-shadow: 0 12px 26px rgba(21, 48, 82, 0.09);
}
html[data-theme="light"] .cta {
  background:
    radial-gradient(ellipse at 70% 100%, rgba(13,140,255,0.08), transparent 62%),
    linear-gradient(180deg, #eef4fb, #e4edf8);
  border-top-color: var(--alt-border-medium);
}
html[data-theme="light"] .footer {
  background: #dfe9f6;
  border-top-color: var(--alt-border-medium);
}
html[data-theme="light"] .footer h4,
html[data-theme="light"] .footer .brand-col .wm,
html[data-theme="light"] .footer ul a:hover,
html[data-theme="light"] .footer .bottom { color: var(--alt-text-primary); }
html[data-theme="light"] .footer ul a,
html[data-theme="light"] .footer .brand-col p { color: var(--alt-text-secondary); }
html[data-theme="light"] .footer .brand-col svg { color: var(--alt-cyan); }
html[data-theme="light"] .hp-list .row .ti,
html[data-theme="light"] .hp-nav .item.active,
html[data-theme="light"] .hp-chart .ch-head .x {
  color: #0d4f88;
}
html[data-theme="light"] .btn-theme {
  background: rgba(19,32,45,0.05);
}
