/* Life-Path Fractal Visualizer — Neo-minimalist dark + glassmorphism bento */

:root {
  --cy: #00F0FF;
  --pp: #B24BFF;
  --bg: oklch(0.13 0.012 270);
  --bg-2: oklch(0.16 0.015 270);
  --glass: rgba(255, 255, 255, 0.035);
  --glass-stroke: rgba(255, 255, 255, 0.08);
  --fg: oklch(0.97 0.01 270);
  --fg-2: oklch(0.72 0.015 270);
  --fg-3: oklch(0.50 0.02 270);
  --fg-dim: oklch(0.38 0.02 270);
  --danger: #ff4d6d;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html, body, #root { min-height: 100%; }

body {
  font-family: "Inter", system-ui, -apple-system, sans-serif;
  background: var(--bg);
  color: var(--fg);
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: -0.005em;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

.mono { font-family: "JetBrains Mono", ui-monospace, Menlo, monospace; font-feature-settings: "ss01"; }

/* ---------- Background FX ---------- */
.bgfx {
  position: fixed; inset: 0; z-index: 0; pointer-events: none; overflow: hidden;
}
.bg-grid {
  position: absolute; inset: -10%;
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse at 50% 40%, #000 30%, transparent 80%);
}
.bg-glow {
  position: absolute; border-radius: 999px; filter: blur(120px); opacity: 0.35;
}
.bg-glow-cy { width: 560px; height: 560px; background: var(--cy); top: -200px; left: -150px; opacity: 0.12;}
.bg-glow-pp { width: 640px; height: 640px; background: var(--pp); bottom: -280px; right: -200px; opacity: 0.14;}
.bg-noise {
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='140' height='140'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.5 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity: 0.025; mix-blend-mode: overlay;
}

/* ---------- Layout ---------- */
.app {
  position: relative; z-index: 1;
  min-height: 100vh;
  padding: 24px;
  max-width: 1680px;
  margin: 0 auto;
}

/* ---------- Topbar ---------- */
.topbar {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 20px;
  padding: 0 4px;
}
.brand { display: flex; gap: 14px; align-items: center; }
.brand-mark {
  display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px;
  background: linear-gradient(135deg, rgba(0,240,255,0.12), rgba(178,75,255,0.12));
  border: 1px solid var(--glass-stroke);
  border-radius: 10px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
.brand-title {
  font-family: "JetBrains Mono", monospace;
  font-size: 12px; font-weight: 600;
  letter-spacing: 0.16em;
  color: var(--fg);
  white-space: nowrap;
}
.brand-sub {
  font-family: "JetBrains Mono", monospace;
  font-size: 10.5px; color: var(--fg-3); letter-spacing: 0.06em;
  white-space: nowrap;
}
.top-meta { display: flex; gap: 8px; }
.pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 10px;
  background: var(--glass);
  border: 1px solid var(--glass-stroke);
  border-radius: 999px;
  font-size: 11px; color: var(--fg-2);
  font-family: "JetBrains Mono", monospace; letter-spacing: 0.03em;
}
.dot { width: 6px; height: 6px; border-radius: 50%; }
.dot-cy { background: var(--cy); box-shadow: 0 0 8px var(--cy); }
.dot-pp { background: var(--pp); box-shadow: 0 0 8px var(--pp); }
.dot-neutral { background: #8892a6; }

/* ---------- Bento grid ---------- */
.bento {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: minmax(92px, auto);
  gap: 14px;
}
.cell-input     { grid-column: span 4; grid-row: span 3; }
.cell-fate      { grid-column: span 3; grid-row: span 3; }
.cell-tree      { grid-column: span 5; grid-row: span 6; }
.cell-stats     { grid-column: span 4; grid-row: span 3; }
.cell-inspector { grid-column: span 3; grid-row: span 3; }
.cell-summary   { grid-column: span 3; grid-row: span 3; }
.cell-saved     { grid-column: span 4; grid-row: span 3; }

@media (max-width: 1180px) {
  .cell-input, .cell-stats, .cell-saved { grid-column: span 6; }
  .cell-fate, .cell-inspector, .cell-summary { grid-column: span 6; }
  .cell-tree { grid-column: span 12; grid-row: span 5; min-height: 560px; }
}
@media (max-width: 720px) {
  .app { padding: 16px; }
  .bento { grid-template-columns: 1fr; gap: 12px; }
  .cell-input, .cell-fate, .cell-tree, .cell-stats,
  .cell-inspector, .cell-summary, .cell-saved { grid-column: span 1; grid-row: auto; }
  .cell-tree { min-height: 440px; }
  .top-meta { display: none; }
}

.cell {
  position: relative;
  background: linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.015));
  border: 1px solid var(--glass-stroke);
  border-radius: 18px;
  padding: 18px;
  display: flex; flex-direction: column;
  backdrop-filter: blur(22px) saturate(130%);
  -webkit-backdrop-filter: blur(22px) saturate(130%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.04),
    0 1px 0 rgba(0,0,0,0.4);
  overflow: hidden;
  min-height: 0;
}
.cell::before {
  content: "";
  position: absolute; inset: 0;
  border-radius: 18px;
  padding: 1px;
  background: linear-gradient(135deg, rgba(0,240,255,0.15), rgba(178,75,255,0.0) 50%, rgba(178,75,255,0.12));
  mask: linear-gradient(#000, #000) content-box, linear-gradient(#000, #000);
  -webkit-mask: linear-gradient(#000, #000) content-box, linear-gradient(#000, #000);
  mask-composite: exclude;
  -webkit-mask-composite: xor;
  pointer-events: none; opacity: 0.6;
}

.cell-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 14px;
  gap: 8px;
  min-width: 0;
}
.cell-label {
  font-family: "JetBrains Mono", monospace;
  font-size: 10.5px;
  letter-spacing: 0.14em;
  color: var(--fg);
  text-transform: uppercase;
  white-space: nowrap;
  flex-shrink: 0;
}
.cell-label.tiny { font-size: 9.5px; color: var(--fg-3); letter-spacing: 0.16em; }
.cell-hint {
  font-family: "JetBrains Mono", monospace;
  font-size: 10px; color: var(--fg-3); letter-spacing: 0.04em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
  text-align: right;
}
@media (max-width: 1280px) {
  .cell-hint { display: none; }
}
.cell-action {
  background: transparent; border: 1px solid var(--glass-stroke);
  color: var(--fg-2); font-family: "JetBrains Mono", monospace;
  font-size: 10px; letter-spacing: 0.08em; padding: 4px 8px;
  border-radius: 6px; cursor: pointer; display: inline-flex; align-items: center; gap: 5px;
  transition: all 0.15s;
}
.cell-action:hover:not(:disabled) { color: var(--cy); border-color: var(--cy); }
.cell-action:disabled { opacity: 0.35; cursor: not-allowed; }

/* ---------- Input cell ---------- */
.input-wrap { position: relative; margin-bottom: 10px; }
.life-input {
  width: 100%;
  background: rgba(0, 0, 0, 0.3);
  border: 1px solid var(--glass-stroke);
  color: var(--fg);
  font-family: "Instrument Serif", Georgia, serif;
  font-size: 22px;
  line-height: 1.25;
  letter-spacing: -0.01em;
  padding: 14px 16px;
  border-radius: 12px;
  resize: none;
  outline: none;
  transition: all 0.25s;
}
.life-input::placeholder { color: var(--fg-dim); font-style: italic; }
.life-input:focus {
  border-color: var(--cy);
  box-shadow: 0 0 0 1px var(--cy), 0 0 24px rgba(0,240,255,0.15), inset 0 0 24px rgba(0,240,255,0.04);
}
.input-ring {
  position: absolute; inset: -6px; pointer-events: none;
  border-radius: 18px;
  background: radial-gradient(ellipse at 50% 50%, rgba(0,240,255,0.06), transparent 70%);
  opacity: 0; transition: opacity 0.3s;
}
.life-input:focus + .input-ring { opacity: 1; }

.choice-examples { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 12px; }
.chip {
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--glass-stroke);
  color: var(--fg-2);
  padding: 4px 10px; border-radius: 999px;
  font-size: 11px; cursor: pointer;
  transition: all 0.15s;
}
.chip:hover { color: var(--cy); border-color: rgba(0,240,255,0.4); background: rgba(0,240,255,0.05); }

.row { display: flex; gap: 8px; flex-wrap: wrap; margin-top: auto; }
.btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 14px; border-radius: 10px;
  font-family: "Inter", sans-serif; font-size: 12px; font-weight: 500;
  letter-spacing: 0.02em; cursor: pointer; border: 1px solid var(--glass-stroke);
  background: var(--glass); color: var(--fg);
  transition: all 0.18s;
}
.btn-sm { padding: 6px 10px; font-size: 11px; }
.btn-primary {
  background: linear-gradient(135deg, rgba(0,240,255,0.18), rgba(178,75,255,0.12));
  border-color: rgba(0,240,255,0.45);
  color: #fff;
  box-shadow: 0 0 0 1px rgba(0,240,255,0.15), 0 6px 22px rgba(0,240,255,0.18), inset 0 1px 0 rgba(255,255,255,0.1);
}
.btn-primary:hover {
  border-color: var(--cy);
  box-shadow: 0 0 0 1px var(--cy), 0 8px 28px rgba(0,240,255,0.32), inset 0 1px 0 rgba(255,255,255,0.15);
  transform: translateY(-1px);
}
.btn-ghost:hover { color: var(--cy); border-color: rgba(0,240,255,0.35); }
.kbd {
  font-family: "JetBrains Mono", monospace; font-size: 10px;
  padding: 1px 6px; border-radius: 4px; background: rgba(0,0,0,0.35);
  color: var(--fg-3); margin-left: 4px; letter-spacing: 0.05em;
}

/* ---------- Fate cell ---------- */
.fate-display {
  display: flex; align-items: center; gap: 10px; margin-bottom: 4px;
}
.fate-code {
  font-family: "JetBrains Mono", monospace;
  font-size: 28px; font-weight: 600;
  letter-spacing: 0.18em;
  color: var(--cy);
  text-shadow: 0 0 18px rgba(0,240,255,0.4);
  flex: 1;
}
.fate-seed { font-size: 10.5px; color: var(--fg-3); letter-spacing: 0.04em; margin-bottom: 14px; }
.icon-btn {
  width: 30px; height: 30px; border-radius: 8px;
  background: var(--glass); border: 1px solid var(--glass-stroke);
  color: var(--fg-2); cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  transition: all 0.15s;
}
.icon-btn:hover:not(:disabled) { color: var(--cy); border-color: var(--cy); }
.icon-btn:disabled { opacity: 0.3; cursor: not-allowed; }
.divider {
  height: 1px; background: var(--glass-stroke); margin: 12px -18px;
}
.fate-input-row { display: flex; gap: 6px; margin-top: 8px; }
.fate-input {
  flex: 1;
  background: rgba(0,0,0,0.3);
  border: 1px solid var(--glass-stroke);
  color: var(--fg);
  padding: 9px 12px;
  border-radius: 8px;
  font-size: 13px; letter-spacing: 0.14em; font-weight: 500;
  outline: none; text-transform: uppercase;
  transition: all 0.15s;
}
.fate-input:focus { border-color: var(--cy); box-shadow: 0 0 0 1px var(--cy); }
.fate-input::placeholder { color: var(--fg-dim); }

/* ---------- Tree cell ---------- */
.tree-canvas {
  position: relative; flex: 1; min-height: 0;
  border-radius: 12px;
  background:
    radial-gradient(ellipse at 50% 100%, rgba(0,240,255,0.04), transparent 60%),
    radial-gradient(ellipse at 50% 0%, rgba(178,75,255,0.03), transparent 60%),
    rgba(0,0,0,0.25);
  border: 1px solid rgba(255,255,255,0.04);
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.canvas-overlay {
  position: absolute; top: 10px; left: 10px; right: 10px;
  display: flex; gap: 6px; flex-wrap: wrap;
}
.legend-chip { white-space: nowrap; }
.legend-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 8px; border-radius: 999px;
  background: rgba(0,0,0,0.4);
  border: 1px solid var(--glass-stroke);
  font-family: "JetBrains Mono", monospace;
  font-size: 10px; letter-spacing: 0.04em;
  color: var(--fg-3);
  backdrop-filter: blur(8px);
}
.legend-chip.clickable { cursor: pointer; color: var(--fg-2); }
.legend-chip.clickable:hover { color: var(--cy); border-color: var(--cy); }

/* Empty tree */
.empty-tree {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 12px; color: var(--fg-3);
  padding: 40px;
}
.empty-glyph { opacity: 0.6; animation: pulse 3s ease-in-out infinite; }
@keyframes pulse { 0%,100% { opacity: 0.4; } 50% { opacity: 0.75; } }
.empty-title {
  font-family: "Instrument Serif", serif;
  font-size: 24px; font-style: italic;
  color: var(--fg-2);
}
.empty-sub {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px; color: var(--fg-3); letter-spacing: 0.04em;
}

/* ---------- Stats cell ---------- */
.stats { display: flex; flex-direction: column; gap: 14px; }
.stat-row { display: flex; flex-direction: column; gap: 6px; }
.stat-head { display: flex; justify-content: space-between; align-items: baseline; }
.stat-label {
  font-family: "JetBrains Mono", monospace;
  font-size: 10.5px; letter-spacing: 0.12em;
  color: var(--fg-2); text-transform: uppercase;
}
.stat-value {
  font-family: "JetBrains Mono", monospace;
  font-size: 14px; font-weight: 600; letter-spacing: 0.03em;
}
.stat-track {
  position: relative;
  height: 4px; border-radius: 2px;
  background: rgba(255,255,255,0.05);
  overflow: hidden;
}
.stat-mid { position: absolute; left: 50%; top: 0; bottom: 0; width: 1px; background: rgba(255,255,255,0.2); }
.stat-fill {
  position: absolute; top: 0; bottom: 0;
  border-radius: 2px;
  transition: all 0.5s cubic-bezier(.4,.2,.2,1);
}
.stats-empty {
  display: flex; flex-direction: column; gap: 8px; justify-content: center; height: 100%;
}
.stats-hint {
  font-size: 11px; color: var(--fg-3); letter-spacing: 0.08em;
}
.stats-sub { font-size: 12px; color: var(--fg-3); }

/* ---------- Inspector cell ---------- */
.inspector { display: flex; flex-direction: column; gap: 10px; height: 100%; }
.insp-meta { display: flex; justify-content: space-between; align-items: center; }
.insp-cat {
  font-family: "JetBrains Mono", monospace;
  font-size: 9.5px; font-weight: 600;
  letter-spacing: 0.16em;
  padding: 3px 8px;
  border: 1px solid;
  border-radius: 999px;
}
.insp-depth { font-size: 10.5px; color: var(--fg-3); letter-spacing: 0.05em; }
.insp-title {
  font-family: "Instrument Serif", serif;
  font-size: 20px; line-height: 1.15;
  color: var(--fg); letter-spacing: -0.01em;
}
.insp-micro {
  font-size: 13px; line-height: 1.5;
  color: var(--fg-2);
  text-wrap: pretty;
}
.insp-step {
  margin-top: auto; display: flex; gap: 6px; flex-wrap: wrap;
  font-size: 10.5px; color: var(--fg-3); letter-spacing: 0.04em;
  padding-top: 10px; border-top: 1px dashed rgba(255,255,255,0.06);
}
.step-tag {
  padding: 2px 6px; border-radius: 4px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--glass-stroke);
  font-weight: 500;
}
.step-tag.pos { color: var(--cy); border-color: rgba(0,240,255,0.3); }
.step-tag.neg { color: var(--pp); border-color: rgba(178,75,255,0.3); }
.inspector-empty {
  display: flex; flex-direction: column; gap: 6px; justify-content: center;
  height: 100%; color: var(--fg-3); font-size: 11px;
}
.muted-sm { font-size: 11px; color: var(--fg-3); }

/* ---------- Summary cell ---------- */
.summary { display: flex; flex-direction: column; gap: 10px; flex: 1; }
.sum-row {
  flex: 1;
  padding: 12px; border-radius: 10px;
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--glass-stroke);
  display: flex; flex-direction: column; gap: 6px;
  transition: all 0.2s;
}
.sum-row:hover { border-color: rgba(255,255,255,0.18); background: rgba(255,255,255,0.04); }
.sum-best { border-left: 2px solid var(--cy); }
.sum-worst { border-left: 2px solid var(--pp); }
.sum-head { display: flex; justify-content: space-between; align-items: center; }
.sum-label {
  font-family: "JetBrains Mono", monospace;
  font-size: 10px; letter-spacing: 0.14em; color: var(--fg-3);
}
.sum-tag { font-family: "JetBrains Mono", monospace; font-size: 10px; letter-spacing: 0.06em; }
.sum-title {
  font-family: "Instrument Serif", serif;
  font-size: 16px; line-height: 1.2; color: var(--fg);
}
.sum-jump {
  align-self: flex-start;
  background: transparent; border: none; padding: 0;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px; letter-spacing: 0.08em;
  color: var(--fg-2); cursor: pointer;
  transition: color 0.15s;
}
.sum-jump:hover { color: var(--cy); }
.summary-empty { display: flex; align-items: center; justify-content: center; flex: 1; color: var(--fg-3); }

/* ---------- Saved cell ---------- */
.saved-empty {
  display: flex; flex-direction: column; gap: 6px; justify-content: center;
  height: 100%; color: var(--fg-3);
}
.saved-list {
  display: flex; flex-direction: column; gap: 6px;
  overflow-y: auto; max-height: 100%;
}
.saved-list::-webkit-scrollbar { width: 4px; }
.saved-list::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 2px; }
.saved-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px; border-radius: 8px;
  background: rgba(0,0,0,0.2);
  border: 1px solid var(--glass-stroke);
  cursor: pointer;
  transition: all 0.15s;
}
.saved-item:hover {
  border-color: rgba(0,240,255,0.35);
  background: rgba(0,240,255,0.04);
}
.saved-code {
  font-size: 11px; color: var(--cy); letter-spacing: 0.14em; font-weight: 600;
  text-shadow: 0 0 8px rgba(0,240,255,0.3);
  flex-shrink: 0;
}
.saved-choice {
  flex: 1;
  font-size: 12.5px; color: var(--fg-2);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.saved-del {
  width: 22px; height: 22px; border-radius: 6px;
  background: transparent; border: 1px solid transparent;
  color: var(--fg-3); cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
}
.saved-del:hover { color: var(--danger); border-color: rgba(255,77,109,0.3); }

/* ---------- Toast ---------- */
.toast {
  position: fixed; bottom: 28px; left: 50%; transform: translateX(-50%);
  background: rgba(10, 12, 20, 0.85);
  border: 1px solid var(--cy);
  color: var(--cy);
  padding: 10px 18px; border-radius: 999px;
  font-family: "JetBrains Mono", monospace;
  font-size: 11.5px; letter-spacing: 0.1em;
  backdrop-filter: blur(18px);
  box-shadow: 0 0 22px rgba(0,240,255,0.2), 0 8px 24px rgba(0,0,0,0.5);
  z-index: 50;
  animation: toast-in 0.22s ease-out;
}
@keyframes toast-in { from { opacity: 0; transform: translate(-50%, 8px); } to { opacity: 1; transform: translate(-50%, 0); } }

/* ---------- Tweaks ---------- */
.tweaks-panel {
  position: fixed; right: 20px; bottom: 20px;
  width: 260px; padding: 16px;
  background: rgba(10, 12, 20, 0.92);
  border: 1px solid var(--glass-stroke);
  border-radius: 14px;
  backdrop-filter: blur(20px);
  z-index: 40;
  box-shadow: 0 10px 40px rgba(0,0,0,0.6);
}
.tweaks-head { margin-bottom: 10px; }
.tweak-row {
  display: flex; align-items: center; gap: 10px;
  padding: 6px 0;
  font-size: 12px; color: var(--fg-2);
}
.tweak-row label { flex: 1; }
.tweak-row input[type="range"] { flex: 1; }
.tweak-row input[type="color"] {
  width: 28px; height: 22px; border: 1px solid var(--glass-stroke); border-radius: 5px;
  background: transparent; padding: 0; cursor: pointer;
}

/* ---------- Topbar pill button ---------- */
.pill-btn {
  cursor: pointer; background: var(--glass); color: var(--fg-2);
  transition: all 0.15s;
}
.pill-btn:hover { color: var(--cy); border-color: var(--cy); }

/* ---------- Settings panel ---------- */
.settings-overlay {
  position: fixed; inset: 0; z-index: 60;
  background: rgba(5, 6, 12, 0.62);
  backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  animation: fade-in 0.18s ease-out;
}
@keyframes fade-in { from { opacity: 0; } to { opacity: 1; } }
.settings-panel {
  width: 100%; max-width: 440px;
  max-height: calc(100vh - 48px);
  overflow-y: auto;
  padding: 22px;
  background: linear-gradient(180deg, rgba(22,24,34,0.96), rgba(14,16,24,0.96));
  border: 1px solid var(--glass-stroke);
  border-radius: 18px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.04),
    0 12px 48px rgba(0,0,0,0.6),
    0 0 0 1px rgba(0,240,255,0.08);
}
.settings-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 18px;
}
.settings-section {
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,0.05);
  margin-top: 14px;
}
.settings-section:first-of-type { border-top: none; margin-top: 0; padding-top: 0; }
.settings-note {
  font-size: 12px; line-height: 1.55; color: var(--fg-3);
  margin: 6px 0 12px;
}
.settings-note a { color: var(--cy); text-decoration: none; }
.settings-note a:hover { text-decoration: underline; }
.settings-key-row { display: flex; gap: 6px; margin-bottom: 10px; }
.settings-key-row .fate-input {
  flex: 1; letter-spacing: 0.02em; text-transform: none; font-size: 12px;
}
.settings-row { margin-top: 0; }
.settings-toggle { margin-top: 14px; }
.settings-toggle label {
  display: flex; align-items: center; gap: 8px;
  font-size: 12px; color: var(--fg-2);
  cursor: pointer;
}
.settings-toggle input[type="checkbox"] { accent-color: var(--cy); }

/* ---------- Narrative source list ---------- */
.source-list { display: flex; flex-direction: column; gap: 8px; margin-top: 6px; }
.source-row {
  display: flex; gap: 10px; align-items: flex-start;
  padding: 10px 12px; border-radius: 10px;
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--glass-stroke);
  cursor: pointer;
  transition: all 0.15s;
}
.source-row:hover { border-color: rgba(0,240,255,0.28); background: rgba(0,240,255,0.03); }
.source-row.active {
  border-color: var(--cy);
  background: rgba(0,240,255,0.06);
  box-shadow: inset 0 0 0 1px rgba(0,240,255,0.15);
}
.source-row input[type="radio"] {
  margin-top: 3px;
  accent-color: var(--cy);
  flex-shrink: 0;
}
.source-body { flex: 1; min-width: 0; }
.source-label {
  font-size: 13px; font-weight: 500; color: var(--fg);
  margin-bottom: 3px;
}
.source-desc {
  font-size: 11.5px; line-height: 1.45; color: var(--fg-3);
  text-wrap: pretty;
}
