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

:root {
  --bg-primary:   #ffffff;
  --bg-secondary: #f6f5f2;
  --bg-tertiary:  #f0ede8;
  --bg-hover:     #eeece8;

  --text-primary:   #1a1a18;
  --text-secondary: #6b6a65;
  --text-tertiary:  #9b9a95;
  --text-info:      #1a5fa8;
  --text-success:   #166534;
  --text-warning:   #854d0e;
  --text-danger:    #991b1b;

  --border:         rgba(0,0,0,0.08);
  --border-medium:  rgba(0,0,0,0.14);
  --border-strong:  rgba(0,0,0,0.22);

  --accent-blue:   #1a5fa8;
  --accent-green:  #16a34a;
  --accent-amber:  #d97706;
  --accent-red:    #dc2626;
  --accent-purple: #7c3aed;

  --bg-info:     #eff6ff;
  --bg-success:  #f0fdf4;
  --bg-warning:  #fffbeb;
  --bg-danger:   #fef2f2;

  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 12px;

  --topbar-height: 48px;
  --sidebar-width: 220px;
  --font: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono: 'SF Mono', 'Fira Code', 'Consolas', monospace;
}

html, body {
  height: 100%;
  font-family: var(--font);
  font-size: 14px;
  color: var(--text-primary);
  background: var(--bg-tertiary);
  -webkit-font-smoothing: antialiased;
}

/* ── Topbar ──────────────────────────────────────────────────────────── */
.topbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--topbar-height);
  background: var(--bg-primary);
  border-bottom: 0.5px solid var(--border-medium);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 20px;
  z-index: 100;
}

.topbar-left {
  display: flex;
  align-items: center;
  gap: 10px;
}

.logo-mark {
  font-size: 16px;
  color: var(--text-secondary);
}

.project-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--text-primary);
}

.project-sub {
  font-size: 12px;
  color: var(--text-tertiary);
}

.topbar-right {
  display: flex;
  align-items: center;
  gap: 8px;
}

.status-pill {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 500;
  padding: 3px 8px;
  border-radius: 10px;
}

.pill-green  { background: var(--bg-success);  color: var(--text-success); }
.pill-amber  { background: var(--bg-warning);  color: var(--text-warning); }
.pill-gray   { background: var(--bg-secondary); color: var(--text-secondary); }
.pill-blue   { background: var(--bg-info);     color: var(--text-info); }

.pill-dot {
  width: 5px; height: 5px;
  border-radius: 50%;
}
.dot-green  { background: var(--accent-green); }
.dot-amber  { background: var(--accent-amber); }
.dot-gray   { background: var(--text-tertiary); }
.dot-blue   { background: var(--accent-blue); }
.dot-red    { background: var(--accent-red); }

.last-updated {
  font-size: 11px;
  color: var(--text-tertiary);
}

.connection-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--accent-green);
  transition: background 0.3s;
}
.connection-dot.offline { background: var(--accent-red); }

/* ── App layout ──────────────────────────────────────────────────────── */
.app-layout {
  display: flex;
  height: 100vh;
  padding-top: var(--topbar-height);
}

/* ── Sidebar ─────────────────────────────────────────────────────────── */
.sidebar {
  width: var(--sidebar-width);
  background: var(--bg-primary);
  border-right: 0.5px solid var(--border);
  padding: 12px 0;
  overflow-y: auto;
  flex-shrink: 0;
  height: 100%;
}

.nav-section-label {
  padding: 4px 14px 2px;
  font-size: 10px;
  font-weight: 500;
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-top: 4px;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 16px;
  font-size: 13px;
  color: var(--text-secondary);
  cursor: pointer;
  transition: background 0.1s;
  border-radius: 0;
}
.nav-item:hover { background: var(--bg-secondary); color: var(--text-primary); }
.nav-item.active {
  background: var(--bg-hover);
  color: var(--text-primary);
  font-weight: 500;
}

/* ── Main content ────────────────────────────────────────────────────── */
.main-content {
  flex: 1;
  overflow-y: auto;
  padding: 20px;
  min-width: 0;
}

/* ── Panels ──────────────────────────────────────────────────────────── */
.panel { display: none; }
.panel.active { display: block; }

.panel-header {
  margin-bottom: 16px;
}

.panel-title {
  font-size: 18px;
  font-weight: 500;
  color: var(--text-primary);
}

.panel-desc {
  font-size: 13px;
  color: var(--text-secondary);
  margin-top: 4px;
  max-width: 600px;
  line-height: 1.6;
}

/* ── Metric cards ────────────────────────────────────────────────────── */
.metrics-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 16px;
}

@media (max-width: 1200px) {
  .metrics-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

.metric-card {
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
  padding: 12px 14px;
}

.metric-label {
  font-size: 11px;
  color: var(--text-secondary);
  margin-bottom: 4px;
}

.metric-value {
  font-size: 24px;
  font-weight: 500;
  color: var(--text-primary);
  line-height: 1.1;
}

.metric-sub {
  font-size: 10px;
  color: var(--text-tertiary);
  margin-top: 2px;
}

/* ── Section box ─────────────────────────────────────────────────────── */
.section-box {
  background: var(--bg-primary);
  border: 0.5px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 14px 16px;
}

.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}

.section-title {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-primary);
}

.section-link {
  font-size: 11px;
  color: var(--text-info);
  cursor: pointer;
}
.section-link:hover { text-decoration: underline; }

.two-col-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

/* ── Agent cards ──────────────────────────────────────────────────────── */
.agent-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.agent-card {
  border: 0.5px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 10px 12px;
  cursor: pointer;
  transition: border-color 0.15s;
  border-left-width: 2px;
}
.agent-card:hover { border-color: var(--border-medium); }
.agent-card.status-running { border-left-color: var(--accent-green); }
.agent-card.status-idle    { border-left-color: var(--border); }
.agent-card.status-starting { border-left-color: var(--accent-amber); }
.agent-card.status-paused  { border-left-color: var(--accent-amber); }
.agent-card.status-killed  { border-left-color: var(--accent-red); }

.agent-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}

.agent-name {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-primary);
}

.agent-desc {
  font-size: 11px;
  color: var(--text-secondary);
  line-height: 1.5;
  margin-bottom: 7px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.agent-meta {
  display: flex;
  gap: 8px;
  font-size: 10px;
  color: var(--text-tertiary);
  margin-bottom: 6px;
}

.progress-bar {
  height: 3px;
  background: var(--border);
  border-radius: 2px;
  overflow: hidden;
}

.progress-fill {
  height: 100%;
  border-radius: 2px;
  transition: width 0.5s ease;
}
.fill-green  { background: var(--accent-green); }
.fill-amber  { background: var(--accent-amber); }
.fill-gray   { background: var(--text-tertiary); opacity: 0.4; }

/* ── Ideas list (top ideas panel) ────────────────────────────────────── */
.ideas-list {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.idea-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 10px;
  border: 0.5px solid var(--border);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background 0.1s;
}
.idea-row:hover { background: var(--bg-secondary); }

.idea-rank {
  font-size: 11px;
  color: var(--text-tertiary);
  width: 16px;
  text-align: right;
  flex-shrink: 0;
}

.idea-content { flex: 1; min-width: 0; }

.idea-title {
  font-size: 12px;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.idea-domain-tag {
  font-size: 10px;
  color: var(--text-tertiary);
  margin-top: 1px;
}

.idea-score {
  font-size: 12px;
  font-weight: 500;
  flex-shrink: 0;
}
.score-high { color: var(--text-success); }
.score-mid  { color: var(--text-warning); }
.score-low  { color: var(--text-tertiary); }

/* ── Playbook entries ─────────────────────────────────────────────────── */
.playbook-entries {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.playbook-row {
  display: flex;
  gap: 12px;
  padding: 8px 0;
  border-bottom: 0.5px solid var(--border);
}
.playbook-row:last-child { border-bottom: none; }

.pb-date {
  font-size: 10px;
  color: var(--text-tertiary);
  flex-shrink: 0;
  width: 68px;
  padding-top: 1px;
}

.pb-content { flex: 1; }

.pb-title {
  font-size: 12px;
  color: var(--text-primary);
  font-weight: 500;
  margin-bottom: 2px;
}

.pb-summary {
  font-size: 11px;
  color: var(--text-secondary);
  line-height: 1.5;
}

.pb-tag {
  display: inline-block;
  font-size: 10px;
  padding: 1px 6px;
  border-radius: 6px;
  margin-top: 3px;
}

/* ── Ideas table ─────────────────────────────────────────────────────── */
.ideas-table-container {
  overflow-x: auto;
}

.ideas-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}

.ideas-table th {
  text-align: left;
  padding: 8px 10px;
  font-weight: 500;
  font-size: 11px;
  color: var(--text-secondary);
  border-bottom: 0.5px solid var(--border-medium);
  background: var(--bg-secondary);
}

.ideas-table td {
  padding: 8px 10px;
  border-bottom: 0.5px solid var(--border);
  vertical-align: top;
}

.ideas-table tr:hover td {
  background: var(--bg-secondary);
}

.ideas-table .idea-title-cell {
  max-width: 260px;
}

.ideas-table .idea-title-text {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  line-height: 1.4;
}

.badge {
  display: inline-block;
  font-size: 10px;
  padding: 2px 7px;
  border-radius: 8px;
  font-weight: 500;
}
.badge-green   { background: var(--bg-success); color: var(--text-success); }
.badge-amber   { background: var(--bg-warning); color: var(--text-warning); }
.badge-gray    { background: var(--bg-secondary); color: var(--text-secondary); }
.badge-blue    { background: var(--bg-info); color: var(--text-info); }
.badge-red     { background: var(--bg-danger); color: var(--text-danger); }

.btn-promote {
  font-size: 10px;
  padding: 2px 8px;
  border: 0.5px solid var(--border-medium);
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--text-secondary);
  cursor: pointer;
  transition: background 0.1s;
}
.btn-promote:hover { background: var(--bg-secondary); }

/* ── Results list ────────────────────────────────────────────────────── */
.results-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.result-card {
  background: var(--bg-primary);
  border: 0.5px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 12px 16px;
  border-left-width: 2px;
  cursor: pointer;
  transition: border-color 0.15s;
}
.result-card:hover { border-color: var(--border-medium); }
.result-card.result-success   { border-left-color: var(--accent-green); }
.result-card.result-failed    { border-left-color: var(--accent-red); }
.result-card.result-abandoned { border-left-color: var(--text-tertiary); }

.result-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}

.result-title {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-primary);
}

.result-metric {
  font-size: 13px;
  font-weight: 500;
}
.metric-pos { color: var(--text-success); }
.metric-neg { color: var(--text-danger); }
.metric-neu { color: var(--text-secondary); }

.result-meta {
  font-size: 11px;
  color: var(--text-tertiary);
  margin-bottom: 6px;
}

.result-notes {
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ── Sparkline ───────────────────────────────────────────────────────── */
.sparkline {
  height: 24px;
  width: 80px;
}

/* ── Playbook panel ──────────────────────────────────────────────────── */
.playbook-container {
  background: var(--bg-primary);
  border: 0.5px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px 24px;
  max-width: 860px;
}

.playbook-raw {
  font-size: 13px;
  line-height: 1.7;
  color: var(--text-primary);
}

.playbook-raw h1 { font-size: 20px; font-weight: 500; margin-bottom: 16px; }
.playbook-raw h2 { font-size: 15px; font-weight: 500; margin: 24px 0 10px; color: var(--text-primary); border-bottom: 0.5px solid var(--border); padding-bottom: 6px; }
.playbook-raw h3 { font-size: 13px; font-weight: 500; margin: 14px 0 6px; }
.playbook-raw p  { margin-bottom: 10px; color: var(--text-secondary); }
.playbook-raw ul { margin: 6px 0 10px 16px; }
.playbook-raw li { margin-bottom: 3px; color: var(--text-secondary); }
.playbook-raw strong { color: var(--text-primary); font-weight: 500; }
.playbook-raw table { width: 100%; border-collapse: collapse; margin: 10px 0; font-size: 12px; }
.playbook-raw th { text-align: left; padding: 6px 10px; background: var(--bg-secondary); border-bottom: 0.5px solid var(--border-medium); font-weight: 500; font-size: 11px; color: var(--text-secondary); }
.playbook-raw td { padding: 6px 10px; border-bottom: 0.5px solid var(--border); }

/* ── Launch panel ────────────────────────────────────────────────────── */
.launch-instructions {
  background: var(--bg-secondary);
  border-radius: var(--radius-lg);
  padding: 14px 16px;
  margin-bottom: 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.instruction-step {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13px;
  color: var(--text-secondary);
}

.step-num {
  width: 20px;
  height: 20px;
  background: var(--bg-primary);
  border: 0.5px solid var(--border-medium);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 500;
  flex-shrink: 0;
  color: var(--text-secondary);
}

.launch-agents {
  display: flex;
  flex-direction: column;
  gap: 1px;
  background: var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 0.5px solid var(--border);
}

.launch-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  background: var(--bg-primary);
  transition: background 0.1s;
}
.launch-row:hover { background: var(--bg-secondary); }

.launch-agent-name {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-primary);
  width: 120px;
  flex-shrink: 0;
}

.launch-prompt-preview {
  flex: 1;
  font-size: 11px;
  color: var(--text-tertiary);
  font-family: var(--font-mono);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.copy-btn {
  font-size: 11px;
  padding: 4px 12px;
  border: 0.5px solid var(--border-medium);
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--text-secondary);
  cursor: pointer;
  flex-shrink: 0;
  transition: background 0.1s, color 0.1s;
}
.copy-btn:hover { background: var(--bg-secondary); }
.copy-btn.copied { color: var(--text-success); border-color: var(--accent-green); }

/* ── Worker signal controls ──────────────────────────────────────────── */
.signal-btn {
  font-size: 10px;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 0.5px solid var(--border-medium);
  background: transparent;
  color: var(--text-secondary);
  transition: background 0.1s;
}
.signal-btn:hover { background: var(--bg-secondary); }
.signal-btn.danger { color: var(--text-danger); border-color: rgba(220,38,38,0.3); }
.signal-btn.danger:hover { background: var(--bg-danger); }

/* ── Modal ───────────────────────────────────────────────────────────── */
.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.35);
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.modal {
  background: var(--bg-primary);
  border-radius: var(--radius-lg);
  border: 0.5px solid var(--border-medium);
  width: 100%;
  max-width: 700px;
  max-height: 80vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 0.5px solid var(--border);
}

.modal-title {
  font-size: 14px;
  font-weight: 500;
  color: var(--text-primary);
}

.modal-close {
  background: none;
  border: none;
  font-size: 14px;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 2px 6px;
  border-radius: var(--radius-sm);
}
.modal-close:hover { background: var(--bg-secondary); }

.modal-body {
  padding: 16px 18px;
  overflow-y: auto;
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-secondary);
}

.modal-section { margin-bottom: 16px; }
.modal-section-title { font-size: 11px; font-weight: 500; color: var(--text-tertiary); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 6px; }

.metrics-inline-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 12px;
}

.metrics-inline-card {
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
  padding: 8px 10px;
  text-align: center;
}

.metrics-inline-val {
  font-size: 18px;
  font-weight: 500;
  color: var(--text-primary);
}

.metrics-inline-label {
  font-size: 10px;
  color: var(--text-tertiary);
  margin-top: 2px;
}

.log-block {
  background: #1a1a18;
  color: #d4d2cb;
  font-family: var(--font-mono);
  font-size: 11px;
  line-height: 1.5;
  padding: 12px 14px;
  border-radius: var(--radius-md);
  overflow-x: auto;
  max-height: 200px;
  overflow-y: auto;
  white-space: pre;
}

/* ── Scrollbar styling ───────────────────────────────────────────────── */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border-medium); border-radius: 3px; }

/* ── Utility ─────────────────────────────────────────────────────────── */
.text-success { color: var(--text-success); }
.text-danger  { color: var(--text-danger); }
.text-warning { color: var(--text-warning); }
.text-info    { color: var(--text-info); }
.text-muted   { color: var(--text-tertiary); }

select.filter-select {
  font-size: 12px;
  padding: 4px 8px;
  border: 0.5px solid var(--border-medium);
  border-radius: var(--radius-sm);
  background: var(--bg-primary);
  color: var(--text-primary);
  cursor: pointer;
}

.panel-controls {
  display: flex;
  gap: 8px;
  margin-top: 8px;
}

/* ── Pipeline Flow ───────────────────────────────────────────────────── */
.pipeline-flow {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 16px;
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
  margin-bottom: 16px;
  overflow-x: auto;
}
.pipeline-stage {
  flex: 1;
  text-align: center;
  padding: 12px 8px;
  background: var(--bg-primary);
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  min-width: 110px;
}
.stage-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.stage-status {
  font-size: 13px;
  margin-top: 4px;
  color: var(--text-tertiary);
}
.stage-status.stage-active {
  color: var(--accent-green);
  font-weight: 600;
}
.stage-status.stage-inactive {
  color: var(--text-tertiary);
}
.pipeline-arrow {
  color: var(--text-tertiary);
  font-size: 18px;
  flex-shrink: 0;
}

/* ── Event rows ──────────────────────────────────────────────────────── */
.event-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 0;
  border-bottom: 1px solid var(--border);
  font-size: 13px;
}
.event-worker { color: var(--text-secondary); min-width: 70px; }
.event-id { color: var(--text-tertiary); font-family: var(--font); }
.event-time { color: var(--text-tertiary); margin-left: auto; }

/* ── Badges ──────────────────────────────────────────────────────────── */
.badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
.badge-green  { background: var(--bg-success); color: var(--text-success); }
.badge-red    { background: var(--bg-danger);  color: var(--text-danger); }
.badge-blue   { background: var(--bg-info);    color: var(--text-info); }
.badge-amber  { background: var(--bg-warning); color: var(--text-warning); }
.badge-gray   { background: var(--bg-tertiary); color: var(--text-secondary); }
.badge-purple { background: #f5f0ff; color: var(--accent-purple); }

/* ── Review cards ────────────────────────────────────────────────────── */
.review-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: var(--bg-primary);
  border: 0.5px solid var(--border);
  border-left-width: 3px;
  border-radius: var(--radius-md);
  margin-bottom: 8px;
  cursor: pointer;
  transition: background 0.1s;
}
.review-card:hover { background: var(--bg-hover); }
.review-card.review-accepted { border-left-color: var(--accent-green); }
.review-card.review-rejected { border-left-color: var(--accent-red); }
.review-card.review-revision { border-left-color: var(--accent-amber); }
.review-id {
  font-family: var(--font-mono);
  color: var(--text-tertiary);
  font-size: 11px;
  flex-shrink: 0;
}
.review-hyp {
  color: var(--text-primary);
  font-size: 13px;
  font-weight: 450;
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── Knowledge entries ───────────────────────────────────────────────── */
.knowledge-entries .playbook-entry,
.playbook-entry {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 0;
  border-bottom: 1px solid var(--border);
}
.entry-tag { font-size: 11px; font-weight: 600; }
.tag-confirmed { color: var(--text-success); }
.tag-dead-end  { color: var(--text-danger); }
.entry-title { font-size: 13px; color: var(--text-primary); }
.entry-date  { font-size: 12px; color: var(--text-tertiary); margin-left: auto; }

/* ── Hypothesis text ─────────────────────────────────────────────────── */
.hyp-text { font-size: 12px; color: var(--text-secondary); max-width: 300px; }

/* ── Launch panel v2 ─────────────────────────────────────────────────── */
.launch-all-row { background: var(--bg-info); border-radius: var(--radius-sm); padding: 12px !important; }
.launch-divider { border: none; border-top: 1px solid var(--border); margin: 8px 0; }
.launch-pid { font-size: 11px; color: var(--text-tertiary); }
.launch-log-preview {
  padding: 4px 12px 8px;
  font-size: 11px;
}
.launch-log-preview pre {
  background: var(--bg-tertiary);
  padding: 6px 8px;
  border-radius: var(--radius-sm);
  font-size: 11px;
  color: var(--text-secondary);
  max-height: 80px;
  overflow-y: auto;
}

.btn-promote { color: var(--accent-blue); }
.btn-sm { padding: 2px 8px; font-size: 11px; cursor: pointer; background: var(--bg-secondary); border: 1px solid var(--border); border-radius: var(--radius-sm); }
.btn-sm:hover { background: var(--bg-hover); }
.btn-sm.btn-green { color: var(--text-success); }
.btn-sm.btn-red { color: var(--text-danger); }

/* ── Nav domain label ────────────────────────────────────────────────── */
.nav-domain { font-size: 10px; color: var(--text-tertiary); }

/* ── Empty state ─────────────────────────────────────────────────────── */
.empty-state { padding: 20px; text-align: center; color: var(--text-tertiary); font-size: 13px; }

/* ── Log content in modal ────────────────────────────────────────────── */
.log-content {
  white-space: pre-wrap;
  word-break: break-all;
  font-size: 12px;
  max-height: 500px;
  overflow-y: auto;
  background: var(--bg-tertiary);
  padding: 12px;
  border-radius: var(--radius-sm);
}

/* ── Papers ─────────────────────────────────────────────────────────── */
.papers-stats { margin-bottom: 8px; }
.papers-list { display: flex; flex-direction: column; gap: 8px; }

.paper-card {
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 12px 14px;
}

.paper-title { font-weight: 600; font-size: 14px; margin-bottom: 4px; }
.paper-title-link { color: var(--accent-blue, #2563eb); text-decoration: none; }
.paper-title-link:hover { text-decoration: underline; }

.paper-meta {
  display: flex; gap: 12px; font-size: 12px; color: var(--text-secondary);
  margin-bottom: 6px;
}
.paper-authors { font-style: italic; }
.paper-cites { color: var(--text-tertiary); }

.paper-abstract {
  font-size: 12px; color: var(--text-secondary);
  line-height: 1.4; margin-bottom: 6px;
}

.paper-relevance {
  font-size: 12px; color: var(--text-primary);
  background: var(--bg-tertiary); padding: 6px 8px;
  border-radius: var(--radius-sm); margin-bottom: 6px;
}

.paper-footer {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 11px; color: var(--text-tertiary);
}

/* ── Experiments Table ──────────────────────────────────────────────── */
.exp-row td { vertical-align: top; padding: 10px 8px; }
.exp-row.exp-running { background: var(--bg-info); }
.exp-title { font-weight: 500; font-size: 13px; }
.exp-id { font-family: 'SF Mono', monospace; font-size: 11px; color: var(--text-tertiary); margin-top: 2px; }
.exp-sub { font-size: 12px; color: var(--text-secondary); max-width: 220px; }
.exp-gpu { font-family: 'SF Mono', monospace; font-size: 12px; color: var(--text-secondary); white-space: nowrap; }
.exp-result { font-size: 12px; }
.exp-actions { white-space: nowrap; }
.col-good { min-width: 90px; }
.col-fail { min-width: 90px; }
.verdict-good { color: var(--text-success); font-weight: 600; font-size: 12px; }
.verdict-fail { color: var(--text-danger); font-weight: 600; font-size: 12px; }
.verdict-revision { color: var(--text-warning); font-weight: 600; font-size: 12px; }
.text-success { color: var(--text-success); }
.text-danger { color: var(--text-danger); }
.text-tertiary { color: var(--text-tertiary); }

/* ETA progress bar */
.exp-eta { margin-top: 6px; }
.eta-bar {
  width: 100%; height: 4px; background: var(--bg-tertiary);
  border-radius: 2px; overflow: hidden; margin-bottom: 3px;
}
.eta-fill {
  height: 100%; background: var(--accent-blue); border-radius: 2px;
  transition: width 1s ease;
}
.eta-text { font-size: 10px; color: var(--text-tertiary); font-family: 'SF Mono', monospace; }
.exp-duration { font-size: 10px; color: var(--text-tertiary); margin-top: 3px; }
.exp-status-cell { min-width: 120px; }

/* Live activity per experiment */
.exp-activity { max-width: 200px; font-size: 11px; }
.exp-activity-line {
  color: var(--text-secondary); padding: 1px 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 200px;
}

/* ── Activity Feed ──────────────────────────────────────────────────── */
.activity-feed {
  max-height: 240px; overflow-y: auto;
  font-family: 'SF Mono', 'Menlo', monospace; font-size: 12px;
  background: var(--bg-secondary); border-radius: 6px;
  padding: 8px; border: 1px solid var(--border);
}
.activity-line {
  padding: 3px 0; display: flex; align-items: baseline; gap: 8px;
  border-bottom: 1px solid var(--border);
}
.activity-line:last-child { border-bottom: none; }
.activity-text { color: var(--text-primary); word-break: break-word; }

/* ── Setup Panel ────────────────────────────────────────────────────── */
.setup-form {
  max-width: 480px;
  display: flex; flex-direction: column; gap: 16px;
  padding: 20px;
  background: var(--bg-secondary);
  border-radius: 8px;
  border: 1px solid var(--border);
}
.setup-field { display: flex; flex-direction: column; gap: 6px; }
.setup-field label { font-size: 13px; font-weight: 500; color: var(--text-primary); }
.setup-input {
  padding: 8px 12px; font-size: 13px;
  border: 1px solid var(--border-medium); border-radius: 6px;
  background: var(--bg-primary); color: var(--text-primary);
  font-family: inherit;
}
.setup-input:focus { outline: none; border-color: var(--accent-blue); }
.setup-error {
  padding: 8px 12px; font-size: 12px;
  background: #fef2f2; color: var(--text-danger);
  border-radius: 6px; border: 1px solid rgba(220,38,38,0.2);
}
.setup-connected {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px; margin-bottom: 16px;
  background: var(--bg-success); border-radius: 8px;
  border: 1px solid rgba(22,163,74,0.2);
}

/* ── Instance Cards ─────────────────────────────────────────────────── */
.instance-card {
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 8px; padding: 16px; margin-bottom: 12px;
}
.instance-header {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 12px; flex-wrap: wrap;
}
.instance-ip { font-family: 'SF Mono', monospace; font-size: 12px; color: var(--text-secondary); }
.instance-type { font-size: 12px; color: var(--text-tertiary); }
.instance-gpus { display: flex; flex-direction: column; gap: 6px; }

/* ── GPU Utilization Bars ───────────────────────────────────────────── */
.gpu-row {
  display: flex; align-items: center; gap: 8px; font-size: 12px;
}
.gpu-label { width: 50px; font-family: 'SF Mono', monospace; color: var(--text-secondary); }
.gpu-bar-track {
  flex: 1; height: 8px; background: var(--bg-tertiary);
  border-radius: 4px; overflow: hidden;
}
.gpu-bar-fill {
  height: 100%; border-radius: 4px;
  transition: width 0.3s ease;
}
.gpu-bar-green { background: var(--accent-green); }
.gpu-bar-amber { background: var(--accent-amber); }
.gpu-bar-red { background: var(--accent-red); }
.gpu-pct { width: 32px; text-align: right; font-family: 'SF Mono', monospace; color: var(--text-primary); }
.gpu-mem { width: 120px; font-family: 'SF Mono', monospace; color: var(--text-tertiary); font-size: 11px; }

/* ── Log Terminal ──────────────────────────────────────────────────── */
.log-terminal {
  background: #0d1117;
  color: #c9d1d9;
  font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
  font-size: 12px;
  line-height: 1.6;
  padding: 12px 14px;
  border-radius: var(--radius-md);
  border: 1px solid #30363d;
  height: calc(100vh - 200px);
  overflow-y: auto;
  overflow-x: hidden;
}

.log-line {
  padding: 2px 0;
  display: flex;
  align-items: baseline;
  gap: 6px;
  border-bottom: 1px solid rgba(48,54,61,0.4);
  word-break: break-word;
}

.log-line-tool { background: rgba(56,139,253,0.06); }
.log-line-result { background: rgba(63,185,80,0.06); }
.log-line-system { background: rgba(210,153,34,0.08); }

.log-agent {
  font-weight: 600;
  font-size: 11px;
  white-space: nowrap;
  flex-shrink: 0;
}

.log-ts {
  font-size: 10px;
  color: #484f58;
  white-space: nowrap;
  flex-shrink: 0;
  min-width: 70px;
}

.log-type-icon {
  font-size: 10px;
  font-weight: 700;
  width: 22px;
  text-align: center;
  flex-shrink: 0;
}
.log-tool-icon { color: #58a6ff; }
.log-result-icon { color: #3fb950; }
.log-sys-icon { color: #d29922; }
.log-text-icon { color: #8b949e; }

.log-text-content {
  color: #c9d1d9;
  white-space: pre-wrap;
  word-break: break-word;
}

.log-line-tool .log-text-content { color: #79c0ff; }
.log-line-result .log-text-content { color: #7ee787; font-size: 11px; }

/* ── Fleet / Data Quality ──────────────────────────────────────────── */
.dq-section { padding: 12px 0; }

.dq-source-row {
  margin-bottom: 4px;
}

.dq-dropdown {
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  overflow: hidden;
}

.dq-summary {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  cursor: pointer;
  background: var(--bg-primary);
  transition: background 0.1s;
  list-style: none;
}
.dq-summary::-webkit-details-marker { display: none; }
.dq-summary::before {
  content: '\25B6';
  font-size: 8px;
  color: var(--text-tertiary);
  transition: transform 0.15s;
}
details[open] > .dq-summary::before { transform: rotate(90deg); }
.dq-summary:hover { background: var(--bg-secondary); }

.dq-name { font-weight: 500; font-size: 13px; color: var(--text-primary); min-width: 100px; }
.dq-version { font-family: 'SF Mono', monospace; font-size: 12px; color: var(--text-tertiary); }
.dq-status { margin-left: auto; }

.dq-detail {
  padding: 8px 14px 12px 28px;
  background: var(--bg-secondary);
  border-top: 1px solid var(--border);
}

.dq-check-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 4px 0;
  font-size: 12px;
}

.dq-check-name { color: var(--text-secondary); }

/* ── Experiment Group Headers ─────────────────────────────────────────── */
.exp-group-header td {
  background: var(--bg-secondary);
  padding: 10px 12px !important;
  border-bottom: 2px solid var(--border);
  border-top: 1px solid var(--border);
}
.exp-group-title {
  font-weight: 600;
  font-size: 13px;
  color: var(--text-primary);
}
.exp-group-count {
  font-size: 11px;
  color: var(--text-tertiary);
  margin-left: 8px;
}
.exp-desired { max-width: 220px; font-size: 12px; color: var(--text-secondary); }
.exp-outcome { max-width: 200px; font-size: 12px; }
.exp-verdict { font-size: 12px; }
.outcome-metric { font-weight: 500; }
.badge-xs { font-size: 9px; padding: 1px 4px; vertical-align: middle; }

/* ── Experiment Modal ─────────────────────────────────────────────────── */
.modal-exp-title { font-size: 16px; font-weight: 600; margin-bottom: 4px; line-height: 1.4; }
.modal-rerun-badge {
  display: inline-block;
  background: #fef3c7;
  color: #92400e;
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 4px;
  margin-bottom: 12px;
}
.modal-section {
  margin-bottom: 16px;
  padding-bottom: 14px;
  border-bottom: 0.5px solid var(--border);
}
.modal-section:last-of-type { border-bottom: none; }
.modal-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-tertiary);
  margin-bottom: 6px;
}
.modal-value {
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-primary);
  word-wrap: break-word;
  overflow-wrap: break-word;
}
.outcome-completed { color: var(--text-primary); }
.outcome-baseline { font-size: 11px; color: var(--text-tertiary); margin-top: 2px; }
.outcome-failed { color: var(--text-primary); }

/* Modal pre blocks (specs, results, logs) */
.modal-body pre {
  background: var(--bg-secondary);
  border: 0.5px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 10px 12px;
  font-size: 11px;
  font-family: var(--font-mono);
  line-height: 1.5;
  white-space: pre-wrap;
  word-break: break-word;
  max-height: 300px;
  overflow-y: auto;
  margin-top: 6px;
  color: var(--text-primary);
}
.modal-body h4 {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary);
  margin-top: 12px;
  margin-bottom: 4px;
}
.review-pre {
  white-space: pre-wrap;
  word-break: break-word;
  font-size: 12px;
  line-height: 1.6;
  background: var(--bg-secondary);
  border: 0.5px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 10px 12px;
  margin-top: 6px;
  max-height: 250px;
  overflow-y: auto;
}
.exp-details {
  margin-top: 16px;
  border-top: 0.5px solid var(--border);
  padding-top: 12px;
}
.exp-details summary {
  cursor: pointer;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-secondary);
  margin-bottom: 8px;
  user-select: none;
}
.exp-details summary:hover { color: var(--text-primary); }
.exp-details[open] summary { margin-bottom: 12px; }

/* ── Experiment Error Banner ──────────────────────────────────────────── */
.exp-error-banner {
  background: #fef2f2;
  border: 1px solid #fca5a5;
  border-radius: 8px;
  padding: 16px;
  margin-bottom: 16px;
}
.exp-error-banner h4 { color: #dc2626; margin-bottom: 8px; font-size: 14px; }
.error-reason { color: #991b1b; font-size: 13px; margin-bottom: 8px; line-height: 1.5; }
.error-stderr {
  background: #1e1e1e;
  color: #f87171;
  padding: 10px;
  border-radius: 6px;
  font-size: 11px;
  max-height: 200px;
  overflow-y: auto;
  white-space: pre-wrap;
  word-break: break-all;
}
.error-meta { color: #6b7280; font-size: 12px; margin-top: 8px; }

/* ── Rerun Section ────────────────────────────────────────────────────── */
.rerun-section {
  background: #eff6ff;
  border: 1px solid #93c5fd;
  border-radius: 8px;
  padding: 16px;
  margin-bottom: 16px;
}
.rerun-section h4 { color: #1d4ed8; margin-bottom: 4px; font-size: 14px; }
.rerun-hint { color: #6b7280; font-size: 12px; margin-bottom: 8px; }
.rerun-textarea {
  width: 100%;
  padding: 8px;
  border: 1px solid #d1d5db;
  border-radius: 6px;
  font-size: 13px;
  font-family: inherit;
  resize: vertical;
  margin-bottom: 8px;
}
.rerun-controls {
  display: flex;
  align-items: center;
  gap: 12px;
}
.rerun-gpu-input {
  width: 40px;
  padding: 4px 6px;
  border: 1px solid #d1d5db;
  border-radius: 4px;
  font-size: 13px;
  text-align: center;
}
.btn-blue {
  background: #2563eb;
  color: #fff;
  border: none;
  padding: 6px 16px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 13px;
}
.btn-blue:hover { background: #1d4ed8; }
.rerun-status { font-size: 12px; margin-top: 8px; padding: 6px 10px; border-radius: 4px; }
.rerun-success { background: #d1fae5; color: #065f46; }
.rerun-error { background: #fef2f2; color: #991b1b; }

/* ── Research Log ──────────────────────────────────────────────────────── */
.research-log-entry {
  background: var(--bg-primary);
  border: 0.5px solid var(--border);
  border-left-width: 3px;
  border-radius: var(--radius-md);
  padding: 12px 16px;
  margin-bottom: 8px;
}
.research-log-entry.log-success { border-left-color: var(--accent-green); }
.research-log-entry.log-failure { border-left-color: var(--accent-red); }

.log-entry-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}
.log-entry-title {
  font-size: 13px;
  font-weight: 500;
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.log-entry-id {
  font-size: 11px;
  font-family: var(--font-mono);
  color: var(--text-tertiary);
}
.log-entry-date {
  font-size: 11px;
  color: var(--text-tertiary);
}

.log-entry-body {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.log-entry-row {
  display: flex;
  gap: 6px;
  font-size: 12px;
  line-height: 1.4;
}
.log-entry-label {
  color: var(--text-secondary);
  font-weight: 500;
  flex-shrink: 0;
  min-width: 60px;
}
.log-entry-notes {
  margin-top: 6px;
}
.log-notes-edit {
  width: 100%;
  font-size: 12px;
  font-family: var(--font);
  padding: 6px 8px;
  border: 0.5px solid var(--border);
  border-radius: var(--radius-sm);
  resize: vertical;
  background: var(--bg-secondary);
  color: var(--text-primary);
}
.log-notes-edit:focus {
  outline: none;
  border-color: var(--accent-blue);
}
.log-entry-actions {
  display: flex;
  gap: 6px;
  margin-top: 8px;
}
.log-entry-actions .btn-green {
  background: var(--bg-success);
  color: var(--text-success);
  border-color: var(--accent-green);
}
.log-entry-actions .btn-red {
  background: var(--bg-danger);
  color: var(--text-danger);
  border-color: var(--accent-red);
}

/* ── Label controls in modal ───────────────────────────────────────────── */
.label-controls {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
}
.label-hint {
  font-size: 11px;
  color: var(--text-tertiary);
}
.label-current {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-secondary);
}
.label-date {
  font-size: 11px;
  color: var(--text-tertiary);
}

/* ── Markdown rendering ────────────────────────────────────────────────── */
.md-rendered {
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-primary);
  word-wrap: break-word;
}
.md-rendered p { margin-bottom: 8px; }
.md-rendered p:last-child { margin-bottom: 0; }
.md-h2 {
  font-size: 15px;
  font-weight: 600;
  color: var(--text-primary);
  margin: 16px 0 8px;
  padding-bottom: 4px;
  border-bottom: 0.5px solid var(--border);
}
.md-h3 {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  margin: 12px 0 6px;
}
.md-h4 {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary);
  margin: 10px 0 4px;
}
.md-li {
  padding-left: 16px;
  position: relative;
  margin-bottom: 3px;
}
.md-li::before {
  content: '•';
  position: absolute;
  left: 4px;
  color: var(--text-tertiary);
}
.md-li.md-ol::before {
  content: counter(md-ol) '.';
  counter-increment: md-ol;
}
.md-check {
  display: block;
  padding-left: 18px;
  position: relative;
  font-size: 12px;
  line-height: 1.4;
  margin-bottom: 2px;
}
.md-check::before {
  position: absolute;
  left: 0;
  font-size: 11px;
}
.md-check.checked::before { content: '✓'; color: var(--accent-green); }
.md-check.unchecked::before { content: '–'; color: var(--text-tertiary); }
.md-check.checked { color: var(--text-primary); }
.md-check.unchecked { color: var(--text-tertiary); }

/* Collapsible subsections */
.md-collapsible {
  margin: 6px 0;
  border: 0.5px solid var(--border);
  border-radius: var(--radius-sm);
  overflow: hidden;
}
.md-collapsible summary {
  cursor: pointer;
  padding: 6px 10px;
  background: var(--bg-secondary);
  user-select: none;
  margin: 0;
  list-style: none;
}
.md-collapsible summary::before {
  content: '▸ ';
  font-size: 10px;
  color: var(--text-tertiary);
}
.md-collapsible[open] summary::before { content: '▾ '; }
.md-collapsible > p,
.md-collapsible > div {
  padding: 6px 10px;
  font-size: 12px;
}
.md-section {
  margin-bottom: 10px;
}
.md-code {
  background: var(--bg-secondary);
  border: 0.5px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 8px 10px;
  font-size: 11px;
  font-family: var(--font-mono);
  line-height: 1.5;
  white-space: pre-wrap;
  word-break: break-word;
  margin: 6px 0;
  display: block;
  max-height: 200px;
  overflow-y: auto;
}
.md-inline-code {
  background: var(--bg-secondary);
  border: 0.5px solid var(--border);
  border-radius: 3px;
  padding: 1px 4px;
  font-size: 11px;
  font-family: var(--font-mono);
}

/* ── Review body in modal ──────────────────────────────────────────────── */
.review-verdict {
  margin-bottom: 10px;
}
.review-body {
  max-height: 400px;
  overflow-y: auto;
  border: 0.5px solid var(--border);
  border-radius: var(--radius-md);
  padding: 12px 14px;
  background: var(--bg-secondary);
}
.review-body .md-rendered {
  font-size: 12px;
}
