:root {
  --bg: #07090c;
  --panel: #0e1218;
  --panel-2: #131923;
  --line: #1d2632;
  --text: #d6e0ec;
  --dim: #6b7a8e;
  --accent: #54f0c8;
  --warn: #f0b454;
  --bad: #f06a6a;
  --good: #54f08e;
  --mono: 'JetBrains Mono', 'Fira Code', ui-monospace, Menlo, monospace;
}

* { box-sizing: border-box; }
[hidden] { display: none !important; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--mono);
  font-size: 13px;
  line-height: 1.5;
}

.topbar {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 18px; border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, #0a0e14, var(--bg));
}
.brand { display: flex; align-items: baseline; gap: 10px; }
.brand .name { font-size: 16px; font-weight: 600; letter-spacing: 0.05em; }
.brand .sub { font-size: 11px; color: var(--dim); text-transform: uppercase; letter-spacing: 0.15em; }
.dot { width: 8px; height: 8px; border-radius: 50%; background: var(--bad); display: inline-block; }
.dot.live { background: var(--accent); box-shadow: 0 0 8px var(--accent); }
.meta { font-size: 11px; color: var(--dim); }
.sep { margin: 0 6px; opacity: 0.4; }

.grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr 1fr;
  grid-auto-rows: minmax(280px, auto);
  gap: 12px;
  padding: 12px;
}
.panel.wide { grid-column: 1 / -1; }

.panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 14px 16px;
  display: flex; flex-direction: column;
}
.panel h2 {
  font-size: 11px; font-weight: 600; letter-spacing: 0.2em;
  color: var(--accent); margin: 0 0 12px; text-transform: uppercase;
}

.label {
  font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--dim); margin-top: 12px; margin-bottom: 6px;
}

.rows { display: grid; grid-template-columns: 1fr 1fr; gap: 4px 12px; }
.row { display: flex; justify-content: space-between; padding: 3px 0; border-bottom: 1px dashed transparent; }
.row .k { color: var(--dim); }
.row .v { font-weight: 500; }
.row .v.warn { color: var(--warn); }
.row .v.bad { color: var(--bad); }
.row .v.good { color: var(--good); }

.loaded #loadedModels { display: flex; flex-wrap: wrap; gap: 6px; }
.model-pill {
  background: var(--panel-2); padding: 3px 8px; border-radius: 3px;
  border: 1px solid var(--line); font-size: 11px;
}
.model-pill .vram { color: var(--accent); margin-left: 6px; }

.ollama-summary { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-bottom: 8px; }
.metric { background: var(--panel-2); padding: 8px 10px; border: 1px solid var(--line); border-radius: 3px; }
.metric .n { font-size: 18px; font-weight: 600; }
.metric .l { font-size: 9px; color: var(--dim); letter-spacing: 0.18em; text-transform: uppercase; }

table.reqlog { width: 100%; border-collapse: collapse; font-size: 11px; }
table.reqlog th { text-align: left; color: var(--dim); font-weight: 400; padding: 4px 6px; border-bottom: 1px solid var(--line); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; }
table.reqlog td { padding: 3px 6px; border-bottom: 1px dotted var(--line); }
table.reqlog .num { text-align: right; font-variant-numeric: tabular-nums; }
table.reqlog .status-2 { color: var(--good); }
table.reqlog .status-4, table.reqlog .status-5 { color: var(--bad); }

.callers { display: flex; flex-direction: column; gap: 6px; max-height: 100%; overflow-y: auto; }
.caller {
  background: var(--panel-2); padding: 8px 10px; border-radius: 3px; border: 1px solid var(--line);
  font-size: 11px;
}
.caller .head { display: flex; justify-content: space-between; color: var(--dim); margin-bottom: 4px; font-size: 10px; }
.caller .inbound { color: var(--dim); margin-bottom: 4px; }
.caller .draft { color: var(--text); }
.caller .send-flag { color: var(--accent); font-size: 9px; letter-spacing: 0.15em; }

.fleet { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 6px; }
.agent {
  background: var(--panel-2); padding: 8px 10px; border-radius: 3px; border: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 2px; font-size: 11px;
}
.agent .top { display: flex; justify-content: space-between; align-items: center; }
.agent .nm { font-weight: 600; }
.agent .freshness {
  font-size: 9px; padding: 2px 6px; border-radius: 2px; letter-spacing: 0.12em; text-transform: uppercase;
}
.freshness.active { background: rgba(84, 240, 142, 0.15); color: var(--good); }
.freshness.stale  { background: rgba(240, 180, 84, 0.15); color: var(--warn); }
.freshness.offline,
.freshness.never  { background: rgba(240, 106, 106, 0.15); color: var(--bad); }
.agent .host { color: var(--dim); font-size: 10px; }
.agent .age { color: var(--dim); font-size: 10px; }

.empty { color: var(--dim); font-style: italic; }

@media (max-width: 1100px) {
  .grid { grid-template-columns: 1fr 1fr; }
  .panel.wide { grid-column: 1 / -1; }
}
@media (max-width: 720px) {
  .grid { grid-template-columns: 1fr; }
}

/* ── tabs + view toggle ─────────────────────────────── */
.tabs { display: flex; gap: 4px; }
.tab {
  background: transparent; border: 1px solid var(--line); color: var(--dim);
  padding: 5px 14px; font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.18em; cursor: pointer; border-radius: 3px;
}
.tab:hover { color: var(--text); }
body[data-view="overview"] .tab[data-tab="overview"],
body[data-view="training"] .tab[data-tab="training"] {
  color: var(--accent); border-color: var(--accent);
}
body[data-view="overview"] .view-training,
body[data-view="overview"] .view-projects,
body[data-view="overview"] .view-activity,
body[data-view="overview"] .view-agent { display: none; }
body[data-view="projects"] .view-overview,
body[data-view="projects"] .view-training,
body[data-view="projects"] .view-activity,
body[data-view="projects"] .view-agent { display: none; }
body[data-view="activity"] .view-overview,
body[data-view="activity"] .view-projects,
body[data-view="activity"] .view-training,
body[data-view="activity"] .view-agent { display: none; }
body[data-view="training"] .view-overview,
body[data-view="training"] .view-projects,
body[data-view="training"] .view-activity,
body[data-view="training"] .view-agent { display: none; }
body[data-view="agent"] .view-overview,
body[data-view="agent"] .view-projects,
body[data-view="agent"] .view-activity,
body[data-view="agent"] .view-training { display: none; }
body[data-view="projects"] .tab[data-tab="projects"],
body[data-view="activity"] .tab[data-tab="activity"] { color: var(--accent); border-color: var(--accent); }

.counts { font-size: 10px; font-weight: 400; color: var(--dim); margin-left: 8px; letter-spacing: 0.1em; }
.back-link { background: transparent; border: 1px solid var(--line); color: var(--dim); padding: 4px 10px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; cursor: pointer; border-radius: 3px; margin-bottom: 12px; }
.back-link:hover { color: var(--accent); border-color: var(--accent); }

/* ── projects browser ─────────────────────────────── */
.proj-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 10px; }
.proj-card {
  background: var(--panel-2); border: 1px solid var(--line); border-radius: 4px;
  padding: 12px; display: flex; flex-direction: column; gap: 8px;
  cursor: pointer; text-decoration: none; color: var(--text);
}
.proj-card:hover { border-color: var(--accent); }
.proj-card.archived { opacity: 0.55; }
.proj-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 10px; }
.proj-name { font-size: 13px; font-weight: 600; }
.proj-slug { font-size: 10px; color: var(--dim); letter-spacing: 0.1em; text-transform: uppercase; margin-top: 2px; }
.proj-desc { font-size: 11px; color: var(--dim); line-height: 1.4; min-height: 32px; }
.proj-stack { display: flex; flex-wrap: wrap; gap: 4px; }
.stack-pill { background: var(--panel); border: 1px solid var(--line); padding: 2px 7px; border-radius: 2px; font-size: 9px; color: var(--dim); letter-spacing: 0.08em; text-transform: uppercase; }
.proj-foot { font-size: 10px; color: var(--dim); }
.proj-foot a { color: var(--accent); text-decoration: none; }
.bar { height: 5px; background: var(--panel); border-radius: 3px; overflow: hidden; display: flex; }
.bar-done { background: var(--good); height: 100%; }
.bar-ip { background: var(--warn); height: 100%; }
.bar-legend { font-size: 10px; color: var(--dim); margin-top: 3px; }

/* ── project detail ───────────────────────────────── */
.project-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 16px; }
.rows.two-col { grid-template-columns: 1fr; }
.phase {
  background: var(--panel-2); border: 1px solid var(--line); border-radius: 3px;
  padding: 10px 12px; margin-bottom: 8px;
}
.phase-head { display: flex; justify-content: space-between; align-items: center; }
.phase-label { font-size: 11px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; }
.phase-desc { font-size: 11px; color: var(--dim); margin: 4px 0 6px; line-height: 1.4; }
.steps { display: flex; flex-direction: column; gap: 4px; padding-left: 8px; border-left: 1px dashed var(--line); }
.step { font-size: 11px; padding: 4px 0; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.step-icon { color: var(--dim); }
.step-title { color: var(--text); flex: 1; }
.step-note { width: 100%; font-size: 10px; color: var(--dim); padding-left: 22px; }
.status-pill.status-done, .status-pill.status-active { background: rgba(84, 240, 142, 0.15); color: var(--good); }
.status-pill.status-pending, .status-pill.status-todo { background: rgba(107, 122, 142, 0.15); color: var(--dim); }
.status-pill.status-in-progress, .status-pill.status-running { background: rgba(240, 180, 84, 0.15); color: var(--warn); }
.status-pill.status-failed, .status-pill.status-cancelled, .status-pill.status-error { background: rgba(240, 106, 106, 0.15); color: var(--bad); }

.readme-meta { font-size: 10px; color: var(--dim); margin-bottom: 6px; }
.readme-body {
  background: #050709; border: 1px solid var(--line); border-radius: 3px;
  padding: 10px 12px; max-height: 400px; overflow: auto;
  font-size: 11px; color: var(--text); white-space: pre-wrap; margin: 0;
}
.readme-foot { font-size: 10px; color: var(--dim); margin-top: 6px; }
.readme-foot a { color: var(--accent); }

/* ── activity feed ────────────────────────────────── */
.filter-row { display: flex; gap: 6px; margin-bottom: 12px; }
.filter-pill {
  background: transparent; border: 1px solid var(--line); color: var(--dim);
  padding: 4px 12px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em;
  cursor: pointer; border-radius: 3px;
}
.filter-pill:hover { color: var(--text); }
.filter-pill.active { color: var(--accent); border-color: var(--accent); }
.filter-pill span { color: var(--dim); margin-left: 6px; font-size: 9px; }
.filter-pill.active span { color: var(--accent); }

.time-header { font-size: 10px; color: var(--dim); letter-spacing: 0.15em; text-transform: uppercase; margin: 14px 0 6px; padding-bottom: 4px; border-bottom: 1px solid var(--line); }
.intent-row {
  background: var(--panel-2); border: 1px solid var(--line); border-radius: 3px;
  padding: 8px 10px; margin-bottom: 5px; font-size: 11px;
}
.intent-top { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 6px; }
.intent-meta { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.intent-right { display: flex; gap: 6px; align-items: center; }
.repo-chip, .branch-chip, .event-badge {
  font-size: 9px; padding: 1px 6px; border-radius: 2px; letter-spacing: 0.08em; text-transform: uppercase;
}
.repo-chip { background: var(--panel); color: var(--accent); border: 1px solid var(--line); }
.branch-chip { background: var(--panel); color: var(--warn); border: 1px solid var(--line); }
.event-badge { background: rgba(84, 240, 200, 0.1); color: var(--accent); }
.intent-meta .src { color: var(--dim); font-size: 10px; }
.intent-meta .reporter { color: var(--dim); font-size: 10px; }
.intent-text { color: var(--dim); margin-top: 4px; line-height: 1.4; }
.cmd-count { font-size: 10px; color: var(--accent); margin-top: 3px; }
.intent-err { font-size: 10px; color: var(--bad); margin-top: 4px; padding: 4px 6px; background: rgba(240,106,106,0.08); border-radius: 2px; }
.age { color: var(--dim); font-size: 10px; }

/* ── agent detail ─────────────────────────────────── */
.agent-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.health-card { padding: 12px; border-radius: 3px; border: 1px solid var(--line); margin-bottom: 12px; }
.health-card.health-active { background: rgba(84, 240, 142, 0.06); border-color: var(--good); }
.health-card.health-stale { background: rgba(240, 180, 84, 0.06); border-color: var(--warn); }
.health-card.health-offline, .health-card.health-never { background: rgba(240, 106, 106, 0.06); border-color: var(--bad); }
.health-pill { display: inline-block; font-size: 10px; padding: 3px 8px; border-radius: 2px; letter-spacing: 0.15em; margin-bottom: 8px; }
.health-detail { font-size: 11px; }
.health-detail .k { color: var(--dim); margin-right: 6px; }
.cmd-list { display: flex; flex-direction: column; gap: 4px; }
.cmd { background: var(--panel-2); border: 1px solid var(--line); border-radius: 2px; padding: 5px 8px; font-size: 10.5px; }
.cmd .row1 { display: flex; justify-content: space-between; color: var(--dim); }
.cmd .row2 { display: flex; justify-content: space-between; align-items: center; margin-top: 2px; }
.cmd .arrow { color: var(--accent); }
.cmd .name { font-family: var(--mono); }
.cmd .when { font-size: 10px; }

/* clickable agents in fleet snapshot */
.agent.clickable { cursor: pointer; }
.agent.clickable:hover { border-color: var(--accent); }

/* ── training: runs table ───────────────────────────── */
.runs-meta { font-size: 10px; color: var(--dim); margin-bottom: 8px; letter-spacing: 0.1em; text-transform: uppercase; }
table.runs-table { width: 100%; border-collapse: collapse; font-size: 11px; }
table.runs-table th { text-align: left; color: var(--dim); font-weight: 400; padding: 5px 8px; border-bottom: 1px solid var(--line); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; }
table.runs-table td { padding: 5px 8px; border-bottom: 1px dotted var(--line); }
table.runs-table .num { text-align: right; font-variant-numeric: tabular-nums; }
table.runs-table tr.run-row { cursor: pointer; }
table.runs-table tr.run-row:hover { background: var(--panel-2); }
table.runs-table tr.run-row.selected { background: var(--panel-2); }
table.runs-table tr.run-row.selected td:first-child { border-left: 2px solid var(--accent); }
.status-pill { font-size: 9px; padding: 2px 7px; border-radius: 2px; letter-spacing: 0.12em; text-transform: uppercase; }
.status-pill.complete { background: rgba(84, 240, 142, 0.15); color: var(--good); }
.status-pill.running  { background: rgba(84, 240, 200, 0.15); color: var(--accent); animation: pulse 1.5s ease-in-out infinite; }
.status-pill.failed   { background: rgba(240, 106, 106, 0.15); color: var(--bad); }
.status-pill.pending  { background: rgba(107, 122, 142, 0.15); color: var(--dim); }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.55; } }

/* ── training: detail pane ──────────────────────────── */
.detail-empty { color: var(--dim); font-style: italic; padding: 20px 0; }
.detail-meta {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 6px 16px;
  margin-bottom: 12px; font-size: 11px;
}
.detail-meta .k { color: var(--dim); }
.detail-meta .v { color: var(--text); margin-left: 6px; }

.progress-wrap { margin-bottom: 12px; }
.progress-bar { height: 6px; background: var(--panel-2); border-radius: 3px; overflow: hidden; }
.progress-fill { height: 100%; background: var(--accent); transition: width 0.3s ease; box-shadow: 0 0 6px var(--accent); }
.progress-text { font-size: 10px; color: var(--dim); margin-top: 4px; letter-spacing: 0.1em; }

.loss-chart { width: 100%; height: 180px; background: var(--panel-2); border: 1px solid var(--line); border-radius: 3px; }
.loss-chart .axis { stroke: var(--line); stroke-width: 1; }
.loss-chart .train-line { fill: none; stroke: var(--accent); stroke-width: 1.5; }
.loss-chart .eval-line  { fill: none; stroke: var(--warn); stroke-width: 1.5; stroke-dasharray: 4 3; }
.loss-chart .train-dot, .loss-chart .eval-dot { stroke-width: 0; }
.loss-chart .train-dot { fill: var(--accent); }
.loss-chart .eval-dot  { fill: var(--warn); }
.loss-chart .tick-label { fill: var(--dim); font-size: 9px; font-family: var(--mono); }
.loss-legend { display: flex; gap: 16px; font-size: 10px; color: var(--dim); margin: 6px 0 12px; letter-spacing: 0.1em; text-transform: uppercase; }
.swatch { display: inline-block; width: 10px; height: 2px; vertical-align: middle; margin-right: 6px; }
.swatch.train { background: var(--accent); }
.swatch.eval  { background: var(--warn); }

.per-class { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 4px; margin-bottom: 12px; }
.per-class .pc {
  background: var(--panel-2); padding: 5px 8px; border-radius: 3px; border: 1px solid var(--line);
  display: flex; justify-content: space-between; font-size: 11px;
}
.per-class .pc .lbl { color: var(--dim); }
.per-class .pc .f1 { color: var(--accent); font-variant-numeric: tabular-nums; }
.per-class .pc .f1.warn { color: var(--warn); }
.per-class .pc .f1.bad { color: var(--bad); }

.log-tail {
  background: #050709; border: 1px solid var(--line); border-radius: 3px;
  padding: 10px 12px; max-height: 260px; overflow: auto;
  font-size: 10.5px; color: var(--text); white-space: pre-wrap; word-break: break-all;
  margin: 0;
}
