/* ============ MARS-500 Emotional Telemetry — design tokens ============ */
:root{
  --bg:          oklch(98% 0.004 240);
  --bg-soft:     oklch(96% 0.006 235);
  --panel:       oklch(99.5% 0.003 240);
  --panel-2:     oklch(97% 0.005 235);
  --ink:         oklch(22% 0.012 250);
  --ink-2:       oklch(36% 0.010 250);
  --ink-3:       oklch(52% 0.008 245);
  --ink-4:       oklch(68% 0.006 240);
  --line:        oklch(88% 0.008 240);
  --line-2:      oklch(92% 0.006 240);
  --hairline:    oklch(90% 0.008 240);
  --accent:      oklch(58% 0.13 220);          /* clinical cyan */
  --accent-soft: oklch(58% 0.13 220 / .10);
  --signal:      oklch(66% 0.16 55);           /* mars amber */
  --signal-soft: oklch(66% 0.16 55 / .12);
  --ok:          oklch(62% 0.13 150);
  --warn:        oklch(68% 0.15 55);
  --alert:       oklch(60% 0.18 25);
  --grid:        oklch(92% 0.006 240);
  --shadow-sm:   0 1px 0 oklch(22% 0.012 250 / .04), 0 1px 2px oklch(22% 0.012 250 / .04);
  --shadow-md:   0 1px 0 oklch(22% 0.012 250 / .05), 0 4px 12px -2px oklch(22% 0.012 250 / .08);
  --radius:      10px;
  --radius-sm:   6px;
  --font-ui:     'Inter Tight', ui-sans-serif, system-ui, -apple-system, 'Helvetica Neue', sans-serif;
  --font-mono:   'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
}
[data-theme="graphite"]{
  --bg:          oklch(14% 0.012 250);
  --bg-soft:     oklch(18% 0.013 250);
  --panel:       oklch(19% 0.013 250);
  --panel-2:     oklch(22% 0.014 250);
  --ink:         oklch(96% 0.005 240);
  --ink-2:       oklch(82% 0.008 240);
  --ink-3:       oklch(65% 0.010 240);
  --ink-4:       oklch(50% 0.010 240);
  --line:        oklch(28% 0.014 250);
  --line-2:      oklch(24% 0.013 250);
  --hairline:    oklch(30% 0.013 250);
  --grid:        oklch(26% 0.013 250);
  --accent:      oklch(74% 0.14 220);
  --accent-soft: oklch(74% 0.14 220 / .14);
  --signal:      oklch(76% 0.14 55);
  --signal-soft: oklch(76% 0.14 55 / .15);
}
[data-theme="mars"]{
  --bg:          oklch(96% 0.012 60);
  --bg-soft:     oklch(93% 0.018 55);
  --panel:       oklch(98% 0.010 55);
  --panel-2:     oklch(94% 0.015 55);
  --ink:         oklch(24% 0.030 35);
  --ink-2:       oklch(38% 0.030 35);
  --ink-3:       oklch(55% 0.025 35);
  --ink-4:       oklch(70% 0.020 35);
  --line:        oklch(86% 0.020 45);
  --line-2:      oklch(90% 0.015 45);
  --hairline:    oklch(88% 0.020 45);
  --grid:        oklch(90% 0.015 50);
  --accent:      oklch(58% 0.14 35);
  --accent-soft: oklch(58% 0.14 35 / .12);
  --signal:      oklch(62% 0.16 50);
  --signal-soft: oklch(62% 0.16 50 / .14);
}

*{ box-sizing:border-box; }
html,body,#root{ height:100%; }
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--font-ui);
  font-feature-settings:'ss01','cv11','tnum';
  -webkit-font-smoothing:antialiased;
  letter-spacing:-0.005em;
  overflow:hidden;
}
.mono{ font-family:var(--font-mono); font-feature-settings:'tnum'; }
.num{ font-variant-numeric:tabular-nums; font-family:var(--font-mono); }

/* ============ Layout ============ */
.app{
  display:grid;
  grid-template-rows: 56px 1fr;
  height:100vh;
  background:
    radial-gradient(1200px 600px at 85% -10%, var(--accent-soft), transparent 60%),
    radial-gradient(900px 500px at -5% 110%, var(--signal-soft), transparent 60%),
    var(--bg);
}

/* header */
.header{
  display:grid;
  grid-template-columns: auto 1fr auto;
  align-items:center;
  gap:24px;
  padding:0 20px;
  border-bottom:1px solid var(--line);
  background:var(--panel);
  backdrop-filter:saturate(1.1);
}
.brand{ display:flex; align-items:center; gap:10px; }
.brand-mark{
  width:26px; height:26px; border-radius:6px;
  background:
    radial-gradient(circle at 30% 30%, oklch(80% 0.14 60), oklch(45% 0.14 35));
  box-shadow: inset 0 0 0 1px oklch(35% 0.05 35 / .4), 0 1px 0 var(--line);
  position:relative;
}
.brand-mark::after{
  content:''; position:absolute; inset:0;
  background: radial-gradient(circle at 68% 72%, transparent 62%, oklch(25% 0.02 35 / .35) 63%, transparent 66%);
  border-radius:inherit;
}
.brand-text{
  font-weight:600; font-size:13px; letter-spacing:.12em; text-transform:uppercase;
}
.brand-text .sub{ color:var(--ink-3); font-weight:500; margin-left:8px; }

.telem{
  display:flex; gap:14px; align-items:center;
  font-family:var(--font-mono); font-size:11px; color:var(--ink-2);
  min-width:0; overflow:hidden;
}
.telem-item{
  display:flex; flex-direction:column; gap:2px;
  padding-right:14px; border-right:1px solid var(--line-2);
  white-space:nowrap;
}
.telem-item:last-child{ border-right:none; }
.telem-label{ color:var(--ink-4); text-transform:uppercase; letter-spacing:.12em; font-size:9px; }
.telem-val{ color:var(--ink); font-size:11.5px; letter-spacing:.02em; white-space:nowrap; }

.header-actions{ display:flex; gap:8px; align-items:center; }
.pill{
  font-size:10.5px; letter-spacing:.14em; text-transform:uppercase;
  padding:5px 10px; border-radius:999px;
  border:1px solid var(--line); color:var(--ink-2);
  background:var(--panel-2);
  font-family:var(--font-ui); font-weight:500;
}
.pill.live{ color:var(--ok); border-color:color-mix(in oklab, var(--ok) 35%, var(--line)); }
.pill.live::before{
  content:''; display:inline-block; width:6px; height:6px; border-radius:50%;
  background:var(--ok); margin-right:6px; vertical-align:middle;
  animation:pulse 1.6s ease-in-out infinite;
}
@keyframes pulse{ 0%,100%{ opacity:.35 } 50%{ opacity:1 } }

/* ============ Main split ============ */
.main{
  display:grid;
  grid-template-columns: 1fr 360px;
  min-height:0;
}
.main.no-detail{ grid-template-columns:1fr; }

.board{ display:grid; grid-template-rows: auto 1fr auto; min-height:0; }

/* phase ribbon + sol axis */
.axis-wrap{
  padding:14px 20px 8px;
  border-bottom:1px solid var(--line);
  background:var(--panel);
}
.axis-wrap.is-collapsed{ padding:10px 20px; }
.axis-wrap.is-collapsed .axis-head{ margin-bottom: 0; }
.timeline-stack.is-collapsed{ border-bottom: 1px solid var(--line); }
.axis-sol .bs-toggle{ display:inline-flex; margin-left: 8px; vertical-align: middle; }

/* ============ BODY METRICS EXPLAINER (L3 reference) ============ */
.bmx-overlay{
  position: fixed; inset: 0;
  background: oklch(0% 0 0 / .42);
  backdrop-filter: blur(3px);
  z-index: 200;
  display: flex; align-items: center; justify-content: center;
  padding: 40px;
  animation: bmxFade .2s ease;
}
@keyframes bmxFade{ from{opacity:0;} to{opacity:1;} }
.bmx-panel{
  width: min(720px, 100%);
  max-height: calc(100vh - 80px);
  overflow-y: auto;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: 0 24px 80px rgba(0,0,0,.3);
  animation: bmxRise .25s cubic-bezier(.3,.1,.2,1);
}
.bmx-panel-wide{ width: min(1040px, 100%); }

.bmx-grid{
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 0;
  align-items: stretch;
}
.bmx-left{
  padding: 18px 20px 16px;
  border-right: 1px solid var(--line);
  background: var(--bg-soft);
  display: flex; flex-direction: column; gap: 14px;
}
.bmx-body-wrap{
  position: relative;
  aspect-ratio: 120 / 220;
  max-height: 360px;
  margin: 0 auto;
  width: 100%;
}
.bmx-body-wrap .body-svg{ width: 100%; height: 100%; }

.bmx-enc-head{ border-top: 1px solid var(--line-2); padding-top: 10px; }
.bmx-enc-title{
  font-size: 10.5px; font-weight: 700; letter-spacing: .14em;
  color: var(--ink-3);
}
.bmx-enc-sub{ font-size: 10px; color: var(--ink-4); letter-spacing: .06em; margin-top: 2px; }

.bmx-enc-list{ display:flex; flex-direction:column; gap: 8px; }
.bmx-enc-row{ display: grid; grid-template-columns: 28px 1fr; gap: 10px; align-items: center; }
.bmx-enc-sw{ display:flex; align-items:center; justify-content:center; height: 22px; }
.bmx-enc-k{ font-size: 11.5px; font-weight: 600; color: var(--ink); }
.bmx-enc-rule{ font-size: 10.5px; color: var(--ink-3); line-height: 1.4; }

.bmx-sw-blob{
  width: 16px; height: 16px; border-radius: 50%;
  background: radial-gradient(circle, oklch(60% 0.16 25 / .7) 0%, oklch(60% 0.16 25 / 0) 70%);
  display: inline-block;
}
.bmx-sw-hue{
  width: 18px; height: 8px; border-radius: 4px;
  background: linear-gradient(90deg,
    oklch(60% 0.16 25) 0%,
    oklch(60% 0.16 15) 25%,
    oklch(60% 0.16 40) 50%,
    oklch(60% 0.16 200) 75%,
    oklch(60% 0.16 145) 100%);
}
.bmx-sw-pulse{
  width: 14px; height: 14px; border-radius: 50%;
  background: oklch(60% 0.18 15);
  box-shadow: 0 0 0 4px oklch(60% 0.18 15 / .18);
  animation: bmxPulse 0.9s ease-in-out infinite;
}
@keyframes bmxPulse{ 0%,100%{ transform: scale(1); opacity: 1; } 50%{ transform: scale(1.2); opacity: .7; } }
.bmx-sw-line{
  width: 22px; height: 0; border-top: 1px solid var(--ink-3);
  position: relative;
}
.bmx-sw-line::after{
  content:''; position:absolute; right:-3px; top:-3px;
  width: 5px; height: 5px; border-radius: 50%; background: var(--ink-2);
}

.bmx-demo-note{
  margin-top: auto;
  font-size: 9.5px; color: var(--ink-4);
  letter-spacing: .04em; line-height: 1.4;
  padding-top: 8px; border-top: 1px dashed var(--line-2);
}

.bmx-right{ display: flex; flex-direction: column; min-width: 0; }
@keyframes bmxRise{ from{opacity:0; transform: translateY(12px);} to{opacity:1; transform: translateY(0);} }

.bmx-head{
  display: grid; grid-template-columns: auto 1fr auto;
  align-items: center; gap: 20px;
  padding: 18px 24px 14px;
  border-bottom: 1px solid var(--line);
}
.bmx-title-block{ display:flex; flex-direction:column; gap: 2px; }
.bmx-eyebrow{ font-size: 10px; color: var(--ink-4); letter-spacing: .16em; }
.bmx-title{ font-size: 19px; font-weight: 600; letter-spacing: -0.01em; color: var(--ink); }
.bmx-head-r{ font-size: 10px; color: var(--ink-3); letter-spacing: .12em; text-align: right; }

.bmx-intro{
  padding: 16px 20px 4px;
  font-size: 12.5px; line-height: 1.55;
  color: var(--ink-2);
}
.bmx-em{ color: var(--ink); font-weight: 600; }

.bmx-list{
  padding: 8px 12px 10px;
  display: flex; flex-direction: column;
}
.bmx-row{
  display: grid; grid-template-columns: 92px 1fr;
  gap: 16px;
  padding: 14px 12px;
  border-top: 1px solid var(--line-2);
}
.bmx-row:first-child{ border-top: 0; }

.bmx-k-col{ display:flex; flex-direction:column; gap: 2px; padding-top: 1px; }
.bmx-k{
  font-size: 17px; font-weight: 700; letter-spacing: .04em;
  color: var(--ink);
}
.bmx-unit{ font-size: 10px; color: var(--ink-4); letter-spacing: .08em; }

.bmx-body{ display:flex; flex-direction:column; gap: 6px; }
.bmx-row-head{ display:flex; align-items: baseline; gap: 8px; }
.bmx-title-s{ font-size: 13px; font-weight: 600; color: var(--ink); }
.bmx-zone{ font-size: 10.5px; color: var(--ink-3); letter-spacing: .04em; }
.bmx-def{ font-size: 12px; line-height: 1.55; color: var(--ink-2); }
.bmx-sc{
  font-size: 11.5px; line-height: 1.55; color: var(--ink-2);
  padding: 7px 10px; border-left: 2px solid var(--accent);
  background: var(--bg-soft);
  border-radius: 0 3px 3px 0;
}
.bmx-sc-tag{
  display: inline-block;
  font-size: 9.5px; font-weight: 700;
  color: var(--accent); letter-spacing: .12em;
  margin-right: 8px;
}

.bmx-foot{
  padding: 10px 24px 14px;
  border-top: 1px solid var(--line);
  font-size: 10px; color: var(--ink-4); letter-spacing: .08em;
}

.pod-silhouette{ cursor: pointer; }
.pod-silhouette:hover{ background: oklch(50% 0.05 240 / .04); }
.axis-head{
  display:flex; align-items:baseline; justify-content:space-between;
  margin-bottom:10px;
}
.axis-title{ font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); font-weight:500; }
.axis-sol{ font-family:var(--font-mono); font-size:22px; letter-spacing:.02em; color:var(--ink); }
.axis-sol .unit{ color:var(--ink-3); font-size:12px; margin-left:6px; letter-spacing:.14em; text-transform:uppercase; }

.phase-ribbon{
  position:relative;
  height:26px;
  border-radius:6px;
  overflow:hidden;
  border:1px solid var(--line);
  background:var(--panel-2);
  margin-bottom:6px;
}
.phase-seg{
  position:absolute; top:0; bottom:0;
  display:flex; align-items:center; padding:0 8px;
  font-size:10px; letter-spacing:.14em; text-transform:uppercase;
  color:oklch(20% 0.02 250 / .78);
  white-space:nowrap; overflow:hidden;
  border-right:1px solid oklch(20% 0.02 250 / .10);
}
[data-theme="graphite"] .phase-seg{ color:oklch(96% 0.005 240 / .9); border-right-color:oklch(10% 0.01 250 / .45); }

.sol-axis{
  position:relative; height:18px;
  font-family:var(--font-mono); font-size:10px; color:var(--ink-4);
}
.sol-tick{ position:absolute; transform:translateX(-50%); }
.sol-tick::before{
  content:''; display:block; width:1px; height:4px; background:var(--line);
  margin:0 auto 2px;
}

/* ============ Multitrack ============ */
.tracks-wrap{ overflow:auto; padding:4px 20px 0; background:var(--bg); position:relative; }
.tracks{
  display:grid;
  grid-template-columns: 220px 1fr;
  gap:0;
  padding-bottom:12px;
}
.row{ display:contents; }
.tracks.compact  .row-label,
.tracks.compact  .row-track  { min-height:86px; height:86px; }
.tracks.spacious .row-label,
.tracks.spacious .row-track  { min-height:118px; height:118px; }
.row-label, .row-track{
  border-bottom:1px solid var(--line-2);
}
.row-label{
  display:grid; grid-template-columns: 32px 1fr auto; align-items:center; gap:10px;
  padding:0 12px 0 4px;
  cursor:pointer;
  transition:background .15s;
  border-right:1px solid var(--line);
}
.row-label:hover{ background:var(--panel-2); }
.row-label.selected{ background:var(--accent-soft); }
.row-avatar{
  width:28px; height:28px; border-radius:50%;
  background:var(--panel-2);
  border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-mono); font-size:10px; color:var(--ink-2);
  font-weight:600; letter-spacing:.02em;
  position:relative;
}
.row-flag{
  position:absolute; bottom:-3px; right:-3px;
  font-size:9px; background:var(--panel); border:1px solid var(--line);
  padding:1px 3px; border-radius:3px; font-family:var(--font-mono);
  color:var(--ink-3);
}
.row-name{ display:flex; flex-direction:column; min-width:0; }
.row-name .n1{ font-size:12.5px; font-weight:500; color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.row-name .n2{ font-size:10.5px; color:var(--ink-3); font-family:var(--font-mono); letter-spacing:.04em; text-transform:uppercase; }
.row-state{
  font-family:var(--font-mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase;
  color:var(--ink-3);
  padding:2px 6px; border-radius:4px; border:1px solid var(--line-2);
  background:var(--panel);
}
.row-state.green{ color:var(--ok);    border-color:color-mix(in oklab, var(--ok) 30%, var(--line)); }
.row-state.amber{ color:var(--warn);  border-color:color-mix(in oklab, var(--warn) 30%, var(--line)); }
.row-state.red{   color:var(--alert); border-color:color-mix(in oklab, var(--alert) 30%, var(--line)); }

.row-track{
  position:relative;
  background: var(--panel);
  background-image:
    linear-gradient(to right, var(--grid) 1px, transparent 1px);
  background-size: 10% 100%;
}
.row-track .now-marker{
  position:absolute; top:0; bottom:0; width:1px;
  background:var(--accent);
  pointer-events:none;
}
.row-track .now-marker::after{
  content:''; position:absolute; top:-3px; left:-3px; width:7px; height:7px;
  background:var(--accent); border-radius:50%;
}

/* Bars (the chosen data-viz style): one row per emotion within a row */
.barstack{
  position:absolute; inset:6px 0 6px 0;
  display:grid; grid-auto-rows: 1fr; gap:2px;
  padding-right:4px;
}
.bar-row{
  position:relative;
  display:flex; align-items:center;
}
.bar-row .bar-track-bg{
  position:absolute; inset:0;
  background:var(--panel-2);
  border-radius:2px;
}
.bar-row .bar-fill{
  position:relative;
  height:100%;
  border-radius:2px;
  transition: width .25s cubic-bezier(.4,.2,.2,1), background-color .2s;
}
.bar-row .bar-key{
  position:absolute; right:6px; top:50%; transform:translateY(-50%);
  font-family:var(--font-mono); font-size:9px; color:var(--ink-4);
  letter-spacing:.08em; text-transform:uppercase; pointer-events:none;
  opacity:0;
  transition:opacity .15s;
}
.row.hover .bar-row .bar-key, .row:hover .bar-row .bar-key{ opacity:.9; }

/* event dots overlayed on the track */
.event-dot{
  position:absolute;
  width:6px; height:6px; border-radius:50%;
  top:6px;
  transform:translateX(-50%);
  background:var(--ink-3); border:1px solid var(--panel);
  cursor:pointer;
  transition: transform .12s, box-shadow .12s;
}
.event-dot:hover{ transform:translateX(-50%) scale(1.6); box-shadow:0 0 0 3px var(--accent-soft); }
.event-dot.storm{ background:oklch(62% 0.14 40); }
.event-dot.comms{ background:oklch(58% 0.12 270); }
.event-dot.medical{ background:oklch(60% 0.14 10); }
.event-dot.discovery{ background:oklch(62% 0.14 160); }
.event-dot.conflict{ background:oklch(55% 0.14 25); }
.event-dot.anniversary{ background:oklch(62% 0.12 310); }
.event-dot.milestone{ background:oklch(60% 0.12 220); }

/* ============ Footer / scrubber ============ */
.footer{
  border-top:1px solid var(--line);
  background:var(--panel);
  padding:12px 20px;
  display:grid;
  grid-template-columns: auto 1fr auto;
  gap:18px; align-items:center;
}
.transport{ display:flex; gap:6px; align-items:center; }
.btn{
  appearance:none; border:1px solid var(--line); background:var(--panel-2);
  color:var(--ink); font-family:var(--font-ui); font-size:12px;
  padding:7px 12px; border-radius:8px; cursor:pointer;
  display:inline-flex; align-items:center; gap:6px;
  transition:background .12s, border-color .12s, color .12s;
}
.btn:hover{ background:var(--panel); border-color:color-mix(in oklab, var(--accent) 30%, var(--line)); }
.btn.icon{ width:34px; height:34px; padding:0; justify-content:center; }
.btn.primary{ background:var(--ink); color:var(--bg); border-color:var(--ink); }
.btn.primary:hover{ background:var(--ink-2); }
.btn.ghost{ border-color:transparent; background:transparent; color:var(--ink-2); }
.btn.ghost:hover{ background:var(--panel-2); color:var(--ink); }

.scrubber-wrap{ position:relative; height:34px; display:flex; align-items:center; }
.scrubber{
  -webkit-appearance:none; appearance:none;
  width:100%; background:transparent; height:34px; margin:0;
}
.scrubber::-webkit-slider-runnable-track{
  height:4px; background:var(--line); border-radius:2px;
}
.scrubber::-webkit-slider-thumb{
  -webkit-appearance:none;
  width:16px; height:16px; border-radius:50%;
  background:var(--accent); border:2px solid var(--panel);
  margin-top:-6px; cursor:grab;
  box-shadow: 0 0 0 1px var(--accent);
}
.scrubber::-moz-range-track{ height:4px; background:var(--line); border-radius:2px; }
.scrubber::-moz-range-thumb{
  width:16px; height:16px; border-radius:50%; background:var(--accent);
  border:2px solid var(--panel); cursor:grab;
}

.speed{
  display:flex; border:1px solid var(--line); border-radius:8px; overflow:hidden;
  font-family:var(--font-mono); font-size:11px;
}
.speed button{
  appearance:none; border:none; background:transparent; color:var(--ink-2);
  padding:6px 9px; cursor:pointer; font-family:inherit; font-size:inherit;
  border-right:1px solid var(--line);
}
.speed button:last-child{ border-right:none; }
.speed button.active{ background:var(--ink); color:var(--bg); }

/* ============ Event tooltip ============ */
.event-tip{
  position:fixed; pointer-events:none;
  background:var(--panel); border:1px solid var(--line);
  border-radius:8px; padding:10px 12px;
  box-shadow: var(--shadow-md);
  font-size:12px; color:var(--ink); max-width:280px;
  z-index:50;
}
.event-tip .t-kind{
  font-family:var(--font-mono); font-size:9.5px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink-3); margin-bottom:2px;
}
.event-tip .t-title{ font-weight:600; font-size:12.5px; margin-bottom:4px; }
.event-tip .t-body{ color:var(--ink-2); font-size:11.5px; line-height:1.45; }
.event-tip .t-sol{ font-family:var(--font-mono); font-size:10px; color:var(--ink-4); margin-top:6px; letter-spacing:.06em;}

/* ============ Detail panel ============ */
.detail{
  border-left:1px solid var(--line);
  background:var(--panel);
  overflow-y:auto;
  display:flex; flex-direction:column;
}
.detail-head{
  padding:18px 20px 12px;
  border-bottom:1px solid var(--line);
  position:relative;
}
.detail-close{
  position:absolute; top:14px; right:14px;
  background:transparent; border:1px solid var(--line); border-radius:6px;
  width:26px; height:26px; cursor:pointer; color:var(--ink-3);
}
.detail-close:hover{ background:var(--panel-2); color:var(--ink); }
.detail-id{
  font-family:var(--font-mono); font-size:10.5px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink-3);
}
.detail-name{ font-size:20px; font-weight:600; margin:4px 0 2px; letter-spacing:-0.01em; }
.detail-role{ font-size:12px; color:var(--ink-2); }
.detail-meta{
  display:flex; gap:14px; margin-top:10px;
  font-family:var(--font-mono); font-size:10.5px; color:var(--ink-3);
  letter-spacing:.02em;
}
.detail-meta .mlabel{ color:var(--ink-4); text-transform:uppercase; letter-spacing:.14em; font-size:9.5px; margin-right:4px; }
.detail-bio{ font-size:12.5px; color:var(--ink-2); line-height:1.5; margin-top:12px; }

.detail-section{
  padding:16px 20px; border-bottom:1px solid var(--line);
}
.section-title{
  font-size:10px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-3); margin-bottom:10px; font-weight:500;
}

.gauge-grid{ display:grid; grid-template-columns: 1fr 1fr; gap:10px 18px; }
.gauge{ display:grid; grid-template-columns: 70px 1fr auto; gap:8px; align-items:center; }
.gauge .glabel{ font-size:10.5px; color:var(--ink-2); text-transform:capitalize; }
.gauge .gbar{ height:6px; background:var(--panel-2); border-radius:3px; overflow:hidden; }
.gauge .gfill{ height:100%; transition: width .25s; border-radius:3px; }
.gauge .gval{ font-family:var(--font-mono); font-size:10.5px; color:var(--ink-3); min-width:26px; text-align:right; }

/* Sparkline grid */
.spark-grid{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.spark-card{
  border:1px solid var(--line-2); border-radius:8px;
  padding:8px 10px 6px; background:var(--panel-2);
}
.spark-card .sc-head{ display:flex; justify-content:space-between; align-items:baseline; }
.spark-card .sc-label{ font-size:10.5px; color:var(--ink-2); text-transform:capitalize; }
.spark-card .sc-val{ font-family:var(--font-mono); font-size:11px; color:var(--ink); }
.spark-card svg{ display:block; width:100%; height:28px; }

.trait-row{
  display:grid; grid-template-columns: 90px 1fr auto; gap:10px; align-items:center;
  margin:6px 0;
}
.trait-row .tlabel{ font-size:10.5px; color:var(--ink-2); text-transform:capitalize; }
.trait-row .tbar{ height:3px; background:var(--line-2); border-radius:2px; overflow:hidden; }
.trait-row .tfill{ height:100%; background:var(--ink-2); }
.trait-row .tval{ font-family:var(--font-mono); font-size:10px; color:var(--ink-3); }

/* ============ Crew Pod Grid (bio-monitors) ============ */
.pods-wrap{
  padding:14px 20px 20px;
  overflow:auto;
  background:var(--bg);
  height:100%;
}
.pods-grid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(480px, 1fr));
  gap:14px;
}
.pods-grid.compact{
  grid-template-columns: repeat(auto-fill, minmax(440px, 1fr));
  gap:10px;
}
.pod{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:12px;
  padding:12px 14px 14px;
  cursor:pointer;
  transition: border-color .15s, box-shadow .15s;
  position:relative;
  overflow:hidden;
}
.pod:hover{ border-color: color-mix(in oklab, var(--accent) 25%, var(--line)); box-shadow:var(--shadow-sm); }
.pod.selected{ border-color:var(--accent); box-shadow: 0 0 0 1px var(--accent), var(--shadow-sm); }
.pod-head{
  display:grid; grid-template-columns: 34px 1fr auto;
  align-items:center; gap:10px;
  padding-bottom:8px; margin-bottom:10px;
  border-bottom:1px dashed var(--line-2);
}
.pod-avatar{
  width:32px; height:32px; border-radius:50%;
  background:var(--panel-2); border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-mono); font-size:10.5px; font-weight:600;
  color:var(--ink-2); position:relative;
}
.pod-flag{
  position:absolute; bottom:-3px; right:-4px;
  font-size:9px; background:var(--panel); border:1px solid var(--line);
  padding:1px 3px; border-radius:3px; font-family:var(--font-mono); color:var(--ink-3);
}
.pod-ident{ min-width:0; }
.pod-name{ font-size:13px; font-weight:600; color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pod-role{ font-size:10.5px; color:var(--ink-3); font-family:var(--font-mono); letter-spacing:.04em; text-transform:uppercase; }
.pod-alert{
  font-family:var(--font-mono); font-size:9.5px; letter-spacing:.12em; text-transform:uppercase;
  padding:3px 7px; border-radius:4px; border:1px solid var(--line-2); background:var(--panel-2); color:var(--ink-3);
}
.pod-alert.green{ color:var(--ok);    border-color:color-mix(in oklab, var(--ok) 30%, var(--line)); }
.pod-alert.amber{ color:var(--warn);  border-color:color-mix(in oklab, var(--warn) 30%, var(--line)); }
.pod-alert.red{   color:var(--alert); border-color:color-mix(in oklab, var(--alert) 30%, var(--line)); background:color-mix(in oklab, var(--alert) 8%, var(--panel)); }
.pod-body{
  display:grid; grid-template-columns: 130px 1fr; gap:12px;
}
.pod-silhouette{
  position:relative;
  background:
    radial-gradient(ellipse at center, var(--panel-2), transparent 70%),
    repeating-linear-gradient(0deg, transparent 0 11px, var(--hairline) 11px 12px);
  border:1px solid var(--line-2); border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden; min-height:380px;
}
.body-svg{ width:100%; height:100%; max-height:100%; }
.pod-eventflag{
  position:absolute; top:8px; right:8px;
  width:18px; height:18px; border-radius:50%;
  background:var(--alert); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-mono); font-size:11px; font-weight:700;
  cursor:pointer; animation:pulse 1.4s ease-in-out infinite;
}
.pod-widgets{
  display:grid; gap:8px;
  grid-template-columns: 1fr 1fr;
  grid-template-areas: "emo vit" "nut nut" "en en";
}
.w-emotion{ grid-area:emo; }
.w-vitals{ grid-area:vit; }
.w-nutrition{ grid-area:nut; }
.w-energy{ grid-area:en; }
.widget{
  background:var(--panel-2);
  border:1px solid var(--line-2);
  border-radius:8px;
  padding:8px 10px 9px;
}
.w-title{
  font-family:var(--font-mono); font-size:9px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--ink-3); margin-bottom:6px; font-weight:500;
}
.w-emo-row{ display:grid; grid-template-columns:auto 1fr; gap:10px; align-items:center; }
.w-emo-meta{ display:flex; flex-direction:column; gap:3px; min-width:0; }
.w-emo-dom-inline{
  font-family:var(--font-body); font-size:10px; letter-spacing:0; text-transform:none;
  color:var(--ink); font-weight:600; margin-left:8px;
}
.w-emo-quad{ font-family:var(--font-mono); font-size:9.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); }
.w-emo-va{ font-size:10px; color:var(--ink-3); font-family:var(--font-mono); letter-spacing:.02em; }
.w-emo-act{ display:grid; grid-template-columns:28px 1fr; gap:5px; align-items:center; margin-top:2px; }
.w-emo-act-lbl{ font-family:var(--font-mono); font-size:8.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-4); }
.ecg{ display:block; width:100%; height:22px; margin-bottom:4px; background:oklch(20% 0.02 150 / .03); border-radius:3px; }
.vitals-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap:6px 10px; }
.v-stat{ display:flex; flex-direction:column; gap:1px; }
.v-label{ font-family:var(--font-mono); font-size:8.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-4); }
.v-val{ font-size:13px; color:var(--ink); letter-spacing:.02em; font-weight:500; }
.v-u{ font-size:9px; color:var(--ink-4); margin-left:2px; font-weight:400; }
.kcal-row{ display:grid; grid-template-columns:auto 1fr; gap:10px; align-items:center; margin-bottom:6px; }
.dial{ position:relative; display:inline-block; }
.dial-center{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.dial-label{ font-size:11px; color:var(--ink); font-weight:500; line-height:1; }
.dial-sub{ font-size:7.5px; color:var(--ink-4); letter-spacing:.12em; text-transform:uppercase; margin-top:1px; }
.kcal-meta{ display:flex; flex-direction:column; gap:4px; }
.kcal-target{ font-size:10px; color:var(--ink-3); }
.kcal-app{ display:grid; grid-template-columns:auto 1fr auto; gap:6px; align-items:center; }
.kcal-app-lbl{ font-size:9.5px; color:var(--ink-3); }
.kcal-app-v{ font-size:10px; color:var(--ink-2); }
.mini-bar{ background:var(--line-2); border-radius:2px; overflow:hidden; height:4px; }
.mini-bar-fill{ height:100%; transition: width .25s; border-radius:2px; }
.macros{ display:grid; gap:3px; margin-bottom:6px; }
.macro-row{ display:grid; grid-template-columns:46px 1fr 46px; gap:6px; align-items:center; }
.macro-k{ font-size:9.5px; color:var(--ink-3); }
.macro-bar{ position:relative; height:5px; background:var(--line-2); border-radius:3px; overflow:hidden; }
.macro-fill{ height:100%; border-radius:3px; transition: width .2s; max-width:100%; }
.macro-v{ font-size:10px; color:var(--ink-2); text-align:right; }
.macro-u{ font-size:8.5px; color:var(--ink-4); margin-left:1px; }
.nut-micros{ display:grid; grid-template-columns:repeat(4, 1fr); gap:6px 10px; }
.micro{ display:grid; grid-template-columns:28px 1fr auto; gap:5px; align-items:center; }
.micro-k{ font-size:9px; color:var(--ink-3); font-family:var(--font-mono); letter-spacing:.04em; text-transform:uppercase; }
.micro-v{ font-size:9.5px; color:var(--ink-2); }
.energy-row{ display:grid; grid-template-columns:auto 1fr; gap:12px; align-items:center; margin-bottom:6px; }
.sleep-donut{ position:relative; width:56px; height:56px; }
.sleep-center{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.sleep-hr{ font-size:12.5px; color:var(--ink); font-weight:600; line-height:1; }
.sleep-u{ font-size:8.5px; color:var(--ink-4); margin-left:1px; font-weight:400; }
.sleep-lbl{ font-size:7.5px; color:var(--ink-4); letter-spacing:.15em; margin-top:1px; }
.energy-stats{ display:grid; gap:3px; }
.e-stat{ display:grid; grid-template-columns: 64px 1fr 26px; gap:6px; align-items:center; }
.e-k{ font-size:9.5px; color:var(--ink-3); }
.e-v{ font-size:10px; color:var(--ink-2); text-align:right; }
.activity-row{ display:flex; gap:10px; align-items:center; padding-top:6px; border-top:1px dashed var(--line-2); }
.a-stat{ display:flex; flex-direction:column; gap:0; }
.a-k{ font-family:var(--font-mono); font-size:8.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-4); }
.a-v{ font-size:11.5px; color:var(--ink); font-weight:500; }
.a-u{ font-size:8.5px; color:var(--ink-4); margin-left:1px; font-weight:400; }
.eva-tag{
  margin-left:auto;
  font-family:var(--font-mono); font-size:9px; letter-spacing:.14em;
  background:var(--signal-soft); color:var(--signal);
  padding:2px 7px; border-radius:4px;
  border:1px solid color-mix(in oklab, var(--signal) 30%, var(--line));
}

/* ============ Legend / toggles ============ */
.legend{
  display:flex; flex-wrap:wrap; gap:6px;
  padding:8px 20px;
  border-bottom:1px solid var(--line);
  background:var(--panel);
}
.legend-chip{
  display:inline-flex; align-items:center; gap:6px;
  font-size:11px; color:var(--ink-2);
  padding:4px 9px; border-radius:999px;
  border:1px solid var(--line);
  background:var(--panel-2);
  cursor:pointer; user-select:none;
  transition:opacity .15s, background .15s;
}
.legend-chip .swatch{ width:9px; height:9px; border-radius:50%; }
.legend-chip.off{ opacity:.4; }
.legend-chip:hover{ background:var(--panel); }

/* ============ Tweaks panel ============ */
.tweaks{
  position:fixed; right:18px; bottom:78px;
  width:280px; z-index:40;
  background:var(--panel); border:1px solid var(--line);
  border-radius:12px; box-shadow: var(--shadow-md);
  padding:14px 14px 10px;
  font-size:12px;
}
.tweaks.hidden{ display:none; }
.tweaks h4{
  margin:0 0 10px;
  font-size:10px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-3); font-weight:500;
  display:flex; justify-content:space-between; align-items:center;
}
.tweaks h4 .close{
  cursor:pointer; border:1px solid var(--line); background:transparent;
  width:20px; height:20px; border-radius:5px; color:var(--ink-3);
}
.tweak-row{ margin:8px 0; }
.tweak-row .tr-label{ font-size:11px; color:var(--ink-2); margin-bottom:5px; display:flex; justify-content:space-between;}
.tweak-row .tr-label .tr-val{ font-family:var(--font-mono); color:var(--ink-3); }
.seg{
  display:flex; border:1px solid var(--line); border-radius:7px; overflow:hidden;
}
.seg button{
  flex:1; appearance:none; border:none; background:transparent;
  padding:6px 4px; font-size:11px; color:var(--ink-2); cursor:pointer;
  border-right:1px solid var(--line-2);
  font-family:var(--font-ui);
}
.seg button:last-child{ border-right:none; }
.seg button.active{ background:var(--ink); color:var(--bg); }
.tweak-row input[type=range]{ width:100%; }
.tweak-row .tog{
  display:flex; align-items:center; gap:8px; cursor:pointer;
}
.tweak-row .tog .knob{
  width:28px; height:16px; border-radius:99px; background:var(--line);
  position:relative; transition:background .15s;
}
.tweak-row .tog .knob::after{
  content:''; position:absolute; top:2px; left:2px; width:12px; height:12px;
  border-radius:50%; background:var(--panel); transition:transform .15s;
}
.tweak-row .tog.on .knob{ background:var(--accent); }
.tweak-row .tog.on .knob::after{ transform:translateX(12px); }

/* ============ Circumplex cells (row view) ============ */
.cx-cell{
  position:absolute; inset:6px 10px 6px 10px;
  display:grid; grid-template-columns: 74px 1fr; gap:14px; align-items:center;
}
.cx-thumb{ display:flex; align-items:center; justify-content:center; }
.cx-thumb svg.circumplex{ display:block; }
.cx-meta{ display:flex; flex-direction:column; gap:3px; min-width:0; }
.cx-quad{
  font-family:var(--font-mono); font-size:10px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink-3);
}
.cx-dom{
  display:flex; align-items:center; gap:6px;
  font-size:12.5px; color:var(--ink); font-weight:500;
}
.cx-dom-dot{ width:8px; height:8px; border-radius:50%; display:inline-block; }
.cx-axes{ font-size:10.5px; color:var(--ink-3); }
.cx-axes-sep{ margin:0 6px; color:var(--ink-4); }
.cx-act{ display:flex; align-items:center; gap:8px; margin-top:2px; }
.cx-act-bar{ flex:1; height:3px; background:var(--line-2); border-radius:2px; overflow:hidden; max-width:120px; }
.cx-act-fill{ height:100%; background:var(--accent); border-radius:2px; transition:width .25s; }
.cx-act-label{ font-size:9.5px; color:var(--ink-3); letter-spacing:.08em; }
.circumplex{ border-radius:50%; }
::-webkit-scrollbar{ width:10px; height:10px; }
::-webkit-scrollbar-thumb{ background:var(--line); border-radius:5px; }
::-webkit-scrollbar-thumb:hover{ background:var(--line-2); }
::-webkit-scrollbar-track{ background:transparent; }

/* utils */
.kv{ display:flex; justify-content:space-between; font-size:11.5px; color:var(--ink-2); margin:3px 0; }
.kv .k{ color:var(--ink-3); font-family:var(--font-mono); font-size:10.5px; letter-spacing:.04em; text-transform:uppercase; }
.kv .v{ font-family:var(--font-mono); color:var(--ink); }

.header-tweak-toggle{
  font-size:10.5px; letter-spacing:.14em; text-transform:uppercase;
  padding:5px 10px; border-radius:999px;
  border:1px solid var(--line); color:var(--ink-2);
  background:var(--panel-2); cursor:pointer;
}
.header-tweak-toggle:hover{ background:var(--panel); color:var(--ink); }
.header-tweak-toggle.active{ background:var(--ink); color:var(--bg); border-color:var(--ink); }

/* ============ BioSim module report panel ============ */
.biosim-panel{
  margin: 0 0 10px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  font-family: var(--font-ui);
}
.bs-header{
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 12px;
  border-bottom: 1px solid var(--hairline);
  background: linear-gradient(180deg, var(--panel-2), var(--panel));
}
.bs-header-l, .bs-header-r{ display:flex; align-items:center; gap:12px; }
.bs-badge{
  font-family: var(--font-mono);
  font-size: 9.5px; font-weight: 700; letter-spacing: .14em;
  padding: 3px 7px; border-radius: 4px;
  background: var(--ink); color: var(--bg); 
}
.bs-header-title{
  font-size: 11.5px; font-weight: 600; letter-spacing: .04em; color: var(--ink-2);
}
.bs-kv{ display:inline-flex; align-items:baseline; gap:5px; font-size: 10px; }
.bs-kv .bs-k{ color: var(--ink-4); font-family: var(--font-mono); letter-spacing:.06em; text-transform: uppercase; font-size: 9px; }
.bs-kv .bs-v{ color: var(--ink-2); font-weight: 500; }
.bs-kv .bs-v.mono, .bs-kv .bs-v.num{ font-family: var(--font-mono); }
.bs-toggle{
  background:none; border:1px solid var(--line); color: var(--ink-3);
  font-family: var(--font-mono); font-size: 11px;
  width: 20px; height: 20px; border-radius: 4px; cursor: pointer;
  display:flex; align-items:center; justify-content:center;
}
.bs-toggle:hover{ border-color: var(--ink-3); color: var(--ink); }

.bs-body{ padding: 10px 12px 12px; display:flex; flex-direction:column; gap: 10px; }

.bs-modules{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 8px 14px;
}
.bs-group{ display:flex; flex-direction:column; gap: 6px; }
.bs-group-head{
  display:flex; align-items:center; gap:6px;
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase;
}
.bs-group-dot{ width:6px; height:6px; border-radius:50%; }
.bs-group-ct{
  margin-left:auto; color: var(--ink-4); font-size: 9px; font-weight: 500;
  padding: 1px 5px; border: 1px solid var(--line); border-radius: 3px;
}
.bs-group-chips{ display:flex; flex-direction:column; gap: 4px; }

.bs-chip{
  display:grid; grid-template-columns: 1fr auto; grid-template-rows: auto auto auto;
  padding: 5px 8px;
  background: var(--bg-soft);
  border: 1px solid var(--line-2);
  border-radius: 4px;
  gap: 3px;
}
.bs-chip-proc{ background: transparent; border-style: dashed; }
.bs-chip-name{
  grid-column: 1 / -1;
  font-family: var(--font-mono); font-size: 10px; font-weight: 600;
  color: var(--ink-2); letter-spacing: .02em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.bs-chip-bar{
  grid-column: 1 / -1;
  height: 3px; background: var(--line-2); border-radius: 2px; overflow: hidden;
}
.bs-chip-fill{ height: 100%; transition: width .3s ease, background .3s ease; }
.bs-chip-meta{
  grid-column: 1 / -1;
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--font-mono); font-size: 9.5px;
}
.bs-chip-val{ color: var(--ink); font-weight: 600; }
.bs-chip-u{ color: var(--ink-4); font-size: 9px; }
.bs-chip-type{ color: var(--ink-3); font-size: 9px; letter-spacing:.04em; }
.bs-chip-flow{ color: var(--ink-3); }

.bs-sub{
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 700;
  letter-spacing: .12em; color: var(--ink-3);
  display:flex; align-items:baseline; gap: 8px;
  padding-bottom: 4px;
  border-bottom: 1px dashed var(--line-2);
}
.bs-sub-ct{ font-weight:400; color: var(--ink-4); letter-spacing:.02em; font-size: 9px; }

.bs-sensors-row, .bs-malf-row{ display:flex; flex-direction:column; gap: 6px; }

.bs-sensors-list{
  display:flex; flex-wrap: wrap; gap: 6px;
}
.bs-sensor{
  display:flex; align-items:baseline; gap: 5px;
  padding: 3px 8px;
  background: var(--bg-soft);
  border: 1px solid var(--line-2);
  border-radius: 14px;
  font-family: var(--font-mono); font-size: 10px;
}
.bs-sensor.alarm{ border-color: var(--warn); background: oklch(from var(--warn) l c h / .08); }
.bs-sensor-name{ color: var(--ink-3); font-size: 9px; letter-spacing:.04em; text-transform: uppercase; }
.bs-sensor-val{ font-weight: 600; color: var(--ink); }
.bs-sensor-u{ color: var(--ink-4); font-size: 9px; }
.bs-sensor-dot{ width:6px; height:6px; border-radius:50%; margin-left: 2px; }

.bs-malf-list{
  display:flex; flex-wrap: wrap; gap: 6px;
}
.bs-empty{
  font-family: var(--font-mono); font-size: 10px; color: var(--ink-4); font-style: italic;
}
.bs-malf{
  display:flex; align-items:center; gap: 6px;
  padding: 3px 8px;
  border-radius: 4px;
  font-family: var(--font-mono); font-size: 10px;
  border: 1px solid var(--line-2);
  background: var(--bg-soft);
}
.bs-malf.low   { border-color: oklch(72% 0.12 80); }
.bs-malf.mid   { border-color: var(--warn); background: oklch(from var(--warn) l c h / .08); }
.bs-malf.sev   { border-color: var(--alert); background: oklch(from var(--alert) l c h / .10); }
.bs-malf.active{ box-shadow: 0 0 0 1px currentColor inset; }
.bs-malf-sev{
  font-size: 9px; font-weight: 700; letter-spacing:.08em;
  padding: 1px 5px; border-radius: 3px;
  background: var(--ink); color: var(--bg);
}
.bs-malf.mid .bs-malf-sev{ background: var(--warn); color: var(--bg); }
.bs-malf.sev .bs-malf-sev{ background: var(--alert); color: var(--bg); }
.bs-malf-mod{ color: var(--ink-2); }
.bs-malf-sol{ color: var(--ink-4); font-size: 9px; }

/* closed state */
.biosim-panel.closed .bs-body{ display:none; }

/* ============ Enhancements: risk band / sparklines / resources / overlay / comm ============ */

/* Header hierarchy */
.brand-meta{ font-family: var(--font-mono); font-size:9.5px; color:var(--ink-3); letter-spacing:.10em; margin-top:2px; }
.telem{ display:flex; align-items:center; gap:16px; }
.telem-item{ display:flex; flex-direction:column; gap:3px; padding:0 10px; border-right:1px solid var(--line-2); }
.telem-item:last-child{ border-right:0; }
.telem-label{
  font-family:var(--font-mono); font-size:9px; letter-spacing:.10em;
  color: var(--ink-4); text-transform:uppercase;
}
.telem-val{ font-size:14px; font-weight:600; color:var(--ink); line-height:1; }
.telem-val.big{ font-size:22px; font-weight:600; letter-spacing:-0.01em; }
.telem-val-row{ display:flex; align-items:center; gap:8px; }
.telem-u{ font-size:11px; color:var(--ink-4); font-weight:500; margin-left:3px; }
.t-primary .telem-val.big{ font-size:26px; }
.sparkline{ display:block; }
.alert-chip{
  display:inline-block; padding:2px 7px; border-radius:12px;
  font-size:14px; font-weight:700; font-family:var(--font-mono); letter-spacing:.04em;
  cursor:pointer; transition: transform .1s;
}
.alert-chip.red{ background: oklch(from var(--alert) l c h / .14); color: var(--alert); }
.alert-chip.amber{ background: oklch(from var(--warn) l c h / .14); color: var(--warn); margin-left:6px; }
.alert-chip:hover{ transform:scale(1.04); }

/* Earth comm widget */
.earth-comm{
  display:flex; align-items:center; gap:8px;
  padding:4px 10px; border-left:1px solid var(--line-2);
}
.ec-text{ display:flex; flex-direction:column; gap:1px; }
.ec-label{ font-family:var(--font-mono); font-size:9px; letter-spacing:.10em; color:var(--ink-4); text-transform:uppercase; }
.ec-val{ font-size:14px; font-weight:600; color: var(--accent); font-family:var(--font-mono); line-height:1; }
.ec-au{ font-size:9.5px; color:var(--ink-4); font-family:var(--font-mono); }

/* Timeline stack (ribbon + risk band + emotion overlay) */
.timeline-stack{ position:relative; margin-bottom:10px; }

.risk-band{
  margin:4px 0 0; position:relative; height: 24px;
  border: 1px solid var(--line); border-radius: 4px; overflow:hidden;
  background: var(--panel);
}
.risk-band-grad{ position:absolute; inset:0; opacity:.45; }
.risk-overlay{ position:absolute; inset:0; width:100%; height:100%; }
.risk-band-legend{
  position:absolute; top:50%; transform:translateY(-50%); left:8px; right:8px;
  display:flex; justify-content:space-between; align-items:center;
  font-family: var(--font-mono); font-size: 8.5px; letter-spacing:.12em;
  color: var(--ink-2); text-transform: uppercase;
  pointer-events:none;
}
.rb-legend-keys{ display:flex; gap:10px; }
.rb-legend-k{ display:inline-flex; align-items:center; gap:4px; }
.rb-dash{ display:inline-block; width:14px; height:1px; border-top:1px dashed var(--ink-2); }
.rb-solid{ display:inline-block; width:14px; height:1.6px; background: var(--ink); }

.emo-overlay-wrap{
  position: absolute; top: 0; left: 0; right:0;
  pointer-events:none;
}
.emo-overlay-svg{
  position:absolute; top: 20px; left:0; right:0; height: calc(100% - 44px); width: 100%;
}
.emo-overlay-label{
  position:absolute; right:10px; top: 24px;
  font-family:var(--font-mono); font-size: 10px; font-weight: 600;
  letter-spacing:.06em;
  background: oklch(from var(--panel) l c h / .92);
  padding: 2px 7px; border-radius: 4px;
  border: 1px solid var(--line);
}

/* Legend chip focus state */
.legend-chip{ transition: border-color .1s, background .1s; }
.legend-chip.focus{ border-color: var(--ink); background: var(--bg-soft); box-shadow: 0 0 0 1px var(--ink); }
.legend-hint{
  font-family:var(--font-mono); font-size:9px; letter-spacing:.06em;
  color: var(--ink-4); padding-left:8px; align-self:center;
}

/* Resource Allocation */
.resources{
  margin: 10px 0;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 10px 12px;
  box-shadow: var(--shadow-sm);
}
.res-head{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:8px; padding-bottom:6px; border-bottom:1px dashed var(--line-2); gap: 12px; }
.res-title{ font-family:var(--font-mono); font-size:10px; font-weight:700; letter-spacing:.14em; color:var(--ink-2); }
.res-sub{ font-family:var(--font-mono); font-size:9px; color:var(--ink-4); letter-spacing:.06em; margin-left: auto; }
.res-toggle{
  display:inline-flex; align-items:center; gap:5px;
  background: var(--bg-soft); border: 1px solid var(--line-2); border-radius: 3px;
  padding: 3px 7px; cursor: pointer;
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 700; letter-spacing:.12em;
  color: var(--ink-3); transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.res-toggle:hover{ color: var(--ink); border-color: var(--line); background: var(--panel); }
.res-toggle-chev{ font-size: 10px; display:inline-block; transition: transform .18s ease; }
.resources.is-collapsed{ padding-bottom: 8px; }
.resources.is-collapsed .res-head{ margin-bottom: 0; border-bottom: none; padding-bottom: 4px; }
.res-collapsed-summary{
  display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 4px 14px; padding-top: 6px;
}
.rcs-chip{
  display: grid; grid-template-columns: 58px 34px 1fr 40px; gap: 6px;
  align-items: center; font-family: var(--font-mono); font-size: 10px;
  padding: 3px 4px;
}
.rcs-lbl{ font-size: 9.5px; letter-spacing:.1em; color: var(--ink-3); font-weight: 700; }
.rcs-now{ color: var(--ink); font-weight: 600; font-size: 11px; text-align: right; }
.rcs-mini{
  position: relative; height: 6px; background: var(--bg-soft);
  border: 1px solid var(--line-2); border-radius: 2px; overflow: hidden;
}
.rcs-mini-now{ position: absolute; top:0; left:0; height: 100%; background: var(--ink-3); opacity: .55; }
.rcs-mini-end{ position: absolute; top:-2px; width: 2px; height: 10px; background: var(--accent); }
.rcs-chip.crit .rcs-mini-end{ background: var(--alert); }
.rcs-end{ color: var(--ink-3); text-align: right; font-size: 10px; }
.rcs-end.bad{ color: var(--alert); font-weight: 700; }
.rcs-end.warn{ color: var(--warn); font-weight: 600; }
.res-rows{ display:grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 10px 18px; }
.res-row{ display:grid; grid-template-columns: 84px 1fr; gap:10px; align-items:center; }
.res-row-l{ display:flex; flex-direction:column; gap:2px; }
.res-label{ font-family:var(--font-mono); font-size:9.5px; letter-spacing:.1em; color:var(--ink-3); font-weight:600; }
.res-val{ font-size:13px; font-weight:600; color: var(--ink); }
.res-u{ color: var(--ink-4); font-size: 10px; font-weight: 400; margin-left: 2px; }
.res-bar{ display:flex; flex-direction:column; gap:3px; }
.res-bar-track{
  position:relative; height: 12px; border-radius: 3px;
  background: linear-gradient(90deg,
    oklch(from var(--ok) l c h / .10),
    oklch(from var(--warn) l c h / .10),
    oklch(from var(--alert) l c h / .10));
  overflow: hidden; border: 1px solid var(--line-2);
}
.res-bar-now{
  position:absolute; left:0; top:0; bottom:0;
  background: linear-gradient(90deg, oklch(from var(--ok) l c h / .35), oklch(from var(--accent) l c h / .40));
  border-right: 1.5px solid var(--ink);
}
.res-bar-end{
  position:absolute; top:-2px; bottom:-2px; width:2px;
  background: var(--ink-3);
}
.res-bar-end::before{
  content:'proj'; position:absolute; left:4px; top:0;
  font-family: var(--font-mono); font-size: 8px; color: var(--ink-3);
  background: var(--panel); padding: 0 3px; border-radius: 2px;
  white-space: nowrap; letter-spacing:.05em;
}
.res-curve{ position:absolute; inset:0; opacity:.55; }
.res-bar-meta{ display:flex; justify-content:space-between; font-family:var(--font-mono); font-size:9px; color:var(--ink-3); }
.res-bar-meta .bad{ color: var(--alert); font-weight: 600; }
.res-bar-meta .warn{ color: var(--warn); font-weight: 600; }
.res-row.crit .res-label{ color: var(--alert); }

/* ALERT chip click affordance + focus pulse on pod */
.pod-alert.clickable{ cursor:pointer; }
.pod-alert.clickable:hover{ transform: scale(1.05); }
.pod-wrap{ transition: box-shadow .3s; border-radius: var(--radius); }
.pod-wrap.pod-focus{
  box-shadow: 0 0 0 2px var(--accent), 0 0 0 4px oklch(from var(--accent) l c h / .18);
  animation: podPulse 1.2s ease-out 2;
}
@keyframes podPulse{
  0% { box-shadow: 0 0 0 2px var(--accent), 0 0 0 2px oklch(from var(--accent) l c h / .4); }
  100% { box-shadow: 0 0 0 2px var(--accent), 0 0 0 10px oklch(from var(--accent) l c h / 0); }
}


/* ============ CrewDetailFull — full-screen per-crew dashboard ============ */
.crew-detail-full{
  position: fixed; inset: 0;
  background: var(--bg);
  z-index: 100;
  display: flex; flex-direction: column;
  overflow: hidden;
  font-family: var(--font-body);
}

/* Header */
.cdf-header{
  flex: 0 0 auto;
  display:grid; grid-template-columns: 1fr auto 1fr;
  align-items: center; gap: 24px;
  padding: 14px 24px;
  border-bottom: 1px solid var(--line);
  background: var(--panel);
}
.cdf-head-l{ display:flex; align-items:center; gap:20px; }
.cdf-back{
  background: transparent; border: 1px solid var(--line);
  font-family: var(--font-mono); font-size: 11px; letter-spacing:.12em;
  padding: 8px 14px; border-radius: 4px; color: var(--ink-2);
  cursor: pointer; font-weight: 600; text-transform: uppercase;
  transition: background .15s, color .15s, border-color .15s;
}
.cdf-back:hover{ background: var(--bg-soft); color: var(--ink); border-color: var(--ink-3); }
.cdf-back-arrow{ margin-right: 4px; font-size: 13px; }
.cdf-id{ display:flex; flex-direction:column; gap:2px; padding: 0 14px; border-left: 1px solid var(--line); border-right: 1px solid var(--line); }
.cdf-code{ font-family: var(--font-mono); font-size: 15px; font-weight: 700; letter-spacing:.08em; color: var(--ink); }
.cdf-flag{ font-family: var(--font-mono); font-size: 10px; letter-spacing:.12em; color: var(--ink-3); }
.cdf-ident{ display:flex; flex-direction:column; gap:2px; }
.cdf-name{ font-size: 20px; font-weight: 600; color: var(--ink); letter-spacing:-.01em; line-height:1.15; }
.cdf-role{ font-family: var(--font-mono); font-size: 11px; letter-spacing:.08em; color: var(--ink-3); text-transform: uppercase; }

.cdf-head-c{ display:flex; gap: 20px; align-items: center; }
.cdf-emo, .cdf-sol{
  display:flex; align-items: baseline; gap: 8px;
  padding: 10px 16px; background: var(--bg-soft);
  border-radius: 6px; border: 1px solid var(--line);
}
.cdf-emo-k, .cdf-sol-k{ font-family: var(--font-mono); font-size: 10px; letter-spacing:.14em; color: var(--ink-3); font-weight: 600; }
.cdf-emo-v{ font-size: 16px; font-weight: 600; letter-spacing:-.01em; }
.cdf-emo-n, .cdf-sol-n{ font-family: var(--font-mono); font-size: 17px; font-weight: 700; color: var(--ink); }
.cdf-sol-sub{ font-family: var(--font-mono); font-size: 11px; color: var(--ink-4); }
.cdf-alert{
  display:flex; align-items: center; gap: 8px;
  padding: 10px 14px; border-radius: 6px; font-family: var(--font-mono);
  font-size: 11px; font-weight: 700; letter-spacing:.14em;
  border: 1px solid transparent;
}
.cdf-alert.sev-green{ background: oklch(from var(--ok) l c h / .10); color: var(--ok); border-color: oklch(from var(--ok) l c h / .3); }
.cdf-alert.sev-amber{ background: oklch(from var(--warn) l c h / .12); color: var(--warn); border-color: oklch(from var(--warn) l c h / .35); }
.cdf-alert.sev-red{ background: oklch(from var(--alert) l c h / .12); color: var(--alert); border-color: oklch(from var(--alert) l c h / .35); }
.cdf-alert-dot{ width: 8px; height: 8px; border-radius: 50%; background: currentColor; box-shadow: 0 0 8px currentColor; }

.cdf-head-r{ justify-self: end; max-width: 440px; }
.cdf-bio-line{
  font-size: 11.5px; color: var(--ink-3); font-style: italic;
  line-height: 1.45; text-align: right;
}

/* 3-column grid */
.cdf-grid{
  flex: 1 1 auto;
  display: grid; grid-template-columns: 340px minmax(0, 1fr) 400px;
  gap: 1px; background: var(--line);
  overflow: hidden;
}
.cdf-col{
  background: var(--bg);
  overflow-y: auto;
  padding: 16px 18px;
  display: flex; flex-direction: column; gap: 16px;
}
.cdf-col::-webkit-scrollbar{ width: 8px; }
.cdf-col::-webkit-scrollbar-thumb{ background: var(--line-2); border-radius: 4px; }

.cdf-sec{
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 14px 16px;
  box-shadow: var(--shadow-sm);
}
.cdf-sec-head{
  display: flex; align-items: baseline; gap: 8px;
  border-bottom: 1px dashed var(--line-2);
  padding-bottom: 8px; margin-bottom: 12px;
}
.cdf-sec-n{ font-family: var(--font-mono); font-size: 10px; font-weight:700; letter-spacing:.1em; color: var(--accent); padding: 2px 6px; background: oklch(from var(--accent) l c h / .10); border-radius: 3px; }
.cdf-sec-t{ font-family: var(--font-mono); font-size: 11px; font-weight: 700; letter-spacing:.14em; color: var(--ink); text-transform: uppercase; }
.cdf-sec-sub{ font-family: var(--font-mono); font-size: 9.5px; letter-spacing:.08em; color: var(--ink-4); margin-left: auto; }

/* --- Left column widgets --- */
.cdf-radar-wrap{ display:flex; flex-direction: column; align-items:center; gap: 10px; }
.taste-radar{ flex-shrink: 0; }
.cdf-radar-legend{
  font-family: var(--font-mono); font-size: 10px; color: var(--ink-3);
  display: flex; flex-direction: row; flex-wrap: wrap;
  justify-content: center; align-items: center; gap: 6px 14px;
  padding-top: 6px; border-top: 1px dashed var(--line-2);
  width: 100%;
}
.rl-row{ display: flex; align-items: center; gap: 6px; }
.rl-sw{ width: 14px; height: 3px; border-radius: 2px; background: oklch(55% 0.19 30); }
.rl-sw.dash{ background: transparent; border-top: 2px dashed var(--ink-3); }
.rl-meta{ font-style: italic; color: var(--ink-4); margin-top: 4px; }

.prop-wrap{ display:flex; flex-direction:column; gap: 8px; }
.prop-header{ display:flex; align-items:center; gap: 10px; }
.prop-badge{
  font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing:.1em;
  padding: 4px 8px; border-radius: 3px;
}
.prop-badge.prop-super{ background: oklch(55% 0.19 20 / .14); color: oklch(48% 0.18 20); }
.prop-badge.prop-medium{ background: oklch(55% 0.18 280 / .14); color: oklch(48% 0.18 280); }
.prop-badge.prop-non{ background: oklch(55% 0.15 200 / .14); color: oklch(48% 0.17 200); }
.prop-bitter{ font-size: 11px; color: var(--ink-3); }
.prop-bitter b{ color: var(--ink); font-family: var(--font-mono); }
.prop-delta{
  font-family: var(--font-mono); font-size: 10px; letter-spacing:.04em;
  margin-left: auto; color: var(--ink-3);
}
.prop-legend{ display:flex; gap: 14px; font-family: var(--font-mono); font-size: 9.5px; color: var(--ink-3); flex-wrap: wrap; }
.prop-legend span{ display:inline-flex; align-items:center; gap: 4px; }
.prop-legend .ps{ display:inline-block; width: 14px; height: 2px; }
.prop-legend b{ color: var(--ink-2); font-weight: 700; }
.ps.sup{ background: oklch(55% 0.19 20); }
.ps.med{ background: oklch(55% 0.18 280); }
.ps.non{ background: oklch(55% 0.15 200); }

.prop-taste-strip{
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px;
  margin-top: 6px;
}
.prop-taste-chip{
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  padding: 5px 4px;
  background: var(--bg-soft); border: 1px solid var(--line-2); border-radius: 3px;
  font-family: var(--font-mono); font-size: 9.5px; letter-spacing:.08em;
  color: var(--ink-3); cursor: pointer;
  transition: background .12s ease, color .12s ease, border-color .12s ease;
}
.prop-taste-chip:hover{ color: var(--ink-2); border-color: var(--line); }
.prop-taste-chip.is-sel{ font-weight: 700; }
.prop-taste-chip .ptc-n{ font-size: 10px; color: inherit; opacity: .85; }

.food-wall{ display:grid; grid-template-columns: 1fr 1fr; gap: 6px; }
.food-card{
  background: var(--bg-soft); border: 1px solid var(--line-2); border-radius: 4px;
  padding: 7px 9px; display: flex; flex-direction: column; gap: 4px;
}
.food-card.food-comfort{ border-left: 2px solid oklch(62% 0.15 140); }
.food-card.food-aversion{ border-left: 2px solid oklch(58% 0.16 25); }
.food-name{ font-size: 11.5px; font-weight: 600; color: var(--ink); line-height: 1.15; }
.food-score{ display:flex; align-items:center; gap: 6px; }
.food-score-bar{ flex: 1; height: 4px; background: var(--line-2); border-radius: 2px; overflow: hidden; }
.food-score-fill{ height: 100%; border-radius: 2px; }
.food-score-n{ font-family: var(--font-mono); font-size: 10px; color: var(--ink-2); font-weight: 600; min-width: 18px; text-align: right; }
.food-meta{ display:flex; justify-content: space-between; font-family: var(--font-mono); font-size: 9px; letter-spacing:.06em; color: var(--ink-4); }
.food-type{ text-transform: uppercase; }

.novelty-spectrum{ display: flex; flex-direction: column; gap: 10px; }
.ns-row{ display: grid; grid-template-columns: 74px 1fr 58px; gap: 8px; align-items: center; }
.ns-lbl, .ns-lbl-end{ font-family: var(--font-mono); font-size: 9.5px; letter-spacing:.1em; color: var(--ink-3); }
.ns-lbl-end{ text-align: right; }
.ns-bar{ position: relative; height: 12px; border-radius: 6px; background: var(--line-2); overflow: visible; }
.ns-bar-grad{ position:absolute; inset:0; border-radius: 6px;
  background: linear-gradient(90deg, oklch(62% 0.03 250), oklch(58% 0.15 145), oklch(55% 0.18 80), oklch(55% 0.19 25)); opacity: .35; }
.ns-bar-grad-r{ background: linear-gradient(90deg, oklch(58% 0.15 145), oklch(62% 0.03 250), oklch(55% 0.19 25)); }
.ns-mark{ position:absolute; top:-4px; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; }
.ns-tick{ width: 3px; height: 20px; background: var(--ink); border-radius: 2px; box-shadow: 0 0 0 2px var(--panel); }
.ns-val{ font-family: var(--font-mono); font-size: 10px; font-weight: 700; color: var(--ink); margin-top: 2px; }
.ns-foot{ font-size: 10.5px; color: var(--ink-3); margin-top: 6px; font-style: italic; }
.ns-foot b{ color: var(--ink); font-style: normal; }

/* --- Center column: Acceptance Chart --- */
.acc-chart-wrap{ display:flex; flex-direction:column; gap: 12px; }
.acc-head{ display:flex; justify-content:space-between; align-items: baseline; }
.acc-title{ font-family: var(--font-mono); font-size: 10px; letter-spacing:.12em; color: var(--ink-2); font-weight: 700; }
.acc-legend-hint{ font-family: var(--font-mono); font-size: 9.5px; color: var(--ink-4); font-style: italic; }
.acc-chart-row{ display:flex; flex-direction: column; gap: 10px; }
.acc-svg{ width: 100%; height: auto; background: var(--bg-soft); border: 1px solid var(--line-2); border-radius: 4px; }
.acc-legend{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px 14px; font-family: var(--font-mono); padding: 18px 10px 8px; background: var(--bg-soft); border: 1px solid var(--line-2); border-radius: 4px; }
.acc-leg-row{ display: grid; grid-template-columns: 10px 1fr 26px; gap: 6px; align-items: center; font-size: 10.5px; cursor: pointer; padding: 3px 5px; border-radius: 3px; transition: background .1s; }
.acc-leg-row:hover{ background: var(--bg-soft); }
.acc-leg-row.muted{ opacity: 0.35; }
.acc-leg-sw{ width: 10px; height: 10px; border-radius: 2px; }
.acc-leg-nm{ color: var(--ink-2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.acc-leg-val{ color: var(--ink-3); text-align: right; font-weight: 600; }
.acc-leg-val.bad{ color: var(--alert); }
.acc-leg-val.warn{ color: var(--warn); }

.rot-advisories{ display: flex; flex-direction: column; gap: 6px; padding: 10px 12px; background: oklch(from var(--alert) l c h / .06); border: 1px solid oklch(from var(--alert) l c h / .25); border-radius: 4px; }
.rot-head{ font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing: .12em; color: var(--alert); }
.rot-card{ display:grid; grid-template-columns: 8px 120px 1fr; gap: 8px; align-items: center; font-size: 11px; color: var(--ink-2); }
.rot-dot{ width: 8px; height: 8px; border-radius: 50%; background: var(--alert); }
.rot-name{ font-weight: 600; color: var(--ink); }
.rot-meta{ font-family: var(--font-mono); font-size: 10px; color: var(--ink-3); }
.rot-meta b{ color: var(--alert); }

.acc-ann{ padding: 10px 12px; background: var(--bg-soft); border: 1px solid var(--line-2); border-radius: 4px; }
.acc-ann-head{ font-family: var(--font-mono); font-size: 9.5px; letter-spacing:.12em; color: var(--ink-3); font-weight: 700; margin-bottom: 4px; }
.acc-ann-body{ font-size: 11px; color: var(--ink-3); line-height: 1.5; }
.acc-ann-body .mono{ font-family: var(--font-mono); background: var(--panel); padding: 1px 5px; border-radius: 2px; color: var(--ink); }

/* Vitals + Meal Log */
.vitals-meal{ display: flex; flex-direction: column; gap: 14px; }
.vm-col{ display: flex; flex-direction: column; gap: 8px; }
.vm-title{ font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing:.12em; color: var(--ink-2); }
.vm-svg{ width: 100%; height: auto; background: var(--bg-soft); border: 1px solid var(--line-2); border-radius: 4px; }
.vm-legend{ display: flex; gap: 12px; font-family: var(--font-mono); font-size: 10px; color: var(--ink-3); }
.vm-lg{ display: inline-flex; align-items: center; gap: 4px; }
.vm-sw{ width: 10px; height: 2px; border-radius: 1px; }

.meal-rows{ display: flex; flex-direction: column; gap: 3px; max-height: 220px; overflow-y: auto; }
.meal-row{
  display: grid; grid-template-columns: 44px 70px 1fr 48px 80px; gap: 8px;
  align-items: center; padding: 6px 8px;
  background: var(--bg-soft); border: 1px solid var(--line-2); border-radius: 3px;
  font-size: 11px;
}
.meal-sol{ font-family: var(--font-mono); color: var(--ink-3); font-weight: 600; }
.meal-type{ font-family: var(--font-mono); font-size: 10px; letter-spacing:.06em; color: var(--ink-3); text-transform: uppercase; }
.meal-food{ color: var(--ink); font-weight: 500; }
.meal-kcal{ font-family: var(--font-mono); color: var(--ink-3); text-align: right; font-size: 10px; }
.meal-accept{ display:flex; align-items: center; gap: 6px; }
.meal-accept-bar{ flex: 1; height: 5px; background: var(--line-2); border-radius: 3px; overflow: hidden; }
.meal-accept-fill{ height: 100%; border-radius: 3px; }
.meal-accept-n{ font-family: var(--font-mono); font-size: 10px; color: var(--ink-2); font-weight: 600; min-width: 20px; text-align: right; }

/* --- Right column: Compensation Lanes --- */
.comp-lanes{ display: flex; flex-direction: column; gap: 12px; }
.comp-lane{
  padding: 10px 12px; background: var(--bg-soft);
  border: 1px solid var(--line-2); border-radius: 4px;
}
.comp-lane.zone-red{ border-left: 3px solid var(--alert); }
.comp-lane.zone-amber{ border-left: 3px solid var(--warn); }
.comp-lane.zone-ok{ border-left: 3px solid var(--ok); }
.comp-lane.zone-cool{ border-left: 3px solid var(--ink-3); }
.cl-head{ display:flex; align-items: baseline; gap: 8px; margin-bottom: 6px; }
.cl-label{ font-family: var(--font-mono); font-size: 11px; font-weight: 700; letter-spacing:.14em; color: var(--ink); }
.cl-unit{ font-family: var(--font-mono); font-size: 9.5px; color: var(--ink-4); }
.cl-now{ margin-left: auto; font-family: var(--font-mono); font-size: 18px; font-weight: 700; }
.cl-now.zone-red{ color: var(--alert); }
.cl-now.zone-amber{ color: var(--warn); }
.cl-now.zone-ok{ color: var(--ok); }
.cl-now.zone-cool{ color: var(--ink-2); }
.cl-pct{ font-size: 10px; font-weight: 600; margin-left: 1px; }
.cl-svg{ width: 100%; height: 44px; display: block; }
.cl-foot{ display:flex; justify-content: space-between; font-family: var(--font-mono); font-size: 9px; letter-spacing:.08em; color: var(--ink-4); margin-top: 2px; }

/* Recommendation cards */
.rec-list{ display: flex; flex-direction: column; gap: 10px; }
.rec-empty{ font-size: 12px; color: var(--ink-3); font-style: italic; padding: 18px 12px; text-align: center; background: var(--bg-soft); border: 1px dashed var(--line-2); border-radius: 4px; }
.rec-card{
  padding: 10px 12px; border-radius: 4px;
  background: oklch(96% 0.02 45);
  border: 1px solid oklch(82% 0.08 45);
  border-left: 3px solid oklch(62% 0.15 50);
  display: flex; flex-direction: column; gap: 6px;
}
.rec-card.sev-critical{ background: oklch(96% 0.03 25); border-color: oklch(78% 0.1 25); border-left-color: var(--alert); }
.rec-head{ display: flex; align-items: center; gap: 8px; }
.rec-sev{
  font-family: var(--font-mono); font-size: 9.5px; letter-spacing:.12em; font-weight: 700;
  padding: 2px 6px; border-radius: 2px;
}
.rec-sev.sev-warn{ background: oklch(65% 0.15 60 / .18); color: oklch(48% 0.15 50); }
.rec-sev.sev-critical{ background: oklch(60% 0.18 25 / .18); color: var(--alert); }
.rec-lane{ font-family: var(--font-mono); font-size: 9.5px; letter-spacing:.1em; color: var(--ink-3); font-weight: 600; }
.rec-headline{ font-size: 12.5px; font-weight: 600; color: var(--ink); line-height: 1.3; }
.rec-body{ display: flex; flex-direction: column; gap: 3px; }
.rec-row{ display: grid; grid-template-columns: 70px 1fr; gap: 8px; font-size: 10.5px; line-height: 1.4; }
.rec-k{ font-family: var(--font-mono); font-size: 9.5px; letter-spacing:.08em; color: var(--ink-4); font-weight: 700; text-transform: uppercase; padding-top: 2px; }
.rec-v{ color: var(--ink-2); }
.rec-v.rec-exp{ color: oklch(48% 0.15 140); font-weight: 500; }



/* ============ Dark charcoal variant for the full-screen detail view ============
   ONLY applies when root theme is graphite — clinical and mars inherit root palette. */
[data-theme="graphite"] .crew-detail-full{
  /* Scoped charcoal palette — pastels tuned for dark surface */
  --bg: oklch(18% 0.008 250);
  --bg-soft: oklch(22% 0.010 250);
  --panel: oklch(24% 0.012 250);
  --panel-2: oklch(27% 0.014 250);
  --ink: oklch(96% 0.004 240);
  --ink-2: oklch(84% 0.008 240);
  --ink-3: oklch(66% 0.014 240);
  --ink-4: oklch(50% 0.016 240);
  --line: oklch(32% 0.012 250);
  --line-2: oklch(28% 0.012 250);
  --accent: oklch(75% 0.14 200);      /* pastel cyan */
  --ok: oklch(74% 0.13 150);          /* pastel green */
  --warn: oklch(80% 0.14 80);         /* pastel amber */
  --alert: oklch(72% 0.16 20);        /* pastel coral */
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.35), 0 0 0 1px oklch(30% 0.010 250 / .6);

  color: var(--ink);
  background: var(--bg);
}

/* Header bar on charcoal */
[data-theme="graphite"] .crew-detail-full .cdf-header{
  background: linear-gradient(180deg, oklch(22% 0.010 250), oklch(19% 0.010 250));
  border-bottom: 1px solid var(--line);
}
[data-theme="graphite"] .crew-detail-full .cdf-back{
  background: oklch(24% 0.012 250); color: var(--ink-2);
  border-color: var(--line);
}
[data-theme="graphite"] .crew-detail-full .cdf-back:hover{
  background: oklch(28% 0.014 250); color: var(--ink);
  border-color: var(--accent);
}

/* Grid backgrounds */
[data-theme="graphite"] .crew-detail-full .cdf-grid{ background: var(--line); }
[data-theme="graphite"] .crew-detail-full .cdf-col{ background: var(--bg); }
[data-theme="graphite"] .crew-detail-full .cdf-sec{
  background: var(--panel); border-color: var(--line);
  box-shadow: inset 0 1px 0 oklch(100% 0 0 / 0.03);
}

/* Section headers — pastel cyan eyebrow */
[data-theme="graphite"] .crew-detail-full .cdf-sec-n{
  background: oklch(from var(--accent) l c h / .16);
  color: var(--accent);
}

/* Left column chips */
[data-theme="graphite"] .crew-detail-full .prop-badge.prop-super{   background: oklch(72% 0.17 20 / .22);  color: oklch(85% 0.14 25);  }
[data-theme="graphite"] .crew-detail-full .prop-badge.prop-medium{  background: oklch(72% 0.16 280 / .22); color: oklch(85% 0.13 280); }
[data-theme="graphite"] .crew-detail-full .prop-badge.prop-non{     background: oklch(72% 0.14 200 / .22); color: oklch(85% 0.12 200); }
[data-theme="graphite"] .crew-detail-full .prop-legend .ps.sup{ background: oklch(78% 0.16 20);  }
[data-theme="graphite"] .crew-detail-full .prop-legend .ps.med{ background: oklch(78% 0.14 280); }
[data-theme="graphite"] .crew-detail-full .prop-legend .ps.non{ background: oklch(78% 0.13 200); }

/* Radar */
[data-theme="graphite"] .crew-detail-full .taste-radar path[stroke-dasharray="4 3"]{ stroke: oklch(60% 0.015 240); }
[data-theme="graphite"] .crew-detail-full .taste-radar path[fill*="oklch(65% 0.02"]{ fill: oklch(60% 0.010 240 / .10); }
[data-theme="graphite"] .crew-detail-full .taste-radar path[fill*="oklch(60% 0.15 30"]{ fill: oklch(72% 0.16 30 / .22); stroke: oklch(82% 0.15 30); }
[data-theme="graphite"] .crew-detail-full .taste-radar circle[fill*="oklch(55% 0.19 30)"]{ fill: oklch(82% 0.15 30); }

/* Food wall */
[data-theme="graphite"] .crew-detail-full .food-card{ background: var(--bg-soft); border-color: var(--line-2); }
[data-theme="graphite"] .crew-detail-full .food-card.food-comfort{ border-left-color: oklch(76% 0.14 145); }
[data-theme="graphite"] .crew-detail-full .food-card.food-aversion{ border-left-color: oklch(76% 0.16 25); }

/* Novelty spectrum */
[data-theme="graphite"] .crew-detail-full .ns-bar{ background: oklch(28% 0.012 250); }
[data-theme="graphite"] .crew-detail-full .ns-bar-grad{ opacity: .55; }
[data-theme="graphite"] .crew-detail-full .ns-tick{ background: var(--ink); box-shadow: 0 0 0 2px var(--panel), 0 0 8px oklch(0% 0 0 / .6); }

/* Acceptance chart */
[data-theme="graphite"] .crew-detail-full .acc-svg{ background: var(--bg-soft); border-color: var(--line-2); }
[data-theme="graphite"] .crew-detail-full .acc-legend{ scrollbar-color: var(--line) transparent; }
[data-theme="graphite"] .crew-detail-full .acc-leg-row:hover{ background: var(--bg-soft); }

[data-theme="graphite"] .crew-detail-full .rot-advisories{
  background: oklch(from var(--alert) l c h / .12);
  border-color: oklch(from var(--alert) l c h / .4);
}

[data-theme="graphite"] .crew-detail-full .acc-ann{ background: var(--bg-soft); border-color: var(--line-2); }
[data-theme="graphite"] .crew-detail-full .acc-ann-body .mono{ background: oklch(20% 0.008 250); color: var(--ink); }

/* Vitals + Meal rows */
[data-theme="graphite"] .crew-detail-full .vm-svg{ background: var(--bg-soft); border-color: var(--line-2); }
[data-theme="graphite"] .crew-detail-full .meal-row{ background: var(--bg-soft); border-color: var(--line-2); }

/* Compensation lanes */
[data-theme="graphite"] .crew-detail-full .comp-lane{ background: var(--bg-soft); border-color: var(--line-2); }

/* Recommendation cards — warm amber on charcoal */
[data-theme="graphite"] .crew-detail-full .rec-card{
  background: linear-gradient(135deg, oklch(30% 0.08 55), oklch(26% 0.06 45));
  border: 1px solid oklch(55% 0.14 55 / .5);
  border-left: 3px solid oklch(78% 0.16 55);
  color: oklch(95% 0.02 60);
}
[data-theme="graphite"] .crew-detail-full .rec-card.sev-critical{
  background: linear-gradient(135deg, oklch(28% 0.11 25), oklch(24% 0.08 20));
  border: 1px solid oklch(55% 0.18 25 / .5);
  border-left: 3px solid var(--alert);
}
[data-theme="graphite"] .crew-detail-full .rec-sev.sev-warn{ background: oklch(70% 0.15 60 / .22); color: oklch(88% 0.14 60); }
[data-theme="graphite"] .crew-detail-full .rec-sev.sev-critical{ background: oklch(70% 0.18 25 / .22); color: oklch(88% 0.14 25); }
[data-theme="graphite"] .crew-detail-full .rec-lane{ color: oklch(85% 0.04 60); }
[data-theme="graphite"] .crew-detail-full .rec-headline{ color: oklch(98% 0.02 60); }
[data-theme="graphite"] .crew-detail-full .rec-k{ color: oklch(70% 0.05 55); }
[data-theme="graphite"] .crew-detail-full .rec-v{ color: oklch(88% 0.03 60); }
[data-theme="graphite"] .crew-detail-full .rec-v.rec-exp{ color: oklch(82% 0.15 145); font-weight: 600; }
[data-theme="graphite"] .crew-detail-full .rec-empty{
  background: var(--bg-soft); border-color: var(--line-2);
  color: var(--ink-3);
}

/* Header alert chips — dim glow instead of solid */
[data-theme="graphite"] .crew-detail-full .cdf-alert.sev-green{ background: oklch(76% 0.13 150 / .14); color: oklch(82% 0.13 150); border-color: oklch(from var(--ok) l c h / .4); }
[data-theme="graphite"] .crew-detail-full .cdf-alert.sev-amber{ background: oklch(80% 0.14 80 / .14); color: oklch(85% 0.14 80); border-color: oklch(from var(--warn) l c h / .45); }
[data-theme="graphite"] .crew-detail-full .cdf-alert.sev-red{ background: oklch(72% 0.16 20 / .14); color: oklch(82% 0.15 25); border-color: oklch(from var(--alert) l c h / .45); }

[data-theme="graphite"] .crew-detail-full .cdf-emo, [data-theme="graphite"] .crew-detail-full .cdf-sol{
  background: oklch(22% 0.010 250); border-color: var(--line);
}

/* scrollbars on charcoal */
[data-theme="graphite"] .crew-detail-full .cdf-col::-webkit-scrollbar-thumb{ background: oklch(36% 0.012 250); }
[data-theme="graphite"] .crew-detail-full .cdf-col::-webkit-scrollbar-track{ background: transparent; }

/* strengthen tick/grid lines on dark */
[data-theme="graphite"] .crew-detail-full .rl-sw.dash{ border-top-color: var(--ink-3); }



/* ================ MEAL PLANNER FULL ================ */
.meal-planner-full{
  position: fixed; inset: 0;
  background: var(--bg);
  z-index: 105;
  display: flex; flex-direction: column;
  overflow: hidden;
  font-family: var(--font-body);
}

/* Header */
.mpf-header{
  flex: 0 0 auto;
  display: grid; grid-template-columns: 1fr auto 1fr;
  align-items: center; gap: 24px;
  padding: 14px 24px;
  border-bottom: 1px solid var(--line);
  background: var(--panel);
}
.mpf-head-l{ display:flex; align-items:center; gap: 18px; }
.mpf-solblock{ display:flex; flex-direction:column; gap:2px; padding: 0 14px; border-left: 1px solid var(--line); border-right:1px solid var(--line); }
.mpf-sol{ font-size: 18px; font-weight: 700; letter-spacing: .06em; color: var(--ink); }
.mpf-earth{ font-size: 10.5px; color: var(--ink-3); letter-spacing:.08em; }
.mpf-phase{ display:flex; flex-direction:column; gap:1px; }
.mpf-phase-k{ font-size: 9.5px; letter-spacing:.12em; color: var(--ink-4); font-weight: 600; }
.mpf-phase-v{ font-size: 13px; font-weight: 600; color: var(--ink-2); }

.mpf-head-c{ display:flex; gap: 14px; align-items: center; }
.mpf-daychip{
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px; border-radius: 999px;
  border: 1px solid;
  font-family: var(--font-mono); font-size: 11.5px; font-weight: 700; letter-spacing: .14em;
}
.mpf-daydot{ width: 9px; height: 9px; border-radius: 50%; box-shadow: 0 0 8px currentColor; }
.mpf-kcal{ display:flex; flex-direction:column; padding: 8px 14px; background: var(--bg-soft); border: 1px solid var(--line); border-radius: 6px; }
.mpf-kcal-k{ font-size: 9.5px; letter-spacing:.14em; color: var(--ink-4); font-weight: 600; }
.mpf-kcal-v{ font-size: 17px; font-weight: 700; color: var(--ink); }

.mpf-head-r{ justify-self: end; display:flex; flex-direction:column; align-items:flex-end; gap: 2px; }
.mpf-role{ font-size: 10.5px; font-weight: 700; letter-spacing:.14em; color: var(--ink-3); }
.mpf-session{ font-size: 9.5px; color: var(--ink-4); letter-spacing:.08em; }

/* Grid */
.mpf-grid{
  flex: 1 1 auto;
  display: grid; grid-template-columns: 1.1fr 0.8fr 1.1fr;
  gap: 1px; background: var(--line);
  overflow: hidden;
}
.mpf-col{
  background: var(--bg);
  overflow-y: auto;
  padding: 14px 16px 18px;
  display: flex; flex-direction: column; gap: 12px;
}
.mpf-col-head{
  margin-bottom: 4px;
}

/* MEAL CARDS */
.meal-card{
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 12px 14px; box-shadow: var(--shadow-sm);
  display: flex; flex-direction: column; gap: 8px;
}
.mc-head{ display:flex; justify-content:space-between; align-items:baseline; border-bottom: 1px dashed var(--line-2); padding-bottom: 6px; }
.mc-slot{ font-family: var(--font-mono); font-size: 10.5px; font-weight: 700; letter-spacing: .14em; color: var(--accent); }
.mc-kcal{ font-size: 12px; font-weight: 700; color: var(--ink); }
.mc-name{ font-size: 15px; font-weight: 600; letter-spacing: -0.005em; color: var(--ink); line-height: 1.2; }
.mc-ingr{ display:flex; flex-wrap:wrap; gap: 4px; }
.mc-chip{
  font-size: 10.5px; padding: 2px 7px; border-radius: 3px;
  background: var(--bg-soft); border: 1px solid var(--line-2);
  color: var(--ink-2);
}
.mc-meta{ display:flex; justify-content:space-between; align-items:center; gap: 10px; font-size: 10.5px; }
.mc-cook{ color: var(--ink-3); font-style: italic; }
.mc-k{ font-family: var(--font-mono); font-size: 9.5px; letter-spacing:.1em; color: var(--ink-4); font-weight: 700; margin-right: 3px; text-transform: uppercase; }
.mc-macro{ display:flex; gap: 8px; font-size: 10px; color: var(--ink-3); }
.mc-macro .mc-prep{ color: var(--ink-4); }
.mc-accept-head{ display:flex; justify-content:space-between; align-items:baseline; margin-top: 4px; }
.mc-accept-lbl{ font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .14em; color: var(--ink-3); font-weight: 700; }
.mc-accept-mean{ font-size: 11px; color: var(--ink); font-weight: 700; }

/* 15-crew heatmap (3 rows × 5 cols) */
.mh-grid{ display:grid; grid-template-columns: repeat(5, 1fr); gap: 3px; }
.mh-cell{
  aspect-ratio: 1 / 1;
  border-radius: 3px;
  display:flex; align-items:center; justify-content:center;
  cursor: default; position: relative;
  transition: transform .1s;
  border: 1px solid rgba(0,0,0,0.05);
}
.mh-cell:hover{ transform: scale(1.06); z-index: 2; box-shadow: 0 2px 6px rgba(0,0,0,0.15); }
.mh-init{ font-family: var(--font-mono); font-size: 9.5px; font-weight: 700; color: rgba(0,0,0,0.55); letter-spacing: .04em; text-transform: uppercase; }

.mh-tip{
  position: fixed; z-index: 200;
  background: var(--panel); border: 1px solid var(--line); border-radius: 6px;
  padding: 8px 10px; box-shadow: 0 4px 12px rgba(0,0,0,.15);
  pointer-events: none; font-size: 11px;
  display: flex; flex-direction: column; gap: 2px;
  min-width: 180px;
}
.mh-tip-name{ font-weight: 600; color: var(--ink); font-size: 12px; }
.mh-tip-role{ color: var(--ink-3); font-size: 10px; letter-spacing:.06em; text-transform: uppercase; }
.mh-tip-v{ color: var(--accent); font-weight: 700; font-size: 13px; margin-top: 2px; }
.mh-tip-dish{ color: var(--ink-3); font-size: 10.5px; font-style: italic; margin-top: 2px; }

/* SOL CONTEXT (center column) */
.sol-ctx{ display: flex; flex-direction: column; gap: 12px; }
.sc-daytype{
  background: var(--bg-soft);
  border: 1px solid var(--line-2);
  border-left: 3px solid;
  border-radius: 4px;
  padding: 10px 12px;
  display: flex; flex-direction: column; gap: 4px;
}
.sc-dt-head{ display:flex; justify-content:space-between; align-items: baseline; }
.sc-dt-label{ font-family: var(--font-mono); font-size: 11.5px; font-weight: 700; letter-spacing:.14em; }
.sc-dt-kcal{ font-size: 10px; color: var(--ink-3); letter-spacing: .08em; font-weight: 600; }
.sc-dt-blurb{ font-size: 11.5px; color: var(--ink-3); line-height: 1.4; font-style: italic; }

.sc-events, .sc-block{ display:flex; flex-direction:column; gap: 6px; }
.sc-h{
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 700;
  letter-spacing:.14em; color: var(--ink-3);
  display:flex; align-items:center; gap:6px;
  border-bottom: 1px dashed var(--line-2); padding-bottom: 4px;
}
.sc-h-warn{ color: var(--alert); }
.sc-h-n{ font-family: var(--font-mono); background: var(--bg-soft); color: var(--ink); padding: 1px 5px; border-radius: 2px; font-size: 10px; }
.sc-ev{
  display: flex; flex-direction: column; gap: 2px;
  padding: 7px 10px; border-radius: 4px;
  background: oklch(from var(--accent) l c h / .08);
  border-left: 2px solid var(--accent);
}
.sc-ev-kind{ font-size: 9.5px; font-weight:700; letter-spacing:.14em; color: var(--accent); text-transform: uppercase; }
.sc-ev-title{ font-size: 12px; font-weight: 600; color: var(--ink); }
.sc-ev-who{ font-size: 10px; color: var(--ink-3); letter-spacing:.05em; }

.sc-agg{ display:flex; flex-direction:column; gap: 6px; }
.sc-agg-row{ display:grid; grid-template-columns: 80px 1fr 28px; gap:8px; align-items:center; font-size: 11px; color: var(--ink-2); }
.sc-agg-k{ font-size: 10.5px; color: var(--ink-3); }
.sc-agg-bar{ height: 6px; background: var(--line-2); border-radius: 3px; overflow: hidden; }
.sc-agg-fill{ height: 100%; border-radius: 3px; }

.sc-alert-list{ display:flex; flex-direction:column; gap: 4px; }
.sc-alert-row{
  display:grid; grid-template-columns: 8px 1fr auto; gap: 8px; align-items:center;
  padding: 6px 9px; background: oklch(from var(--alert) l c h / .08);
  border: 1px solid oklch(from var(--alert) l c h / .28);
  border-radius: 4px; font-size: 11px;
}
.sc-alert-dot{ width: 8px; height: 8px; border-radius: 50%; background: var(--alert); box-shadow: 0 0 6px var(--alert); }
.sc-alert-name{ color: var(--ink); font-weight: 600; }
.sc-alert-role{ font-size: 10px; color: var(--ink-3); letter-spacing:.05em; text-transform: uppercase; }

.sc-lowinv{ display:flex; flex-direction:column; gap: 3px; }
.sc-lowinv-row{ display:grid; grid-template-columns: 1fr auto auto; gap: 8px; align-items: baseline;
  padding: 5px 9px; background: var(--bg-soft); border-left: 2px solid var(--alert); border-radius: 3px; font-size: 11px; }
.sc-lowinv-name{ color: var(--ink); font-weight: 500; }
.sc-lowinv-pct{ color: var(--alert); font-weight: 700; font-size: 10.5px; }
.sc-lowinv-harv{ color: var(--ink-4); font-size: 9.5px; letter-spacing: .05em; }

/* ALTERNATIVES (right column) */
.alt-list{ display:flex; flex-direction:column; gap: 10px; }
.alt-card{
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 10px 12px; cursor: pointer;
  transition: border-color .15s, box-shadow .15s, transform .1s;
  display:flex; flex-direction:column; gap:6px;
  box-shadow: var(--shadow-sm);
}
.alt-card:hover{ border-color: var(--ink-3); }
.alt-card.alt-selected{
  border-color: oklch(58% 0.16 50); border-left: 3px solid oklch(58% 0.16 50);
  box-shadow: 0 0 0 1px oklch(58% 0.16 50 / .2), var(--shadow-sm);
}
.alt-head{ display:flex; align-items:center; gap: 10px; border-bottom: 1px dashed var(--line-2); padding-bottom: 6px; }
.alt-rank{ font-size: 12px; font-weight: 700; color: var(--ink-3); letter-spacing: .08em; }
.alt-overall{ display:flex; align-items: baseline; gap: 4px; padding: 2px 8px; background: oklch(58% 0.16 50 / .12); border-radius: 3px; }
.alt-overall-n{ font-size: 14px; font-weight: 700; color: oklch(45% 0.16 50); }
.alt-overall-k{ font-family: var(--font-mono); font-size: 9.5px; letter-spacing:.12em; color: oklch(45% 0.14 50); font-weight: 700; }
.alt-commit{
  margin-left: auto;
  background: oklch(58% 0.16 50); color: white; border: 0;
  font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing: .12em;
  padding: 5px 10px; border-radius: 3px; cursor: pointer;
}
.alt-commit:hover{ background: oklch(52% 0.18 50); }

.alt-body{ display: grid; grid-template-columns: 94px 1fr; gap: 10px; align-items: center; }
.alt-menu{ display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.alt-line{ font-size: 11px; color: var(--ink-2); line-height: 1.3; display:flex; align-items: flex-start; gap: 6px; }
.alt-slot{ font-size: 9px; font-weight: 700; letter-spacing:.08em; color: var(--ink-4); padding: 1px 5px; background: var(--bg-soft); border-radius: 2px; flex-shrink: 0; margin-top: 1px; }

.alt-scores{ display:flex; justify-content: space-between; font-size: 10px; color: var(--ink-3); padding-top: 4px; border-top: 1px dashed var(--line-2); }

.score-radar{ display: block; }

/* INVENTORY STRIP (bottom) */
.inv-strip{
  flex: 0 0 auto;
  background: var(--panel); border-top: 1px solid var(--line);
  padding: 12px 20px 14px;
  display: flex; flex-direction: column; gap: 8px;
}
.inv-strip-head{
  display: flex; align-items: baseline; gap: 8px;
  padding-bottom: 6px; border-bottom: 1px dashed var(--line-2);
}
.inv-groups{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.inv-group{ display: flex; flex-direction: column; gap: 5px; }
.inv-g-head{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom: 2px; }
.inv-g-title{ font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing: .12em; }
.inv-g-n{ font-size: 9.5px; color: var(--ink-4); letter-spacing: .06em; font-weight: 600; }
.inv-bars{ display: flex; flex-direction: column; gap: 3px; }
.inv-bar-wrap{
  display: grid; grid-template-columns: 100px 1fr 36px 50px; gap: 7px;
  align-items: center; font-size: 10.5px;
}
.inv-bar-lbl{ color: var(--ink-2); font-weight: 500; }
.inv-bar{
  position: relative; height: 8px; background: var(--bg-soft); border-radius: 2px;
  overflow: hidden; border: 1px solid var(--line-2);
}
.inv-bar-safety{
  position: absolute; top: -2px; bottom: -2px; width: 2px;
  background: var(--ink-3); opacity: .45;
  box-shadow: 0 0 0 1px var(--panel);
}
.inv-bar-fill{ height: 100%; border-radius: 2px; transition: width .2s; }
.inv-bar-fill.low{ background: var(--alert) !important; }
.inv-bar-pct{ color: var(--ink-3); font-size: 10px; text-align: right; font-weight: 600; }
.inv-bar-harv{ color: var(--ink-4); font-size: 9.5px; letter-spacing: .04em; }
.inv-bar-harv.soon{ color: oklch(58% 0.15 140); font-weight: 700; }

/* COMMIT CTA */
.mpf-commit{
  position: fixed; right: 22px; bottom: 22px;
  z-index: 110;
  background: linear-gradient(135deg, oklch(58% 0.17 50), oklch(55% 0.18 40));
  color: white; border: 0; border-radius: 8px;
  padding: 12px 22px;
  font-family: var(--font-mono); font-size: 12px; font-weight: 700; letter-spacing: .14em;
  cursor: pointer; text-transform: uppercase;
  box-shadow: 0 4px 16px oklch(58% 0.17 50 / .35), 0 2px 4px rgba(0,0,0,.1);
  transition: transform .15s, box-shadow .15s;
}
.mpf-commit:hover{ transform: translateY(-2px); box-shadow: 0 6px 22px oklch(58% 0.17 50 / .45), 0 3px 6px rgba(0,0,0,.12); }
.mpf-commit.committed{ background: linear-gradient(135deg, oklch(55% 0.15 145), oklch(50% 0.17 150)); box-shadow: 0 4px 16px oklch(55% 0.15 145 / .45); }

/* PLAN button in timeline header */
.plan-btn{
  margin-left: 12px;
  background: var(--ink);
  color: var(--panel);
  border: 0; border-radius: 3px;
  font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing: .14em;
  padding: 4px 10px; cursor: pointer;
  vertical-align: middle;
  transition: background .15s;
}
.plan-btn:hover{ background: oklch(25% 0.01 250); }
.axis-hint{ font-size: 9.5px; color: var(--ink-4); font-weight: 400; letter-spacing: .04em; font-style: italic; margin-left: 6px; }



/* ================ SCENARIO SIM ================ */

/* Trigger tab on right edge */
.scn-trigger{
  position: fixed; right: 0; top: 50%; transform: translateY(-50%);
  z-index: 120;
  background: var(--ink); color: var(--panel);
  border: 0; border-right: 0;
  border-radius: 6px 0 0 6px;
  padding: 16px 8px;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  cursor: pointer;
  box-shadow: -2px 2px 8px rgba(0,0,0,0.12);
  transition: background .15s, transform .15s;
}
.scn-trigger:hover{ background: oklch(25% 0.01 250); transform: translateY(-50%) translateX(-3px); }
.scn-trigger.on{ background: oklch(55% 0.17 28); color: white; box-shadow: -2px 2px 12px oklch(55% 0.17 28 / .4); }
.scn-trigger-icon{ font-size: 16px; }
.scn-trigger-label{
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 700; letter-spacing: .18em;
  writing-mode: vertical-rl; transform: rotate(180deg);
}

/* Drawer */
.scn-drawer{
  position: fixed; right: 0; top: 0; bottom: 0;
  width: 380px;
  background: var(--panel);
  border-left: 1px solid var(--line);
  z-index: 125;
  transform: translateX(100%);
  transition: transform .28s cubic-bezier(.3,.1,.2,1);
  display: flex; flex-direction: column;
  box-shadow: -4px 0 24px rgba(0,0,0,.12);
  overflow-y: auto;
}
.scn-drawer.open{ transform: translateX(0); }
.scn-drawer-head{
  padding: 18px 20px 10px;
  display: flex; align-items: baseline; justify-content: space-between;
  border-bottom: 1px solid var(--line);
}
.scn-drawer-title{
  font-size: 18px; font-weight: 600; letter-spacing: -0.01em; color: var(--ink);
}
.scn-drawer-close{
  background: transparent; border: 0; font-size: 22px; color: var(--ink-3);
  cursor: pointer; padding: 0 6px; line-height: 1;
}
.scn-drawer-close:hover{ color: var(--ink); }
.scn-drawer-sub{
  padding: 10px 20px 14px;
  font-size: 11px; color: var(--ink-3); font-style: italic;
  line-height: 1.45;
  border-bottom: 1px dashed var(--line-2);
}

.scn-preset-list{
  display: flex; flex-direction: column; gap: 6px;
  padding: 14px 16px;
}
.scn-preset{
  display: grid; grid-template-columns: 56px 1fr auto; gap: 10px;
  align-items: center;
  background: var(--bg-soft); border: 1px solid var(--line-2);
  border-left: 3px solid var(--ink-3);
  border-radius: 4px; padding: 9px 11px;
  cursor: pointer; text-align: left;
  transition: border-color .15s, background .15s, transform .1s;
}
.scn-preset:hover{ background: var(--bg); transform: translateX(-2px); }
.scn-preset.sev-red{ border-left-color: var(--alert); }
.scn-preset.sev-amber{ border-left-color: var(--warn); }
.scn-preset-sol{ font-size: 11px; color: var(--ink-3); font-weight: 700; letter-spacing: .06em; }
.scn-preset-title{ font-size: 12.5px; font-weight: 600; color: var(--ink); line-height: 1.2; }
.scn-preset-sub{ font-size: 10.5px; color: var(--ink-3); margin-top: 2px; line-height: 1.3; }
.scn-preset-kind{ font-size: 9px; letter-spacing: .12em; color: var(--ink-4); font-weight: 600;
  background: var(--panel); padding: 2px 6px; border-radius: 2px; }

/* Custom event form */
.scn-custom{
  margin: 8px 16px;
  padding: 14px;
  border: 1px dashed var(--line-2); border-radius: 6px;
  background: var(--bg-soft);
}
.scn-custom-head{
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 700; letter-spacing: .14em;
  color: var(--ink-3); margin-bottom: 8px;
}
.scn-custom-grid{
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
}
.scn-custom-grid label{
  display: flex; flex-direction: column; gap: 3px;
  font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .08em;
  color: var(--ink-3); font-weight: 600; text-transform: uppercase;
}
.scn-custom-grid input, .scn-custom-grid select{
  background: var(--panel); border: 1px solid var(--line); border-radius: 3px;
  padding: 5px 7px; font-size: 11.5px; color: var(--ink); font-family: var(--font-body);
  outline: none;
}
.scn-custom-grid input:focus, .scn-custom-grid select:focus{ border-color: var(--accent); }
.scn-title-field{ grid-column: 1 / -1; }
.scn-inject-btn{
  width: 100%; margin-top: 10px;
  background: var(--ink); color: var(--panel); border: 0; border-radius: 4px;
  padding: 9px; font-family: var(--font-mono); font-size: 11px; font-weight: 700; letter-spacing: .14em;
  cursor: pointer;
}
.scn-inject-btn:hover{ background: oklch(25% 0.01 250); }

/* Library */
.scn-library{
  margin: 6px 16px 20px;
  padding: 10px 12px;
  border-top: 1px solid var(--line-2);
}
.scn-library-head{
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 700; letter-spacing: .14em;
  color: var(--ink-4); margin-bottom: 6px;
}
.scn-library-list{ display: flex; flex-direction: column; gap: 3px; }
.scn-library-row{
  display: flex; justify-content: space-between;
  font-size: 10.5px; padding: 4px 6px;
  background: var(--bg-soft); border-radius: 2px;
  color: var(--ink-2);
}
.scn-lib-t{ font-weight: 500; color: var(--ink); }
.scn-lib-m{ color: var(--ink-3); }
.scn-library-empty{ font-size: 10.5px; color: var(--ink-4); font-style: italic; padding: 8px 6px; text-align: center; }

/* ============ SIMULATION MODE tint ============ */
body.sim-mode .app::before{
  content: ''; position: fixed; inset: 0;
  background:
    radial-gradient(ellipse at top right, oklch(60% 0.16 28 / .06) 0%, transparent 55%),
    radial-gradient(ellipse at bottom left, oklch(60% 0.14 40 / .04) 0%, transparent 50%);
  pointer-events: none; z-index: 1;
  animation: simPulse 3.2s ease-in-out infinite;
}
@keyframes simPulse{
  0%,100%{ opacity: 1; }
  50%{ opacity: 0.55; }
}
body.sim-mode .axis-wrap,
body.sim-mode .pods-wrap,
body.sim-mode .footer{
  box-shadow: inset 0 0 0 1px oklch(60% 0.14 30 / .15);
}

/* Sim banner */
.sim-banner{
  position: fixed; top: 0; left: 0; right: 380px;
  z-index: 118;
  background: linear-gradient(90deg, oklch(35% 0.16 25), oklch(42% 0.17 30), oklch(35% 0.16 25));
  color: white;
  padding: 8px 22px;
  display: flex; align-items: center; gap: 14px;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em;
  animation: bannerSlide .3s cubic-bezier(.3,.1,.2,1);
  box-shadow: 0 2px 12px oklch(35% 0.16 25 / .4);
}
body.sim-mode .app .header{ margin-top: 32px; }
@keyframes bannerSlide{ from{ transform: translateY(-100%); } to{ transform: translateY(0); } }
.sim-dot{ width: 10px; height: 10px; border-radius: 50%; background: oklch(75% 0.18 25); box-shadow: 0 0 10px oklch(75% 0.18 25); animation: blink 1.2s ease-in-out infinite; }
@keyframes blink{ 0%,100%{opacity:1;} 50%{opacity:.4;} }
.sim-label{ font-weight: 700; letter-spacing: .18em; }
.sim-scn{ opacity: .95; font-weight: 600; }
.sim-sol{ margin-left: auto; opacity: .75; font-size: 10px; }
.sim-abort{
  background: transparent; border: 1px solid rgba(255,255,255,.3); color: white;
  font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing: .14em;
  padding: 4px 10px; border-radius: 3px; cursor: pointer;
}
.sim-abort:hover{ background: rgba(255,255,255,.1); }

/* ============ EVENT LOG panel ============ */
.evlog{
  position: fixed; left: 0; bottom: 0;
  width: 520px; max-width: 42vw;
  z-index: 116;
  background: oklch(14% 0.008 250);
  color: oklch(88% 0.02 150);
  border: 1px solid oklch(32% 0.02 150);
  border-bottom: 0; border-left: 0;
  border-radius: 0 6px 0 0;
  transform: translateY(100%);
  transition: transform .3s cubic-bezier(.3,.1,.2,1);
  font-family: var(--font-mono);
  box-shadow: 0 -4px 16px rgba(0,0,0,.3);
  max-height: 55vh;
  display: flex; flex-direction: column;
}
.evlog.open{ transform: translateY(0); }
.evlog-head{
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 14px;
  border-bottom: 1px solid oklch(28% 0.01 150);
  background: oklch(16% 0.01 150);
}
.evlog-title{ font-size: 10.5px; letter-spacing: .18em; color: oklch(78% 0.12 150); font-weight: 700; }
.evlog-live{ display: inline-flex; align-items: center; gap: 5px; font-size: 10px; color: oklch(70% 0.18 25); font-weight: 700; }
.evlog-live-dot{ width: 7px; height: 7px; border-radius: 50%; background: oklch(70% 0.18 25); animation: blink 1s ease-in-out infinite; }
.evlog-body{
  padding: 10px 14px 14px;
  overflow-y: auto;
  font-size: 11px; line-height: 1.65;
  display: flex; flex-direction: column; gap: 3px;
}
.evlog-row{
  display: grid; grid-template-columns: 60px 84px 1fr; gap: 10px;
  padding: 2px 0;
  animation: evlogFade .3s ease-out;
}
@keyframes evlogFade{ from{ opacity: 0; transform: translateY(4px); } to{ opacity: 1; transform: translateY(0); } }
.evlog-t{ color: oklch(60% 0.02 150); font-size: 10px; }
.evlog-tag{
  font-size: 9.5px; letter-spacing: .14em; font-weight: 700;
  padding: 2px 6px; border-radius: 2px; text-align: center;
  align-self: start;
}
.tag-event{ background: oklch(35% 0.12 25 / .5); color: oklch(85% 0.14 25); }
.tag-detect{ background: oklch(35% 0.10 200 / .5); color: oklch(85% 0.12 200); }
.tag-analyze{ background: oklch(35% 0.08 250 / .5); color: oklch(85% 0.10 250); }
.tag-generate{ background: oklch(35% 0.10 60 / .5); color: oklch(85% 0.14 60); }
.tag-commit{ background: oklch(38% 0.13 150 / .5); color: oklch(82% 0.14 150); }
.tag-dispatch{ background: oklch(35% 0.10 150 / .5); color: oklch(82% 0.10 150); }
.tag-monitor{ background: oklch(35% 0.05 250 / .5); color: oklch(75% 0.05 250); }
.evlog-msg{ color: oklch(92% 0.015 150); }
.evlog-cursor{ color: oklch(75% 0.15 150); animation: blink .8s step-end infinite; }

/* ============ RESPONSE PLANS panel ============ */
.sim-rp-wrap{
  position: fixed; right: 0; top: 0; bottom: 0;
  width: 380px;
  background: var(--panel);
  border-left: 1px solid var(--line);
  box-shadow: -8px 0 32px rgba(0,0,0,.18);
  z-index: 117;
  overflow-y: auto;
  animation: rpSlide .35s cubic-bezier(.3,.1,.2,1);
}
@keyframes rpSlide{ from{ opacity: 0; transform: translateX(30px); } to{ opacity: 1; transform: translateX(0); } }
.sim-rp-wrap .rp-panel{
  background: transparent; border: 0; border-radius: 0;
  box-shadow: none; padding: 18px 20px;
}
.rp-panel{
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 14px 16px;
  box-shadow: 0 8px 32px rgba(0,0,0,.18);
}
.rp-head{
  display: flex; align-items: baseline; gap: 8px;
  padding-bottom: 10px; margin-bottom: 12px;
  border-bottom: 1px solid var(--line);
}
.rp-list{ display: flex; flex-direction: column; gap: 12px; }
.rp-card{
  background: var(--bg-soft);
  border: 1px solid var(--line-2);
  border-radius: 6px;
  padding: 12px 14px;
  display: flex; flex-direction: column; gap: 8px;
}
.rp-card.rp-recommended{
  border-color: oklch(58% 0.16 50 / .5);
  border-left: 3px solid oklch(58% 0.16 50);
  background: oklch(98% 0.02 50);
}
.rp-card.rp-accepted{ border-color: var(--ok); background: oklch(96% 0.05 150); }
.rp-card-head{ display: flex; align-items: center; gap: 8px; }
.rp-rec{ font-size: 9.5px; font-weight: 700; letter-spacing: .14em; color: oklch(50% 0.16 50); background: oklch(92% 0.08 55); padding: 2px 6px; border-radius: 2px; }
.rp-card-title{ font-size: 14px; font-weight: 600; color: var(--ink); }
.rp-actions{ margin: 0; padding-left: 18px; font-size: 11.5px; color: var(--ink-2); line-height: 1.45; }
.rp-actions li{ margin: 2px 0; }
.rp-cost, .rp-effect{
  background: var(--panel); border: 1px solid var(--line-2); border-radius: 4px;
  padding: 6px 10px;
}
.rp-cost-head, .rp-effect-head{
  font-size: 9.5px; font-weight: 700; letter-spacing: .12em;
  color: var(--ink-4); margin-bottom: 4px;
}
.rp-cost-row{ display: flex; justify-content: space-between; font-size: 10.5px; color: var(--ink-2); line-height: 1.5; }
.rp-cost-row span:first-child{ color: var(--ink-3); text-transform: uppercase; font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .06em; }
.rp-effect-grid{ display: grid; grid-template-columns: 1fr 1fr; gap: 4px 10px; }
.rp-effect-grid > div{ display: flex; justify-content: space-between; align-items: baseline; font-size: 10.5px; }
.rp-effect-grid > div span:first-child{ color: var(--ink-4); font-size: 9.5px; letter-spacing: .06em; text-transform: uppercase; }
.rp-effect-grid .pos{ color: oklch(52% 0.15 150); font-weight: 700; }
.rp-effect-grid .neg{ color: oklch(54% 0.17 25); font-weight: 700; }
.rp-accept{
  border: 1px solid var(--ink-3); background: var(--panel); color: var(--ink);
  padding: 9px; border-radius: 4px; cursor: pointer;
  font-family: var(--font-mono); font-size: 11px; font-weight: 700; letter-spacing: .14em;
  transition: background .15s;
}
.rp-accept:hover:not(:disabled){ background: var(--bg-soft); }
.rp-accept:disabled{ opacity: .5; cursor: not-allowed; }
.rp-accept.primary{ background: oklch(58% 0.16 50); color: white; border-color: oklch(58% 0.16 50); }
.rp-accept.primary:hover:not(:disabled){ background: oklch(52% 0.18 50); }

/* ============ PRE/POST COMPARE modal ============ */
.pp-modal{
  position: fixed; inset: 0;
  z-index: 200;
  background: oklch(18% 0.01 250 / .75);
  backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  padding: 40px 32px;
  animation: ppFade .3s ease-out;
}
@keyframes ppFade{ from{ opacity: 0; } to{ opacity: 1; } }
.pp-card{
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 10px;
  box-shadow: 0 24px 64px rgba(0,0,0,.35);
  width: 100%; max-width: 980px;
  overflow: hidden;
  display: flex; flex-direction: column;
  animation: ppRise .35s cubic-bezier(.3,.1,.2,1);
}
@keyframes ppRise{ from{ opacity: 0; transform: translateY(24px) scale(.98); } to{ opacity: 1; transform: translateY(0) scale(1); } }
.pp-head{
  display: flex; justify-content: space-between; align-items: flex-start;
  padding: 22px 28px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, var(--bg-soft), var(--panel));
}
.pp-eyebrow{ font-size: 10.5px; font-weight: 700; letter-spacing: .18em; color: var(--accent); margin-bottom: 6px; }
.pp-title{ font-size: 24px; font-weight: 600; letter-spacing: -0.015em; color: var(--ink); }
.pp-sub{ font-size: 11px; color: var(--ink-3); margin-top: 4px; letter-spacing: .04em; }
.pp-verdict{ text-align: right; }
.pp-verdict-k{ font-size: 10px; letter-spacing: .14em; color: var(--ink-4); font-weight: 700; }
.pp-verdict-v{ font-size: 28px; font-weight: 700; color: oklch(52% 0.15 150); letter-spacing: -0.02em; }

.pp-split{
  display: grid; grid-template-columns: 1fr 60px 1fr;
  gap: 0; padding: 24px 28px;
}
.pp-col{ display: flex; flex-direction: column; gap: 12px; padding: 10px 0; }
.pp-col-head{
  font-size: 10.5px; font-weight: 700; letter-spacing: .14em; color: var(--ink-3);
  padding-bottom: 6px; border-bottom: 1px solid var(--line-2);
}
.pp-col-head.pp-head-good{ color: oklch(48% 0.15 150); }
.pp-col-pre .pp-col-head{ color: oklch(52% 0.16 25); }
.pp-col-sub{ font-size: 10.5px; color: var(--ink-3); font-style: italic; margin-top: -6px; }
.pp-row{
  display: grid; grid-template-columns: 1fr auto; gap: 12px;
  align-items: baseline;
  padding: 10px 0;
  border-bottom: 1px dashed var(--line-2);
  font-size: 13px;
}
.pp-row-k{ color: var(--ink-2); font-weight: 500; }
.pp-row-v{ font-size: 16px; font-weight: 700; color: var(--ink); letter-spacing: -0.01em; }
.pp-row-v.pp-bad{ color: oklch(52% 0.16 25); }
.pp-row-v.pp-good{ color: oklch(48% 0.15 150); }
.pp-delta{ font-size: 11px; margin-left: 8px; color: var(--ink-3); font-weight: 600; }
.pp-row-v.pp-good .pp-delta{ color: oklch(52% 0.14 150); }

.pp-divider{ display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; padding: 0 10px; }
.pp-divider-line{ flex: 1; width: 1px; background: var(--line); }
.pp-divider-vs{
  font-size: 12px; font-weight: 700; letter-spacing: .14em; color: var(--ink-3);
  padding: 8px; background: var(--bg-soft); border: 1px solid var(--line); border-radius: 50%;
  width: 42px; height: 42px; display: flex; align-items: center; justify-content: center;
}

.pp-footer{
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 28px;
  border-top: 1px solid var(--line);
  background: var(--bg-soft);
}
.pp-disclaimer{ font-size: 10.5px; color: var(--ink-4); font-style: italic; }
.pp-actions{ display: flex; gap: 10px; }
.pp-btn{
  font-family: var(--font-mono); font-size: 11px; font-weight: 700; letter-spacing: .14em;
  padding: 10px 18px; border-radius: 4px; cursor: pointer; border: 1px solid;
}
.pp-save{ background: var(--ink); color: var(--panel); border-color: var(--ink); }
.pp-save:hover{ background: oklch(25% 0.01 250); }
.pp-close{ background: var(--panel); color: var(--ink-2); border-color: var(--line); }
.pp-close:hover{ background: var(--bg-soft); color: var(--ink); }

/* Make sure overview is readable when sim is active and drawer open */
body.sim-mode{ overflow: hidden; }



/* ================ MARS WEATHER WIDGET (header) ================ */
.mars-widget{
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px 8px 10px;
  background: linear-gradient(180deg, oklch(96% 0.012 45), oklch(92% 0.020 45));
  border: 1px solid oklch(80% 0.03 45);
  border-radius: 4px;
  cursor: pointer;
  transition: background .15s, transform .1s;
  min-width: 200px;
}
.mars-widget:hover{
  background: linear-gradient(180deg, oklch(94% 0.025 45), oklch(88% 0.040 45));
  transform: translateY(-1px);
}
.mw-dot{
  width: 10px; height: 10px; border-radius: 50%;
  flex-shrink: 0;
  transition: box-shadow .2s, background .2s;
}
.mw-stack{ display: flex; flex-direction: column; gap: 2px; flex: 1; min-width: 0; }
.mw-row1{
  display: flex; align-items: baseline; gap: 4px;
  font-family: var(--font-mono); font-size: 10.5px; color: var(--ink-2);
  letter-spacing: .04em;
}
.mw-row1 b{ color: var(--ink); font-weight: 700; }
.mw-sep{ color: var(--ink-4); }
.mw-tau{ color: oklch(50% 0.14 40); font-weight: 600; }
.mw-row2{
  display: flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 9px; letter-spacing: .12em;
}
.mw-sev{ font-weight: 700; }
.mw-ev{ color: var(--ink-3); font-weight: 500; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 140px; }
.mw-chev{ margin-left: auto; color: var(--ink-3); font-size: 10px; }

/* ================ MARS ENV OVERLAY ================ */
body.me-open{ overflow: hidden; }
.me-overlay{
  position: fixed; inset: 0;
  z-index: 130;
  background: oklch(98% 0.008 45);
  overflow-y: auto;
  animation: meFade .3s cubic-bezier(.3,.1,.2,1);
}
@keyframes meFade{ from{ opacity: 0; transform: scale(1.01); } to{ opacity: 1; transform: scale(1); } }
.me-scroll{
  max-width: 1560px;
  margin: 0 auto;
  padding: 28px 40px 60px;
}

.me-header{
  display: flex; justify-content: space-between; align-items: flex-start;
  padding: 8px 0 24px;
  border-bottom: 1px solid oklch(85% 0.03 45);
  margin-bottom: 24px;
}
.me-eyebrow{
  font-family: var(--font-mono); font-size: 10px; font-weight: 700;
  letter-spacing: .22em; color: oklch(50% 0.14 40);
  margin-bottom: 6px;
}
.me-title{
  font-size: 28px; font-weight: 600; letter-spacing: -0.02em; color: var(--ink);
  line-height: 1.1;
}
.me-meta{
  margin-top: 10px;
  display: flex; gap: 22px; flex-wrap: wrap;
  font-family: var(--font-mono); font-size: 11px; color: var(--ink-3);
  letter-spacing: .04em;
}
.me-meta b{ color: var(--ink); font-weight: 600; }
.me-season{
  padding: 2px 8px; border-radius: 10px;
  font-size: 10px; font-weight: 700; letter-spacing: .14em;
  background: oklch(90% 0.05 35); color: oklch(40% 0.10 35);
}
.me-s-spring{ background: oklch(93% 0.06 130); color: oklch(38% 0.12 140); }
.me-s-summer{ background: oklch(93% 0.08 70); color: oklch(38% 0.14 55); }
.me-s-autumn{ background: oklch(92% 0.06 35); color: oklch(40% 0.14 35); }
.me-s-winter{ background: oklch(93% 0.03 240); color: oklch(38% 0.08 245); }
.me-close{
  background: var(--panel); border: 1px solid var(--line); color: var(--ink);
  padding: 9px 14px; border-radius: 4px;
  font-family: var(--font-mono); font-size: 11px; font-weight: 700; letter-spacing: .16em;
  cursor: pointer;
}
.me-close:hover{ background: var(--bg-soft); }

/* ── Region shell ── */
.me-region{
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 18px 22px;
  margin-bottom: 18px;
}
.me-region-head{
  display: flex; align-items: baseline; gap: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line-2);
  margin-bottom: 16px;
}
.me-region-kicker{
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  letter-spacing: .14em; color: oklch(55% 0.15 40);
  background: oklch(95% 0.03 45);
  padding: 3px 8px; border-radius: 2px;
}
.me-region-title{ font-size: 15px; font-weight: 600; color: var(--ink); letter-spacing: -0.005em; }
.me-region-sub{
  margin-left: auto;
  font-family: var(--font-mono); font-size: 10.5px; color: var(--ink-3);
  letter-spacing: .06em;
}

/* ── R1 Seasonal Timeline ── */
.seasonal-axis{
  position: relative;
  height: 68px;
  border-radius: 4px;
  overflow: hidden;
  border: 1px solid var(--line-2);
}
.seasonal-band{
  position: absolute; top: 0; bottom: 0;
  display: flex; align-items: center; justify-content: center;
}
.seasonal-label{
  font-family: var(--font-mono); font-size: 9px; font-weight: 700;
  letter-spacing: .18em; color: oklch(40% 0.05 45 / .55);
}
.storm-window{
  position: absolute; top: 0; bottom: 0;
  background: repeating-linear-gradient(45deg, oklch(55% 0.15 40 / .12) 0 4px, transparent 4px 8px);
  pointer-events: none;
}
.ls-anchor{
  position: absolute; top: 0; bottom: 0; pointer-events: none;
}
.ls-tick{
  position: absolute; top: 0; bottom: 0; width: 1px;
  background: oklch(40% 0.02 45 / .4);
}
.ls-label{
  position: absolute; top: 2px;
  font-family: var(--font-mono); font-size: 8.5px; font-weight: 600;
  letter-spacing: .08em;
  color: oklch(30% 0.04 40);
  white-space: nowrap;
  transform: translateX(-50%);
  background: rgba(255,255,255,.7);
  padding: 1px 4px;
  border-radius: 2px;
}
.me-ev-marker{
  position: absolute; bottom: 6px; height: 6px;
  border-radius: 1px;
}
.me-ev-dust_storm{ background: oklch(55% 0.17 35); }
.me-ev-spe{ background: oklch(55% 0.22 300); }
.me-ev-temp_anomaly{ background: oklch(65% 0.12 230); }
.me-ev-dust_devil{ background: oklch(65% 0.10 85); }
.sol-cursor{
  position: absolute; top: 0; bottom: 0;
  width: 2px; background: var(--ink);
  pointer-events: none;
  z-index: 5;
}
.sol-cursor-head{
  position: absolute; top: -18px; left: 50%; transform: translateX(-50%);
  font-family: var(--font-mono); font-size: 9px; font-weight: 700;
  letter-spacing: .12em;
  background: var(--ink); color: var(--panel);
  padding: 2px 6px; border-radius: 2px; white-space: nowrap;
}
.seasonal-scrub{
  position: absolute; inset: 0;
  cursor: crosshair;
}
.seasonal-legend{
  margin-top: 12px;
  display: flex; flex-wrap: wrap; gap: 14px;
  font-family: var(--font-mono); font-size: 10px; color: var(--ink-3);
  letter-spacing: .05em;
}
.seasonal-legend span{ display: inline-flex; align-items: center; gap: 6px; }
.leg-sq{ display: inline-block; width: 10px; height: 10px; border-radius: 2px; }
.leg-storm{ background: repeating-linear-gradient(45deg, oklch(55% 0.15 40 / .35) 0 3px, transparent 3px 6px); border: 1px solid oklch(60% 0.15 40 / .4); }
.leg-ev{ display: inline-block; width: 14px; height: 4px; border-radius: 1px; }
.leg-ev-dust_storm{ background: oklch(55% 0.17 35); }
.leg-ev-spe{ background: oklch(55% 0.22 300); }
.leg-ev-temp_anomaly{ background: oklch(65% 0.12 230); }
.leg-sep{ width: 1px; background: var(--line); height: 12px; align-self: center; }

/* ── R2 Current Conditions Grid ── */
.me-split-2{
  display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-bottom: 18px;
}
.me-split-2 .me-region{ margin-bottom: 0; }

.me-split-67{ display: grid; grid-template-columns: 60fr 40fr; gap: 18px; margin-bottom: 18px; }
.me-split-67-l, .me-split-67-r{ display: flex; flex-direction: column; gap: 18px; min-width: 0; }
.me-split-67 .me-region{ margin-bottom: 0; height: 100%; }
@media (max-width: 1200px){ .me-split-67{ grid-template-columns: 1fr; } }

.cc-grid{
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
}
.cc-cell{
  background: var(--bg-soft);
  border: 1px solid var(--line-2);
  border-radius: 6px;
  padding: 12px 14px;
  display: flex; flex-direction: column; gap: 4px;
  position: relative;
}
.cc-lbl{
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 700;
  letter-spacing: .14em; color: var(--ink-3); text-transform: uppercase;
}
.cc-main{ display: flex; align-items: baseline; gap: 4px; }
.cc-val{
  font-size: 28px; font-weight: 700; color: var(--ink); letter-spacing: -0.015em;
}
.cc-unit{
  font-size: 12px; color: var(--ink-3); font-weight: 500;
}
.cc-sub{
  font-size: 10.5px; color: var(--ink-3);
  line-height: 1.35;
}
.cc-spark-row{
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 2px;
}
.me-spark{ display: block; opacity: .85; }
.cc-note{
  font-family: var(--font-mono); font-size: 11px; color: var(--ink-3);
}
.wind-arrow{
  display: inline-block;
  font-size: 14px; color: oklch(60% 0.08 200); font-weight: 700;
  transition: transform .3s;
}

/* ── R3 Active Events ── */
.me-nominal{
  display: flex; align-items: center; gap: 16px;
  padding: 20px;
  background: oklch(96% 0.04 150);
  border: 1px solid oklch(80% 0.08 150);
  border-radius: 6px;
}
.me-nominal-icon{
  font-size: 36px; color: oklch(50% 0.14 150);
}
.me-nominal-t{
  font-family: var(--font-mono); font-size: 13px; font-weight: 700;
  letter-spacing: .14em; color: oklch(40% 0.14 150);
}
.me-nominal-s{ font-size: 11.5px; color: var(--ink-2); margin-top: 3px; }

.we-cards{ display: flex; flex-direction: column; gap: 12px; }
.we-card{
  background: var(--bg-soft);
  border: 1px solid var(--line-2);
  border-left: 3px solid var(--ink-3);
  border-radius: 5px;
  padding: 12px 14px;
}
.we-card.we-dust_storm{ border-left-color: oklch(55% 0.17 35); background: oklch(97% 0.03 40); }
.we-card.we-spe{ border-left-color: oklch(55% 0.22 300); background: oklch(97% 0.02 300); }
.we-card.we-temp_anomaly{ border-left-color: oklch(65% 0.12 230); }
.we-top{ display: flex; justify-content: space-between; margin-bottom: 4px; }
.we-kind{
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 700;
  letter-spacing: .18em; color: var(--ink-3); text-transform: uppercase;
}
.we-severity{
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 700;
  letter-spacing: .18em; color: oklch(45% 0.18 30);
  padding: 2px 8px; border-radius: 2px;
  background: oklch(95% 0.04 30);
}
.we-title{ font-size: 15px; font-weight: 600; color: var(--ink); letter-spacing: -0.005em; }
.we-summary{ font-size: 11.5px; color: var(--ink-2); margin-top: 4px; line-height: 1.45; }
.we-timeline{ margin-top: 10px; }
.we-tl-bar{
  height: 4px; background: var(--line-2); border-radius: 2px;
  overflow: hidden;
}
.we-tl-fill{
  height: 100%; background: oklch(55% 0.17 35);
  transition: width .3s;
}
.we-tl-meta{
  display: flex; justify-content: space-between; margin-top: 4px;
  font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .06em; color: var(--ink-3);
}
.we-tl-meta span:nth-child(2){ color: var(--ink); font-weight: 600; }
.we-impact{
  display: flex; flex-wrap: wrap; gap: 10px; margin-top: 10px;
}
.we-imp{
  display: flex; align-items: baseline; gap: 6px;
  padding: 4px 10px; border-radius: 3px;
  background: var(--panel);
  border: 1px solid var(--line-2);
  font-family: var(--font-mono);
}
.we-imp span{ font-size: 9.5px; letter-spacing: .08em; color: var(--ink-3); text-transform: uppercase; }
.we-imp b{ font-size: 12px; font-weight: 700; }
.we-imp.neg b{ color: oklch(52% 0.16 25); }
.we-imp.pos b{ color: oklch(48% 0.15 150); }
.we-imp.bad b{ color: oklch(45% 0.20 28); }
.we-imp.warn b{ color: oklch(55% 0.15 75); }
.we-imp.ok b{ color: oklch(48% 0.15 150); }
.we-sim{
  margin-top: 10px;
  background: var(--ink); color: var(--panel); border: 0;
  padding: 7px 14px; border-radius: 3px;
  font-family: var(--font-mono); font-size: 10.5px; font-weight: 700; letter-spacing: .14em;
  cursor: pointer;
}
.we-sim:hover{ background: oklch(25% 0.01 250); }

/* ── R4 Forecast ── */
.fc-bars{
  display: flex; gap: 2px;
  align-items: flex-end;
  padding: 10px 0;
  min-height: 80px;
}
.fc-col{
  flex: 1; display: flex; flex-direction: column; align-items: center; gap: 4px;
  cursor: default;
  padding: 2px;
  transition: background .15s;
}
.fc-col:hover{ background: var(--bg-soft); }
.fc-col.fc-hi{ background: oklch(97% 0.03 40); }
.fc-bar{
  width: 100%;
  border-radius: 2px;
  min-height: 12px;
  transition: height .2s;
}
.fc-sol{
  font-family: var(--font-mono); font-size: 9px; color: var(--ink-3);
  letter-spacing: .04em;
}
.fc-legend{
  display: flex; flex-wrap: wrap; gap: 12px;
  margin-top: 10px;
  font-family: var(--font-mono); font-size: 9.5px; color: var(--ink-3);
  letter-spacing: .05em;
}
.fc-legend span{ display: inline-flex; align-items: center; gap: 5px; }
.fc-upcoming{
  margin-top: 14px; padding-top: 12px;
  border-top: 1px dashed var(--line-2);
}
.fc-up-head{
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 700;
  letter-spacing: .14em; color: var(--ink-4); margin-bottom: 6px;
}
.fc-up-row{
  display: grid; grid-template-columns: 60px 1fr auto; gap: 12px;
  padding: 4px 0;
  font-size: 11px;
  border-bottom: 1px dashed var(--line-2);
}
.fc-up-row:last-child{ border-bottom: 0; }
.fc-up-sol{
  font-family: var(--font-mono); font-weight: 700;
  color: oklch(55% 0.17 35); letter-spacing: .06em;
}
.fc-up-title{ color: var(--ink-2); }
.fc-up-dur{ font-family: var(--font-mono); font-size: 10px; color: var(--ink-3); }

/* ── R5 Cascade ── */
.cascade-svg{
  width: 100%; height: auto;
  background: var(--bg-soft);
  border-radius: 6px;
  padding: 8px;
}
.cas-fac-lbl{
  font-family: var(--font-mono); font-size: 10px; font-weight: 600;
  fill: var(--ink); letter-spacing: .06em;
}
.cas-fac-val{
  font-family: var(--font-mono); font-size: 10.5px; font-weight: 700;
  letter-spacing: .06em;
}
.cas-sys-lbl{
  font-family: var(--font-mono); font-size: 10.5px; font-weight: 600;
  fill: var(--ink); letter-spacing: .06em;
}
.cas-link-lbl{
  font-family: var(--font-mono); font-size: 10px; fill: var(--ink);
  font-weight: 700;
}
.cas-note{
  margin-top: 10px; padding: 10px 12px;
  background: oklch(98% 0.015 45); border: 1px dashed oklch(85% 0.04 45);
  border-radius: 4px;
  font-size: 11px; color: var(--ink-3); font-style: italic; line-height: 1.5;
}

/* ── R6 Correlation ── */
.hc-svg{ width: 100%; height: auto; background: var(--bg-soft); border-radius: 6px; }
.hc-lbl{
  font-family: var(--font-mono); font-size: 9px; font-weight: 700;
  letter-spacing: .1em; fill: var(--ink-3);
}
.hc-note{
  margin-top: 10px; font-size: 11px; color: var(--ink-3); line-height: 1.5;
  font-style: italic;
}

/* ── R7 Dust ── */
.dust-row{
  display: flex; flex-direction: column; gap: 14px;
}
.dust-gauge{ display: flex; align-items: center; gap: 14px; }
.dust-gauge svg{ flex-shrink: 0; }
.dust-history{ width: 100%; }
.dust-history .me-spark{ width: 100%; height: auto; display: block; }
.dust-pct{
  font-family: var(--font-mono); font-size: 22px; font-weight: 700;
  fill: var(--ink); letter-spacing: -0.02em;
}
.dust-sub{
  font-family: var(--font-mono); font-size: 8px; font-weight: 700;
  letter-spacing: .18em; fill: var(--ink-3);
}
.dust-stats{ display: flex; flex-direction: column; gap: 8px; }
.dust-stat-lbl{
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 600;
  letter-spacing: .12em; color: var(--ink-3); text-transform: uppercase;
}
.dust-stat-val{
  font-size: 18px; font-weight: 700; color: var(--ink); letter-spacing: -0.01em;
  font-family: var(--font-mono);
}
.dust-history{
  padding: 12px 16px;
  background: var(--bg-soft);
  border: 1px solid var(--line-2);
  border-radius: 6px;
}
.dust-hist-head{
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 700;
  letter-spacing: .14em; color: var(--ink-3); margin-bottom: 8px;
}
.dust-reco{
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 6px;
  min-width: 200px;
}
.dust-reco-head{
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 700;
  letter-spacing: .14em; color: var(--ink-4); margin-bottom: 6px;
}
.dust-reco-t{ font-size: 13px; font-weight: 600; color: var(--ink); }
.dust-reco-sub{ font-size: 10.5px; color: var(--ink-3); margin: 3px 0 10px; }
.dust-reco-btn{
  width: 100%;
  padding: 8px; border-radius: 3px;
  border: 1px solid var(--line);
  background: var(--panel); color: var(--ink-3);
  font-family: var(--font-mono); font-size: 10.5px; font-weight: 700; letter-spacing: .14em;
  cursor: pointer;
}
.dust-reco-btn.primary{
  background: oklch(55% 0.17 40); color: white; border-color: oklch(55% 0.17 40);
}
.dust-reco-btn:disabled{ opacity: .5; cursor: not-allowed; }
.dust-reco-btn.primary:hover{ background: oklch(50% 0.19 40); }

@media (max-width: 1200px){
  .me-split-2{ grid-template-columns: 1fr; }
  .cc-grid{ grid-template-columns: 1fr 1fr; }
  .dust-row{ grid-template-columns: 1fr; }
}


/* ============ CrewDetailFull · Affect Circumplex (Russell) ============ */
.cdf-circumplex-wrap{
  display:grid; grid-template-columns: auto 1fr; gap: 24px;
  align-items: center; padding: 8px 4px;
}
.cdf-cx-meta{ display:flex; flex-direction:column; gap:10px; }
.cdf-cx-quad{
  display:inline-flex; align-items:center; gap:8px;
  font-family: var(--font-mono); font-size:13px; font-weight:700;
  letter-spacing:.12em; padding:6px 12px;
  background: oklch(from currentColor l c h / .10);
  border: 1px solid oklch(from currentColor l c h / .28);
  border-radius:4px; align-self:flex-start;
}
.cdf-cx-q-dot{ width:8px; height:8px; border-radius:50%; box-shadow: 0 0 8px currentColor; }
.cdf-cx-kv{
  display:grid; grid-template-columns: 100px 1fr; gap:10px; align-items:baseline;
  font-family: var(--font-mono); font-size:11px;
}
.cdf-cx-kv .k{ color: var(--ink-4); letter-spacing:.1em; text-transform:uppercase; }
.cdf-cx-kv .v{ color: var(--ink); font-weight:700; font-size:14px; }
.cdf-cx-legend{
  margin-top:6px; padding-top:10px;
  border-top:1px dashed var(--line-2);
  display:flex; flex-direction:column; gap:6px;
}
.cdf-cx-legend .cx-leg-row{
  display:flex; align-items:center; gap:8px;
  font-size:11px; color:var(--ink-2);
}
.cdf-cx-legend .cx-leg-dot{ width:8px; height:8px; border-radius:50%; }
.cdf-cx-legend .cx-leg-foot{
  margin-top:4px; font-family:var(--font-mono); font-size:9.5px;
  letter-spacing:.08em; color:var(--ink-4); font-style:italic;
}
