/* evot-eval styles */

/* Layout */
.layout { display: flex; height: 100vh; overflow: hidden; }

.sidebar {
  width: 180px; min-width: 180px;
  background: #111720; border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  padding: 16px 0;
}
.sidebar-logo {
  padding: 0 16px 20px; font-size: 14px; font-weight: 700; color: var(--accent);
  letter-spacing: -0.3px; display: flex; align-items: center; gap: 8px;
}
.sidebar-nav { display: flex; flex-direction: column; gap: 2px; flex: 1; }
.nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 16px; font-size: 13px; color: var(--muted);
  text-decoration: none; border-left: 3px solid transparent;
  transition: background 0.15s, color 0.15s;
}
.nav-item:hover { background: rgba(255,255,255,0.03); color: var(--fg); }
.nav-item.active {
  background: var(--accent-dim); color: #fff; font-weight: 500;
  border-left-color: var(--accent);
}
.nav-item svg { opacity: 0.7; flex-shrink: 0; }
.nav-item.active svg { opacity: 1; }

/* Collapsible nav group (Benchmarks), grouped with other nav items */
.nav-group { display: flex; flex-direction: column; }
.nav-group-toggle {
  width: 100%; background: none; border: none; cursor: pointer; font: inherit;
  border-left: 3px solid transparent;
}
.nav-group-label { flex: 1; text-align: left; }
.nav-caret { opacity: 0.6; transition: transform 0.15s; }
.nav-group.expanded .nav-caret { transform: rotate(90deg); }
.nav-group-items { display: none; flex-direction: column; }
.nav-group.expanded .nav-group-items { display: flex; }
.nav-item.nav-sub { padding-left: 42px; font-size: 12px; }

.main { flex: 1; overflow: hidden; display: flex; flex-direction: column; min-height: 0; }

/* Views */
.view { display: none; flex-direction: column; flex: 1; min-height: 0; overflow: hidden; }
.view.active { display: flex; }
.detail-body { flex: 1; min-height: 0; display: flex; flex-direction: column; overflow: hidden; }

/* New Run Bar */
.new-run-bar {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  padding: 12px 20px; border-bottom: 1px solid var(--border); background: rgba(0,0,0,0.2);
}
.new-run-bar select {
  background: var(--panel2); color: var(--fg); border: 1px solid var(--border);
  padding: 6px 10px; border-radius: 6px; font-size: 12px;
}
.agent-checks { display: flex; gap: 10px; }
.agent-checks label {
  color: var(--muted); font-size: 12px; display: flex; align-items: center; gap: 3px; cursor: pointer;
}
.run-status { color: var(--muted); font-size: 12px; }
.run-log {
  background: rgba(0,0,0,0.3); border-bottom: 1px solid var(--border);
  padding: 10px 20px; font-family: var(--mono); font-size: 11px; color: var(--muted);
  max-height: 200px; overflow-y: auto; white-space: pre-wrap;
}
.hidden { display: none !important; }

/* Runs List */
.runs-list { padding: 16px 20px; display: flex; flex-direction: column; gap: 12px; overflow-y: auto; flex: 1; min-height: 0; }
.run-card {
  background: var(--panel); border: 1px solid var(--border); border-radius: var(--card-radius);
  display: flex; align-items: stretch; transition: border-color 0.15s;
}
.run-card:hover { border-color: var(--accent-border); }
.run-card-body { flex: 1; padding: 16px 20px; cursor: pointer; }
.run-card-actions { display: flex; flex-direction: column; justify-content: center; gap: 6px; padding: 10px 14px; border-left: 1px solid var(--border); }
.btn-cancel { background: none; border: 1px solid var(--cache); color: var(--cache); border-radius: 6px; padding: 4px 10px; font-size: 11px; cursor: pointer; }
.btn-cancel:hover { background: var(--cache); color: #000; }
.btn-delete { background: none; border: 1px solid var(--del); color: var(--del); border-radius: 6px; padding: 4px 10px; font-size: 11px; cursor: pointer; }
.btn-delete:hover { background: var(--del); color: #fff; }
.btn-delete-confirm { background: var(--del); color: #fff; font-weight: 700; }
.run-card-header { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.run-card-id { color: var(--accent); font-size: 12px; font-weight: 600; }
.run-card-task { color: var(--fg); font-size: 13px; font-weight: 500; }
.run-card-evaluator { color: var(--muted); font-size: 12px; }
.run-card-agents { display: flex; gap: 10px; margin-top: 6px; font-size: 12px; }
.run-card-agents .pass { color: var(--accent); }
.run-card-agents .fail { color: var(--del); }
.run-card-agents .pending { color: var(--muted); }
.run-card-agents .running { color: var(--blue); }
.run-card-meta { color: var(--muted); font-size: 11px; margin-top: 6px; }

/* Page Header */
.page-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 24px; border-bottom: 1px solid var(--border);
}
.page-header h2 { margin: 0; font-size: 16px; color: var(--fg); }

/* Primary Button */
.primary-btn {
  background: var(--accent); color: #000; border: none; border-radius: 6px;
  padding: 7px 16px; font-size: 12px; font-weight: 600; cursor: pointer;
}
.primary-btn:hover { background: #6ee7b7; }

/* Detail Header */
.detail-header {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 24px; border-bottom: 1px solid var(--border); background: var(--panel);
}
.back-btn {
  color: var(--accent); text-decoration: none; font-size: 13px;
  padding: 4px 8px; border-radius: 6px;
}
.back-btn:hover { background: var(--panel2); }
.detail-title { color: var(--fg); font-size: 14px; font-weight: 500; font-family: var(--mono); }
.detail-verdict { font-size: 12px; }

/* Detail Tabs */
.detail-tabs {
  display: flex; gap: 0; padding: 0 24px;
  border-bottom: 1px solid var(--border); background: var(--panel);
}
.detail-tab {
  background: none; border: none; border-bottom: 2.5px solid transparent;
  color: var(--muted); padding: 11px 18px; font-size: 13px; cursor: pointer;
  transition: color 0.15s;
}
.detail-tab:hover { color: var(--fg); }
.detail-tab.active { color: #fff; border-bottom-color: var(--accent); }

/* Detail Content */
.detail-content { flex: 1; overflow-y: auto; padding: 24px; min-height: 0; }
.detail-content.no-scroll { overflow: hidden; display: flex; flex-direction: column; padding: 0; }
.tab-panel { flex: 1; min-height: 0; overflow-y: auto; padding: 0; }
.tab-panel.no-scroll { overflow: hidden; display: flex; flex-direction: column; }
#comparison-traces { display: flex; flex-direction: column; overflow: hidden; }

/* Summary Cards */
.summary-cards { display: flex; gap: 16px; flex-wrap: wrap; }
.agent-card {
  background: var(--panel); border: 1px solid var(--border); border-radius: var(--card-radius);
  padding: 20px; min-width: 200px; flex: 1;
}
.agent-card h3 { margin: 0 0 12px; font-size: 14px; color: var(--fg); font-weight: 600; }
.stat { display: flex; justify-content: space-between; padding: 7px 0; font-size: 13px; border-bottom: 1px solid rgba(255,255,255,0.04); }
.stat span:first-child { color: var(--muted); }
.stat .val { color: var(--fg); font-weight: 500; font-family: var(--mono); font-size: 12px; }
.pass { color: var(--accent); }
.fail { color: var(--del); }

/* Compare Chart */
/* Compare bar charts */
.compare-model-header { padding: 16px 24px 0; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.compare-model-label { font-size: 12px; color: var(--muted); text-transform: uppercase; letter-spacing: 1px; font-weight: 600; }
.compare-model-name { font-size: 18px; font-weight: 700; color: var(--fg); }
.compare-model-item { display: flex; align-items: center; gap: 6px; margin-right: 16px; font-size: 13px; color: var(--muted); }
.compare-bars { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; padding: 24px; }
.bar-chart-card { background: var(--panel); border: 1px solid var(--border); border-radius: var(--card-radius); padding: 24px 28px; }
.bar-chart-title { font-size: 11px; font-weight: 600; letter-spacing: 1.2px; color: var(--muted); text-transform: uppercase; margin-bottom: 18px; text-align: center; }
.bar-row { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.bar-label { font-size: 12px; color: var(--muted); min-width: 110px; text-align: right; font-weight: 500; display: flex; flex-direction: column; align-items: flex-end; gap: 2px; }
.bar-agent-name { font-size: 13px; font-weight: 600; color: var(--fg); }
.bar-agent-model { font-size: 10px; color: var(--muted); font-weight: 400; }
.legend-model { font-size: 11px; color: var(--muted); font-weight: 400; margin-left: 4px; }
.bar-track { flex: 1; height: 10px; background: var(--panel2); border-radius: 5px; overflow: hidden; }
.bar-fill { height: 100%; border-radius: 5px; transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1); }
.bar-fill.bar-segment { border-radius: 0; display: inline-block; float: left; }
.bar-fill.bar-segment:first-child { border-radius: 5px 0 0 5px; }
.bar-fill.bar-segment:last-child { border-radius: 0 5px 5px 0; }
.bar-fill.bar-segment:only-child { border-radius: 5px; }
.bar-value { font-size: 13px; font-weight: 600; color: var(--fg); min-width: 70px; font-family: var(--mono); }
.bar-diff { font-size: 12px; color: var(--muted); margin-top: 14px; text-align: center; }
.bar-diff strong { color: var(--accent); }
.bar-breakdown-detail { font-size: 11px; color: var(--muted); padding-left: 4px; }
.bar-stacked-legend { display: flex; justify-content: center; gap: 16px; margin-top: 14px; font-size: 11px; color: var(--muted); }
.bar-legend { display: flex; justify-content: center; gap: 20px; padding: 12px; font-size: 12px; color: var(--muted); }

/* Tool breakdown */
.tools-columns { display: grid; gap: 16px; }
.tools-col { background: var(--panel2); border-radius: 10px; padding: 16px 18px; }
.tools-col-header { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; color: var(--fg); margin-bottom: 12px; padding-bottom: 8px; border-bottom: 1px solid var(--border); white-space: nowrap; overflow: hidden; }
.tools-col-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.tools-col-count { margin-left: auto; font-size: 11px; font-weight: 400; color: var(--muted); }
.tools-item { margin-bottom: 8px; }
.tools-item-top { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 3px; }
.tools-item-name { font-size: 11px; font-family: var(--mono); color: var(--muted); display: flex; align-items: baseline; gap: 5px; }
.tools-item-calls { font-size: 10px; font-family: system-ui, sans-serif; color: var(--muted); background: var(--panel); border-radius: 3px; padding: 0 4px; }
.tools-item-val { font-size: 11px; font-weight: 500; color: var(--muted); }
.tools-item-track { height: 4px; background: var(--panel); border-radius: 2px; overflow: hidden; }
.tools-item-fill { height: 100%; border-radius: 2px; transition: width 0.4s ease; opacity: 0.85; }
.legend-item { display: flex; align-items: center; gap: 6px; }
.legend-dot { width: 10px; height: 10px; border-radius: 3px; display: inline-block; }

/* Traces */
.traces-header { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; flex-shrink: 0; }
.traces-header select { background: var(--panel2); color: var(--fg); border: 1px solid var(--border); padding: 5px 10px; border-radius: 6px; font-size: 12px; }
.traces-body { display: flex; flex: 1; gap: 0; border: 1px solid var(--border); border-radius: var(--card-radius); overflow: hidden; min-height: 0; }
.traces-list-col { display: flex; flex-direction: column; width: 260px; min-width: 260px; border-right: 1px solid var(--border); min-height: 0; }
.traces-list {
  flex: 1; overflow-y: auto; background: var(--panel);
}
.trace-item {
  padding: 12px 14px; border-bottom: 1px solid rgba(255,255,255,0.04); cursor: pointer; font-size: 12px;
  transition: background 0.15s;
}
.trace-item:hover { background: rgba(255,255,255,0.03); }
.trace-item.active { background: var(--accent-dim); border-left: 3px solid var(--accent); }
.trace-item-id { color: var(--accent); font-weight: 600; }
.trace-item-model { color: var(--fg); font-weight: 500; }
.trace-item-meta { color: var(--muted); font-size: 11px; margin-top: 3px; }
.trace-item-tokens { color: var(--muted); font-size: 10px; margin-top: 3px; font-family: var(--mono); font-variant-numeric: tabular-nums; }
.trace-item-tokens .badge { margin-left: 0; }
.badge.compact { background: var(--orange-dim); color: var(--orange); font-size: 9px; padding: 1px 5px; border-radius: 4px; margin-left: 6px; font-weight: 600; border: 1px solid rgba(251,146,60,0.3); }
.traces-detail { flex: 1; display: flex; flex-direction: column; overflow: hidden; }
.traces-detail-tabs {
  display: flex; gap: 0; padding: 0 14px; border-bottom: 1px solid var(--border); background: var(--panel2); flex-shrink: 0;
}
.traces-detail-tab {
  background: none; border: none; border-bottom: 2px solid transparent;
  color: var(--muted); padding: 9px 14px; font-size: 12px; cursor: pointer;
  transition: color 0.15s;
}
.traces-detail-tab:hover { color: var(--fg); }
.traces-detail-tab.active { color: #fff; border-bottom-color: var(--accent); }
.traces-detail-content { padding: 16px; font-size: 12px; color: var(--fg); overflow-y: auto; flex: 1; min-height: 0; }

/* Evaluators */
.models-list { padding: 16px 20px; display: flex; flex-direction: column; gap: 12px; overflow-y: auto; flex: 1; min-height: 0; }
.evaluator-card {
  background: var(--panel); border: 1px solid var(--border); border-radius: var(--card-radius); padding: 18px 20px;
}
.evaluator-card h3 { margin: 0 0 12px; font-size: 14px; color: var(--fg); font-weight: 600; }
.evaluator-field { display: flex; gap: 8px; font-size: 12px; padding: 5px 0; }
.evaluator-field .label { color: var(--muted); min-width: 70px; }
.evaluator-field .value { color: var(--fg); }
.evaluator-actions { margin-top: 12px; display: flex; gap: 8px; }
.evaluator-actions button {
  background: var(--panel2); border: 1px solid var(--border); color: var(--fg); padding: 5px 12px;
  border-radius: 6px; font-size: 11px; cursor: pointer; transition: border-color 0.15s;
}
.evaluator-actions button:hover { border-color: var(--accent); }
.evaluator-actions button.danger { color: var(--del); border-color: var(--del); }

/* Evaluator Form Page */
.evaluator-form-page { padding: 24px; max-width: 480px; }
.form-group { margin-bottom: 16px; }
.form-group label { display: block; font-size: 11px; color: var(--muted); margin-bottom: 5px; text-transform: uppercase; letter-spacing: 0.04em; }
.form-group input {
  width: 100%; padding: 9px 12px; background: var(--panel2); border: 1px solid var(--border);
  border-radius: 6px; color: var(--fg); font-size: 13px; outline: none; transition: border-color 0.15s;
}
.form-group input:focus { border-color: var(--accent); }
.btn-primary { background: var(--accent); color: #111; border: none; padding: 8px 16px; border-radius: 6px; font-size: 12px; cursor: pointer; font-weight: 600; }
.btn-primary:hover { background: #6ee7b7; }
.btn-secondary { background: var(--panel2); color: var(--fg); border: 1px solid var(--border); padding: 8px 16px; border-radius: 6px; font-size: 12px; cursor: pointer; }
.btn-secondary:hover { border-color: var(--accent); }

.empty { color: var(--muted); text-align: center; padding: 48px; font-size: 13px; }

/* ccglass-style blocks */
.block {
 background: var(--panel); border: 1px solid var(--border);
 border-radius: 10px; margin-bottom: 10px; overflow: hidden;
}
.block .h {
 display: flex; justify-content: space-between; align-items: center;
 padding: 8px 14px; background: rgba(255,255,255,0.02);
 font-family: var(--mono);
 font-size: 12px; color: var(--muted); border-bottom: 1px solid var(--border);
}
.block pre {
 margin: 0; padding: 12px 14px; white-space: pre-wrap; word-break: break-word;
 font-family: var(--mono);
 font-size: 12px; color: var(--fg); max-height: 400px; overflow: auto;
}
.tag {
 display: inline-block; font-size: 10px; padding: 2px 7px; border-radius: 10px;
 margin-left: 6px; font-weight: 600;
}
.tag.cache { background: var(--orange-dim); color: var(--orange); border: 1px solid rgba(251,146,60,0.3); }
.tag.tool { background: var(--accent-dim); color: var(--accent); border: 1px solid var(--accent-border); }
.tag.result { background: var(--blue-dim); color: var(--blue); border: 1px solid rgba(96,165,250,0.3); }
.tag.err { background: rgba(248,113,113,0.12); color: var(--del); border: 1px solid rgba(248,113,113,0.3); }
.tag.skill { background: var(--purple-dim); color: var(--purple); border: 1px solid rgba(167,139,250,0.3); }
.tag.latest { background: var(--accent-dim); color: var(--accent); border: 1px solid var(--accent-border); }
.tag.parallel { background: var(--accent-dim); color: var(--accent); border: 1px solid var(--accent-border); }
.tag.id { background: var(--panel2); color: var(--muted); font-family: var(--mono); border: 1px solid var(--border); }
.tag.tok { background: var(--panel2); color: var(--muted); font-size: 10px; font-variant-numeric: tabular-nums; border: 1px solid var(--border); }

/* fold / details */
.fold { border: none; background: none; }
.fold > summary { cursor: pointer; list-style: none; padding: 4px 0; }
.fold > summary::-webkit-details-marker { display: none; }
.fold > summary .more.hide { display: none; }
.fold[open] > summary .more.show { display: none; }
.fold[open] > summary .more.hide { display: inline; }
.fold > summary .more { color: var(--accent); font-size: 11px; }

/* replayed-history fold (messages tab): muted, de-emphasized */
.replayed-fold {
  margin: 6px 0;
  border-left: 2px dashed var(--border);
  padding-left: 10px;
  opacity: 0.75;
}
.replayed-fold > summary { padding: 4px 0; }
.replayed-fold > summary .more.show { color: var(--muted); font-style: italic; }
.replayed-fold > summary .more.hide { color: var(--muted); font-style: italic; }
.replayed-fold .replayed-body { margin-top: 6px; }
.replayed-fold .replayed-body .block { opacity: 0.9; }

/* ===== Span detail: one LLM round-trip (request envelope + response) =====
   Hierarchy is built from indentation + a left rule, not nested boxes. */
.span-detail { font-size: 12px; }

/* REQUEST / RESPONSE sections: a thin top rule + small-caps title, no big box */
.io { padding: 16px 0; margin-top: 0; border-top: 1px solid var(--border); }
.io:first-of-type { border-top: none; padding-top: 8px; }
.io-head { display: flex; align-items: baseline; gap: 10px; margin-bottom: 12px; }
.io-title { font-size: 12px; font-weight: 700; letter-spacing: 0.04em; }
.io-input .io-title { color: var(--blue); }
.io-execution .io-title { color: var(--orange); }
.io-output .io-title { color: var(--accent); }
.io-endpoint { font-family: var(--mono); font-size: 11px; color: var(--muted); }
.io-meta { margin-left: auto; font-size: 11px; color: var(--muted); font-variant-numeric: tabular-nums; font-family: var(--mono); }
.io-params { font-family: var(--mono); font-size: 11px; color: var(--muted); margin: 4px 0 8px; padding: 8px 12px; background: var(--panel2); border-radius: 8px; border: 1px solid var(--border); }

/* execution section */
.exec-flow { padding: 4px 0; }
.exec-parallel-group { border-left: 3px solid var(--orange); padding-left: 12px; margin: 4px 0; }
.exec-parallel-label { font-size: 11px; color: var(--orange); font-weight: 600; margin-bottom: 6px; letter-spacing: 0.04em; }
.exec-pair { margin: 8px 0; padding: 10px 14px; background: var(--panel); border: 1px solid var(--border); border-radius: 10px; }
.exec-tool-name { font-size: 12px; font-weight: 600; color: var(--fg); margin-bottom: 4px; display: flex; align-items: center; gap: 8px; }
.exec-input, .exec-output { display: flex; gap: 6px; margin: 4px 0; font-size: 12px; }
.exec-input { color: var(--muted); }
.exec-output { color: var(--fg); }
.exec-output.exec-error { color: var(--del); }
.exec-arrow { font-size: 10px; flex-shrink: 0; margin-top: 2px; }
.exec-input .exec-arrow { color: var(--blue); }
.exec-output .exec-arrow { color: var(--accent); }
.exec-output.exec-error .exec-arrow { color: var(--del); }
.exec-input pre, .exec-output pre { margin: 0; font-size: 11px; white-space: pre-wrap; word-break: break-all; }
.exec-input .fold, .exec-output .fold { font-size: 11px; }

/* system / tools folds in the request envelope */
.req-fold { margin: 2px 0; }
.req-fold > summary { font-size: 12px; color: var(--fg); }
.req-fold-meta { color: var(--muted); font-size: 11px; }
.req-fold-body { padding: 6px 0 6px 14px; border-left: 1px solid var(--border); margin: 6px 0 6px 4px; }

/* messages divider line */
.msg-divider { display: flex; align-items: center; gap: 10px; margin: 12px 0 8px; color: var(--muted); font-size: 11px; }
.msg-divider::before { content: ""; height: 1px; width: 14px; background: var(--border); }
.msg-divider::after { content: ""; flex: 1; height: 1px; background: var(--border); }
.md-label { letter-spacing: 0.05em; text-transform: uppercase; font-weight: 600; }
.md-count { font-variant-numeric: tabular-nums; }

/* a message: role header + a left rule grouping its content blocks */
.msg { margin: 0 0 12px; }
.msg-h { display: flex; align-items: baseline; gap: 8px; margin-bottom: 4px; }
.msg-role { font-size: 12px; font-weight: 600; text-transform: lowercase; }
.msg-user .msg-role { color: var(--purple); }
.msg-assistant .msg-role { color: var(--blue); }
.msg-n { font-size: 10px; color: var(--muted); font-variant-numeric: tabular-nums; }
.msg-idx { font-family: var(--mono); font-size: 10px; color: var(--muted); opacity: 0.7; }
.msg-new { font-size: 9px; font-weight: 700; letter-spacing: 0.06em; padding: 2px 7px; border-radius: 8px; background: var(--accent-dim); color: var(--accent); border: 1px solid var(--accent-border); }
.msg-body { padding-left: 12px; border-left: 2px solid var(--border); }
.msg-is-new > .msg-body { border-left-color: var(--accent); }
.msg-is-new > .msg-h .msg-role { color: var(--accent); }

/* a content block inside a message */
.cb { margin: 6px 0; }
.cb-h { display: flex; align-items: baseline; gap: 6px; margin-bottom: 2px; font-family: var(--mono); font-size: 11px; }
.cb-pos { color: var(--muted); font-size: 10px; }
.cb-label { color: var(--fg); font-weight: 600; }
.cb-thinking .cb-label { color: var(--muted); }
.cb-tool .cb-label { color: var(--accent); }
.cb-result .cb-label { color: var(--blue); }
.cb-err .cb-label { color: var(--del); }
.cb-meta { margin-left: auto; display: flex; align-items: center; gap: 6px; }
.cb-cache { font-size: 9px; font-weight: 700; padding: 2px 6px; border-radius: 8px; background: var(--orange-dim); color: var(--orange); border: 1px solid rgba(251,146,60,0.3); }
.cb-id { font-size: 9px; font-family: var(--mono); padding: 2px 6px; border-radius: 8px; background: var(--panel2); color: var(--muted); border: 1px solid var(--border); }
.cb-tok { font-size: 10px; color: var(--muted); font-variant-numeric: tabular-nums; }
/* light, low-weight body so it doesn't compete with the message rule */
.cb pre { margin: 0; padding: 6px 10px; white-space: pre-wrap; word-break: break-word; font-family: var(--mono); font-size: 11.5px; line-height: 1.5; color: var(--fg); background: var(--panel2); border-left: 2px solid var(--border); border-radius: 0 6px 6px 0; max-height: 320px; overflow: auto; }
.cb-thinking pre { color: var(--muted); font-style: italic; background: none; border-left-color: transparent; padding-left: 0; }

/* carried-over collapse + new-this-request boundary */
.carried-fold { margin-bottom: 6px; }
.carried-fold > summary { font-size: 11px; color: var(--muted); }
.carried-body { padding-left: 10px; border-left: 1px dashed var(--border); margin-top: 6px; opacity: 0.72; }
.new-boundary { display: flex; align-items: center; gap: 10px; margin: 14px 0; font-size: 10px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--accent); }
.new-boundary::before, .new-boundary::after { content: ""; height: 2px; background: var(--accent); opacity: 0.3; }
.new-boundary::before { width: 14px; }
.new-boundary::after { flex: 1; }

.span-detail .muted { color: var(--muted); }

/* ---- Duration bar (Pier-style proportional timeline) ---- */
.duration-bar { display: flex; height: 22px; margin-bottom: 14px; border-radius: 6px; overflow: hidden; gap: 1px; --bar-c1: #4a5568; --bar-c2: #5a6a7a; --bar-c3: #6b7b8c; --bar-c4: #7c8c9e; }
.duration-seg { position: relative; cursor: pointer; transition: opacity 0.15s; min-width: 2px; }
.duration-seg:hover { opacity: 0.8; }
.duration-seg-active { box-shadow: inset 0 0 0 2px var(--accent); }
.dur-tip { position: absolute; bottom: 100%; left: 50%; transform: translateX(-50%); margin-bottom: 6px; white-space: nowrap; padding: 4px 10px; background: var(--panel); border: 1px solid var(--border); border-radius: 6px; font-size: 11px; color: var(--fg); pointer-events: none; z-index: 10; }
.dur-tip b { color: var(--accent); }
[data-theme="light"] .duration-bar { --bar-c1: #94a3b8; --bar-c2: #78909c; --bar-c3: #607d8b; --bar-c4: #546e7a; }

/* ---- Gutter metadata column (Pier-style) ---- */


/* ---- Tool call collapsed rows ---- */
.tc-row { margin: 6px 0; border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
.tc-row.tc-open { border-color: var(--accent-border); }
.tc-head { display: flex; align-items: center; gap: 6px; width: 100%; padding: 8px 12px; background: var(--panel); border: none; cursor: pointer; font-size: 12px; color: var(--fg); text-align: left; transition: background 0.1s; }
.tc-head:hover { background: rgba(255,255,255,0.03); }
.tc-icon { font-size: 13px; flex-shrink: 0; }
.tc-prefix { font-weight: 600; white-space: nowrap; }
.tc-code { font-family: var(--mono); font-size: 11px; background: var(--panel2); padding: 2px 6px; border-radius: 4px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 400px; display: inline-block; vertical-align: middle; }
.tc-err { font-size: 10px; font-weight: 700; text-transform: uppercase; color: var(--del); }
.tc-chevron { margin-left: auto; font-size: 10px; color: var(--muted); transition: transform 0.15s; }
.tc-desc-hint { font-size: 11px; color: var(--muted); font-style: italic; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 300px; display: inline-block; vertical-align: middle; }
.tc-row-def .tc-head { gap: 8px; }
.tc-detail { padding: 10px 14px; border-top: 1px solid var(--border); background: rgba(255,255,255,0.015); }
.tc-section { margin: 6px 0; }
.tc-section-label { font-family: var(--mono); font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: var(--muted); margin-bottom: 4px; display: flex; align-items: center; gap: 6px; }

/* ---- Capped content block (max-height + scroll + expand) ---- */
.capped-block { position: relative; }
.capped-block pre { max-height: 280px; overflow: auto; margin: 0; padding: 6px 10px; white-space: pre-wrap; word-break: break-word; font-family: var(--mono); font-size: 11.5px; line-height: 1.5; color: var(--fg); background: var(--panel2); border-left: 2px solid var(--border); border-radius: 0 6px 6px 0; }
.capped-block.capped-open pre { max-height: none; }
.capped-toggle { display: block; margin-top: 3px; padding: 2px 8px; font-size: 10px; font-family: var(--mono); color: var(--accent); background: none; border: none; cursor: pointer; opacity: 0.8; }
.capped-toggle:hover { opacity: 1; text-decoration: underline; }
[data-theme="light"] .capped-block pre { color: #1f2328; }

/* raw json tab */
.raw-json { margin: 8px 0 0; padding: 14px 16px; white-space: pre; overflow: auto; max-height: calc(100vh - 220px); font-family: var(--mono); font-size: 11.5px; line-height: 1.5; color: var(--fg); background: var(--panel2); border: 1px solid var(--border); border-radius: 10px; }
[data-theme="light"] .raw-json { color: #1f2328; background: rgba(0,0,0,0.04); }

/* request diff (diff mode) */
.diff-loading, .diff-hint { padding: 16px; color: var(--muted); font-size: 12px; }
.diff-view { margin-top: 8px; border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
.diff-head { display: flex; align-items: center; gap: 12px; padding: 8px 14px; background: var(--panel2); border-bottom: 1px solid var(--border); font-size: 11px; font-family: var(--mono); }
.diff-side { font-weight: 600; }
.diff-head .diff-del { color: var(--del); }
.diff-head .diff-add { color: var(--accent); }
.diff-stat { margin-left: auto; color: var(--muted); }
.diff-body { margin: 0; padding: 0; max-height: calc(100vh - 260px); overflow: auto; font-family: var(--mono); font-size: 11.5px; line-height: 1.5; }
.diff-line { display: flex; white-space: pre; }
.diff-gutter { flex: 0 0 22px; text-align: center; color: var(--muted); user-select: none; }
.diff-text { flex: 1; padding-right: 12px; }
.diff-line.diff-add { background: rgba(74,222,128,0.1); }
.diff-line.diff-add .diff-gutter { color: var(--accent); }
.diff-line.diff-del { background: rgba(248,113,113,0.1); }
.diff-line.diff-del .diff-gutter { color: var(--del); }
.diff-line.diff-ctx { color: var(--muted); }
.diff-body-pane { padding: 12px 14px; max-height: calc(100vh - 260px); overflow: auto; }

/* overview metric comparison */
.diff-metrics { width: 100%; border-collapse: collapse; font-size: 12px; }
.diff-metrics td { padding: 6px 10px; border-bottom: 1px solid var(--border); font-variant-numeric: tabular-nums; }
.diff-metrics tr:last-child td { border-bottom: none; }
.dm-label { color: var(--muted); width: 30%; }
.dm-a { color: var(--del); }
.dm-b { color: var(--accent); }
.diff-metrics tr:not(.changed) .dm-a, .diff-metrics tr:not(.changed) .dm-b { color: var(--fg); opacity: 0.6; }

/* message content-block set diff */
.msg-diff-counts { display: flex; gap: 14px; margin-bottom: 12px; font-size: 11px; font-family: var(--mono); }
.mdc-add { color: var(--accent); }
.mdc-del { color: var(--del); }
.mdc-common { color: var(--muted); }
.msg-diff-section { margin-bottom: 16px; }
.msg-diff-title { font-size: 11px; font-weight: 700; letter-spacing: 0.04em; padding: 4px 0; margin-bottom: 6px; border-bottom: 1px solid var(--border); }
.msg-diff-add { color: var(--accent); }
.msg-diff-del { color: var(--del); }
.msg-diff-block { padding: 4px 0 4px 10px; margin: 6px 0; border-left: 2px solid var(--border); }
.msg-diff-block.diff-add { border-left-color: var(--accent); background: rgba(74,222,128,0.05); }
.msg-diff-block.diff-del { border-left-color: var(--del); background: rgba(248,113,113,0.05); }
.msg-diff-blabel { display: flex; gap: 8px; align-items: baseline; margin-bottom: 2px; font-family: var(--mono); font-size: 10px; }
.mdb-idx { color: var(--muted); }
.mdb-role { font-weight: 600; }
.mdb-role.msg-user { color: var(--purple); }
.mdb-role.msg-assistant { color: var(--blue); }

/* diff mode: toggle button + list column + picked rows */
.traces-list-tools { padding: 8px 10px; border-bottom: 1px solid var(--border); background: var(--panel2); }
.diff-toggle { font-size: 11px; padding: 4px 12px; border-radius: 6px; border: 1px solid var(--border); background: transparent; color: var(--muted); cursor: pointer; transition: all 0.15s; }
.diff-toggle:hover { color: var(--fg); border-color: var(--fg); }
.diff-toggle.on { background: var(--accent); border-color: var(--accent); color: #0e1116; font-weight: 600; }
.trace-item.diff-pick { box-shadow: inset 3px 0 0 var(--accent); background: var(--accent-dim); }

[data-theme="light"] .cb pre { color: #1f2328; background: rgba(0,0,0,0.04); }
[data-theme="light"] .cb-thinking pre { color: #57606a; background: none; }
[data-theme="light"] .replayed-fold > summary .more.show,
[data-theme="light"] .replayed-fold > summary .more.hide { color: #656d76; }

/* replay tab */
.replay-panel { display: flex; flex-direction: column; gap: 12px; }
.replay-section-title { font-size: 11px; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); margin-bottom: 6px; }

/* Span Details list (per-row replay) */
#replay-span-list { display: flex; flex-direction: column; gap: 6px; }
.replay-span-row { border: 1px solid var(--border); border-radius: 6px; padding: 8px 10px; }
.replay-span-row.replay-span-active { border-color: var(--accent); }
.replay-row-head { display: flex; align-items: center; gap: 10px; }
.replay-row-seq { font-family: var(--mono); color: var(--muted); font-size: 12px; min-width: 34px; }
.replay-row-tools { flex: 1; display: flex; flex-wrap: wrap; gap: 4px; min-width: 0; align-items: center; }
.replay-tools-label { font-size: 11px; color: var(--muted); margin-right: 4px; white-space: nowrap; }
.replay-tool-chip { background: var(--accent-dim); color: var(--accent); border-radius: 6px; padding: 2px 8px; font-size: 11px; font-weight: 600; display: inline-flex; gap: 5px; align-items: center; border: 1px solid var(--accent-border); }
.replay-tool-target { color: var(--muted); font-weight: 400; font-family: var(--mono); }
.replay-row-meta { font-size: 11px; color: var(--muted); white-space: nowrap; }
.replay-row-btn { background: var(--accent); color: #0e1116; border: none; border-radius: 6px; padding: 4px 14px; cursor: pointer; font-weight: 600; font-size: 12px; }
.replay-row-btn:disabled { opacity: 0.35; cursor: not-allowed; }
.replay-row-react { font-size: 11px; color: var(--muted); margin-top: 5px; font-family: var(--mono); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.replay-hist { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 6px; }
.replay-hist-item { font-size: 11px; border-radius: 4px; padding: 2px 8px; cursor: pointer; border: 1px solid var(--border); background: rgba(255,255,255,0.03); color: var(--fg); font-family: var(--mono); }
.replay-hist-item:hover { border-color: var(--accent); }
.replay-hist-ok { color: var(--accent); }
.replay-hist-warn { color: var(--orange); }
[data-theme="light"] .replay-hist-item { background: #f6f8fa; }
.replay-react-role { color: #8b5cf6; }
.replay-row-result:not(:empty) { margin-top: 8px; }
.replay-progress { display: flex; align-items: center; gap: 8px; color: var(--muted); font-style: italic; font-size: 12px; padding: 4px 0; }
.replay-spinner { width: 12px; height: 12px; border: 2px solid var(--border); border-top-color: var(--accent); border-radius: 50%; animation: replay-spin 0.7s linear infinite; }
@keyframes replay-spin { to { transform: rotate(360deg); } }

.replay-controls { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; padding: 12px; background: rgba(255,255,255,0.02); border: 1px solid var(--border); border-radius: 10px; }
.replay-controls label { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; color: var(--muted); }
.replay-controls select { background: var(--panel2); color: var(--fg); border: 1px solid var(--border); border-radius: 6px; padding: 3px 8px; }
.replay-hint { font-size: 11px; color: var(--muted); flex: 1 1 100%; }
.replay-loading { color: var(--muted); padding: 10px; font-style: italic; }
.replay-err { color: var(--del); padding: 8px; }
.replay-verdict { padding: 6px 10px; border-radius: 8px; font-weight: 600; font-size: 12px; margin-bottom: 6px; }
.replay-verdict.replay-ok { background: var(--accent-dim); color: var(--accent); border: 1px solid var(--accent-border); }
.replay-verdict.replay-warn { background: var(--orange-dim); border: 1px solid rgba(251,146,60,0.4); color: var(--orange); }
.replay-cols { display: grid; grid-auto-flow: column; grid-auto-columns: minmax(160px, 1fr); gap: 8px; overflow-x: auto; }
.replay-col { border: 1px solid var(--border); border-radius: 6px; padding: 8px; font-size: 12px; line-height: 1.6; }
.replay-col-h { font-size: 11px; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); margin-bottom: 6px; padding-bottom: 4px; border-bottom: 1px solid var(--border); }
.replay-col-orig { color: var(--blue); }
.replay-col.replay-match { border-color: var(--accent-border); }
.replay-col.replay-diff { border-color: rgba(251,146,60,0.5); }
.replay-col code { background: rgba(255,255,255,0.06); padding: 1px 4px; border-radius: 3px; font-size: 11px; word-break: break-all; }
.replay-empty, .replay-text { color: var(--muted); font-style: italic; }
[data-theme="light"] .replay-controls select { background: #fff; color: #1f2328; }
[data-theme="light"] .replay-col code { background: #f0f0f0; }

/* cards (overview) */
.cards { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 14px; }
.cards .card {
 background: var(--panel); border: 1px solid var(--border); border-radius: var(--card-radius);
 padding: 10px 14px; min-width: 100px;
}
.cards .card .k { font-size: 10px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.04em; }
.cards .card .v { font-size: 14px; color: var(--fg); font-weight: 500; margin-top: 3px; font-family: var(--mono); }
.cards .card .v small { font-size: 10px; color: var(--muted); font-weight: 400; }

/* flow timeline */
.flow .timeline { padding: 8px 0; }
.step { position: relative; display: flex; gap: 10px; padding: 5px 0 5px 26px; }
.step.indent { padding-left: 50px; }
.step .dot {
 position: absolute; left: 0; top: 5px; width: 18px; text-align: center;
 font-size: 12px; color: var(--accent);
}
.step.indent .dot { left: 24px; }
.step.user .dot { color: var(--cache); }
.step.stop .dot { color: var(--muted); }
.step .node { flex: 1; min-width: 0; }
.step .lead { font-family: var(--mono); font-size: 12.5px; }
.step .lead b { color: var(--accent); }
.step .prev { color: var(--muted); font-size: 12px; font-family: var(--mono); }
.step.tool_use, .step.skill, .step.tool_result {
 border-left: 2px solid hsl(var(--hue, 210) 60% 48%);
 background: hsl(var(--hue, 210) 60% 48% / 0.07);
 border-radius: 0 6px 6px 0; margin-left: -2px;
}
.step.tool_use .dot, .step.skill .dot { color: hsl(var(--hue, 210) 70% 66%); }
.step .step-body { background: none; border: none; margin: 2px 0 0; }
.step .step-body > summary { padding: 0; }
.step .step-body > pre {
 margin: 4px 0 0; padding: 8px 12px; background: var(--panel2);
 border-radius: 8px; max-height: 320px; overflow: auto;
 white-space: pre-wrap; word-break: break-word;
 font-family: var(--mono); font-size: 12px;
}
.toolmenu { margin-bottom: 12px; }

/* Diff mode */
.diff-btn { margin-left: 12px; padding: 4px 12px; border-radius: 6px; border: 1px solid var(--border); background: var(--panel2); color: var(--muted); cursor: pointer; font-size: 12px; }
.diff-btn.on { background: var(--accent); border-color: var(--accent); color: #0e1116; font-weight: 600; }
.trace-item.diff-pick { border-left: 3px solid var(--accent); background: var(--accent-dim); }
.diff-title { font-size: 13px; font-weight: 600; color: var(--muted); padding: 8px 0; }
.diff-stats { font-size: 12px; color: var(--muted); padding: 8px 12px; border-bottom: 1px solid var(--border); margin-bottom: 12px; }
.diff-section { font-size: 12px; font-weight: 600; padding: 6px 12px; margin: 8px 0 4px; }
.diff-section.add { color: var(--accent); }
.diff-section.del { color: var(--del); }
.diff-empty { font-size: 12px; color: var(--muted); padding: 4px 12px; margin: 0; }
.diff-add { border-left: 3px solid var(--accent); margin: 4px 12px; padding: 4px 8px; background: rgba(74,222,128,0.05); border-radius: 6px; }
.diff-del { border-left: 3px solid var(--del); margin: 4px 12px; padding: 4px 8px; background: rgba(248,113,113,0.05); border-radius: 6px; }
.diff-block-header { font-size: 11px; color: var(--muted); margin-bottom: 4px; display: flex; gap: 8px; align-items: center; }
.diff-tag { background: var(--panel2); padding: 2px 7px; border-radius: 4px; font-size: 10px; color: var(--muted); border: 1px solid var(--border); }
.diff-pre { font-size: 11px; color: var(--fg); margin: 0; white-space: pre-wrap; word-break: break-word; max-height: 200px; overflow: auto; }

/* Log tab */
.log-container { padding: 16px; flex: 1; min-height: 0; display: flex; flex-direction: column; overflow: hidden; }
.log-output { flex: 1; min-height: 0; background: var(--bg); border: 1px solid var(--border); border-radius: 10px; padding: 16px; font-size: 12px; font-family: var(--mono); color: var(--fg); overflow-y: auto; white-space: pre-wrap; word-break: break-word; margin: 0; }
.log-status { display: flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 600; padding: 8px 14px; margin-bottom: 10px; border-radius: 8px; border: 1px solid var(--border); background: var(--panel); }
.log-status-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--muted); flex-shrink: 0; }
.log-status-connecting { color: var(--muted); }
.log-status-running { color: var(--blue); border-color: rgba(96,165,250,0.3); }
.log-status-running .log-status-dot { background: var(--blue); animation: pulse-dot 1.2s ease-in-out infinite; }
.log-status-done { color: var(--accent); border-color: var(--accent-border); }
.log-status-done .log-status-dot { background: var(--accent); }
.log-status-error { color: var(--del); border-color: rgba(248,113,113,0.3); }
.log-status-error .log-status-dot { background: var(--del); }
.log-line { padding: 2px 0; line-height: 1.6; border-bottom: 1px solid rgba(255,255,255,0.03); }
.log-line:last-child { border-bottom: none; }
.log-header { color: var(--blue); font-weight: 600; }
.log-agent { color: var(--purple); font-weight: 500; }
.log-start { color: var(--muted); }
.log-request { color: var(--blue); }
.log-pass { color: var(--accent); font-weight: 600; }
.log-fail { color: var(--del); font-weight: 600; }
.log-text { color: var(--fg); }

/* Running state */
.run-status-badge { color: var(--blue); font-size: 11px; margin-left: 8px; animation: pulse 1.5s infinite; }
.elapsed { color: var(--blue); font-weight: 600; font-variant-numeric: tabular-nums; }
.run-card.running { border-left: 3px solid var(--blue); }
.run-card-agents .running { color: var(--blue); }
.detail-verdict.running { color: var(--blue); }
.detail-verdict .elapsed-time { animation: none; opacity: 1; }
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.5; } }

/* Span time badge */
.span-time-badge { padding: 8px 14px; margin-bottom: 14px; background: var(--panel2); border: 1px solid var(--border); border-radius: 8px; font-size: 12px; color: var(--fg); font-variant-numeric: tabular-nums; font-family: var(--mono); }

/* Refresh indicator dot */
.refresh-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: var(--blue); margin-left: 8px; animation: pulse-dot 1.2s ease-in-out infinite; vertical-align: middle; }
@keyframes pulse-dot { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.4; transform: scale(0.7); } }

/* Share button & popup */
.share-btn { margin-left: 8px; padding: 5px 12px; border-radius: 6px; border: 1px solid var(--border); background: var(--panel2); color: var(--muted); cursor: pointer; font-size: 12px; transition: all 0.15s; }
.share-btn:hover { background: var(--accent-dim); border-color: var(--accent-border); color: var(--accent); }
.share-popup { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.6); display: flex; align-items: center; justify-content: center; z-index: 1000; }
.share-popup-inner { background: var(--panel); border: 1px solid var(--border); border-radius: 14px; padding: 24px; min-width: 500px; max-width: 700px; }
.share-popup-inner h4 { margin: 0 0 16px; color: var(--fg); font-size: 14px; }
.share-link-row { display: flex; gap: 8px; margin-bottom: 10px; }
.share-link-row input { flex: 1; background: var(--panel2); border: 1px solid var(--border); border-radius: 6px; padding: 8px 12px; color: var(--fg); font-size: 12px; font-family: var(--mono); }
.share-link-row button { padding: 8px 14px; border-radius: 6px; border: 1px solid var(--border); background: var(--panel2); color: var(--fg); cursor: pointer; font-size: 12px; white-space: nowrap; }
.share-link-row button:hover { border-color: var(--accent); color: var(--accent); }
.share-close { margin-top: 12px; padding: 8px 20px; border-radius: 6px; border: 1px solid var(--border); background: var(--panel2); color: var(--fg); cursor: pointer; font-size: 12px; }
.share-close:hover { border-color: var(--accent); color: var(--accent); }

/* Tasks */
.tasks-list { display: flex; flex-direction: column; gap: 10px; padding: 16px 0; overflow-y: auto; flex: 1; min-height: 0; }
.task-card { background: var(--panel); border: 1px solid var(--border); border-radius: var(--card-radius); padding: 16px 20px; }
.task-card-header { display: flex; align-items: center; justify-content: space-between; }
.task-name { font-size: 14px; color: var(--fg); font-weight: 500; }
.task-actions { display: flex; gap: 8px; }
.btn-sm { padding: 5px 12px; border-radius: 6px; border: 1px solid var(--border); background: var(--panel2); color: var(--fg); cursor: pointer; font-size: 12px; text-decoration: none; transition: border-color 0.15s; }
.btn-sm:hover { border-color: var(--accent); color: var(--accent); }
.btn-danger { border-color: rgba(248,113,113,0.4); color: var(--del); }
.btn-danger:hover { background: rgba(248,113,113,0.08); color: var(--del); }
.task-form-page { padding: 24px; max-width: 700px; }
.form-group { margin-bottom: 16px; }
.form-group label { display: block; font-size: 12px; color: var(--muted); margin-bottom: 6px; }
.form-group input, .form-group textarea { width: 100%; background: var(--panel2); border: 1px solid var(--border); border-radius: 6px; padding: 10px 12px; color: var(--fg); font-size: 13px; font-family: var(--mono); box-sizing: border-box; transition: border-color 0.15s; }
.form-group input:disabled { opacity: 0.6; }
.form-group textarea { resize: vertical; line-height: 1.5; }
.form-actions { display: flex; gap: 12px; align-items: center; }
.empty-state { color: var(--muted); font-size: 13px; padding: 40px 0; text-align: center; }

/* YAML validation */
.yaml-status { font-size: 11px; margin-left: 8px; font-weight: 500; }
.yaml-ok { color: var(--accent); }
.yaml-err { color: var(--del); }
.yaml-error { font-size: 12px; color: var(--del); margin-top: 6px; font-family: var(--mono); background: rgba(248,113,113,0.06); border: 1px solid rgba(248,113,113,0.3); border-radius: 6px; padding: 8px 10px; display: none; }
.yaml-error:not(:empty) { display: block; }
.form-group textarea.input-error { border-color: var(--del); }
.form-group textarea.input-valid { border-color: var(--accent); }

/* ---- Light theme overrides ---- */
[data-theme="light"] .new-run-bar { background: #f0f2f5; border-color: var(--border); }
[data-theme="light"] .new-run-bar select { background: #fff; color: #333; border-color: #d0d7de; }
[data-theme="light"] .agent-checks label { color: #444; }
[data-theme="light"] .run-status { color: #666; }
[data-theme="light"] .run-log { background: #fff; border-color: var(--border); color: #444; }
[data-theme="light"] .run-card { background: #fff; border-color: #d0d7de; }
[data-theme="light"] .run-card:hover { border-color: #0969da; }
[data-theme="light"] .run-card-id { color: var(--accent); }
[data-theme="light"] .run-card-task { color: #1f2328; }
[data-theme="light"] .run-card-evaluator { color: #656d76; }
[data-theme="light"] .run-card-meta { color: #656d76; }
[data-theme="light"] .page-header { border-color: var(--border); }
[data-theme="light"] .page-header h2 { color: #1f2328; }
[data-theme="light"] .detail-header { border-color: var(--border); }
[data-theme="light"] .back-btn { color: var(--accent); }
[data-theme="light"] .back-btn:hover { background: #f0f2f5; }
[data-theme="light"] .detail-title { color: #1f2328; }
[data-theme="light"] .detail-tabs { border-color: var(--border); background: #f6f8fa; }
[data-theme="light"] .detail-tab { color: #656d76; }
[data-theme="light"] .detail-tab:hover { color: #1f2328; }
[data-theme="light"] .detail-tab.active { color: #1f2328; border-bottom-color: var(--accent); }
[data-theme="light"] .agent-card { background: #fff; border-color: #d0d7de; }
[data-theme="light"] .agent-card h3 { color: #1f2328; }
[data-theme="light"] .stat { border-color: #eee; }
[data-theme="light"] .stat span:first-child { color: #656d76; }
[data-theme="light"] .stat .val { color: #1f2328; }
[data-theme="light"] .bar-chart-card { background: #fff; border-color: #d0d7de; }
[data-theme="light"] .bar-chart-title { color: #444; }
[data-theme="light"] .bar-label { color: #333; }
[data-theme="light"] .bar-agent-name { color: #1f2328; }
[data-theme="light"] .bar-agent-model { color: #656d76; }
[data-theme="light"] .legend-model { color: #656d76; }
[data-theme="light"] .bar-track { background: #eaecef; }
[data-theme="light"] .bar-value { color: #1f2328; }
[data-theme="light"] .bar-diff { color: #555; }
[data-theme="light"] .bar-legend { color: #555; }
[data-theme="light"] .traces-header select { background: #fff; color: #333; border-color: #d0d7de; }
[data-theme="light"] .traces-body { border-color: #d0d7de; }
[data-theme="light"] .traces-list-col { border-color: #d0d7de; }
[data-theme="light"] .traces-list { background: #f6f8fa; }
[data-theme="light"] .traces-list-tools { background: #f6f8fa; }
[data-theme="light"] .trace-item { border-color: #eee; }
[data-theme="light"] .trace-item:hover { background: #eef2f7; }
[data-theme="light"] .trace-item.active { background: #e8f0fe; border-left-color: var(--accent); }
[data-theme="light"] .trace-item-id { color: var(--accent); }
[data-theme="light"] .trace-item-model { color: #333; }
[data-theme="light"] .trace-item-meta { color: #656d76; }
[data-theme="light"] .trace-item-tokens { color: #656d76; }
[data-theme="light"] .badge.compact { background: #fff3cd; color: #856404; }
[data-theme="light"] .traces-detail-tabs { border-color: var(--border); background: #f6f8fa; }
[data-theme="light"] .traces-detail-tab { color: #656d76; }
[data-theme="light"] .traces-detail-tab:hover { color: #1f2328; }
[data-theme="light"] .traces-detail-tab.active { color: #1f2328; border-bottom-color: var(--accent); }
[data-theme="light"] .traces-detail-content { color: #333; }
[data-theme="light"] .evaluator-card { background: #fff; border-color: #d0d7de; }
[data-theme="light"] .evaluator-card h3 { color: #1f2328; }
[data-theme="light"] .evaluator-field .label { color: #656d76; }
[data-theme="light"] .evaluator-field .value { color: #333; }
[data-theme="light"] .evaluator-actions button { background: #f6f8fa; border-color: #d0d7de; color: #333; }
[data-theme="light"] .evaluator-actions button:hover { background: #eee; }
[data-theme="light"] .form-group input { background: #fff; border-color: #d0d7de; color: #1f2328; }
[data-theme="light"] .form-group input:focus { border-color: var(--accent); }
[data-theme="light"] .form-group label { color: #656d76; }
[data-theme="light"] .empty { color: #888; }
[data-theme="light"] .block { background: #fff; border-color: #d0d7de; }
[data-theme="light"] .block .h { background: #f6f8fa; color: #656d76; border-color: #eee; }
[data-theme="light"] .block pre { color: #1f2328; }
[data-theme="light"] .cards .card { background: #fff; border-color: #d0d7de; }
[data-theme="light"] .cards .card .k { color: #656d76; }
[data-theme="light"] .cards .card .v { color: #1f2328; }
[data-theme="light"] .step .dot { color: var(--accent); }
[data-theme="light"] .step .lead b { color: var(--accent); }
[data-theme="light"] .step .step-body > pre { background: #f6f8fa; color: #1f2328; }
[data-theme="light"] .fold > summary .more { color: var(--accent); }
[data-theme="light"] .diff-btn { background: #f6f8fa; border-color: #d0d7de; color: #333; }
[data-theme="light"] .diff-stats { color: #656d76; border-color: var(--border); }
[data-theme="light"] .diff-pre { color: #1f2328; }
[data-theme="light"] .log-output { background: #fff; border-color: #d0d7de; color: #1f2328; }
[data-theme="light"] .share-btn { background: #f6f8fa; border-color: #d0d7de; color: #333; }
[data-theme="light"] .share-btn:hover { border-color: var(--accent); color: var(--accent); }
[data-theme="light"] .share-popup-inner { background: #fff; border-color: #d0d7de; }
[data-theme="light"] .share-popup-inner h4 { color: #1f2328; }
[data-theme="light"] .share-link-row input { background: #f6f8fa; border-color: #d0d7de; color: #1f2328; }
[data-theme="light"] .share-link-row button { background: #f6f8fa; border-color: #d0d7de; color: #333; }
[data-theme="light"] .share-link-row button:hover { background: #eee; color: #000; }
[data-theme="light"] .share-close { background: #f6f8fa; border-color: #d0d7de; color: #333; }
[data-theme="light"] .task-card { background: #fff; border-color: #d0d7de; }
[data-theme="light"] .task-name { color: #1f2328; }
[data-theme="light"] .btn-sm { background: #f6f8fa; border-color: #d0d7de; color: #333; }
[data-theme="light"] .btn-sm:hover { background: #eee; color: #000; }
[data-theme="light"] .form-group textarea { background: #fff; border-color: #d0d7de; color: #1f2328; }
[data-theme="light"] .yaml-error { background: #fff0f0; border-color: #ffc0c0; }
[data-theme="light"] .empty-state { color: #888; }
[data-theme="light"] .tag.id { background: #eef2f7; color: #656d76; }
[data-theme="light"] .tag.tok { background: #f0f0f0; color: #666; }

/* ---- Span Compare ---- */
.span-compare { padding: 16px 0; }
.sc-section { margin-bottom: 32px; }
.sc-collapsible { cursor: pointer; }
.sc-collapsible > summary { list-style: none; }
.sc-collapsible > summary::-webkit-details-marker { display: none; }
.sc-collapsible > summary::before { content: '▶'; display: inline-block; margin-right: 8px; font-size: 10px; transition: transform 0.2s; }
.sc-collapsible[open] > summary::before { transform: rotate(90deg); }
.sc-model-note { font-size: 11px; color: var(--muted); margin-bottom: 8px; }
.sc-title { font-size: 13px; font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 12px; padding-bottom: 6px; border-bottom: 1px solid var(--border); }

/* Summary Cards */
.sc-summary-cards { display: flex; gap: 14px; flex-wrap: wrap; }
.sc-card { background: var(--panel); border: 1px solid var(--border); border-radius: var(--card-radius); padding: 16px 20px; flex: 1; min-width: 200px; }
.sc-card-header { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
.sc-card-dot { width: 8px; height: 8px; border-radius: 50%; }
.sc-card-name { font-weight: 600; font-size: 14px; color: var(--fg); }
.sc-card-verdict { font-size: 11px; font-weight: 700; margin-left: auto; padding: 3px 10px; border-radius: 8px; }
.sc-card-verdict.pass { background: var(--accent-dim); color: var(--accent); border: 1px solid var(--accent-border); }
.sc-card-verdict.fail { background: rgba(248,113,113,0.12); color: var(--del); border: 1px solid rgba(248,113,113,0.3); }
.sc-card-metrics { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.sc-metric { text-align: center; }
.sc-metric-val { display: block; font-size: 16px; font-weight: 700; color: var(--fg); font-variant-numeric: tabular-nums; font-family: var(--mono); }
.sc-metric-label { font-size: 10px; color: var(--muted); text-transform: uppercase; }

/* Timeline */
.sc-timeline { position: relative; padding-top: 24px; }
.sc-time-axis { position: relative; height: 20px; margin-bottom: 4px; margin-left: 120px; }
.sc-time-tick { position: absolute; font-size: 10px; color: var(--muted); transform: translateX(-50%); }
.sc-lane { display: flex; align-items: center; margin-bottom: 6px; }
.sc-lane-label { width: 140px; font-size: 11px; color: var(--muted); display: flex; align-items: center; gap: 6px; flex-shrink: 0; flex-wrap: wrap; }
.sc-lane-name { font-weight: 600; color: var(--fg); }
.sc-lane-model { font-size: 10px; color: var(--muted); width: 100%; padding-left: 12px; }
.sc-lane-dot { width: 6px; height: 6px; border-radius: 50%; }
.sc-lane-track { flex: 1; height: 28px; background: var(--panel); border-radius: 6px; position: relative; overflow: hidden; }
.sc-span-block { position: absolute; top: 3px; height: 22px; border-radius: 3px; opacity: 0.85; cursor: pointer; transition: opacity 0.15s, transform 0.15s; min-width: 2px; }
.sc-span-block:hover, .sc-span-block.sc-span-hover { opacity: 1; transform: scaleY(1.3); z-index: 2; }

/* Tool Comparison Grid */
.sc-tool-grid { background: var(--panel); border: 1px solid var(--border); border-radius: var(--card-radius); padding: 14px; }
.sc-tool-row { display: grid; grid-template-columns: 140px repeat(auto-fit, minmax(120px, 1fr)); gap: 12px; align-items: center; padding: 6px 0; border-bottom: 1px solid rgba(255,255,255,0.04); }
.sc-tool-row:last-child { border-bottom: none; }
.sc-tool-row.sc-tool-header { font-size: 11px; font-weight: 600; color: var(--muted); border-bottom: 1px solid var(--border); padding-bottom: 8px; margin-bottom: 4px; }
.sc-tool-name { font-size: 12px; color: var(--fg); font-family: var(--mono); }
.sc-tool-agent { display: flex; align-items: center; gap: 8px; }
.sc-tool-bar-track { flex: 1; height: 4px; background: var(--panel2); border-radius: 2px; overflow: hidden; }
.sc-tool-bar-fill { height: 100%; border-radius: 2px; transition: width 0.3s; }
.sc-tool-count { font-size: 11px; color: var(--muted); min-width: 24px; text-align: right; font-variant-numeric: tabular-nums; }

/* Tool Sequence */
.sc-sequence { background: var(--panel); border: 1px solid var(--border); border-radius: var(--card-radius); padding: 16px; }
.sc-seq-row { display: flex; align-items: center; margin-bottom: 4px; }
.sc-seq-row:last-child { margin-bottom: 0; }
.sc-seq-label { width: 140px; font-size: 11px; color: var(--muted); display: flex; align-items: center; gap: 6px; flex-shrink: 0; flex-wrap: wrap; }
.sc-seq-track { display: flex; gap: 1px; flex: 1; }
.sc-seq-cell { flex: 1; height: 18px; border-radius: 3px; opacity: 0.85; cursor: pointer; transition: opacity 0.15s; min-width: 0; }
.sc-seq-cell.sc-seq-parallel { display: flex; flex-direction: column; gap: 1px; background: transparent; }
.sc-seq-cell.sc-seq-parallel .sc-seq-layer { flex: 1; border-radius: 2px; min-height: 0; }
.sc-seq-cell:hover { opacity: 1; outline: 1px solid #fff; z-index: 1; }
.sc-seq-cell.sc-seq-empty { background: var(--panel2); opacity: 0.3; cursor: default; }
.sc-seq-cell.sc-seq-empty:hover { outline: none; opacity: 0.3; }
.sc-seq-ruler { margin-bottom: 2px; }
.sc-seq-ruler .sc-seq-track { gap: 1px; }
.sc-seq-tick { flex: 1; font-size: 9px; color: var(--muted); text-align: center; min-width: 0; border-left: 1px solid var(--border); height: 14px; line-height: 14px; }
.sc-seq-tick-minor { border-left: 1px solid rgba(255,255,255,0.06); color: transparent; }
.sc-seq-legend { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 12px; padding-top: 10px; border-top: 1px solid var(--border); }
.sc-seq-legend-item { display: flex; align-items: center; gap: 4px; font-size: 10px; color: var(--muted); transition: opacity 0.2s; }
.sc-seq-legend-dot { width: 8px; height: 8px; border-radius: 3px; }
.sc-seq-legend-pct { color: var(--muted); font-size: 9px; margin-left: 2px; }
.sc-seq-legend-active { opacity: 1; color: var(--fg); font-weight: 600; }
.sc-seq-legend-dim { opacity: 0.4; }
.sc-seq-cell { transition: opacity 0.2s; }
.sc-seq-dim { opacity: 0.15 !important; }
.sc-seq-highlight { opacity: 1 !important; box-shadow: 0 0 0 1px rgba(255,255,255,0.3); }
.sc-seq-layer { transition: opacity 0.2s; }
.sc-seq-layer.sc-seq-dim { opacity: 0.15 !important; }
.sc-seq-layer.sc-seq-highlight { opacity: 1 !important; }

/* Span Table */
.sc-table-wrap { overflow-x: auto; }
.sc-table { width: 100%; border-collapse: collapse; font-size: 11px; table-layout: fixed; }
.sc-table th { text-align: left; padding: 8px 10px; background: var(--panel2); color: var(--muted); font-weight: 600; border-bottom: 1px solid var(--border); position: sticky; top: 0; overflow: hidden; }
.sc-table td { padding: 6px 10px; border-bottom: 1px solid rgba(255,255,255,0.04); vertical-align: top; overflow: hidden; }
.sc-table-seq { color: var(--muted); font-variant-numeric: tabular-nums; width: 36px; max-width: 36px; }
.sc-table-cell { min-width: 0; }
.sc-table-tools { color: var(--fg); font-family: var(--mono); font-size: 11px; }
.sc-table-meta { color: var(--muted); font-size: 10px; margin-top: 2px; font-variant-numeric: tabular-nums; }
.sc-table-empty { color: var(--border); }
.sc-table-more { text-align: center; color: var(--muted); font-style: italic; }
.sc-table tbody tr:hover { background: rgba(255,255,255,0.02); }

/* Light theme */
[data-theme="light"] .sc-title { color: #555; border-color: #e8e8e8; }
[data-theme="light"] .sc-card { background: #f8f9fa; }
[data-theme="light"] .sc-card-name { color: #222; }
[data-theme="light"] .sc-metric-val { color: #111; }
[data-theme="light"] .sc-metric-label { color: #888; }
[data-theme="light"] .sc-lane-track { background: #f0f0f0; }
[data-theme="light"] .sc-lane-name { color: #1f2328; }
[data-theme="light"] .sc-lane-model { color: #656d76; }
[data-theme="light"] .sc-tool-grid { background: #f8f9fa; }
[data-theme="light"] .sc-tool-row { border-color: #eee; }
[data-theme="light"] .sc-tool-name { color: #333; }
[data-theme="light"] .sc-tool-bar-track { background: #e8e8e8; }
[data-theme="light"] .sc-sequence { background: #f8f9fa; }
[data-theme="light"] .sc-table th { background: #f0f0f0; color: #555; }
[data-theme="light"] .sc-table td { border-color: #eee; }
[data-theme="light"] .sc-table tbody tr:hover { background: #f5f5f5; }

/* ============================================
   Sessions & Comparisons pages (new)
   ============================================ */

/* Filter bar */
.filter-bar {
  display: flex; gap: 10px; padding: 12px 24px; flex-wrap: wrap;
  border-bottom: 1px solid var(--border); background: var(--panel);
}
.filter-bar select {
  background: var(--panel2); color: var(--fg); border: 1px solid var(--border);
  padding: 6px 12px; border-radius: 6px; font-size: 12px;
}

/* Action bar */
.action-bar {
  text-align: right; white-space: nowrap;
}
.action-bar #selected-count { font-size: 11px; color: var(--muted); margin-right: 8px; }
.primary-btn-sm {
  background: var(--accent); color: #0e1116; border: none; border-radius: 6px;
  padding: 5px 12px; font-size: 11px; font-weight: 600; cursor: pointer;
}
.primary-btn-sm:hover { opacity: 0.85; }
.danger-btn-sm {
  background: transparent; color: var(--del); border: 1px solid rgba(248,113,113,0.4); border-radius: 6px;
  padding: 5px 12px; font-size: 11px; font-weight: 600; cursor: pointer;
}
.danger-btn-sm:hover { background: rgba(248,113,113,0.08); }

/* Sessions table */
.sessions-table {
  width: 100%; border-collapse: collapse; font-size: 12px;
}
.sessions-table th {
  text-align: left; padding: 8px 12px; color: var(--muted); font-size: 11px;
  text-transform: uppercase; border-bottom: 1px solid var(--border); position: sticky; top: 0;
  background: var(--panel);
}
.sessions-table td { padding: 8px 12px; border-bottom: 1px solid var(--border); }
.sessions-table tbody tr { cursor: pointer; }
.sessions-table tbody tr:hover { background: var(--panel2); }
.session-id-cell { font-family: var(--mono); font-size: 11px; max-width: 280px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Verdict badges */
.verdict { font-size: 11px; font-weight: 600; padding: 2px 6px; border-radius: 4px; }
.verdict-pass { color: var(--add); }
.verdict-fail { color: var(--del); }
.verdict-running { color: var(--cache); }

/* Detail header */
.detail-header {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 20px; border-bottom: 1px solid var(--border);
}
.back-btn { color: var(--accent); text-decoration: none; font-size: 13px; }
.detail-title { font-size: 14px; font-weight: 600; font-family: var(--mono); }
.detail-verdict { font-size: 12px; font-weight: 600; }
.detail-verdict.pass, .detail-verdict.PASS { color: var(--add); }
.detail-verdict.fail, .detail-verdict.FAIL { color: var(--del); }

/* Comparison cards */
.comparisons-list { padding: 12px 20px; display: flex; flex-direction: column; gap: 10px; overflow-y: auto; }
.comparison-card {
  background: var(--panel); border: 1px solid var(--border); border-radius: var(--card-radius);
  padding: 14px 18px; cursor: pointer; transition: border-color 0.15s;
}
.comparison-card:hover { border-color: var(--accent-border); }
.comparison-card-header { display: flex; align-items: center; gap: 8px; }
.comparison-source { font-size: 12px; }
.comparison-name { font-weight: 500; font-size: 13px; flex: 1; }
.comparison-verdict { font-size: 12px; color: var(--muted); }
.comparison-card-meta { font-size: 11px; color: var(--muted); margin-top: 4px; }

/* Comparison detail name input */
.comparison-name-input {
  background: transparent; border: 1px solid transparent; color: var(--fg);
  font-size: 14px; font-weight: 600; font-family: var(--mono); padding: 4px 8px;
  border-radius: 4px; flex: 1;
}
.comparison-name-input:hover { border-color: var(--border); }
.comparison-name-input:focus { border-color: var(--accent); outline: none; }

/* Summary table (comparison detail) */
.summary-table { width: 100%; border-collapse: collapse; font-size: 12px; margin: 12px 0; }
.summary-table th {
  text-align: left; padding: 8px 12px; color: var(--muted); font-size: 11px;
  text-transform: uppercase; border-bottom: 1px solid var(--border);
}
.summary-table td { padding: 8px 12px; border-bottom: 1px solid var(--border); }
.summary-actions { padding: 12px 0; }

/* Buttons */
.primary-btn {
  background: var(--accent); color: #0e1116; border: none; padding: 7px 16px;
  border-radius: 6px; font-size: 12px; font-weight: 600; cursor: pointer;
}
.primary-btn:hover { opacity: 0.9; }
.secondary-btn {
  color: var(--accent); text-decoration: none; font-size: 12px; padding: 6px 14px;
  border: 1px solid var(--accent-border); border-radius: 6px;
}
.secondary-btn:hover { background: var(--accent-dim); }
.danger-btn {
  background: transparent; color: var(--del); border: 1px solid rgba(248,113,113,0.4);
  padding: 6px 14px; border-radius: 6px; font-size: 12px; cursor: pointer;
}
.danger-btn:hover { background: rgba(248,113,113,0.08); }
.icon-btn { background: none; border: none; cursor: pointer; font-size: 14px; padding: 4px; }

/* Page header */
.page-header { display: flex; align-items: center; justify-content: space-between; padding: 12px 20px; border-bottom: 1px solid var(--border); }
.page-header h2 { margin: 0; font-size: 16px; }

/* View content */
.view-content { flex: 1; overflow-y: auto; display: flex; flex-direction: column; min-height: 0; }

/* Loading / Error / Empty */
.loading { color: var(--muted); padding: 40px; text-align: center; }
.error { color: var(--del); padding: 40px; text-align: center; }

/* Detail tabs (reuse traces style) */
.detail-tabs {
  display: flex; gap: 0; padding: 0 24px; border-bottom: 1px solid var(--border);
  background: var(--panel);
}
.detail-tab {
  padding: 11px 18px; font-size: 12px; color: var(--muted); cursor: pointer;
  border: none; background: none; border-bottom: 2.5px solid transparent;
  transition: color 0.15s;
}
.detail-tab:hover { color: var(--fg); }
.detail-tab.active { color: var(--fg); border-bottom-color: var(--accent); }

/* Run cards */
.runs-list { padding: 12px 20px; display: flex; flex-direction: column; gap: 10px; overflow-y: auto; }
.run-card {
  background: var(--panel); border: 1px solid var(--border); border-radius: var(--card-radius);
  padding: 14px 18px; cursor: pointer; transition: border-color 0.15s;
}
.run-card:hover { border-color: var(--accent-border); }
.run-card-header { display: flex; align-items: center; gap: 10px; font-size: 13px; }
.run-id { color: var(--accent); font-weight: 600; }
.run-task { font-weight: 500; }
.run-evaluator { color: var(--muted); font-size: 12px; }
.run-time { color: var(--muted); font-size: 11px; margin-left: auto; }
.run-card-agents { margin-top: 6px; display: flex; gap: 8px; flex-wrap: wrap; }
.run-agent-badge { font-size: 11px; padding: 2px 6px; border-radius: 4px; }
.run-actions { padding: 12px 0; display: flex; gap: 10px; }

/* Agent verdict inline */
.agent-verdict-inline { font-size: 12px; padding: 3px 8px; border-radius: 6px; background: var(--panel2); }
.agent-verdict-inline.pass { color: var(--accent); }
.agent-verdict-inline.fail { color: var(--del); }
.agent-verdict-inline.pending { color: var(--cache); }

/* Task & Evaluator items */
.task-item, .model-item { background: var(--panel); border: 1px solid var(--border); border-radius: var(--card-radius); padding: 14px 18px; }
.task-item:hover, .model-item:hover { border-color: var(--accent-border); }
.model-edit-form, .task-edit-form { padding: 20px; max-width: 720px; }
.code-input { font-family: var(--mono); font-size: 12px; line-height: 1.5; resize: vertical; white-space: pre; overflow-wrap: normal; overflow-x: auto; }
.task-header, .eval-header { display: flex; align-items: center; gap: 10px; }
.task-name { font-size: 14px; color: var(--fg); font-weight: 500; }
.task-meta, .eval-meta { font-size: 12px; color: var(--muted); margin-top: 4px; }
.eval-name { font-size: 14px; color: var(--fg); font-weight: 500; }
.eval-model { font-size: 12px; color: var(--accent); }
.task-delete, .eval-delete { margin-left: auto; }

/* Add form */
.settings-panel { padding: 16px 20px; overflow-y: auto; flex: 1; min-height: 0; }
.add-form { margin-top: 20px; padding: 16px; background: var(--panel); border: 1px solid var(--border); border-radius: var(--card-radius); }
/* Evaluators add-form is a direct child of .view-content (no padding), so inset
   it to align with the list cards above and cap its width like the edit form. */
#model-add-form { margin: 20px 20px 0; max-width: 720px; }
.add-form h3 { font-size: 14px; margin: 0 0 12px; color: var(--fg); }
.form-row { margin-bottom: 12px; }
.form-row label { display: block; font-size: 12px; color: var(--muted); margin-bottom: 4px; }
.form-input { width: 100%; background: var(--bg); border: 1px solid var(--border); border-radius: 6px; padding: 8px 12px; color: var(--fg); font-size: 13px; box-sizing: border-box; }
.form-input-sm { width: 120px; background: var(--bg); border: 1px solid var(--border); border-radius: 6px; padding: 8px 10px; color: var(--fg); font-size: 13px; }
.form-row-inline { display: flex; gap: 16px; }
.agent-check-label { display: flex; align-items: center; gap: 4px; font-size: 12px; color: var(--fg); cursor: pointer; }
.danger { color: var(--del); border-color: rgba(248,113,113,0.4); }
.danger:hover { background: rgba(248,113,113,0.08); }

/* Compare section (comparison detail) */
.compare-section { margin: 16px 0; }
.compare-section h3 { font-size: 13px; color: var(--muted); margin: 0 0 10px; }
.compare-bar-row { display: flex; align-items: center; gap: 10px; margin: 6px 0; }
.compare-label { width: 100px; font-size: 12px; font-weight: 500; text-align: right; }
.compare-bar { height: 20px; border-radius: 4px; min-width: 4px; }
.compare-value { font-size: 11px; color: var(--muted); min-width: 60px; }
.compare-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.compare-table th { text-align: left; padding: 8px 10px; color: var(--muted); font-size: 11px; text-transform: uppercase; border-bottom: 1px solid var(--border); }
.compare-table td { padding: 8px 10px; border-bottom: 1px solid var(--border); }

/* Benchmarks Tasks panel reuses .settings-panel */

/* ============================================
   Session Tags
   ============================================ */
.session-tags { display: flex; flex-wrap: wrap; gap: 4px; }
.tag {
  display: inline-block; padding: 2px 8px; border-radius: 6px;
  font-size: 11px; font-weight: 500; white-space: nowrap;
  background: var(--panel2); color: var(--muted); border: 1px solid var(--border);
}
.tag-task { background: var(--blue-dim); color: var(--blue); border-color: rgba(96,165,250,0.3); }
.tag-agent { background: var(--accent-dim); color: var(--accent); border-color: var(--accent-border); }
.tag-model { background: var(--purple-dim); color: var(--purple); border-color: rgba(167,139,250,0.3); }
.tag-verdict { font-weight: 700; }
.tag-verdict.tag-pass { background: var(--accent-dim); color: var(--accent); border-color: var(--accent-border); }
.tag-verdict.tag-fail { background: rgba(248,113,113,0.12); color: var(--del); border-color: rgba(248,113,113,0.3); }

[data-theme="light"] .tag { background: #f0f2f5; color: #656d76; border-color: #d8dee4; }
[data-theme="light"] .tag-task { background: #dbeafe; color: #1e40af; border-color: #93c5fd; }
[data-theme="light"] .tag-agent { background: #dcfce7; color: #166534; border-color: #86efac; }
[data-theme="light"] .tag-model { background: #f3e8ff; color: #6b21a8; border-color: #d8b4fe; }
[data-theme="light"] .tag-verdict.tag-pass { background: #dcfce7; color: #166534; border-color: #86efac; }
[data-theme="light"] .tag-verdict.tag-fail { background: #fee2e2; color: #991b1b; border-color: #fca5a5; }

.search-input {
  width: 300px; padding: 7px 14px; border-radius: 6px;
  background: var(--panel2); color: var(--fg); border: 1px solid var(--border);
  font-size: 13px; outline: none; transition: border-color 0.15s;
}
.search-input:focus { border-color: var(--accent); }

/* ============================================
   Running Run Card - Pulse / Breathing
   ============================================ */
.run-card-running {
  border-left: 3px solid var(--accent);
  animation: pulse-border 2s ease-in-out infinite;
}
@keyframes pulse-border {
  0%, 100% { border-left-color: var(--accent); opacity: 1; }
  50% { border-left-color: var(--accent); opacity: 0.6; }
}
.run-elapsed {
  color: var(--accent); font-size: 12px; font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.verdict-running { color: var(--accent); }
.run-agent-badge.verdict-running::before {
  content: ""; display: inline-block; width: 6px; height: 6px;
  border-radius: 50%; background: var(--accent); margin-right: 4px;
  animation: breathe 1.5s ease-in-out infinite;
}
@keyframes breathe {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.4; transform: scale(0.8); }
}

/* ============================================
   Pagination
   ============================================ */
.pagination {
  display: flex; align-items: center; justify-content: center;
  gap: 4px; padding: 16px 20px; border-top: 1px solid var(--border);
}
.page-btn {
  background: var(--panel2); border: 1px solid var(--border); color: var(--fg);
  padding: 6px 10px; border-radius: 6px; font-size: 12px; cursor: pointer;
  min-width: 32px; text-align: center;
  transition: background 0.15s, border-color 0.15s;
}
.page-btn:hover:not(:disabled) { background: var(--accent); color: #0e1116; border-color: var(--accent); }
.page-btn.active { background: var(--accent); color: #0e1116; border-color: var(--accent); font-weight: 600; }
.page-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.page-ellipsis { color: var(--muted); font-size: 12px; padding: 0 4px; }
.page-info { color: var(--muted); font-size: 12px; margin-left: 12px; }

/* ============================================
   Running row pulse animation
   ============================================ */
.row-running {
  animation: row-pulse 2s ease-in-out infinite;
}
@keyframes row-pulse {
  0%, 100% { background: transparent; }
  50% { background: rgba(57, 208, 216, 0.06); }
}
.run-id-cell { font-weight: 600; color: var(--accent); font-family: var(--mono); font-size: 12px; }
.run-elapsed { color: var(--cache); font-size: 12px; font-family: var(--mono); }
.comparison-name-cell { font-weight: 500; margin-right: 8px; }

/* Traces list: show more */
.trace-show-more {
  padding: 10px 12px; text-align: center; font-size: 12px;
  color: var(--accent); cursor: pointer; border-top: 1px solid var(--border);
}
.trace-show-more:hover { background: var(--panel2); }

/* ============================================
   Span Detail Inline Panel (Compare page)
   ============================================ */
.sc-table-clickable { cursor: pointer; transition: background 0.15s; }
.sc-table-clickable:hover { background: var(--panel2); }
.sc-cell-active { background: var(--panel2); outline: 1px solid var(--border); outline-offset: -1px; border-radius: 4px; }
.sc-cell-summary { }
.sc-inline-detail { display: none; }
.sc-inline-detail.open { display: block; margin-top: 8px; border-top: 1px solid var(--border); padding-top: 8px; }
.sc-inline-detail-panel { font-size: 12px; max-height: 300px; overflow-y: auto; }
.msg-flow { max-width: 100%; overflow: hidden; }
.sc-detail-tabs { display: flex; gap: 0; border-bottom: 1px solid var(--border); margin-bottom: 8px; }
.sc-detail-tab { padding: 4px 10px; font-size: 11px; cursor: pointer; border: none; background: none; color: var(--muted); border-bottom: 2px solid transparent; }
.sc-detail-tab.active { color: var(--accent); border-bottom-color: var(--accent); }
.sc-detail-tab:hover { color: var(--fg); }
.sc-detail-body { max-height: 400px; overflow-y: auto; }
.sc-detail-body .block { margin-bottom: 6px; }
.sc-detail-body pre { font-size: 11px; max-height: 200px; overflow: auto; }
.sc-detail-loading { color: var(--muted); font-size: 12px; padding: 8px 0; }
.sc-row-expanded { background: var(--panel2); }
.sc-table-seq { cursor: pointer; }
.sc-table-seq:hover { color: var(--accent); }

/* ============================================
   Message Flow (git-style rail)
   ============================================ */
.msg-flow { display: flex; flex-direction: column; gap: 6px; padding: 8px 0; }
.flow-node { border-left: 3px solid var(--border); border-radius: 4px; background: var(--panel); padding: 6px 10px; }
.flow-label { font-size: 11px; font-family: var(--mono); color: var(--muted); margin-bottom: 2px; }
.flow-text { font-size: 12px; color: var(--fg); font-family: var(--mono); white-space: pre-wrap; word-break: break-all; }
.flow-code { font-size: 11px; color: var(--fg); font-family: var(--mono); white-space: pre-wrap; word-break: break-all; background: var(--panel2); border-radius: 6px; padding: 6px 8px; margin: 4px 0; overflow-x: auto; }
.flow-expand { font-size: 11px; color: var(--accent); cursor: pointer; margin-top: 4px; }
.flow-user { border-left-color: var(--blue); }
.flow-assistant { border-left-color: var(--accent); }
.flow-system { border-left-color: var(--purple); }

/* Session running indicator */
.pulse-dot {
  display: inline-block; width: 8px; height: 8px; border-radius: 50%;
  background: var(--blue); margin-left: 4px; vertical-align: middle;
  animation: pulse-dot 1.2s ease-in-out infinite;
}
.live-badge {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 11px; font-weight: 600; color: var(--blue);
}
.live-badge .pulse-dot { margin-left: 0; }

/* ============================================
   Share bar
   ============================================ */
.traces-header {
  display: flex; align-items: center; gap: 10px; padding: 8px 14px;
}
.traces-header .share-btn { margin-left: auto; }
.share-btn {
  background: var(--panel2); border: 1px solid var(--border); color: var(--fg);
  padding: 5px 12px; border-radius: 6px; font-size: 12px; cursor: pointer;
  transition: all 0.15s;
}
.share-btn:hover { background: var(--accent-dim); color: var(--accent); border-color: var(--accent-border); }
