/* ── IDH tokens ─────────────────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@300;400;500;600;700;800&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

:root {
  --n-0:  #ffffff;
  --n-50: #f4f5f9;
  --n-100:#eceef4;
  --n-150:#e4e7ef;
  --n-200:#d7dbe6;
  --n-300:#c2c7d6;
  --n-400:#9aa1b4;
  --n-500:#6f7689;
  --n-600:#4b5163;
  --n-700:#363b4a;
  --n-800:#272b36;
  --n-850:#21242e;
  --n-900:#1a1c24;
  --n-950:#13151b;

  --accent-300:#9db4e8;
  --accent-400:#6f93dd;
  --accent-500:#4f78d6;
  --accent-600:#3a61bd;
  --accent-glow: rgba(79,120,214,0.45);

  --success-500:#4e9e7e;
  --warning-500:#c79a4f;
  --danger-500:#cf6b6b;

  --font-sans:'Manrope',ui-sans-serif,system-ui,-apple-system,sans-serif;
  --font-mono:'IBM Plex Mono',ui-monospace,'SF Mono',Menlo,monospace;

  --text-2xs:0.6875rem;
  --text-xs:0.75rem;
  --text-sm:0.875rem;
  --text-base:1rem;
  --text-md:1.125rem;
  --text-lg:1.375rem;
  --text-xl:1.75rem;

  --fw-light:300;--fw-regular:400;--fw-medium:500;
  --fw-semibold:600;--fw-bold:700;--fw-extrabold:800;

  --lh-tight:1.1;--lh-snug:1.25;--lh-normal:1.5;--lh-relaxed:1.65;
  --ls-tight:-0.02em;--ls-snug:-0.01em;--ls-normal:0;
  --ls-wide:0.04em;--ls-wider:0.12em;

  --space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;
  --space-5:1.5rem;--space-6:2rem;--space-7:2.5rem;--space-8:3rem;

  --radius-sm:10px;--radius-md:16px;--radius-lg:24px;
  --radius-xl:32px;--radius-pill:999px;--radius-circle:50%;

  --ease-soft:cubic-bezier(0.34,1.2,0.45,1);
  --ease-out:cubic-bezier(0.22,0.61,0.36,1);
  --dur-fast:130ms;--dur-base:220ms;--dur-slow:380ms;
}

/* ── Light theme (default) ── */
:root,[data-theme="light"] {
  --bg:var(--n-100);
  --surface:var(--n-100);
  --surface-raised:var(--n-50);
  --surface-sunken:var(--n-150);
  --surface-control:var(--n-100);
  --text-strong:var(--n-700);
  --text-body:var(--n-600);
  --text-muted:var(--n-500);
  --text-faint:var(--n-400);
  --text-on-accent:#ffffff;
  --border-hair:var(--n-200);
  --accent:var(--accent-500);
  --accent-strong:var(--accent-600);
  --nm-light:rgba(255,255,255,0);
  --nm-dark:rgba(53,59,74,0.16);
  --nm-dark-strong:rgba(53,59,74,0.24);
  --focus-ring:var(--accent-glow);

  --nm-raised-sm:-3px -3px 6px var(--nm-light), 3px 3px 6px var(--nm-dark);
  --nm-raised-md:-6px -6px 12px var(--nm-light), 6px 6px 12px var(--nm-dark);
  --nm-raised-lg:-10px -10px 22px var(--nm-light), 10px 10px 22px var(--nm-dark-strong);
  --nm-sunken-sm:inset -2px -2px 5px var(--nm-light), inset 2px 2px 5px var(--nm-dark);
  --nm-sunken-md:inset -4px -4px 9px var(--nm-light), inset 4px 4px 9px var(--nm-dark);
  --nm-sunken-lg:inset -7px -7px 15px var(--nm-light), inset 7px 7px 15px var(--nm-dark-strong);
  --nm-pressed:inset -2px -2px 6px var(--nm-light), inset 2px 2px 6px var(--nm-dark);
  --nm-glow:0 0 0 1px var(--accent-glow), 0 0 14px var(--accent-glow);
}

/* ── Dark theme ── */
[data-theme="dark"] {
  --bg:var(--n-850);
  --surface:var(--n-850);
  --surface-raised:var(--n-800);
  --surface-sunken:var(--n-900);
  --surface-control:var(--n-850);
  --text-strong:#e7eaf2;
  --text-body:#c2c7d6;
  --text-muted:#8b92a5;
  --text-faint:#62697b;
  --text-on-accent:#ffffff;
  --border-hair:#2c3140;
  --accent:var(--accent-400);
  --accent-strong:var(--accent-300);
  --nm-light:rgba(255,255,255,0.05);
  --nm-dark:rgba(0,0,0,0.45);
  --nm-dark-strong:rgba(0,0,0,0.6);

  --nm-raised-sm:-3px -3px 6px var(--nm-light), 3px 3px 6px var(--nm-dark);
  --nm-raised-md:-6px -6px 12px var(--nm-light), 6px 6px 12px var(--nm-dark);
  --nm-raised-lg:-10px -10px 22px var(--nm-light), 10px 10px 22px var(--nm-dark-strong);
  --nm-sunken-sm:inset -2px -2px 5px var(--nm-light), inset 2px 2px 5px var(--nm-dark);
  --nm-sunken-md:inset -4px -4px 9px var(--nm-light), inset 4px 4px 9px var(--nm-dark);
  --nm-sunken-lg:inset -7px -7px 15px var(--nm-light), inset 7px 7px 15px var(--nm-dark-strong);
  --nm-pressed:inset -2px -2px 6px var(--nm-light), inset 2px 2px 6px var(--nm-dark);
  --nm-glow:0 0 0 1px var(--accent-glow), 0 0 14px var(--accent-glow);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

body {
  font-family:var(--font-sans);
  background:var(--bg);
  color:var(--text-body);
  font-size:var(--text-base);
  line-height:var(--lh-normal);
  font-weight:var(--fw-regular);
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}

h1,h2,h3,h4{color:var(--text-strong);font-weight:var(--fw-bold);line-height:var(--lh-tight);letter-spacing:var(--ls-tight)}

.idh-eyebrow {
  font-family:var(--font-mono);
  font-size:var(--text-2xs);
  letter-spacing:var(--ls-wider);
  text-transform:uppercase;
  color:var(--text-faint);
  font-weight:var(--fw-medium);
}

/* ── Header ── */
header {
  background:linear-gradient(145deg,var(--n-800) 0%,var(--n-850) 100%);
  color:#e7eaf2;
  padding:var(--space-5) var(--space-6);
  position:relative;
  overflow:hidden;
}
header::before {
  content:'';
  position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 120% at 0% 50%, rgba(79,120,214,0.14) 0%, transparent 60%);
  pointer-events:none;
}
.header-inner {
  display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);
  position:relative;
}
.header-brand{}
header h1 {
  font-size:var(--text-xl);
  font-weight:var(--fw-extrabold);
  letter-spacing:var(--ls-tight);
  color:#e7eaf2;
}
header p {
  margin-top:2px;
  font-size:var(--text-xs);
  color:var(--n-400);
  line-height:var(--lh-relaxed);
}
.header-link{color:var(--n-400);text-decoration:none;border-bottom:1px solid rgba(255,255,255,0.15);transition:color var(--dur-fast),border-color var(--dur-fast)}
.header-link:hover{color:var(--n-100);border-color:var(--n-100)}

.header-actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0;position:relative}

/* ── Calc toggle switch ── */
.calc-toggle {
  display:inline-flex;align-items:center;gap:var(--space-2);
  cursor:pointer;
  flex-shrink:0;
  user-select:none;
}
.calc-toggle input { position:absolute;opacity:0;width:0;height:0;pointer-events:none }
.calc-toggle-track {
  position:relative;
  width:44px;height:24px;
  border-radius:var(--radius-pill);
  background:var(--n-800);
  box-shadow:var(--nm-sunken-md);
  transition:background var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
  flex-shrink:0;
}
.calc-toggle input:checked ~ .calc-toggle-track {
  background:var(--accent);
  box-shadow:var(--nm-sunken-sm), 0 0 8px var(--accent-glow);
}
.calc-toggle-thumb {
  position:absolute;
  top:4px;left:4px;
  width:16px;height:16px;
  border-radius:var(--radius-circle);
  background:var(--n-500);
  box-shadow:var(--nm-raised-sm);
  transition:transform var(--dur-base) var(--ease-soft), background var(--dur-base) var(--ease-out);
}
.calc-toggle input:checked ~ .calc-toggle-track .calc-toggle-thumb {
  transform:translateX(20px);
  background:#fff;
  box-shadow:var(--nm-raised-md);
}
.calc-toggle-icon {
  color:var(--n-500);
  flex-shrink:0;
  transition:color var(--dur-base);
}
.calc-toggle:has(input:checked) .calc-toggle-icon {
  color:var(--accent-300);
}
.calc-toggle-label {
  font-family:var(--font-mono);
  font-size:var(--text-2xs);
  font-weight:var(--fw-semibold);
  letter-spacing:var(--ls-wider);
  text-transform:uppercase;
  color:var(--n-400);
  transition:color var(--dur-base);
}
.calc-toggle:has(input:checked) .calc-toggle-label {
  color:var(--accent-300);
}

.share-btn {
  display:inline-flex;align-items:center;gap:6px;
  height:38px;padding:0 var(--space-3);
  border:none;border-radius:var(--radius-pill);
  background:var(--n-700);
  color:var(--n-300);
  cursor:pointer;
  font-family:var(--font-mono);
  font-size:var(--text-2xs);
  font-weight:var(--fw-semibold);
  letter-spacing:var(--ls-wide);
  box-shadow:var(--nm-raised-sm);
  transition:box-shadow var(--dur-base) var(--ease-out),background var(--dur-base),color var(--dur-base);
}
.share-btn:hover{background:var(--accent-600);color:#fff;box-shadow:var(--nm-raised-md)}

.theme-btn {
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;flex-shrink:0;
  border:none;border-radius:var(--radius-circle);
  background:var(--n-700);
  color:var(--n-300);
  cursor:pointer;
  font-size:var(--text-md);
  box-shadow:var(--nm-raised-sm);
  transition:box-shadow var(--dur-base) var(--ease-out),background var(--dur-base);
}
.theme-btn:hover{background:var(--n-600);color:var(--n-100)}

.share-toast {
  position:absolute;top:calc(100% + 8px);right:0;
  background:var(--n-800);color:#e7eaf2;
  font-family:var(--font-mono);font-size:var(--text-xs);
  padding:6px 14px;border-radius:var(--radius-pill);
  box-shadow:0 4px 16px rgba(0,0,0,0.28);
  white-space:nowrap;pointer-events:none;
  opacity:0;transform:translateY(-4px);
  transition:opacity var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out);
}
.share-toast--visible{opacity:1;transform:translateY(0)}

/* ── Dashboard grid ── */
.dashboard {
  display:grid;
  grid-template-columns:320px 1fr;
  min-height:calc(100vh - 68px);
  align-items:start;
}

/* ── Left sidebar (groups) ── */
.groups-sidebar {
  background:var(--surface-raised);
  box-shadow:var(--nm-raised-lg);
  padding:var(--space-4);
  display:flex;flex-direction:column;gap:var(--space-3);
  min-height:calc(100vh - 68px);
  position:sticky;top:0;
  overflow-y:auto;
  max-height:100vh;
  overflow-x:hidden;
}
.gs-header{display:flex;flex-direction:column;gap:var(--space-3)}
.gs-title-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}
.gs-title {
  font-size:var(--text-xs);font-weight:var(--fw-bold);
  letter-spacing:var(--ls-wider);text-transform:uppercase;
  color:var(--text-faint);font-family:var(--font-mono);
}
.traffic-row{display:flex;align-items:center;gap:var(--space-2)}
.traffic-row input{flex:1;min-width:0}
.gs-even-btn {
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 10px;
  border:none;border-radius:var(--radius-pill);
  background:var(--surface-sunken);
  box-shadow:var(--nm-sunken-sm);
  color:var(--text-faint);
  font-family:var(--font-mono);font-size:var(--text-2xs);
  font-weight:var(--fw-medium);letter-spacing:var(--ls-wide);
  cursor:pointer;
  transition:box-shadow var(--dur-fast) var(--ease-out),color var(--dur-fast);
}
.gs-even-btn:hover{box-shadow:var(--nm-raised-sm);color:var(--text-strong)}
/* ── Sidebar settings + projection ── */
.sidebar-section-label {
  font-family:var(--font-mono);font-size:var(--text-2xs);font-weight:var(--fw-bold);
  letter-spacing:var(--ls-wider);text-transform:uppercase;color:var(--text-faint);
  padding-top:var(--space-2);
  border-top:1px solid var(--border-hair);
}
.sidebar-settings{display:flex;flex-direction:column;gap:var(--space-3)}
.sidebar-projection{display:flex;flex-direction:column;gap:var(--space-3)}

/* ── Groups grid (main area, horizontal) ── */
.groups-grid {
  padding-left:var(--space-4);
  display:flex;
  flex-wrap:nowrap;
  gap:var(--space-3);
  align-items:start;
  overflow-x:auto;
  padding-bottom:var(--space-2);
  transition:gap var(--dur-base) var(--ease-out);
}
.group-col {
  display:flex;flex-direction:column;gap:var(--space-3);
  flex:0 0 290px;min-width:290px;
}
.group-col--add {
  flex:0 0 140px;min-width:140px;
  justify-content:flex-start;
  padding-top:var(--space-1);
}
.ctrl-result-spacer{flex:1}
.result-card-slot{min-height:0}

/* ── Group rows (main grid) ── */
.group-row {
  background:var(--surface-raised);
  border-radius:var(--radius-lg);
  padding:var(--space-4);
  box-shadow:var(--nm-raised-md);
  display:flex;flex-direction:column;gap:var(--space-3);
}
.ctrl-row{box-shadow:var(--nm-raised-md), 0 0 0 1.5px var(--border-hair)}

/* ── Control section in sidebar ── */
.sidebar-control{display:flex;flex-direction:column;gap:var(--space-3)}
.sidebar-control .fg{gap:var(--space-1)}
.group-row-header{display:flex;align-items:center;justify-content:space-between}
.group-row-fields{display:flex;flex-direction:column;gap:var(--space-2)}
.group-row-fields .fg{min-width:0}
.group-row-fields .fg input,.group-row-fields .fg .rate-display{width:100%;min-width:0;box-sizing:border-box}

/* ── Distribution knob ── */
.dist-fg{}
.knob-row{display:flex;align-items:center;gap:var(--space-2)}
.dist-knob{
  flex:1;
  -webkit-appearance:none;
  appearance:none;
  height:6px;
  border-radius:var(--radius-pill);
  background:var(--surface-sunken);
  box-shadow:var(--nm-sunken-sm);
  outline:none;
  cursor:pointer;
  transition:box-shadow var(--dur-base) var(--ease-out);
}
.dist-knob:focus{box-shadow:var(--nm-sunken-sm), 0 0 0 1.5px var(--accent)}
.dist-knob::-webkit-slider-thumb{
  -webkit-appearance:none;
  appearance:none;
  width:20px;height:20px;
  border-radius:var(--radius-circle);
  background:var(--surface-raised);
  box-shadow:var(--nm-raised-sm);
  cursor:pointer;
  transition:box-shadow var(--dur-fast) var(--ease-out);
}
.dist-knob::-webkit-slider-thumb:hover{box-shadow:var(--nm-raised-md)}
.dist-knob::-moz-range-thumb{
  width:20px;height:20px;
  border:none;
  border-radius:var(--radius-circle);
  background:var(--surface-raised);
  box-shadow:var(--nm-raised-sm);
  cursor:pointer;
}
.dist-knob-val{
  font-family:var(--font-mono);
  font-size:var(--text-xs);
  font-weight:var(--fw-bold);
  color:var(--text-strong);
  min-width:36px;
  text-align:right;
  flex-shrink:0;
}

/* ── Add group button ── */
.add-group-btn {
  background:none;border:2px dashed var(--border-hair);border-radius:var(--radius-lg);
  color:var(--text-faint);font-family:var(--font-mono);font-size:var(--text-xs);
  padding:var(--space-3) var(--space-3);cursor:pointer;width:100%;
  transition:all var(--dur-base) var(--ease-out);letter-spacing:var(--ls-wide);
  min-height:80px;
}
.add-group-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(79,120,214,0.04)}

/* ── Main area ── */
.main-area {
  padding:var(--space-5);
  padding-left:calc(var(--space-5) + 10px);
  display:flex;flex-direction:column;gap:var(--space-5);
  min-width:0;
}

/* ── Projection section ── */
.projection-section {
  background:var(--surface-raised);
  border-radius:var(--radius-xl);
  padding:var(--space-5) var(--space-6);
  box-shadow:var(--nm-raised-lg);
}

/* ── Radio groups (now in sidebar) ── */
.radio-group{display:flex;flex-direction:column;gap:var(--space-2)}
.radio-label {
  font-family:var(--font-mono);font-size:var(--text-2xs);
  font-weight:var(--fw-medium);letter-spacing:var(--ls-wider);
  text-transform:uppercase;color:var(--text-faint);
  display:flex;align-items:center;gap:4px;
}
.radio-pills{display:flex;flex-wrap:wrap;gap:var(--space-1)}
.radio-pill{display:inline-flex;cursor:pointer;position:relative}
.radio-pill input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.radio-pill span {
  display:inline-flex;align-items:center;
  padding:5px 14px;
  border-radius:var(--radius-pill);
  font-family:var(--font-mono);font-size:var(--text-2xs);
  font-weight:var(--fw-semibold);letter-spacing:var(--ls-wide);
  background:var(--surface-sunken);box-shadow:var(--nm-sunken-sm);
  color:var(--text-muted);
  transition:all var(--dur-fast) var(--ease-out);
  white-space:nowrap;cursor:pointer;
}
.radio-pill input:checked + span {
  background:var(--accent);color:#fff;
  box-shadow:var(--nm-raised-sm),0 0 0 1.5px var(--accent);
}
.radio-pill:hover span{color:var(--text-strong)}

/* ── Form group ── */
.fg{display:flex;flex-direction:column;gap:var(--space-1)}
.fg label {
  font-family:var(--font-mono);
  font-size:var(--text-2xs);
  font-weight:var(--fw-medium);
  letter-spacing:var(--ls-wider);
  text-transform:uppercase;
  color:var(--text-faint);
  display:flex;align-items:center;gap:var(--space-1);
}
.fg .hint{font-size:var(--text-xs);color:var(--text-faint);font-family:var(--font-mono)}

/* ── Sunken input / select ── */
.fg input,.fg select {
  height:40px;
  padding:0 var(--space-3);
  border:none;
  border-radius:var(--radius-md);
  background:var(--surface-sunken);
  box-shadow:var(--nm-sunken-md);
  font-family:var(--font-sans);
  font-size:var(--text-sm);
  font-weight:var(--fw-medium);
  color:var(--text-strong);
  outline:none;
  transition:box-shadow var(--dur-base) var(--ease-out);
  appearance:none;
  -webkit-appearance:none;
  cursor:pointer;
}
.fg input:focus,.fg select:focus {
  box-shadow:var(--nm-sunken-md), inset 0 0 0 1.5px var(--accent), inset 0 0 10px var(--accent-glow);
}

/* ── Key input highlight ── */
.fg input.input--key {
  box-shadow:var(--nm-sunken-md), inset 0 0 0 1.5px var(--accent);
  font-weight:var(--fw-bold);
}
.fg input.input--key:focus {
  box-shadow:var(--nm-sunken-md), inset 0 0 0 2px var(--accent), inset 0 0 14px var(--accent-glow);
}


/* ── Group badge ── */
.group-badge {
  display:inline-flex;align-items:center;
  padding:3px 10px;
  border-radius:var(--radius-pill);
  font-family:var(--font-mono);
  font-size:var(--text-2xs);
  font-weight:var(--fw-medium);
  letter-spacing:var(--ls-wider);
  text-transform:uppercase;
  box-shadow:var(--nm-raised-sm);
}
.badge-ctrl{background:var(--surface-raised);color:var(--text-muted)}
.badge-variant{color:#fff}

/* ── Conversion rate display ── */
.rate-display {
  height:40px;
  display:flex;align-items:center;justify-content:center;
  border-radius:var(--radius-md);
  background:var(--surface-sunken);
  box-shadow:var(--nm-sunken-sm);
  font-family:var(--font-mono);
  font-size:var(--text-sm);
  font-weight:var(--fw-bold);
  color:var(--text-strong);
  letter-spacing:var(--ls-snug);
}

/* ── Remove button ── */
.btn-remove {
  display:inline-flex;align-items:center;justify-content:center;
  width:24px;height:24px;
  border:none;border-radius:var(--radius-circle);
  background:var(--surface-sunken);
  box-shadow:var(--nm-sunken-sm);
  color:var(--danger-500);
  font-size:var(--text-xs);
  cursor:pointer;
  transition:box-shadow var(--dur-fast) var(--ease-out);
}
.btn-remove:hover{box-shadow:var(--nm-raised-sm)}

/* ── Alert ── */
.alert {
  padding:var(--space-2) var(--space-3);
  border-radius:var(--radius-md);
  font-size:var(--text-xs);
  line-height:var(--lh-relaxed);
  box-shadow:var(--nm-sunken-sm);
}
.alert-warn{background:rgba(199,154,79,0.12);color:var(--warning-500)}
.alert-info{background:rgba(79,120,214,0.10);color:var(--accent)}
.sidebar-help-note{margin-top:var(--space-3)}

/* ── Result card (sits in .result-card-slot inside each .group-col) ── */
.result-card {
  background:var(--surface-raised);
  border-radius:var(--radius-lg);
  padding:var(--space-5);
  box-shadow:var(--nm-raised-md);
  display:flex;flex-direction:column;gap:0;
  transition:box-shadow var(--dur-base) var(--ease-out);
}
.result-card.win{box-shadow:var(--nm-raised-md), 0 0 0 1.5px var(--success-500)}
.result-card.loss{box-shadow:var(--nm-raised-md), 0 0 0 1.5px var(--danger-500)}
.result-card.inconclusive{box-shadow:var(--nm-raised-md), 0 0 0 1.5px var(--warning-500)}
.rc-head{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-4)}
.rc-title{font-size:var(--text-xs);font-weight:var(--fw-semibold);color:var(--text-faint);font-family:var(--font-mono);letter-spacing:var(--ls-wide);text-transform:uppercase}

/* ── Status badge (result) ── */
.badge {
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 12px;
  border-radius:var(--radius-pill);
  font-family:var(--font-mono);
  font-size:var(--text-2xs);
  font-weight:var(--fw-medium);
  letter-spacing:var(--ls-wide);
  text-transform:uppercase;
  white-space:nowrap;
  margin-bottom:var(--space-3);
  box-shadow:var(--nm-sunken-sm);
  background:var(--surface-sunken);
}
.badge-win{color:var(--success-500)}
.badge-loss{color:var(--danger-500)}
.badge-wait{color:var(--warning-500)}
.badge-no{color:var(--text-faint)}

/* ── Progress bar ── */
.bar-track{height:8px;background:var(--surface-sunken);box-shadow:var(--nm-sunken-sm);border-radius:var(--radius-pill);overflow:hidden;margin-bottom:var(--space-1)}
.bar-fill{height:100%;border-radius:var(--radius-pill);transition:width 0.6s var(--ease-out)}
.bar-labels{display:flex;justify-content:space-between;font-size:var(--text-2xs);color:var(--text-faint);font-family:var(--font-mono);margin-bottom:var(--space-4)}

/* ── Unified calculation chain ── */
.calc-chain{
  display:flex;flex-direction:column;
  font-family:var(--font-mono);
  font-size:var(--text-2xs);
}
.cc-step{display:flex;justify-content:space-between;align-items:baseline;gap:var(--space-3);padding:5px 0;min-width:0}
.cc-key{color:var(--text-faint);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center;gap:4px}
.cc-val{color:var(--text-faint);white-space:nowrap;flex-shrink:0}

/* Projection elements hidden */
.proj-hidden { display:none !important; }

/* Compact mode: hide all calc steps, show only confidence + uplift rows */
.groups-grid.calc-hidden .cc-input,
.groups-grid.calc-hidden .cc-mid,
.groups-grid.calc-hidden .cc-out,
.groups-grid.calc-hidden .cc-divider {
  display:none;
}

/* Mid-tier steps — pooled rate, SE formula */
.cc-mid .cc-key,.cc-mid .cc-val{color:var(--text-faint);opacity:.7}

/* Output steps — z, p-value */
.cc-key--out,.cc-val--out{color:var(--text-muted) !important;opacity:1;font-weight:var(--fw-medium)}

/* Result steps — confidence, threshold, uplift */
.cc-key--result{color:var(--text-body) !important;font-weight:var(--fw-semibold)}
.cc-val--result{color:var(--text-strong) !important;font-weight:var(--fw-bold);font-size:var(--text-xs)}

.cc-divider{height:1px;background:var(--border-hair);margin:var(--space-2) 0}
.pos{color:var(--success-500) !important}
.neg{color:var(--danger-500) !important}

/* ── ? help button ── */
.help-btn {
  display:inline-flex;align-items:center;justify-content:center;
  width:16px;height:16px;
  border-radius:var(--radius-circle);
  border:none;
  background:var(--surface-sunken);
  box-shadow:var(--nm-sunken-sm);
  color:var(--accent);
  font-family:var(--font-mono);
  font-size:9px;
  font-weight:var(--fw-bold);
  cursor:pointer;
  vertical-align:middle;
  margin-left:4px;
  position:relative;
  flex-shrink:0;
  transition:box-shadow var(--dur-fast) var(--ease-out),background var(--dur-fast);
}
.help-btn:hover{background:var(--accent);color:var(--text-on-accent);box-shadow:var(--nm-raised-sm)}

/* ── Floating tooltip (JS-driven, appended to body) ── */
.tip {
  position:fixed;
  z-index:9999;
  background:var(--n-800);
  color:#e7eaf2;
  font-size:0.85rem;
  font-weight:400;
  font-family:var(--font-sans);
  line-height:1.5;
  padding:8px 12px;
  border-radius:6px;
  box-shadow:0 4px 16px rgba(0,0,0,0.25);
  pointer-events:none;
  max-width:240px;
  white-space:normal;
  text-align:left;
  opacity:0;
  transition:opacity 0.1s;
}
.tip.tip--visible{opacity:1}

/* ── Concept bottom sheet ── */
.concept-sidebar{position:fixed;inset:0;z-index:200;pointer-events:none}
.concept-sidebar.is-open{pointer-events:all}
.sidebar-backdrop{position:absolute;inset:0;background:rgba(33,36,46,0.25);opacity:0;transition:opacity var(--dur-base)}
.concept-sidebar.is-open .sidebar-backdrop{opacity:1}
.sidebar-panel{
  position:absolute;left:0;right:0;bottom:0;
  max-height:42vh;
  background:var(--surface-raised);
  box-shadow:0 -8px 40px rgba(0,0,0,0.18);
  border-radius:var(--radius-xl) var(--radius-xl) 0 0;
  transform:translateY(100%);
  transition:transform var(--dur-slow) var(--ease-soft);
  display:flex;flex-direction:column;
}
.concept-sidebar.is-open .sidebar-panel{transform:translateY(0)}
.sidebar-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:var(--space-4) var(--space-6);
  border-bottom:1px solid var(--border-hair);
  flex-shrink:0;
}
.sidebar-label{font-size:var(--text-md);font-weight:var(--fw-bold);color:var(--text-strong);letter-spacing:var(--ls-snug)}
.sidebar-close{background:var(--surface-sunken);border:none;box-shadow:var(--nm-sunken-sm);width:32px;height:32px;border-radius:var(--radius-circle);font-size:var(--text-md);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:box-shadow var(--dur-fast),color var(--dur-fast)}
.sidebar-close:hover{box-shadow:var(--nm-raised-sm);color:var(--text-strong)}
.sidebar-body{padding:var(--space-4) var(--space-6);font-size:var(--text-sm);line-height:var(--lh-relaxed);color:var(--text-body);overflow-y:auto;flex:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--space-4) var(--space-6);align-content:start}
.sidebar-body p{margin-bottom:var(--space-3)}
.sidebar-body h4{font-family:var(--font-mono);font-size:var(--text-2xs);font-weight:var(--fw-medium);letter-spacing:var(--ls-wider);text-transform:uppercase;color:var(--accent);margin:var(--space-3) 0 var(--space-1)}
.sidebar-body ul{padding-left:var(--space-5);margin-bottom:var(--space-3)}
.sidebar-body li{margin-bottom:var(--space-1)}
.sidebar-body strong{color:var(--text-strong);font-weight:var(--fw-semibold)}
.sidebar-body code{font-family:var(--font-mono);font-size:var(--text-xs);background:var(--surface-sunken);box-shadow:var(--nm-sunken-sm);padding:2px 8px;border-radius:var(--radius-sm);color:var(--accent)}

/* ── Scenarios section ── */
.scen-inputs{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-bottom:var(--space-4);align-items:end}
.scen-inputs .fg{min-width:0}
.scen-inputs .fg .hint{font-size:var(--text-2xs);color:var(--text-faint);font-family:var(--font-mono);margin-top:2px;display:block}

.scen-stat-row{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  justify-content:start;
  gap:0;
  padding:0;
  background:var(--surface-sunken);
  border-radius:var(--radius-md);
  box-shadow:var(--nm-sunken-sm);
  margin-bottom:var(--space-4);
  font-family:var(--font-mono);
  overflow:hidden;
}
.scen-stat{display:flex;flex-direction:column;gap:2px;padding:var(--space-2) var(--space-4);border-right:1px solid var(--border-hair)}
.scen-stat:last-child{border-right:none;flex:1}
.scen-stat--wide{grid-column:span 1}
.scen-stat-label{font-size:var(--text-2xs);letter-spacing:var(--ls-wider);text-transform:uppercase;color:var(--text-faint)}
.scen-stat-val{font-size:var(--text-xs);font-weight:var(--fw-bold);color:var(--text-strong)}
.scen-stat-val strong{color:var(--accent)}

.chart-box{background:var(--surface-sunken);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--nm-sunken-md);min-width:0;display:flex;flex-direction:column}
.chart-box h4{font-size:var(--text-sm);font-weight:var(--fw-bold);color:var(--text-strong);margin-bottom:4px;letter-spacing:var(--ls-snug)}
.chart-box p{font-size:var(--text-xs);color:var(--text-faint);margin-bottom:var(--space-4);line-height:var(--lh-relaxed);font-family:var(--font-mono)}
.chart-box-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-4)}
.chart-title-group{flex:1;min-width:0}
.chart-box-title{font-size:var(--text-sm);font-weight:var(--fw-bold);color:var(--text-strong);letter-spacing:var(--ls-snug)}
.chart-copy-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:32px;height:32px;flex-shrink:0;
  border:1px solid var(--border-hair);border-radius:var(--radius-sm);
  background:var(--surface-raised);
  color:var(--text-muted);
  cursor:pointer;
  transition:all var(--dur-fast) var(--ease-out);
}
.chart-copy-btn:hover{
  color:var(--text-strong);
  background:var(--surface-raised);
  border-color:var(--accent);
  box-shadow:var(--nm-raised-sm)
}
.chart-wrap{position:relative;height:260px;flex:1}
.proj-charts-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);margin-top:var(--space-4)}
@media(max-width:1300px){.proj-charts-row{grid-template-columns:1fr}}
.scen-chart-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-4)}
.scen-chart-title{font-size:var(--text-sm);font-weight:var(--fw-bold);color:var(--text-strong);letter-spacing:var(--ls-snug)}
.scen-chart-sub{font-size:var(--text-xs);color:var(--text-faint);font-family:var(--font-mono);margin-top:2px;line-height:var(--lh-relaxed)}

/* ── Empty state ── */
.empty{text-align:center;padding:var(--space-8);color:var(--text-faint);font-size:var(--text-sm);font-family:var(--font-mono);letter-spacing:var(--ls-wide)}

/* ── Responsive ── */
@media(max-width:900px){
  .dashboard{grid-template-columns:1fr}
  .groups-sidebar{min-height:auto;position:static;max-height:none}
  .groups-grid{flex-wrap:wrap}
  .group-col{flex:0 0 180px;min-width:180px}
}

/* ── Mobile: row-based layout for narrow screens ── */
@media(max-width:820px){
  .dashboard{grid-template-columns:1fr;min-height:auto}
  .groups-sidebar{
    min-height:auto;
    position:static;
    max-height:none;
    box-shadow:var(--nm-sunken-lg);
    margin-bottom:var(--space-4);
  }
}

@media(max-width:1200px){
  .scen-stat-row{grid-template-columns:repeat(3,1fr)}
}

@media(max-width:800px){
  .scen-stat-row{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:640px){
  .groups-grid{
    flex-direction:column;
    flex-wrap:nowrap;
    overflow-x:visible;
    gap:var(--space-4);
  }
  .group-col{
    flex:1 1 auto;
    min-width:100%;
    display:grid;
    grid-template-columns:1fr;
    gap:var(--space-3);
  }
  .group-col--add{
    min-width:100%;
  }
  .ctrl-result-spacer{display:none}

  /* Stack group row and result card vertically, both full-width */
  .group-col .group-row,
  .group-col .result-card-slot{
    width:100%;
  }

  /* Tighter spacing on mobile */
  .main-area{padding:var(--space-4)}
  .projection-section{padding:var(--space-4)}

  .scen-stat-row{grid-template-columns:1fr}
  .scen-stat{border-right:none;border-bottom:1px solid var(--border-hair);padding:var(--space-2) var(--space-3)}
  .scen-stat:last-child{border-bottom:none}
}
