@font-face { font-family:"Space Grotesk"; src:url("/static/fonts/space-grotesk-500.woff2") format("woff2"); font-weight:500; font-display:swap; }
@font-face { font-family:"Space Grotesk"; src:url("/static/fonts/space-grotesk-700.woff2") format("woff2"); font-weight:700; font-display:swap; }

:root {
  /* base */
  --bg: #0a0c16;
  --bg-2: #0c1124;
  --bg-3: #11162a;
  --fg: #e8e9ee;
  --fg-dim: #aab2d6;
  --fg-faint: #7e88b8;
  --accent: #3B82F6;
  --accent-2: #6366f1;
  --accent-3: #2dd4bf;   /* teal, glow only */
  --danger: #e0696b;
  /* glass */
  --glass-bg: rgba(255,255,255,.055);
  --glass-bg-2: rgba(255,255,255,.085);
  --glass-border: rgba(255,255,255,.12);
  --glass-hi: inset 0 1px 0 rgba(255,255,255,.06);
  /* chat */
  --user: linear-gradient(135deg,#3B82F6,#6366f1);
  --assistant: rgba(255,255,255,.06);
  --tool: rgba(255,255,255,.04);
  --border: rgba(255,255,255,.10);
  /* shape + depth */
  --r-sm: 10px; --r: 14px; --r-lg: 18px;
  --shadow-1: 0 2px 8px rgba(0,0,0,.30);
  --shadow-2: 0 10px 30px rgba(0,0,0,.40);
  --shadow-3: 0 20px 50px rgba(0,0,0,.50);
  --glow: 0 0 18px rgba(96,165,250,.45);
  /* type */
  --font-display: "Space Grotesk", -apple-system, BlinkMacSystemFont, sans-serif;
  --font-ui: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Helvetica Neue", sans-serif;
  /* motion */
  --ease: cubic-bezier(.4,0,.2,1);
  --dur-fast: 120ms; --dur: 220ms;
  /* rail (kept var names that JS/legacy CSS may reference) */
  --rail-bg: rgba(255,255,255,.04);
  --rail-fg: var(--fg-faint);
  --rail-fg-on: #ffffff;
  /* legacy aliases (kept so older rules in this file still resolve) */
  --radius: var(--r-sm);
  --shadow: var(--shadow-2);
  --tool-border: var(--glass-border);
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  height: 100%;
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-ui);
  font-size: 14px;
  line-height: 1.55;
}

h1, h2, h3, .brand, #topbar-title, #session-title {
  font-family: var(--font-display);
  letter-spacing: -.01em;
}

/* ---------------- Sidebar ---------------- */

#sidebar {
  width: 260px;
  flex-shrink: 0;
  background: var(--glass-bg);
  border-right: 1px solid var(--glass-border);
  box-shadow: var(--glass-hi);
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
  display: flex;
  flex-direction: column;
  padding: 14px;
  gap: 12px;
  overflow-y: auto;
}

#new-chat { width: 100%; }

.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
}

.logo {
  width: 34px;
  height: 34px;
  background: var(--accent);
  color: #fff;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 16px;
}

.brand-name {
  font-weight: 700;
  font-size: 16px;
}

.brand-sub {
  font-size: 11px;
  color: var(--fg-dim);
}

.sidebar-section {
  margin-top: 6px;
}

.sidebar-section h3 {
  margin: 0 0 4px 0;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--fg-dim);
  font-weight: 600;
}

#session-list, #memory-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

#session-list li, #memory-list li {
  padding: 7px 9px;
  border-radius: var(--r-sm);
  cursor: pointer;
  font-size: 13px;
  color: var(--fg-dim);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  border: 1px solid transparent;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}

#session-list li {
  position: relative;
  display: flex;
  align-items: center;
  gap: 4px;
}

#session-list li .title {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

#session-list li .edit-btn {
  opacity: 0;
  background: transparent;
  border: none;
  color: var(--fg-dim);
  cursor: pointer;
  font-size: 13px;
  padding: 0 6px;
  flex-shrink: 0;
  transition: opacity 0.12s;
}

#session-list li:hover .edit-btn {
  opacity: 1;
}

#session-list li .edit-btn:hover {
  color: var(--accent);
}

.sidebar-rename-input {
  flex: 1;
  background: var(--bg);
  color: var(--fg);
  border: 1px solid var(--accent-2);
  border-radius: 4px;
  padding: 3px 6px;
  font-size: 13px;
  font-family: inherit;
  outline: none;
  min-width: 0;
  width: 100%;
}

#session-list li:hover, #memory-list li:hover {
  background: var(--glass-bg);
  color: var(--fg);
  border-color: var(--glass-border);
}

#session-list li.active {
  background: var(--glass-bg-2);
  color: var(--fg);
  border-color: var(--glass-border);
  box-shadow: inset 2px 0 0 var(--accent);
}

.mem-category {
  font-size: 10px;
  text-transform: uppercase;
  color: var(--fg-dim);
  margin-top: 8px;
  padding: 0 9px;
}

/* ---------------- Main ---------------- */

#main {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  position: relative;
  background: transparent;
}

#header {
  padding: 10px 18px;
  border-bottom: 1px solid var(--glass-border);
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--glass-bg);
  box-shadow: var(--glass-hi);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  gap: 14px;
}

#session-title {
  flex: 1;
  min-width: 0;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 15px;
  letter-spacing: -.01em;
  color: var(--fg);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

#clock {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
  padding: 4px 10px;
  border: 1px solid var(--glass-border);
  border-radius: var(--r-sm);
  background: var(--glass-bg);
  font-family: "SF Mono", Menlo, Consolas, monospace;
  line-height: 1.1;
  min-width: 180px;
}

.clock-row {
  display: flex;
  align-items: baseline;
  gap: 8px;
}

#clock-time {
  font-size: 13px;
  color: var(--accent);
  font-weight: 600;
  letter-spacing: 0.04em;
}

#clock-date {
  font-size: 10.5px;
}

.clock-dim {
  color: var(--fg-dim);
}

#clock-location {
  font-size: 10.5px;
  font-family: -apple-system, sans-serif;
}

#clock-location.active {
  color: var(--accent-2);
}

.header-actions {
  display: flex;
  gap: 8px;
}

#chat {
  flex: 1;
  overflow-y: auto;
  padding: 22px 28px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

/* Empty chat / no-session placeholder (CSS-only; #chat is empty until a
   message is appended, so this never collides with JS-rendered content). */
#chat:empty::before {
  content: "Tell Buddy what's going on.";
  margin: auto;
  font-family: var(--font-display);
  font-size: 16px;
  color: var(--fg-faint);
  text-align: center;
  opacity: .8;
}

/* Message bubbles */

.msg {
  max-width: 82%;
  padding: 12px 15px;
  border-radius: var(--r);
  word-wrap: break-word;
  animation: msgin var(--dur) var(--ease);
}

@keyframes msgin { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .msg { animation: none; } }

.msg.user {
  align-self: flex-end;
  background: var(--user);
  color: #fff;
  box-shadow: var(--shadow-1), 0 0 18px rgba(96,165,250,.22);
}

.msg.assistant {
  align-self: flex-start;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  box-shadow: var(--shadow-1), var(--glass-hi);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
}

.msg.assistant .meta,
.msg.tool .meta {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--fg-faint);
  margin-bottom: 5px;
}

.msg.tool {
  align-self: flex-start;
  background: var(--tool);
  border: 1px solid var(--glass-border);
  font-size: 12px;
  color: var(--fg-dim);
  max-width: 70%;
  font-family: "SF Mono", Menlo, Consolas, monospace;
}

.msg.tool .tool-name {
  color: var(--accent);
  font-weight: 600;
}

.msg .content pre {
  background: var(--bg);
  padding: 10px;
  border-radius: 6px;
  overflow-x: auto;
  font-size: 12.5px;
  line-height: 1.45;
}

.msg .content code {
  background: var(--bg);
  padding: 1px 5px;
  border-radius: 3px;
  font-size: 12.5px;
}

.msg .content p { margin: 0 0 0.5em 0; }
.msg .content p:last-child { margin-bottom: 0; }
.msg .content h1, .msg .content h2, .msg .content h3, .msg .content h4 {
  margin: 0.7em 0 0.3em;
  color: var(--accent);
}
.msg .content h1 { font-size: 16px; }
.msg .content h2 { font-size: 15px; }
.msg .content h3 { font-size: 14px; }
.msg .content ul, .msg .content ol { padding-left: 22px; margin: 0.3em 0; }
.msg .content li { margin-bottom: 2px; }
.msg .content strong { color: var(--fg); }
.msg .content blockquote {
  border-left: 3px solid var(--accent-2);
  margin: 0.5em 0;
  padding-left: 12px;
  color: var(--fg-dim);
}

.msg .rate {
  display: flex;
  gap: 6px;
  margin-top: 8px;
  opacity: 0.45;
  transition: opacity 0.15s;
}

.msg:hover .rate {
  opacity: 1;
}

.msg .rate button {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--fg-dim);
  padding: 2px 8px;
  border-radius: 5px;
  font-size: 12px;
  cursor: pointer;
  transition: all 0.15s;
}

.msg .rate button:hover {
  color: var(--fg);
  border-color: var(--fg-dim);
}

.msg .rate button.active.up {
  color: #7ec27e;
  border-color: #7ec27e;
  background: rgba(126, 194, 126, 0.08);
}

.msg .rate button.active.down {
  color: var(--danger);
  border-color: var(--danger);
  background: rgba(201, 107, 107, 0.08);
}

.msg .attachments {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 8px;
}

.msg .attachments img {
  max-width: 140px;
  max-height: 100px;
  border-radius: 6px;
  border: 1px solid var(--border);
}

.msg .attachments .file {
  padding: 5px 9px;
  background: var(--bg);
  border-radius: 5px;
  font-size: 12px;
  color: var(--fg-dim);
}

/* ---------------- Composer ---------------- */

#composer {
  border-top: 1px solid var(--glass-border);
  padding: 12px 20px 14px;
  background: var(--glass-bg);
  box-shadow: var(--glass-hi);
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
}

#attachments {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 8px;
}
#attachments:empty { margin-bottom: 0; }

#attachments .chip {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: var(--fg-dim);
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 12px;
  display: flex;
  align-items: center;
  gap: 6px;
}

#attachments .chip button {
  background: transparent;
  border: none;
  color: var(--fg-faint);
  cursor: pointer;
  font-size: 14px;
  padding: 0;
}
#attachments .chip button:hover { color: var(--danger); }

.composer-row {
  display: flex;
  align-items: flex-end;
  gap: 8px;
}

#input {
  flex: 1;
  background: var(--glass-bg);
  color: var(--fg);
  border: 1px solid var(--glass-border);
  border-radius: var(--r);
  padding: 10px 14px;
  font-size: 14px;
  font-family: var(--font-ui);
  resize: none;
  line-height: 1.45;
  max-height: 200px;
  transition: border var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}

#input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: var(--glow);
}

.composer-hint {
  display: flex;
  gap: 8px;
  margin-top: 8px;
  font-size: 11px;
  color: var(--fg-faint);
  align-items: center;
}

.composer-hint #hint-model {
  color: var(--accent);
  font-weight: 600;
}

.composer-hint .hint-dim {
  color: var(--fg-dim);
}

/* ---------------- Buttons ---------------- */
/* Base .btn / .primary / .ghost / .danger live in the Nebula component layer
   (bottom of this file). Only legacy-unique extras remain here. */

.upload-btn {
  cursor: pointer;
}

/* ---------------- Modal ---------------- */

.modal {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 50;
}

.modal.hidden {
  display: none;
}

.modal-body {
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  width: min(760px, 90vw);
  max-height: 80vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.modal-body header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
  background: var(--bg-3);
  font-family: "SF Mono", monospace;
  font-size: 13px;
}

.modal-body pre {
  margin: 0;
  padding: 18px;
  overflow-y: auto;
  white-space: pre-wrap;
  word-break: break-word;
  font-family: "SF Mono", monospace;
  font-size: 13px;
  color: var(--fg);
  line-height: 1.6;
  background: var(--bg);
}

.modal-actions {
  display: flex;
  gap: 4px;
}

/* Rendered markdown inside the memory modal */
.md-render {
  padding: 20px 26px 30px;
  overflow-y: auto;
  color: var(--fg);
  font-size: 14px;
  line-height: 1.65;
  background: var(--bg);
}

.md-render.raw {
  font-family: "SF Mono", Menlo, Consolas, monospace;
  font-size: 13px;
  white-space: pre-wrap;
  word-break: break-word;
}

.md-render h1 { color: var(--accent); font-size: 22px; margin: 0 0 10px; border-bottom: 1px solid var(--border); padding-bottom: 8px; }
.md-render h2 { color: var(--accent); font-size: 18px; margin: 22px 0 8px; }
.md-render h3 { color: var(--accent); font-size: 15px; margin: 16px 0 6px; text-transform: uppercase; letter-spacing: 0.04em; }
.md-render h4 { color: var(--fg); font-size: 14px; margin: 12px 0 4px; }
.md-render p { margin: 0 0 10px; }
.md-render ul, .md-render ol { padding-left: 22px; margin: 0 0 10px; }
.md-render li { margin-bottom: 4px; }
.md-render strong { color: var(--fg); font-weight: 600; }
.md-render em { color: var(--fg-dim); }
.md-render code {
  background: var(--bg-3);
  padding: 1px 5px;
  border-radius: 3px;
  font-size: 13px;
  font-family: "SF Mono", monospace;
}
.md-render pre {
  background: var(--bg-3);
  padding: 12px;
  border-radius: 6px;
  overflow-x: auto;
  margin: 8px 0;
}
.md-render blockquote {
  border-left: 3px solid var(--accent-2);
  margin: 10px 0;
  padding: 4px 14px;
  color: var(--fg-dim);
  background: rgba(140, 113, 64, 0.06);
}
.md-render a { color: var(--accent); }
.md-render hr {
  border: none;
  border-top: 1px solid var(--border);
  margin: 16px 0;
}

/* Print view -- only the modal body renders when printing */
@media print {
  body > *:not(.modal) { display: none !important; }
  .modal, .modal-body { background: #fff !important; color: #000 !important; display: block !important; width: 100% !important; max-width: none !important; max-height: none !important; border: none !important; box-shadow: none !important; position: static !important; }
  .modal-body header { display: none !important; }
  .md-render { background: #fff !important; color: #000 !important; padding: 0 !important; }
  .md-render h1, .md-render h2, .md-render h3, .md-render h4 { color: #000 !important; border-color: #888 !important; }
  .md-render code, .md-render pre { background: #f5f5f5 !important; color: #000 !important; }
  .md-render blockquote { background: #fafafa !important; color: #333 !important; border-left-color: #888 !important; }
  .md-render a { color: #0066cc !important; }
}

/* ---------------- Misc ---------------- */

#health-dot {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  color: var(--fg-faint);
  padding: 3px 10px;
  border-radius: 999px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
}

#health-dot::before {
  content: "●";
  color: var(--fg-faint);
  font-size: 9px;
}

#health-dot.ok::before {
  color: #5fd38a;
  text-shadow: 0 0 8px rgba(95,211,138,.6);
}

#health-dot.warn::before {
  color: var(--danger);
  text-shadow: 0 0 8px rgba(224,105,107,.55);
}

.thinking {
  display: inline-block;
  color: var(--fg-dim);
  font-style: italic;
}

.thinking::after {
  content: "…";
  animation: dots 1.4s infinite;
}

@keyframes dots {
  0%, 20% { opacity: 0.2; }
  50% { opacity: 1; }
  100% { opacity: 0.2; }
}

::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--fg-dim); }

/* Browse tab */

.browse-layout {
  display: grid;
  grid-template-columns: 220px 280px 1fr;
  gap: 12px;
  height: calc(100vh - 150px);
}

.browse-sources, .browse-items, .browse-entry {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 7px;
  overflow-y: auto;
  padding: 8px;
}

.browse-sources .book {
  padding: 7px 9px;
  border-radius: 5px;
  cursor: pointer;
  font-size: 13px;
  color: var(--fg);
}

.browse-sources .book:hover { background: var(--bg-3); }

.browse-sources .book.active {
  background: var(--bg-3);
  color: var(--accent);
}

.browse-sources .book .count {
  color: var(--fg-dim);
  font-size: 11px;
  margin-left: 4px;
}

.browse-items .item {
  padding: 8px 10px;
  border-radius: 5px;
  cursor: pointer;
  font-size: 12.5px;
  color: var(--fg);
  border-bottom: 1px solid var(--border);
}

.browse-items .item:last-child { border-bottom: none; }

.browse-items .item:hover { background: var(--bg-3); }

.browse-items .item.active {
  background: var(--bg-3);
  color: var(--accent);
}

.browse-items .item .summary {
  font-size: 11px;
  color: var(--fg-dim);
  margin-top: 2px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.browse-entry {
  padding: 16px 18px;
  font-size: 13px;
  line-height: 1.65;
}

.browse-entry h2, .browse-entry h3 {
  color: var(--accent);
  font-size: 15px;
  margin-top: 14px;
}

.browse-entry h1 {
  color: var(--accent);
  font-size: 17px;
  margin-top: 0;
}

.browse-entry pre {
  background: var(--bg-3);
  padding: 10px;
  border-radius: 5px;
  overflow-x: auto;
  font-size: 12px;
}

.browse-entry ul { padding-left: 20px; }

/* Settings */

.settings {
  max-width: 520px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.settings label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 12.5px;
  color: var(--fg);
}

.settings label.checkbox {
  flex-direction: row;
  align-items: center;
  gap: 9px;
}

.settings label span {
  color: var(--fg-dim);
}

.settings input, .settings select {
  background: var(--bg);
  color: var(--fg);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 8px 10px;
  font-family: inherit;
  font-size: 13px;
}

.settings input[type=checkbox] { width: auto; }

.settings input:focus, .settings select:focus {
  outline: 1px solid var(--accent-2);
}

#settings-status {
  font-size: 12px;
}

/* Feedback tab */

#feedback-stats {
  font-size: 13px;
}

.fb-entry {
  display: flex;
  gap: 10px;
  padding: 8px 10px;
  border-bottom: 1px solid var(--border);
  font-size: 12.5px;
}

.fb-entry .mark {
  font-size: 16px;
  flex-shrink: 0;
}

.fb-entry .body {
  flex: 1;
  color: var(--fg-dim);
}

.fb-entry .body .preview {
  color: var(--fg);
}

.fb-entry .body .comment {
  margin-top: 2px;
  font-style: italic;
}

.fb-entry .ts {
  color: var(--fg-dim);
  font-size: 11px;
  flex-shrink: 0;
}

.dim { color: var(--fg-dim); font-size: 12.5px; }

/* Voice / distill */

#voice-btn.recording {
  color: var(--danger);
  animation: pulse 1.1s infinite;
}

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.55; }
}

.distill-btn {
  width: 100%;
  margin-bottom: 8px;
  font-size: 12px;
  text-align: left;
  padding: 6px 9px;
}

.distill-btn.busy {
  opacity: 0.5;
  pointer-events: none;
}

.tool-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 9px;
  background: var(--tool);
  border: 1px solid var(--tool-border);
  border-radius: 12px;
  font-family: "SF Mono", monospace;
  font-size: 11px;
  color: var(--fg-dim);
  margin: 2px 4px 2px 0;
}

.tool-chip .name {
  color: var(--accent);
}

.tool-chip.done {
  opacity: 0.7;
}

.streaming-cursor::after {
  content: "▌";
  display: inline-block;
  color: var(--accent);
  animation: blink 1s step-end infinite;
  margin-left: 2px;
}

@keyframes blink {
  50% { opacity: 0; }
}

.distill-toast {
  position: fixed;
  top: 18px;
  right: 18px;
  background: var(--bg-3);
  border: 1px solid var(--accent-2);
  color: var(--fg);
  padding: 10px 14px;
  border-radius: 7px;
  font-size: 12.5px;
  z-index: 100;
  max-width: 320px;
  box-shadow: 0 8px 30px rgba(0,0,0,0.4);
  animation: slide-in 0.25s ease;
}

@keyframes slide-in {
  from { transform: translateX(400px); opacity: 0; }
  to { transform: translateX(0); opacity: 1; }
}

/* Memory-modal frontmatter (chips + details) */
.md-render .mm-frontmatter {
  background: var(--bg-3);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 14px;
  margin-bottom: 18px;
}
.md-render .mm-pills {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-bottom: 10px;
}
.md-render .mm-pill {
  display: inline-flex; flex-direction: column;
  padding: 6px 12px;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 14px;
  font-size: 11px;
  line-height: 1.2;
}
.md-render .mm-pill .mm-k {
  color: var(--fg-dim);
  font-size: 9px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.md-render .mm-pill .mm-v {
  color: var(--accent);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.md-render .mm-rows {
  display: flex; flex-direction: column; gap: 6px;
  padding-top: 10px;
  border-top: 1px solid var(--border);
}
.md-render .mm-row {
  display: flex; gap: 10px; align-items: baseline; flex-wrap: wrap;
  font-size: 12px;
}
.md-render .mm-row .mm-k {
  color: var(--fg-dim);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 10px;
  min-width: 90px;
}
.md-render .mm-row .mm-v { color: var(--fg); }
.md-render .mm-tag {
  display: inline-block;
  background: var(--bg-2);
  border: 1px solid var(--border);
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 11px;
  margin-right: 4px;
  color: var(--fg);
}

/* Per-session cost chip next to the clock / persona badge */
.session-cost {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--bg-3);
  color: var(--fg-dim);
  font-size: 11px;
  font-weight: 500;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
  margin-right: 6px;
  cursor: default;
}
.session-cost.hidden { display: none; }

/* Active-persona badge in the chat header */
.persona-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  border-radius: 999px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: var(--accent);
  font-size: 11px;
  font-weight: 600;
  white-space: nowrap;
  cursor: default;
  box-shadow: 0 0 12px rgba(96,165,250,.2);
}
.persona-badge.hidden { display: none; }

/* ---------------- Sections (Stage 3a) ---------------- */
#sections-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 2px; }
.section-item {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 8px; border-radius: var(--r-sm); cursor: pointer; font-size: 13px;
  color: var(--fg-dim); border: 1px solid transparent;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.section-item:hover { background: var(--glass-bg); color: var(--fg); border-color: var(--glass-border); }
.section-item.active {
  background: var(--glass-bg-2); color: var(--fg); font-weight: 600;
  border-color: var(--glass-border); box-shadow: inset 2px 0 0 var(--accent);
}
.section-item .section-dot { color: var(--accent); font-size: 10px; }
.section-item .section-name { flex: 1; }
.section-item .section-edit-btn { opacity: 0; padding: 0 4px; border: none; background: transparent; box-shadow: none; }
.section-item .section-edit-btn:hover { transform: none; background: transparent; color: var(--accent); }
.section-item:hover .section-edit-btn { opacity: 0.7; }
.section-pill {
  margin-left: 8px; font-size: 11px; padding: 3px 9px; border-radius: 999px;
  background: var(--glass-bg); border: 1px solid var(--glass-border); color: var(--fg-dim);
}
.section-pill:empty { display: none; }
/* Shared modal card - used by section-edit, about-modal, and outcomes modal (3c) */
.modal-card { display: flex; flex-direction: column; gap: 8px; padding: 20px; width: min(440px, 90vw); background: var(--bg-2); border: 1px solid var(--border); border-radius: var(--radius); }
.modal-card textarea, .modal-card input[type="text"] { padding: 8px 10px; border: 1px solid var(--border); border-radius: 8px; background: var(--bg); color: var(--fg); font-family: inherit; font-size: 13px; width: 100%; box-sizing: border-box; }
.modal-card h3 { margin: 0 0 4px; }
.modal-card label { font-size: 12px; opacity: 0.8; }

#section-edit .modal-card { max-width: 360px; gap: 8px; }
#section-edit .modal-card header { display: flex; justify-content: space-between; align-items: center; }
#section-edit label { font-size: 12px; opacity: 0.8; }

#about-modal .modal-card { display: flex; flex-direction: column; gap: 10px; padding: 20px; max-width: 420px; }
#about-target { margin-left: 8px; }

/* ---------------- App shell (rail + topbar + views) ---------------- */

body { margin:0; display:flex; height:100vh; overflow:hidden; background:var(--bg); color:var(--fg); }

/* Rail - glass vertical bar */
#rail {
  width:68px; display:flex; flex-direction:column; align-items:center; gap:4px;
  padding:14px 0; flex-shrink:0;
  background:var(--glass-bg); border-right:1px solid var(--glass-border);
  box-shadow:var(--glass-hi);
  -webkit-backdrop-filter:blur(18px); backdrop-filter:blur(18px);
}
#rail .rail-brand {
  width:38px; height:38px; border-radius:11px;
  background:var(--user); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-weight:700; font-size:18px;
  margin-bottom:10px; box-shadow:var(--glow);
}
#rail .rail-ic {
  width:50px; height:50px; border:1px solid transparent; background:transparent;
  color:var(--rail-fg); border-radius:var(--r-sm);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px;
  font-size:17px; cursor:pointer;
  transition:background var(--dur) var(--ease), color var(--dur) var(--ease), transform var(--dur-fast) var(--ease), box-shadow var(--dur) var(--ease);
}
#rail .rail-ic span { font-size:8.5px; letter-spacing:.02em; font-weight:600; }
#rail .rail-ic:hover { background:var(--glass-bg-2); color:var(--fg-dim); transform:translateY(-1px); }
#rail .rail-ic.on {
  background:var(--glass-bg-2); color:var(--rail-fg-on);
  border-color:var(--glass-border);
  box-shadow:inset 2px 0 0 var(--accent), 0 0 14px rgba(96,165,250,.25);
}
#rail .rail-bottom { margin-top:auto; }

#app { flex:1; display:flex; flex-direction:column; min-width:0; }

/* Topbar - glass */
#topbar {
  height:54px; flex-shrink:0; display:flex; align-items:center; padding:0 20px;
  background:var(--glass-bg); border-bottom:1px solid var(--glass-border);
  box-shadow:var(--glass-hi);
  -webkit-backdrop-filter:blur(18px); backdrop-filter:blur(18px);
}
#topbar-title { font-family:var(--font-display); font-weight:700; font-size:16px; letter-spacing:-.01em; }
#topbar .topbar-right { margin-left:auto; display:flex; align-items:center; gap:14px; color:var(--fg-dim); font-size:13px; }
#topbar-user { color:var(--fg-dim); font-size:12.5px; }

#views { flex:1; min-height:0; }
.view { height:100%; display:flex; min-height:0; }
.view.hidden { display:none; }

/* People view (list + detail) - shared .vsidebar/.vmain used by later views too */
.vsidebar { width:230px; background:var(--glass-bg); border-right:1px solid var(--glass-border); padding:14px; display:flex; flex-direction:column; gap:10px; overflow:auto; -webkit-backdrop-filter:blur(16px); backdrop-filter:blur(16px); box-shadow:var(--glass-hi); }
@supports not (backdrop-filter: blur(1px)) { .vsidebar { background:var(--bg-2); } }
.vsidebar-head { font-family:var(--font-display); font-weight:700; font-size:13px; letter-spacing:.02em; color:var(--fg-dim); text-transform:uppercase; padding:2px 2px 4px; }
.vsearch { padding:7px 10px; border:1px solid var(--glass-border); border-radius:var(--r-sm); background:var(--glass-bg); color:var(--fg); font-family:inherit; width:100%; transition:border var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.vsearch:focus { border-color:var(--accent); box-shadow:var(--glow); outline:none; }
.vmain { flex:1; overflow:auto; background:transparent; }
.vmain-pad { padding:24px 28px; max-width:900px; }
.people-item { padding:9px 11px; border-radius:var(--r-sm); cursor:pointer; color:var(--fg-dim); font-size:13.5px; transition:background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease); border:1px solid transparent; }
.people-item:hover { background:var(--glass-bg-2); color:var(--fg); border-color:var(--glass-border); }
.people-item.active { background:var(--glass-bg-2); color:var(--accent); border-color:var(--glass-border); box-shadow:var(--glow); }
#people-list { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:3px; }
.person-head { display:flex; align-items:center; gap:10px; margin-bottom:20px; flex-wrap:wrap; padding-bottom:16px; border-bottom:1px solid var(--glass-border); }
.person-head h2 { margin:0; font-family:var(--font-display); font-size:1.35rem; letter-spacing:-.01em; }
.person-head .btn.primary { margin-left:auto; }
.chip { font-size:11px; padding:3px 9px; border-radius:20px; background:var(--tool); color:var(--accent); }
.cardgrid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.pcard { background:var(--glass-bg); border:1px solid var(--glass-border); border-radius:var(--r); padding:16px 18px; box-shadow:var(--shadow-1), var(--glass-hi); -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px); transition:box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.pcard:hover { border-color:rgba(255,255,255,.18); box-shadow:var(--shadow-2), var(--glass-hi); }
@supports not (backdrop-filter: blur(1px)) { .pcard { background:var(--bg-2); } }
.pcard-t { font-size:10px; text-transform:uppercase; letter-spacing:.07em; color:var(--fg-faint); margin-bottom:8px; font-family:var(--font-display); font-weight:700; }
.muted { color:var(--fg-dim); }

/* Knowledge view (search + browse) - Nebula reskin */
#view-knowledge { display:flex; height:100%; overflow:hidden; }

/* --- Sidebar: search + source list --- */
#view-knowledge .vsidebar { gap:8px; }

#kb-q {
  width:100%; padding:8px 12px;
  border:1px solid var(--glass-border); border-radius:var(--r-sm);
  background:var(--glass-bg); color:var(--fg); font-family:var(--font-ui); font-size:13px;
  transition:border var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
#kb-q:focus { border-color:var(--accent); box-shadow:var(--glow); outline:none; }
#kb-q::placeholder { color:var(--fg-faint); }
@supports not (backdrop-filter: blur(1px)) { #kb-q { background:var(--bg-2); } }

#kb-source {
  width:100%; padding:7px 10px;
  border:1px solid var(--glass-border); border-radius:var(--r-sm);
  background-color:var(--glass-bg); color:var(--fg-dim); font-family:var(--font-ui); font-size:12px;
  transition:border var(--dur) var(--ease);
  appearance:none; -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%237e88b8'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 10px center;
}
#kb-source:focus { border-color:var(--accent); box-shadow:var(--glow); outline:none; }
@supports not (backdrop-filter: blur(1px)) { #kb-source { background-color:var(--bg-2); } }

.kb-sources { display:flex; flex-direction:column; gap:3px; overflow:auto; flex:1; padding-top:2px; }

.kb-source {
  padding:7px 10px; border-radius:var(--r-sm); cursor:pointer; font-size:13px;
  color:var(--fg-dim); border:1px solid transparent;
  transition:background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease);
  display:flex; align-items:center; justify-content:space-between; gap:6px;
}
.kb-source:hover { background:var(--glass-bg-2); color:var(--fg); border-color:var(--glass-border); }
.kb-source.active {
  background:var(--glass-bg-2); color:var(--accent);
  border-color:rgba(59,130,246,.35); box-shadow:0 0 10px rgba(59,130,246,.12);
}
.kb-source .count {
  color:var(--fg-faint); font-size:10px; font-family:var(--font-display);
  font-weight:700; letter-spacing:.04em;
  background:var(--glass-bg); border:1px solid var(--glass-border);
  padding:1px 6px; border-radius:20px; flex-shrink:0;
}
.kb-source.active .count { color:var(--accent); border-color:rgba(59,130,246,.3); }

/* --- Main area --- */
#view-knowledge .vmain { height:100%; }
#view-knowledge .vmain-pad { max-width:760px; }

/* muted inline state messages (idle, search, load, error, no-results) */
#kb-main > .muted {
  display:block; padding:48px 0; text-align:center;
  color:var(--fg-faint); font-size:14px; line-height:1.6;
}

/* --- Results grid (search hits + browse items) --- */
.kb-results { display:flex; flex-direction:column; gap:10px; margin-top:12px; }

.kb-hit, .kb-item {
  cursor:pointer;
  transition:border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease), transform var(--dur-fast) var(--ease);
}
.kb-hit:hover, .kb-item:hover {
  border-color:var(--accent); box-shadow:var(--shadow-2), var(--glass-hi), 0 0 12px rgba(59,130,246,.15);
  transform:translateY(-1px);
}
.kb-hit:active, .kb-item:active { transform:translateY(0); }

/* Source + score badge row inside a hit (KB-only; leaves People .pcard-t alone) */
.kb-hit .pcard-t, .kb-item .pcard-t { display:flex; align-items:center; gap:6px; margin-bottom:0; }

/* Tool hint (-> pis_xxx suggestion) */
.kb-hint {
  margin-top:8px; padding:6px 10px;
  font-size:11.5px; color:var(--accent-2); font-family:var(--font-display); font-weight:500;
  background:rgba(99,102,241,.08); border:1px solid rgba(99,102,241,.2);
  border-radius:var(--r-sm);
  letter-spacing:.01em;
}

/* --- Source browse header + back button --- */
#kb-main > h2, .vmain-pad > h2 {
  font-family:var(--font-display); font-size:1.3rem; font-weight:700;
  letter-spacing:-.01em; margin:0 0 16px; color:var(--fg);
  padding-bottom:12px; border-bottom:1px solid var(--glass-border);
}

.kb-entry-head { margin-bottom:16px; }

/* --- Entry detail typography --- */
/* The rendered entry lives in .vmain-pad directly; scope all typographic
   rules to #kb-main to avoid touching other views that reuse .vmain-pad */

#kb-main h1 {
  font-family:var(--font-display); font-size:1.6rem; font-weight:700;
  letter-spacing:-.02em; line-height:1.25;
  color:var(--fg); margin:0 0 24px;
  padding-bottom:16px; border-bottom:1px solid var(--glass-border);
}

#kb-main h2 {
  font-family:var(--font-display); font-size:1.25rem; font-weight:700;
  letter-spacing:-.01em; line-height:1.3;
  color:var(--fg); margin:28px 0 10px;
}

#kb-main h3 {
  font-family:var(--font-display); font-size:.9rem; font-weight:700;
  letter-spacing:.04em; text-transform:uppercase;
  color:var(--accent); margin:22px 0 8px;
  display:flex; align-items:center; gap:8px;
}
#kb-main h3::after {
  content:''; flex:1; height:1px;
  background:linear-gradient(90deg, rgba(59,130,246,.3), transparent);
}

#kb-main p {
  font-family:var(--font-ui); font-size:14px; line-height:1.7;
  color:var(--fg); margin:0 0 12px;
}

#kb-main ul, #kb-main ol {
  margin:6px 0 16px; padding-left:20px;
}
#kb-main ul li, #kb-main ol li {
  font-family:var(--font-ui); font-size:14px; line-height:1.65;
  color:var(--fg-dim); margin-bottom:5px;
}
#kb-main ul li::marker { color:var(--accent); }
#kb-main ol li::marker { color:var(--accent-2); font-weight:700; }

#kb-main strong { color:var(--fg); font-weight:600; }

/* Scripts / quotes: highlight list items that read as direct-speech lines */
#kb-main h3 + ul li {
  padding:8px 12px 8px 14px;
  border-left:2px solid rgba(59,130,246,.35);
  background:rgba(255,255,255,.03); border-radius:0 var(--r-sm) var(--r-sm) 0;
  color:var(--fg); line-height:1.6; margin-bottom:6px; list-style:none; margin-left:-20px;
}
#kb-main h3 + ul { padding-left:20px; }

/* Phase script lists: same accent-bar treatment as h3+ul but reached via class
   because a <p> sits between the <h3> and <ul> (breaking the adjacent-sibling rule) */
#kb-main ul.kb-scripts li {
  padding:8px 12px 8px 14px;
  border-left:2px solid rgba(59,130,246,.35);
  background:rgba(255,255,255,.03); border-radius:0 var(--r-sm) var(--r-sm) 0;
  color:var(--fg); line-height:1.6; margin-bottom:6px; list-style:none; margin-left:-20px;
}
#kb-main ul.kb-scripts { padding-left:20px; }

/* Phase separator */
#kb-main hr {
  border:none; border-top:1px solid var(--glass-border); margin:20px 0;
}

/* Pre/code blocks (raw JSON fallback) */
#kb-main pre {
  font-size:12px; line-height:1.55; color:var(--fg-dim);
  background:var(--glass-bg); border:1px solid var(--glass-border);
  border-radius:var(--r-sm); padding:12px 14px;
  overflow-x:auto; white-space:pre-wrap; word-break:break-word;
  margin:6px 0 14px;
}
@supports not (backdrop-filter: blur(1px)) { #kb-main pre { background:var(--bg-2); } }

/* Settings view */
#view-settings { display:flex; }
.set-wrap { display:flex; flex-direction:column; gap:16px; }
.set-form { display:flex; flex-direction:column; gap:10px; }
.set-form label { display:flex; flex-direction:column; gap:4px; font-size:13px; }
.set-form label.checkbox { flex-direction:row; align-items:center; gap:8px; }
.set-form input, .set-form select { padding:7px 10px; border:1px solid var(--border); border-radius:8px; background:var(--bg); color:var(--fg); font-family:inherit; }
.set-row { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.memory-list { list-style:none; margin:10px 0 0; padding:0; display:flex; flex-direction:column; gap:2px; }
.memory-item { padding:6px 9px; border-radius:8px; cursor:pointer; font-size:13px; }
.memory-item:hover { background:var(--bg-3); }
.mem-category { font-size:10px; text-transform:uppercase; letter-spacing:.06em; color:var(--fg-dim); margin:8px 0 2px; }

/* Stage 3c - outcome chip (proposed label + confirm button) */
.outcome-chip { display:flex; gap:8px; align-items:center; margin-top:12px; flex-wrap:wrap; }
.outcome-chip select { padding:4px 8px; border:1px solid var(--glass-border); border-radius:var(--r-sm); background:var(--glass-bg); color:var(--fg); font-family:inherit; font-size:13px; }

/* Stage 3c - outcome timeline */
.timeline { list-style:none; padding:0; margin:0; }
.timeline li { padding:12px 0; border-bottom:1px solid var(--glass-border); }
.timeline li:last-child { border-bottom:0; }
.timeline .ex { font-size:0.9em; line-height:1.5; }
.timeline .oc-state { margin-top:8px; display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.lbl { display:inline-flex; align-items:center; font-size:0.75em; font-weight:600; padding:3px 10px; border-radius:999px; color:#fff; letter-spacing:.03em; }
.lbl.pending { background:var(--glass-bg-2); color:var(--fg-dim); border:1px solid var(--glass-border); }
.timeline .oc-correct { padding:4px 8px; border:1px solid var(--glass-border); border-radius:var(--r-sm); background:var(--glass-bg); color:var(--fg); font-family:inherit; font-size:13px; transition:border var(--dur) var(--ease); }
.timeline .oc-correct:focus { border-color:var(--accent); outline:none; box-shadow:var(--glow); }

/* Outcome label chips - 7 distinct accent tints */
.lbl-warming  { background:linear-gradient(135deg,#f97316,#fb923c); box-shadow:0 0 10px rgba(249,115,22,.35); }
.lbl-cooling  { background:linear-gradient(135deg,#38bdf8,#0ea5e9); box-shadow:0 0 10px rgba(56,189,248,.35); }
.lbl-neutral  { background:linear-gradient(135deg,#94a3b8,#64748b); box-shadow:none; }
.lbl-no_reply { background:linear-gradient(135deg,#475569,#334155); box-shadow:none; color:var(--fg-dim); }
.lbl-advanced { background:linear-gradient(135deg,#a78bfa,#7c3aed); box-shadow:0 0 10px rgba(167,139,250,.35); }
.lbl-won      { background:linear-gradient(135deg,#34d399,#059669); box-shadow:0 0 10px rgba(52,211,153,.35); }
.lbl-lost     { background:linear-gradient(135deg,#f87171,#dc2626); box-shadow:0 0 10px rgba(248,113,113,.35); }

/* Stage 3d-1 - growth/skills view */
.growth-head { display:flex; align-items:center; justify-content:space-between; }
.skill { margin:10px 0; }
.skill-h { display:flex; justify-content:space-between; align-items:center; }
.skill-trend { color:var(--fg-dim); font-size:0.85em; }
.skill-bar { height:8px; background:var(--border); border-radius:6px; overflow:hidden; margin:4px 0; }
.skill-bar span { display:block; height:100%; background:var(--accent); }
.skill-why { font-size:0.85em; }
#growth-goal { padding:3px 6px; border:1px solid var(--border); border-radius:6px; background:var(--bg); color:var(--fg); }

/* Stage 3d-2 - Coach panel (+ Playbook reuses .coach-overlay/.coach-panel) */
.coach-overlay { position: fixed; inset: 0; background: rgba(4,6,14,.5); z-index: 60; display: flex; justify-content: flex-end; -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px); }
.coach-panel {
  width: 400px; max-width: 92vw; height: 100%; overflow: auto;
  padding: 20px; display: flex; flex-direction: column; gap: 14px;
  background: var(--glass-bg-2); border-left: 1px solid var(--glass-border);
  box-shadow: var(--shadow-3), var(--glass-hi);
  -webkit-backdrop-filter: blur(22px); backdrop-filter: blur(22px);
  animation: coach-slide .18s var(--ease);
}
@supports not (backdrop-filter: blur(1px)) { .coach-panel { background: var(--bg-2); } }
@keyframes coach-slide { from { transform: translateX(24px); opacity: .4; } to { transform: translateX(0); opacity: 1; } }
@media (prefers-reduced-motion: reduce) { .coach-panel { animation: none; } }
.coach-head { display: flex; align-items: center; justify-content: space-between; padding-bottom: 12px; border-bottom: 1px solid var(--glass-border); }
.coach-head b { font-family: var(--font-display); font-size: 1.05rem; }
.coach-head #coach-x, .coach-head #pb-x { padding: 2px 8px; font-size: 1rem; line-height: 1; }
.coach-explain { font-size: 0.85em; line-height: 1.5; background: var(--glass-bg); border: 1px solid var(--glass-border); border-radius: var(--r-sm); padding: 10px 12px; margin: 0; color: var(--fg-dim); }
.coach-tip { font-size: 0.82em; margin: 0; }
.coach-for { font-size: 0.9em; padding: 6px 11px; border-radius: var(--r-sm); background: var(--user); color: #fff; align-self: flex-start; box-shadow: var(--glow); }
.coach-for-none { background: var(--glass-bg); color: var(--fg-dim); border: 1px solid var(--glass-border); box-shadow: none; }
#coach-draft { width: 100%; resize: vertical; min-height: 90px; font-size: 16px; padding: 10px 12px; border: 1px solid var(--glass-border); border-radius: var(--r-sm); background: var(--glass-bg); color: var(--fg); box-sizing: border-box; }
#coach-draft:focus { outline: none; border-color: var(--accent); box-shadow: var(--glow); }
.coach-actions { display: flex; justify-content: flex-end; gap: 8px; }
.coach-card { border-top: 1px solid var(--glass-border); margin-top: 4px; padding-top: 14px; display: flex; flex-direction: column; gap: 8px; }
.coach-card label { font-size: 0.78em; text-transform: uppercase; letter-spacing: .04em; color: var(--fg-faint); }
.coach-stronger { border: 1px solid var(--accent); border-radius: var(--r-sm); padding: 12px 14px; background: var(--glass-bg); white-space: pre-wrap; line-height: 1.45; box-shadow: var(--glow); }
.coach-panel h2 { font-family: var(--font-display); margin: 0 0 6px; }
.pb-overview { font-size: 0.9em; color: var(--fg-dim); }
.pb-phase { border-top: 1px solid var(--glass-border); margin-top: 10px; padding-top: 10px; }
.pb-phase h3 { font-family: var(--font-display); margin: 0 0 4px; color: var(--accent); }

/* ===================== Nebula: aurora background ===================== */

#aurora { position:fixed; inset:0; z-index:-1; overflow:hidden; pointer-events:none; background:var(--bg); }
#aurora span { position:absolute; border-radius:50%; filter:blur(80px); opacity:.5; }
#aurora span:nth-child(1){ width:55vw; height:55vw; left:-10vw; top:-15vw; background:#1e3a8a; animation:drift1 28s var(--ease) infinite alternate; }
#aurora span:nth-child(2){ width:45vw; height:45vw; right:-10vw; top:10vh; background:#4338ca; animation:drift2 34s var(--ease) infinite alternate; }
#aurora span:nth-child(3){ width:40vw; height:40vw; left:25vw; bottom:-20vw; background:#0d9488; opacity:.3; animation:drift3 40s var(--ease) infinite alternate; }
@keyframes drift1 { to{ transform:translate(8vw,6vh) scale(1.1);} }
@keyframes drift2 { to{ transform:translate(-6vw,8vh) scale(1.05);} }
@keyframes drift3 { to{ transform:translate(5vw,-6vh) scale(1.12);} }
@media (prefers-reduced-motion: reduce){ #aurora span{ animation:none; } }

/* ===================== Nebula: reusable components ===================== */

.glass-panel, .glass-card {
  background: var(--glass-bg); border:1px solid var(--glass-border);
  border-radius: var(--r); box-shadow: var(--shadow-1), var(--glass-hi);
  -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px);
}
@supports not (backdrop-filter: blur(1px)) { .glass-panel,.glass-card{ background:#11162a; } }
.btn { font-family:var(--font-ui); font-size:13px; font-weight:600; border:1px solid var(--glass-border);
  background:var(--glass-bg); color:var(--fg); border-radius:var(--r-sm); padding:8px 14px; cursor:pointer;
  transition:transform var(--dur-fast) var(--ease), box-shadow var(--dur) var(--ease), background var(--dur) var(--ease); }
.btn:hover { transform:translateY(-1px); background:var(--glass-bg-2); }
.btn.primary, .btn-primary { background:var(--user); border-color:transparent; color:#fff; box-shadow:var(--glow); }
.btn.primary:hover { box-shadow:0 0 24px rgba(96,165,250,.6); }
.btn.ghost { background:transparent; }
.btn.danger, .danger { color:var(--danger); }
.field, input:not([type=checkbox]):not([type=radio]):not([type=file]):not([type=range]):not([type=color]), textarea, select {
  font-family:var(--font-ui); color:var(--fg); background:var(--glass-bg);
  border:1px solid var(--glass-border); border-radius:var(--r-sm); padding:10px 12px; outline:none;
  transition:border var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.field:focus, input:not([type=checkbox]):not([type=radio]):not([type=file]):not([type=range]):not([type=color]):focus, textarea:focus, select:focus {
  border-color:var(--accent); box-shadow:var(--glow); }
.chip { display:inline-flex; align-items:center; gap:5px; font-size:11px; padding:3px 9px; border-radius:999px;
  background:var(--glass-bg); border:1px solid var(--glass-border); color:var(--fg-dim); }
.empty-state { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px;
  text-align:center; padding:48px 24px; color:var(--fg-faint); }
.empty-state .es-icon { font-size:30px; opacity:.7; }
.empty-state .es-title { font-family:var(--font-display); font-size:16px; color:var(--fg-dim); }
.view { animation:viewin var(--dur) var(--ease); }
@keyframes viewin { from{ opacity:0; transform:translateY(8px);} to{ opacity:1; transform:none;} }
@media (prefers-reduced-motion: reduce){ .view{ animation:none; } }

/* ===================== Nebula: People view polish ===================== */

/* Sidebar "no people" empty state - the list will just be empty; give the add-btn area breathing room */
#people-list:empty + #people-add { margin-top:4px; }

/* "Pick a person" placeholder - JS renders <p class="muted"> into #person-detail with no id */
#person-detail > p.muted {
  display:flex; align-items:center; justify-content:center;
  height:100%; min-height:200px;
  font-size:1rem; color:var(--fg-faint);
  font-style:italic; text-align:center; padding:48px 32px;
}

/* Person detail header */
.person-head h2 { color:var(--fg); }
.person-head .chip {
  background:var(--glass-bg-2); border:1px solid var(--glass-border);
  color:var(--accent); font-size:10.5px; padding:3px 10px; border-radius:999px;
}

/* Card grid: make the last card (Analyse / odd one out) span full width when alone */
.cardgrid .pcard:last-child:nth-child(odd) { grid-column: 1 / -1; }

/* Game plan "also in sections" note */
.pcard .muted { font-size:0.85em; line-height:1.5; }

/* Rebuild + Strategize button group */
#rebuild-strategy { font-size:12px; padding:6px 12px; }
#strategize { font-size:13px; }

/* Timeline exchange blocks */
.timeline .ex b { color:var(--fg-dim); font-size:0.8em; text-transform:uppercase; letter-spacing:.04em; margin-right:4px; }

/* Modal card upgrade: glass panel, glow on focus */
.modal { display:flex; align-items:center; justify-content:center; }
.modal-card {
  background:var(--glass-bg-2); border:1px solid var(--glass-border);
  border-radius:var(--r); box-shadow:var(--shadow-3), var(--glass-hi);
  -webkit-backdrop-filter:blur(22px); backdrop-filter:blur(22px);
  padding:24px; gap:10px;
}
@supports not (backdrop-filter: blur(1px)) { .modal-card { background:var(--bg-2); } }
.modal-card h3 { font-family:var(--font-display); font-size:1.1rem; margin:0 0 4px; }
.modal-card label { font-size:12px; color:var(--fg-dim); }
.modal-actions { display:flex; gap:8px; }

/* Outcome confirm chip inside the log-a-move modal */
.outcome-chip > span { font-size:12px; color:var(--fg-dim); }

/* Sidebar "people" heading row */
.vsidebar-head { display:flex; align-items:center; gap:6px; }

/* Add person button scoped to sidebar */
#view-people #people-add { width:100%; justify-content:center; margin-top:auto; font-size:13px; }

/* ===================== Nebula: Growth view polish ===================== */

/* Scrollable body with consistent gap between cards */
#growth-body {
  display: flex; flex-direction: column; gap: 16px;
  padding: 20px 22px; overflow-y: auto; height: 100%;
}

/* Header row: "Your growth" heading + Refresh button */
.growth-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px; }
.growth-head h2 {
  font-family: var(--font-display); font-size: 1.3rem; font-weight: 700;
  letter-spacing: -.02em; color: var(--fg); margin: 0;
}

/* Self-archetype + Skills pcards: override Stage 3d-1 generic margin */
#growth-body .pcard { margin: 0; }

/* Archetype card: label lists (Values / Strengths / Growth edges) */
#growth-body .pcard ul {
  margin: 4px 0 10px; padding-left: 18px;
  display: flex; flex-direction: column; gap: 3px;
}
#growth-body .pcard ul li { color: var(--fg-dim); font-size: 0.88em; line-height: 1.45; }

/* Strengths list - subtle teal accent bullet */
#growth-body .pcard p + ul li::marker { color: var(--accent-3); }

/* Identity / Voice / Values labels inside archetype card */
#growth-body .pcard > p > b {
  font-family: var(--font-display); font-size: 0.78em; text-transform: uppercase;
  letter-spacing: .06em; color: var(--fg-faint);
}

/* Summary paragraph */
#growth-body .pcard > p:first-of-type { color: var(--fg); line-height: 1.5; }

/* Goal selector row */
#growth-body .pcard > p.muted {
  display: flex; align-items: center; gap: 10px;
  font-size: 0.82em; text-transform: uppercase; letter-spacing: .05em; color: var(--fg-faint);
  margin: 8px 0 10px;
}

/* Goal select - override Stage 3d-1 plain styling */
#growth-goal {
  flex: 1; max-width: 220px;
  padding: 7px 10px; border: 1px solid var(--glass-border);
  border-radius: var(--r-sm); background: var(--glass-bg-2);
  color: var(--fg); font-family: var(--font-ui); font-size: 13px;
  cursor: pointer;
  transition: border var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
#growth-goal:focus { border-color: var(--accent); box-shadow: var(--glow); outline: none; }
@supports not (backdrop-filter: blur(1px)) { #growth-goal { background: var(--bg-3); } }

/* ---- Skill rows ---- */
.skill { margin: 12px 0; }
.skill:first-child { margin-top: 4px; }
.skill:last-child  { margin-bottom: 0; }

/* Skill name + trend inline */
.skill-h {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 5px;
}
.skill-h b {
  font-family: var(--font-display); font-size: 0.9rem;
  font-weight: 600; color: var(--fg);
}

/* Skill level label (numeric N/5) */
.skill-level {
  font-family: var(--font-display); font-size: 0.72rem; font-weight: 600;
  color: var(--fg-faint); letter-spacing: .02em; margin-left: auto; margin-right: 8px;
}

/* Trend arrow: views-growth.js sets data-trend="up|flat|down" on the span */
.skill-trend { font-size: 0.82em; font-weight: 700; color: var(--fg-faint); }
.skill-trend[data-trend="up"]   { color: #34d399; }   /* teal-green */
.skill-trend[data-trend="down"] { color: #f87171; }   /* soft red */

/* Progress track + fill */
.skill-bar {
  height: 7px; background: rgba(255,255,255,.08);
  border-radius: 999px; overflow: hidden; margin: 0 0 5px;
  box-shadow: inset 0 1px 2px rgba(0,0,0,.3);
}
.skill-bar span {
  display: block; height: 100%;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  border-radius: 999px;
  box-shadow: 0 0 8px rgba(99,102,241,.4);
  transition: width 400ms var(--ease);
}

/* Rationale text */
.skill-why {
  font-size: 0.8em; color: var(--fg-faint); line-height: 1.4;
  font-style: italic; margin: 0;
}

/* ---- Empty states ---- */

/* "Still learning you" and "No skill read yet" - style the <i class="muted"> tags */
#growth-body .pcard > i.muted {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; padding: 28px 16px; gap: 8px;
  color: var(--fg-faint); font-size: 0.88em; line-height: 1.5;
  font-style: italic;
}

/* Loading state */
#growth-body > p.muted {
  display: flex; align-items: center; justify-content: center;
  min-height: 160px; color: var(--fg-faint); font-style: italic;
}

/* Error/signed-out state */
#growth-body > p.muted:only-child { height: 100%; }

/* ===================== Nebula: Settings view ===================== */

/* Hide Appearance (theme-toggle) section - Nebula is dark-only.
   Content-anchored so it targets the card that actually holds the theme
   controls regardless of section order. */
#view-settings .pcard:has(#set-theme-light) { display: none; }

/* Section headings: display font, uppercase, accent tint */
#view-settings .pcard-t {
  font-family: var(--font-display);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--accent);
  margin-bottom: 12px;
}

/* Form field label text (not checkbox descriptions, which stay body text) */
.set-form label:not(.checkbox) > span {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--fg-faint);
}

/* Glass inputs / selects inside settings (override legacy bg/border tokens) */
.set-form input:not([type=checkbox]):not([type=radio]),
.set-form select {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--r-sm);
  color: var(--fg);
  font-family: var(--font-ui);
  font-size: 13px;
  padding: 8px 11px;
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  box-sizing: border-box;
  width: 100%;
}
.set-form input:not([type=checkbox]):not([type=radio]):focus,
.set-form select:focus {
  border-color: var(--accent);
  outline: none;
  box-shadow: var(--glow);
}
@supports not (backdrop-filter: blur(1px)) {
  .set-form input:not([type=checkbox]):not([type=radio]),
  .set-form select { background: var(--bg-2); }
}

/* Status / helper text */
#view-settings .muted { color: var(--fg-faint); font-size: 12px; }

/* Memory list: glass list items */
.memory-list { gap: 3px; }
#memory-list .memory-item {
  color: var(--fg-dim);
  border-radius: var(--r-sm);
  padding: 7px 10px;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
#memory-list .memory-item:hover {
  background: var(--glass-bg-2);
  color: var(--fg);
  border: 1px solid var(--glass-border);
  padding: 6px 9px; /* compensate for 1px border */
}
.mem-category {
  font-family: var(--font-display);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--fg-faint);
  margin: 10px 0 3px;
  padding-left: 2px;
}

/* ===================== Nebula: memory-modal glass upgrade ===================== */

/* Overlay backdrop */
#memory-modal { background: rgba(4,6,14,.65); -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); }
@supports not (backdrop-filter: blur(1px)) { #memory-modal { background: rgba(4,6,14,.82); } }

/* Glass panel */
#memory-modal .modal-body {
  background: var(--glass-bg-2);
  border: 1px solid var(--glass-border);
  border-radius: var(--r);
  box-shadow: var(--shadow-3), var(--glass-hi), 0 0 40px rgba(99,102,241,.12);
  -webkit-backdrop-filter: blur(22px);
  backdrop-filter: blur(22px);
  overflow: hidden;
}
@supports not (backdrop-filter: blur(1px)) { #memory-modal .modal-body { background: var(--bg-2); } }

/* Header bar */
#memory-modal .modal-body header {
  background: rgba(255,255,255,.035);
  border-bottom: 1px solid var(--glass-border);
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 600;
  color: var(--fg);
  padding: 12px 16px;
}

/* Title text */
#memory-modal-title {
  color: var(--accent);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .01em;
}

/* Rendered markdown content area */
#memory-modal .md-render {
  background: transparent;
  padding: 22px 28px 32px;
}

/* Raw pre view */
#memory-modal .modal-body pre {
  background: rgba(0,0,0,.25);
  border-top: 1px solid var(--glass-border);
}

/* ---- Dashboard (home base) ------------------------------------------------ */
.dash { max-width: 880px; margin: 0 auto; }
.dash-greet { font-size: 1.5rem; font-weight: 600; margin-bottom: 2px; }
.dash-gsub { color: var(--fg-dim); margin-bottom: 18px; font-size: .9rem; }
.dash-hero {
  display: block; text-decoration: none; color: inherit; margin-bottom: 18px;
  padding: 18px 20px; border-radius: 16px;
  background: linear-gradient(120deg, rgba(59,130,246,.22), rgba(99,102,241,.12));
  border: 1px solid rgba(59,130,246,.35);
  transition: transform .15s ease, box-shadow .15s ease;
}
.dash-hero:hover { transform: translateY(-1px); box-shadow: 0 8px 30px rgba(0,0,0,.25); }
.dash-hero-k { text-transform: uppercase; letter-spacing: .08em; font-size: .7rem; color: var(--fg-dim); margin-bottom: 6px; }
.dash-hero-move { font-size: 1.15rem; font-weight: 600; line-height: 1.3; }
.dash-hero-sub { color: var(--fg-dim); font-size: .85rem; margin-top: 6px; }
.dash-hero-why { color: var(--fg-dim); font-size: .8rem; margin-top: 8px; font-style: italic; }
.dash-empty { color: var(--fg-dim); }
.dash-bento { display: grid; grid-template-columns: 1.4fr 1fr; gap: 14px; }
.dash-bento .dash-tile:first-child { grid-row: span 2; }
.dash-tile { display: block; text-decoration: none; color: inherit; padding: 16px; }
.dash-tile-t { text-transform: uppercase; letter-spacing: .08em; font-size: .7rem; color: var(--fg-dim); margin-bottom: 12px; }
.dash-person { display: block; text-decoration: none; color: inherit; padding: 9px 0; border-bottom: 1px solid var(--border); }
.dash-person:last-child { border-bottom: 0; }
.dash-person-h { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.dash-nx { color: var(--fg-dim); font-size: .85rem; margin-top: 3px; }
.dash-out { display: block; text-decoration: none; color: inherit; padding: 7px 0; border-bottom: 1px solid var(--border); font-size: .88rem; }
.dash-out:last-child { border-bottom: 0; }
.dash-arch { font-size: .9rem; margin: 0 0 10px; }
.dash-goal { margin-top: 10px; font-size: .8rem; }
.chip-sec { background: rgba(99,102,241,.16); color: var(--accent-2); }
