/**
 * NADIR Calibration Lab — layout and panel chrome
 */

:root {
  --cl-topbar-h: 56px;
  --cl-footer-h: 40px;
  --cl-gap: 14px;
  --cl-panel-radius: 14px;
  --cl-mono: "IBM Plex Mono", ui-monospace, monospace;
  --cl-sans: Manrope, Inter, system-ui, sans-serif;
}

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

.cl-body {
  margin: 0;
  min-height: 100vh;
  font-family: var(--cl-sans);
  font-size: 14px;
  line-height: 1.5;
  color: var(--text2);
  background:
    radial-gradient(ellipse 60% 40% at 100% 0%, var(--nadir-magma-glow-soft), transparent 50%),
    linear-gradient(180deg, var(--nadir-charcoal-1000) 0%, var(--bg) 100%);
  -webkit-font-smoothing: antialiased;
}

.cl-grid-bg.bg-grid {
  position: fixed;
  inset: 0;
  z-index: 0;
  opacity: 0.25;
}

#cl-root {
  position: relative;
  z-index: 1;
  min-height: 100vh;
}

.cl-demo-banner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 16px;
  padding: 10px 18px;
  background: linear-gradient(90deg, rgba(249, 115, 22, 0.18), rgba(91, 156, 246, 0.12));
  border-bottom: 1px solid rgba(249, 115, 22, 0.35);
  font-size: 13px;
  color: var(--text1, #e8edf2);
}

.cl-demo-banner strong {
  color: #f97316;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  font-size: 11px;
}

.cl-demo-banner span {
  color: var(--text2, #b8c4d0);
}

.cl-app {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* ── Top bar ── */
.cl-topbar {
  height: var(--cl-topbar-h);
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 0 20px;
  border-bottom: 1px solid var(--border-subtle);
  background: rgba(10, 11, 13, 0.92);
  backdrop-filter: blur(12px);
  position: sticky;
  top: 0;
  z-index: 20;
}

.cl-brand {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  color: var(--text);
  font-weight: 700;
  letter-spacing: -0.02em;
}

.cl-brand em {
  font-style: normal;
  font-weight: 500;
  color: var(--nadir-magma-400);
  font-size: 13px;
}

.cl-topbar-meta {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: var(--text3);
  font-family: var(--cl-mono);
}

.cl-build-tag {
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid var(--border-subtle);
  background: rgba(255, 255, 255, 0.03);
}

.cl-api-status.live {
  color: var(--ok);
}

.cl-sep { opacity: 0.4; }

.cl-topbar-nav {
  display: flex;
  gap: 12px;
}

.cl-topbar-nav a {
  color: var(--text3);
  text-decoration: none;
  font-size: 13px;
}

.cl-topbar-nav a:hover { color: var(--text); }

/* ── Intro splash ── */
.cl-intro {
  margin: 24px auto;
  max-width: 920px;
  padding: 28px 32px;
  border: 1px solid var(--border-subtle);
  border-radius: var(--cl-panel-radius);
  background: linear-gradient(145deg, rgba(24, 28, 35, 0.95), rgba(15, 17, 21, 0.98));
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.cl-intro[hidden] { display: none !important; }

.cl-eyebrow {
  margin: 0 0 8px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--nadir-magma-400);
  font-weight: 600;
}

.cl-intro h1 {
  margin: 0 0 10px;
  font-size: clamp(22px, 3vw, 32px);
  color: var(--text);
  letter-spacing: -0.03em;
}

.cl-lead {
  margin: 0;
  max-width: 56ch;
  color: var(--text3);
}

/* ── Main grid ── */
.cl-main {
  flex: 1;
  display: grid;
  grid-template-columns: minmax(260px, 300px) minmax(380px, 1fr) minmax(280px, 320px);
  gap: var(--cl-gap);
  padding: 16px 20px 12px;
  max-width: 1680px;
  width: 100%;
  margin: 0 auto;
}

.cl-main[hidden] { display: none !important; }

.cl-column {
  display: flex;
  flex-direction: column;
  gap: var(--cl-gap);
  min-width: 0;
}

/* ── Panels ── */
.cl-panel {
  border: 1px solid var(--border-subtle);
  border-radius: var(--cl-panel-radius);
  background: linear-gradient(165deg, rgba(24, 28, 35, 0.88), rgba(15, 17, 21, 0.95));
  overflow: hidden;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.cl-panel-head {
  padding: 14px 16px 10px;
  border-bottom: 1px solid var(--border-subtle);
}

.cl-panel-head h2 {
  margin: 0;
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
}

.cl-panel-head p {
  margin: 4px 0 0;
  font-size: 12px;
  color: var(--text3);
}

.cl-panel-body {
  padding: 14px 16px 16px;
}

.cl-panel-scene .cl-panel-body {
  padding: 0;
}

.cl-placeholder {
  color: var(--text3);
  font-size: 13px;
}

.cl-placeholder p { margin: 0; }

#cl-scene-canvas {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  background: #0a0b0d;
}

.cl-canvas-hint {
  margin: 0;
  padding: 10px 16px 14px;
  font-size: 12px;
  color: var(--text3);
  border-top: 1px solid var(--border-subtle);
}

/* ── Sensor grid ── */
.cl-sensor-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}

.cl-sensor-grid-live {
  grid-template-columns: repeat(2, 1fr);
}

.cl-sensor-alert {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 12px 14px;
  margin-bottom: 12px;
  border-radius: 10px;
  border: 1px solid rgba(255, 59, 48, 0.45);
  background: rgba(255, 59, 48, 0.1);
  color: #ffb4ae;
}

.cl-sensor-alert-icon { font-size: 18px; line-height: 1; }
.cl-sensor-alert p { margin: 4px 0 0; font-size: 12px; color: var(--text3); }

.cl-sensor-tier-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}

.cl-sensor-health,
.cl-sensor-mahal {
  font-family: var(--cl-mono);
  font-size: 11px;
  color: var(--text3);
}

.cl-sensor-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2px;
}

.cl-sensor-sub {
  margin: 0 0 8px;
  font-size: 10px;
  color: var(--text3);
}

.cl-sensor-value-row {
  display: flex;
  align-items: baseline;
  gap: 4px;
  margin-bottom: 8px;
}

.cl-sensor-baseline-row {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  color: var(--text3);
  margin-bottom: 6px;
}

.cl-sensor-baseline-val {
  font-family: var(--cl-mono);
  color: var(--text2);
}

.cl-sensor-degrade-pct {
  margin-left: auto;
  font-family: var(--cl-mono);
  color: var(--nadir-magma-400);
}

.cl-sensor-bar-track {
  position: relative;
  height: 4px;
  border-radius: 2px;
  background: rgba(255, 255, 255, 0.06);
  margin-bottom: 8px;
  overflow: hidden;
}

.cl-sensor-bar-base {
  position: absolute;
  inset: 0;
}

.cl-sensor-bar-current {
  display: block;
  height: 100%;
  border-radius: 2px;
  background: linear-gradient(90deg, #5b9cf6, #f5a623);
  transition: width 0.15s ease;
}

.cl-sensor-bar-current.critical {
  background: linear-gradient(90deg, #ff3b3b, #ff6b6b);
}

.cl-sensor-spark {
  width: 100%;
  height: 28px;
  display: block;
  border-radius: 4px;
  background: rgba(0, 0, 0, 0.25);
}

.cl-sensor-status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #22c55e;
}

.cl-sensor-status-dot[data-status="caution"] { background: #f5a623; }
.cl-sensor-status-dot[data-status="critical"] { background: #ff3b3b; }

.cl-sensor-card {
  padding: 12px;
  border-radius: 10px;
  border: 1px solid var(--border-subtle);
  background: rgba(0, 0, 0, 0.2);
}

.cl-sensor-label {
  display: block;
  font-size: 11px;
  color: var(--text3);
  margin-bottom: 6px;
}

.cl-sensor-value {
  font-family: var(--cl-mono);
  font-size: 20px;
  font-weight: 600;
  color: var(--text);
}

.cl-sensor-unit {
  font-size: 11px;
  color: var(--text3);
  margin-left: 4px;
}

/* ── Algorithm list placeholder ── */
.cl-algo-list {
  margin: 0;
  padding-left: 18px;
  color: var(--text3);
}

.cl-algo-list li { margin-bottom: 6px; }

/* ── Vehicle selector ── */
.cl-vehicle-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  margin-bottom: 14px;
}

.cl-vehicle-card {
  appearance: none;
  border: 1px solid var(--border-subtle);
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.25);
  padding: 10px;
  text-align: left;
  cursor: pointer;
  color: var(--text2);
  font: inherit;
  transition: border-color 0.15s, background 0.15s;
}

.cl-vehicle-card:hover {
  border-color: rgba(249, 115, 22, 0.35);
}

.cl-vehicle-card.active {
  border-color: var(--nadir-magma-400);
  background: rgba(249, 115, 22, 0.08);
  box-shadow: inset 0 0 0 1px rgba(249, 115, 22, 0.2);
}

.cl-vehicle-swatch {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--swatch, #5b9cf6);
  margin-bottom: 6px;
}

.cl-vehicle-card-title {
  display: block;
  font-weight: 700;
  color: var(--text);
  font-size: 13px;
}

.cl-vehicle-card-meta,
.cl-vehicle-card-class {
  display: block;
  font-size: 11px;
  color: var(--text3);
}

.cl-vehicle-detail {
  border-top: 1px solid var(--border-subtle);
  padding-top: 12px;
}

.cl-detail-title {
  margin: 0 0 6px;
  font-size: 14px;
  color: var(--text);
}

.cl-detail-summary {
  margin: 0 0 10px;
  font-size: 12px;
  color: var(--text3);
}

.cl-spec-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin: 0 0 10px;
}

.cl-spec-grid dt {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text3);
}

.cl-spec-grid dd {
  margin: 2px 0 0;
  font-family: var(--cl-mono);
  font-size: 12px;
  color: var(--text);
}

.cl-detail-notes {
  margin: 0 0 10px;
  font-size: 12px;
  color: var(--text3);
  line-height: 1.45;
}

.cl-mount-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 11px;
}

.cl-mount-table th,
.cl-mount-table td {
  padding: 6px 4px;
  border-bottom: 1px solid var(--border-subtle);
  text-align: left;
}

.cl-mount-table th {
  color: var(--text3);
  font-weight: 600;
}

.cl-mount-table tr.optional td {
  opacity: 0.65;
}

.cl-mount-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-right: 6px;
  vertical-align: middle;
}

/* ── Damage selector ── */
.cl-damage-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 10px;
}

.cl-damage-card {
  appearance: none;
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  border: 1px solid var(--border-subtle);
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.22);
  padding: 10px 12px;
  text-align: left;
  cursor: pointer;
  color: var(--text2);
  font: inherit;
}

.cl-damage-body {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.cl-damage-card:hover { border-color: rgba(255, 59, 48, 0.35); }
.cl-damage-card.active {
  border-color: var(--red, #ff3b3b);
  background: rgba(255, 59, 48, 0.08);
}

.cl-damage-icon {
  font-size: 18px;
  width: 28px;
  text-align: center;
}

.cl-damage-title {
  font-weight: 700;
  color: var(--text);
  font-size: 13px;
}

.cl-damage-meta {
  display: block;
  font-size: 11px;
  color: var(--text3);
}

.cl-btn-ghost {
  width: 100%;
  margin-bottom: 12px;
  font-size: 12px;
}

.cl-damage-detail {
  border-top: 1px solid var(--border-subtle);
  padding-top: 12px;
  margin-bottom: 12px;
}

.cl-tier-badge {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  margin: 0 0 10px;
}

.cl-tier-badge.tier-nominal { background: rgba(52, 199, 89, 0.15); color: var(--ok); }
.cl-tier-badge.tier-caution { background: rgba(255, 177, 74, 0.15); color: var(--amber); }
.cl-tier-badge.tier-critical { background: rgba(255, 59, 48, 0.15); color: var(--red); }

.cl-drift-readout {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin: 0 0 10px;
}

.cl-drift-readout dt {
  font-size: 10px;
  color: var(--text3);
  text-transform: uppercase;
}

.cl-drift-readout dd {
  margin: 2px 0 0;
  font-family: var(--cl-mono);
  font-size: 12px;
  color: var(--text);
}

.cl-affected {
  font-size: 11px;
  color: var(--text3);
  margin: 8px 0 0;
}

.cl-severity-label {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  color: var(--text3);
}

.cl-severity-label input[type="range"] {
  flex: 1;
  accent-color: var(--nadir-magma-500);
}

.cl-sensor-card.degraded {
  border-color: rgba(255, 59, 48, 0.35);
  background: rgba(255, 59, 48, 0.06);
}

.cl-sensor-card.critical {
  border-color: rgba(255, 59, 48, 0.55);
  box-shadow: inset 0 0 0 1px rgba(255, 59, 48, 0.15);
}

/* ── Buttons ── */
.cl-btn {
  appearance: none;
  border: 1px solid var(--border-subtle);
  background: rgba(255, 255, 255, 0.04);
  color: var(--text);
  border-radius: 10px;
  padding: 10px 16px;
  font: inherit;
  font-weight: 600;
  cursor: pointer;
}

.cl-btn-primary {
  border-color: rgba(249, 115, 22, 0.45);
  background: linear-gradient(180deg, rgba(249, 115, 22, 0.25), rgba(219, 71, 34, 0.18));
  color: #fff;
}

.cl-btn-primary:hover {
  border-color: var(--nadir-magma-400);
}

/* ── Footer ── */
.cl-footer {
  height: var(--cl-footer-h);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 20px;
  border-top: 1px solid var(--border-subtle);
  font-size: 11px;
  color: var(--text3);
  background: rgba(6, 7, 8, 0.85);
}

/* ── Responsive ── */
@media (max-width: 1200px) {
  .cl-main {
    grid-template-columns: 1fr 1fr;
  }
  .cl-column-right {
    grid-column: 1 / -1;
    flex-direction: row;
    flex-wrap: wrap;
  }
  .cl-column-right .cl-panel {
    flex: 1 1 280px;
  }
}

@media (max-width: 768px) {
  .cl-main {
    grid-template-columns: 1fr;
    padding: 12px;
  }
  .cl-intro {
    flex-direction: column;
    align-items: flex-start;
    margin: 12px;
    padding: 20px;
  }
  .cl-topbar-nav { display: none; }
}

/* ── API scoring strip (commit 7) ── */
.cl-api-strip {
  border-top: 1px solid var(--border-subtle);
  padding: 12px 16px 14px;
  background: rgba(0, 0, 0, 0.25);
}

.cl-api-strip-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}

.cl-api-strip-title {
  font-weight: 600;
  color: var(--text);
  font-size: 12px;
}

.cl-api-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  color: var(--text3);
  margin-left: auto;
}

.cl-api-latency {
  font-family: var(--cl-mono);
  font-size: 10px;
  color: var(--text3);
}

.cl-api-compare-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.cl-api-col {
  padding: 10px;
  border-radius: 10px;
  border: 1px solid var(--border-subtle);
  background: rgba(255, 255, 255, 0.02);
}

.cl-api-col-label {
  display: block;
  font-size: 10px;
  color: var(--text3);
  margin-bottom: 6px;
}

.cl-api-metrics {
  display: grid;
  gap: 4px;
  margin: 0;
  font-size: 10px;
}

.cl-api-metrics div {
  display: flex;
  justify-content: space-between;
  gap: 8px;
}

.cl-api-metrics dt { color: var(--text3); margin: 0; }
.cl-api-metrics dd {
  margin: 0;
  font-family: var(--cl-mono);
  color: var(--text2);
}

.cl-api-match-badge {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  background: rgba(255, 255, 255, 0.06);
  color: var(--text3);
}

.cl-api-match-badge[data-status="match"] {
  background: rgba(52, 199, 89, 0.15);
  color: var(--ok);
}

.cl-api-match-badge[data-status="mismatch"] {
  background: rgba(255, 59, 48, 0.12);
  color: var(--red);
}

.cl-api-action,
.cl-api-evidence {
  margin: 8px 0 0;
  font-size: 10px;
  color: var(--text3);
}

/* ── Algorithm panel (commit 8) ── */
.cl-algo-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-bottom: 12px;
}

.cl-algo-count {
  margin-left: auto;
  font-family: var(--cl-mono);
  font-size: 11px;
  color: var(--nadir-magma-400);
}

.cl-algo-list-live {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.cl-algo-card {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--border-subtle);
  background: rgba(0, 0, 0, 0.2);
  cursor: pointer;
  transition: border-color 0.15s;
}

.cl-algo-card.active {
  border-color: rgba(249, 115, 22, 0.45);
  background: rgba(249, 115, 22, 0.06);
}

.cl-algo-card input { margin-top: 4px; accent-color: var(--nadir-magma-500); }

.cl-algo-swatch {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--algo, #5b9cf6);
  margin-top: 6px;
  flex-shrink: 0;
}

.cl-algo-card-body { flex: 1; min-width: 0; }

.cl-algo-name {
  display: block;
  font-weight: 600;
  font-size: 12px;
  color: var(--text);
}

.cl-algo-desc {
  display: block;
  font-size: 10px;
  color: var(--text3);
  margin-top: 2px;
  line-height: 1.4;
}

.cl-algo-tags { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 6px; }

.cl-algo-tag {
  font-size: 9px;
  padding: 2px 6px;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.06);
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.cl-algo-score {
  font-family: var(--cl-mono);
  font-size: 11px;
  font-weight: 600;
  color: var(--text3);
  flex-shrink: 0;
}

.cl-algo-score[data-status="triggered"] { color: var(--red); }
.cl-algo-score[data-status="active"] { color: var(--ok); }

.cl-algo-summary {
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--border-subtle);
}

.cl-algo-summary-text {
  margin: 0;
  font-size: 11px;
  color: var(--text3);
}

/* ── Score overlay (commit 9) ── */
.cl-overlay-tier-row {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}

.cl-overlay-label {
  display: block;
  font-size: 10px;
  color: var(--text3);
  margin-bottom: 4px;
}

.cl-overlay-arrow {
  color: var(--text3);
  font-size: 18px;
  padding-top: 12px;
}

.cl-overlay-improve {
  margin-left: auto;
  font-family: var(--cl-mono);
  font-size: 12px;
  font-weight: 600;
  color: var(--nadir-magma-400);
}

.cl-overlay-improve[data-status="good"] { color: var(--ok); }

.cl-overlay-channels {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}

.cl-overlay-channel {
  padding: 10px;
  border-radius: 10px;
  border: 1px solid var(--border-subtle);
  background: rgba(0, 0, 0, 0.2);
}

.cl-overlay-ch-head {
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  font-weight: 600;
  margin-bottom: 6px;
}

.cl-overlay-delta.positive { color: var(--ok); font-family: var(--cl-mono); }

.cl-overlay-values {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
  font-family: var(--cl-mono);
  font-size: 12px;
}

.cl-overlay-corr-val { color: var(--ok); }

.cl-overlay-bar-group { display: grid; gap: 4px; margin-bottom: 8px; }

.cl-overlay-bar-row {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 8px;
  align-items: center;
}

.cl-overlay-bar-label {
  font-size: 9px;
  color: var(--text3);
  text-transform: uppercase;
}

.cl-overlay-bar-track {
  height: 4px;
  border-radius: 2px;
  background: rgba(255, 255, 255, 0.06);
  overflow: hidden;
}

.cl-overlay-bar {
  display: block;
  height: 100%;
  border-radius: 2px;
}

.cl-overlay-bar-raw {
  background: linear-gradient(90deg, #ff3b3b, #f5a623);
}

.cl-overlay-bar-corr {
  background: linear-gradient(90deg, #22c55e, #5b9cf6);
}

.cl-overlay-contrib {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.cl-contrib-chip {
  font-size: 9px;
  padding: 2px 6px;
  border-radius: 4px;
  background: color-mix(in srgb, var(--chip, #5b9cf6) 20%, transparent);
  color: var(--text2);
}

.cl-overlay-hint {
  margin: 12px 0 0;
  font-size: 11px;
  color: var(--text3);
}

@media (max-width: 768px) {
  .cl-api-compare-grid,
  .cl-overlay-channels {
    grid-template-columns: 1fr;
  }
}

/* ── Full stack banner (commit 10) ── */
.cl-full-stack-banner {
  margin: 0 0 12px;
  padding: 8px 12px;
  border-radius: 8px;
  font-size: 11px;
  border: 1px solid var(--border-subtle);
  background: rgba(255, 255, 255, 0.03);
  color: var(--text3);
}

.cl-full-stack-banner[data-active="true"] {
  border-color: rgba(249, 115, 22, 0.45);
  background: rgba(249, 115, 22, 0.08);
  color: var(--nadir-magma-400);
}

/* ── Benchmark panel (commit 12) ── */
.cl-bench-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}

.cl-bench-progress {
  margin-bottom: 12px;
}

.cl-bench-progress-bar {
  height: 6px;
  border-radius: 3px;
  background: rgba(255, 255, 255, 0.06);
  overflow: hidden;
  margin-bottom: 6px;
}

.cl-bench-progress-bar span {
  display: block;
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--nadir-magma-500), var(--nadir-magma-400));
  transition: width 0.15s ease;
}

.cl-bench-progress-text {
  font-size: 11px;
  color: var(--text3);
  font-family: var(--cl-mono);
}

.cl-bench-best {
  padding: 10px 12px;
  margin-bottom: 12px;
  border-radius: 10px;
  border: 1px solid rgba(52, 199, 89, 0.35);
  background: rgba(52, 199, 89, 0.08);
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  font-size: 12px;
}

.cl-bench-best-label {
  font-size: 10px;
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.cl-bench-best-score {
  font-family: var(--cl-mono);
  color: var(--ok);
}

.cl-bench-best-meta {
  width: 100%;
  font-size: 10px;
  color: var(--text3);
}

.cl-bench-table-wrap {
  max-height: 320px;
  overflow: auto;
  border: 1px solid var(--border-subtle);
  border-radius: 10px;
}

.cl-bench-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 11px;
}

.cl-bench-table th {
  position: sticky;
  top: 0;
  background: rgba(10, 11, 13, 0.95);
  text-align: left;
  padding: 8px 10px;
  color: var(--text3);
  font-weight: 600;
  border-bottom: 1px solid var(--border-subtle);
}

.cl-bench-table td {
  padding: 8px 10px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  color: var(--text2);
}

.cl-bench-row-top {
  background: rgba(249, 115, 22, 0.06);
}

.cl-bench-empty {
  text-align: center;
  color: var(--text3);
  padding: 24px !important;
}

/* ── Detection metrics panel (commit 13) ── */
.cl-panel-metrics .cl-metrics-body {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.cl-metrics-empty {
  padding: 20px;
  text-align: center;
  color: var(--text3);
  font-size: 13px;
  border: 1px dashed var(--border-subtle);
  border-radius: 10px;
}

.cl-metrics-kpis {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.cl-metric-card {
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--border-subtle);
  background: rgba(255, 255, 255, 0.02);
}

.cl-metric-label {
  display: block;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text3);
  margin-bottom: 4px;
}

.cl-metric-value {
  display: block;
  font-family: var(--cl-mono);
  font-size: 18px;
  font-weight: 600;
  color: var(--text);
}

.cl-metric-sub {
  display: block;
  font-size: 10px;
  color: var(--text3);
  margin-top: 4px;
}

.cl-metric-bar {
  height: 4px;
  margin-top: 8px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  overflow: hidden;
}

.cl-metric-bar span {
  display: block;
  height: 100%;
  width: 0;
  border-radius: 999px;
  background: linear-gradient(90deg, #38bdf8, #22d3ee);
  transition: width 0.25s ease;
}

.cl-metric-bar-accent span {
  background: linear-gradient(90deg, #f97316, #fb923c);
}

.cl-metrics-visual-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.cl-metrics-chart-title {
  margin: 0 0 2px;
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
}

.cl-metrics-chart-sub {
  margin: 0 0 10px;
  font-size: 10px;
  color: var(--text3);
}

.cl-confusion-wrap {
  padding: 12px;
  border: 1px solid var(--border-subtle);
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.2);
}

.cl-confusion-matrix {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.cl-confusion-axis-top,
.cl-confusion-row {
  display: grid;
  grid-template-columns: 36px repeat(3, 1fr);
  gap: 4px;
  align-items: center;
}

.cl-confusion-axis-top span,
.cl-confusion-row-label {
  font-size: 9px;
  font-family: var(--cl-mono);
  color: var(--text3);
  text-align: center;
}

.cl-confusion-cell {
  aspect-ratio: 1.4;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, calc(0.03 + var(--heat, 0) * 0.35));
  border: 1px solid rgba(255, 255, 255, calc(0.04 + var(--heat, 0) * 0.2));
}

.cl-confusion-cell.match {
  box-shadow: inset 0 0 0 1px rgba(34, 197, 94, 0.45);
}

.cl-confusion-count {
  font-family: var(--cl-mono);
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
}

.cl-confusion-legend {
  display: flex;
  gap: 12px;
  margin-top: 10px;
  font-size: 10px;
  color: var(--text3);
}

.cl-confusion-legend i {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 2px;
  margin-right: 4px;
  vertical-align: middle;
}

.cl-metrics-spark-wrap {
  padding: 12px;
  border: 1px solid var(--border-subtle);
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.2);
}

.cl-metrics-spark-wrap canvas {
  width: 100%;
  height: auto;
  border-radius: 8px;
}

.cl-spark-legend {
  display: flex;
  gap: 12px;
  margin-top: 8px;
  font-size: 10px;
}

.cl-spark-prec { color: #38bdf8; }
.cl-spark-rec { color: #a78bfa; }
.cl-spark-tier { color: #f97316; }

.cl-metrics-pr-detail {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 18px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--border-subtle);
  font-size: 11px;
  color: var(--text3);
}

.cl-metrics-pr-detail strong {
  color: var(--text);
  font-family: var(--cl-mono);
}

.cl-metrics-window {
  margin-left: auto;
  font-family: var(--cl-mono);
}

/* ── Timeline scrubber (commit 14) ── */
.cl-panel-timeline .cl-timeline-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.cl-timeline-clock-wrap {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
}

.cl-timeline-clock {
  font-family: var(--cl-mono);
  font-size: 14px;
  font-weight: 600;
  color: var(--nadir-magma-400);
}

.cl-timeline-canvas-wrap {
  border: 1px solid var(--border-subtle);
  border-radius: 10px;
  overflow: hidden;
  background: #0a0c10;
}

.cl-timeline-canvas-wrap canvas {
  display: block;
  width: 100%;
  height: auto;
  cursor: crosshair;
}

.cl-timeline-controls {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
}

.cl-timeline-transport {
  display: flex;
  gap: 6px;
}

.cl-btn-icon {
  min-width: 36px;
  padding: 6px 10px;
  font-size: 14px;
}

.cl-timeline-speed {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  color: var(--text3);
}

.cl-timeline-speed select {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  color: var(--text);
  padding: 4px 8px;
  font-size: 11px;
}

.cl-timeline-slider {
  flex: 1;
  min-width: 120px;
  accent-color: var(--nadir-magma-400);
}

.cl-timeline-duration {
  font-family: var(--cl-mono);
  font-size: 11px;
  color: var(--text3);
}

.cl-timeline-hint {
  margin: 10px 0 0;
  font-size: 11px;
  color: var(--text3);
}

/* HORIZON CTA (Block G1) */
.cl-horizon-cta {
  margin-top: 14px;
  border: 1px solid rgba(249, 115, 22, 0.45);
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(249, 115, 22, 0.12), rgba(255, 59, 48, 0.08));
}

.cl-horizon-cta-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
}

.cl-horizon-cta-kicker {
  font-family: var(--cl-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--nadir-magma-400);
  margin: 0 0 4px;
}

.cl-horizon-cta-title {
  font-size: 15px;
  font-weight: 700;
  margin: 0 0 6px;
  color: var(--text);
}

.cl-horizon-cta-body {
  font-size: 12px;
  color: var(--text2);
  margin: 0;
  max-width: 52ch;
}

.cl-horizon-cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.cl-horizon-cta-evidence {
  font-family: var(--cl-mono);
  font-size: 11px;
  color: var(--text3);
  margin: 8px 0 0;
}

/* Forecast narrative (Block G2) */
.cl-forecast-narrative {
  margin-top: 12px;
  border: 1px solid var(--border-subtle);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.02);
}

.cl-forecast-headline {
  font-size: 14px;
  font-weight: 700;
  color: var(--nadir-magma-300);
  margin: 0 0 8px;
}

.cl-forecast-body {
  font-size: 12px;
  line-height: 1.55;
  color: var(--text2);
  margin: 0 0 12px;
}

.cl-forecast-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  font-size: 11px;
}

.cl-forecast-stats dt {
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 10px;
}

.cl-forecast-stats dd {
  margin: 2px 0 0;
  font-family: var(--cl-mono);
  color: var(--text);
}

.cl-forecast-hint {
  margin: 10px 0 0;
  font-size: 10px;
  color: var(--text3);
}

.cl-scenario-feed-btn {
  font-size: 11px;
}

.cl-record-banner {
  display: flex;
  gap: 10px;
  align-items: center;
  padding: 8px 14px;
  font-size: 12px;
  color: var(--text2);
  background: rgba(52, 199, 89, 0.08);
  border-bottom: 1px solid rgba(52, 199, 89, 0.35);
}

.cl-record-banner strong {
  color: var(--ok);
}

@media (max-width: 1100px) {
  .cl-metrics-kpis {
    grid-template-columns: repeat(2, 1fr);
  }
  .cl-metrics-visual-row {
    grid-template-columns: 1fr;
  }
  .cl-forecast-stats {
    grid-template-columns: 1fr;
  }
}

/* Pulse parity panel — tier gates only */
.cl-pulse-badge {
  margin-left: 8px;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #6ee7b7;
  background: rgba(52, 211, 153, 0.12);
  border: 1px solid rgba(52, 211, 153, 0.35);
}

.cl-pulse-parity {
  margin-top: 12px;
  border-top: 1px solid var(--border);
}

.cl-pulse-parity-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 16px;
}

@media (max-width: 900px) {
  .cl-pulse-parity-grid {
    grid-template-columns: 1fr;
  }
}

.cl-pulse-parity-label {
  display: block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text3);
  margin-bottom: 8px;
}

.cl-pulse-parity-scenario {
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 10px;
}

.cl-pulse-parity-metrics {
  display: grid;
  gap: 6px;
  font-size: 12px;
}

.cl-pulse-parity-metrics div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.cl-pulse-parity-metrics dt {
  color: var(--text3);
}

.cl-pulse-parity-col-center {
  text-align: center;
}

.cl-pulse-parity-gate {
  font-size: 11px;
  color: var(--text2);
  margin: 8px 0 12px;
}

.cl-pulse-includes {
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: 12px;
  color: var(--text2);
}

.cl-pulse-includes li {
  padding: 4px 0 4px 14px;
  position: relative;
}

.cl-pulse-includes li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--ok);
  font-size: 11px;
}

.cl-pulse-excludes {
  margin-top: 12px;
  font-size: 11px;
  color: var(--text3);
  font-style: italic;
}

#cl-pulse-match[data-status="match"] {
  color: var(--ok);
}

#cl-pulse-match[data-status="mismatch"] {
  color: var(--warn);
}

/* Workflow bridge CTA — offline graceful (N34) */
.cl-workflow-bridge {
  margin-top: 14px;
  border: 1px solid rgba(255, 59, 48, 0.35);
  border-radius: var(--cl-panel-radius);
  background: linear-gradient(135deg, rgba(255, 59, 48, 0.08), rgba(249, 115, 22, 0.06));
  overflow: hidden;
}

.cl-workflow-bridge-inner {
  padding: 16px 18px;
}

.cl-workflow-bridge-inner.cl-workflow-offline {
  border-left: 3px solid var(--warn);
}

.cl-workflow-kicker {
  margin: 0 0 4px;
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #ff6b6b;
  font-weight: 700;
}

.cl-workflow-title {
  margin: 0 0 8px;
  font-size: 15px;
  font-weight: 700;
  color: var(--text1, #e8edf2);
}

.cl-workflow-body {
  margin: 0 0 12px;
  font-size: 13px;
  color: var(--text2);
}

.cl-workflow-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.cl-workflow-preview-out {
  margin: 12px 0 0;
  padding: 12px;
  max-height: 220px;
  overflow: auto;
  font-family: var(--cl-mono);
  font-size: 11px;
  background: rgba(0, 0, 0, 0.35);
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.cl-workflow-offline-banner {
  margin: 0 0 12px;
  padding: 10px 12px;
  border-radius: 8px;
  background: rgba(255, 177, 74, 0.12);
  border: 1px solid rgba(255, 177, 74, 0.35);
  font-size: 12px;
  color: var(--text2);
}

.cl-workflow-offline-banner strong {
  display: block;
  color: #ffb14a;
  margin-bottom: 4px;
}

.cl-workflow-offline-hint {
  margin: 8px 0 0;
  font-size: 11px;
  opacity: 0.85;
}
