:root {
  --admin-header-accent: var(--v-brand-teal, #1375d9);
}

body:has(.admin-wrap) {
  --admin-bg: var(--bg);
}

body[data-product="runtimeai"]:has(.admin-wrap) {
  --admin-header-accent: var(--accent, #2563eb);
}

body[data-product="simops"]:has(.admin-wrap) {
  --admin-header-accent: var(--v-brand-teal, #1375d9);
}

.admin-wrap {
  min-height: 100vh;
  min-height: 100dvh;
  max-width: 100%;
  overflow-x: clip;
  background: var(--admin-bg);
  color: var(--text);
  display: flex;
  flex-direction: column;
  font-size: 14.5px;
}

body:has(.vantage-feedback-fab) .admin-wrap {
  padding-bottom: 3rem;
}

.admin-status-row {
  padding: 0.35rem 1rem;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
}

.admin-status-text {
  margin: 0;
  font-size: 0.88rem;
  color: var(--muted);
  max-width: 100%;
  word-break: break-word;
}

.admin-top {
  display: flex;
  gap: 1rem;
  justify-content: space-between;
  align-items: center;
  padding: 0.85rem 1rem;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
  position: relative;
}

body:has(.admin-wrap) .admin-top::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: color-mix(in srgb, var(--accent) 55%, var(--border));
  pointer-events: none;
}

.admin-tabs {
  display: flex;
  gap: 0.5rem;
  padding: 0.6rem 1rem;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
}

.admin-tab-btn {
  appearance: none;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  padding: 0.45rem 0.7rem;
  border-radius: 999px;
  cursor: pointer;
  font-weight: 650;
  font-size: 0.9rem;
}

.admin-tab-btn.active {
  background: rgba(82, 154, 255, 0.12);
  border-color: rgba(82, 154, 255, 0.35);
}

.admin-tab-panel.hidden {
  display: none;
}

.admin-tab-btn.hidden {
  display: none;
}

.admin-title {
  font-weight: 800;
  font-size: 1.05rem;
  letter-spacing: -0.025em;
  line-height: 1.2;
}

.admin-sub {
  margin-top: 0.35rem;
  color: var(--muted);
  font-size: 0.85rem;
  line-height: 1.4;
  max-width: 36rem;
}

body:has(.admin-wrap) .admin-top > div:first-child .app-version-badge {
  display: inline-block;
  margin-top: 0.25rem;
  padding: 0.1rem 0.4rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--muted);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-size: 0.62rem;
}

.admin-actions {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  flex-wrap: wrap;
}

.admin-actions .theme-toggle.theme-toggle--admin {
  width: 36px;
  height: 36px;
  padding: 0;
  flex-shrink: 0;
}

.admin-login-cluster.hidden {
  display: none !important;
}

.admin-login-cluster {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}

.admin-login-fields {
  display: flex;
  gap: 0.45rem;
  flex-wrap: wrap;
  align-items: center;
}

.admin-login-input {
  padding: 0.55rem 0.7rem;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  min-width: 7.5rem;
  width: 8.75rem;
  font: inherit;
}

.admin-login-input::placeholder {
  color: var(--muted);
}

.admin-login-remember {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.85rem;
  color: var(--muted);
  user-select: none;
  white-space: nowrap;
}

.admin-login-remember input {
  margin: 0;
}

.admin-link {
  text-decoration: none;
  display: inline-block;
}

.admin-open-sim {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  line-height: 1;
}

.admin-open-sim svg {
  display: block;
  flex-shrink: 0;
}

.admin-tab-panel:not(.hidden) {
  flex: 1;
  min-height: 0;
  min-width: 0;
  overflow: auto;
}

#tab-main.admin-tab-panel:not(.hidden) {
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

#tab-main .admin-main {
  flex: 1;
  min-height: 0;
}

.admin-main {
  flex: 1;
  display: grid;
  grid-template-columns: minmax(16rem, min(38vw, 26rem)) minmax(0, 1fr);
  min-height: 0;
  min-width: 0;
  overflow: hidden;
}

.admin-main > .admin-left,
.admin-main > .admin-right {
  min-width: 0;
}

.admin-settings {
  padding: 0.75rem;
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
}

.admin-agent-tests {
  padding: 0.75rem;
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
  width: 100%;
  max-width: none;
  box-sizing: border-box;
}

.agent-eval-section-heading {
  margin: 0 0 0.5rem;
  font-size: 1.15rem;
  font-weight: 700;
  line-height: 1.3;
  color: var(--text);
}

.agent-eval-start-callout {
  margin: 0 0 0.65rem;
  padding: 0.65rem 0.85rem;
  max-width: min(52rem, 100%);
  box-sizing: border-box;
  border-radius: 10px;
  border: 2px solid rgba(82, 154, 255, 0.5);
  background: color-mix(in srgb, rgba(82, 154, 255, 0.12) 100%, var(--panel) 88%);
  box-shadow:
    0 0 0 1px color-mix(in srgb, rgba(82, 154, 255, 0.22) 100%, transparent),
    0 2px 8px rgba(0, 0, 0, 0.06);
}

.agent-eval-start-callout .agent-eval-controls {
  margin-bottom: 0;
}

.agent-eval-controls {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 0.5rem 0.75rem;
  margin-bottom: 0.5rem;
}

.agent-eval-controls .runs-filter {
  min-width: 12rem;
}

.agent-eval-scenario-label {
  margin: 0;
}

.agent-eval-intro {
  margin: 0.35rem 0 0.5rem;
  max-width: 52rem;
  line-height: 1.45;
}

.agent-eval-methodology-details {
  margin: 0.35rem 0 0;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--panel);
}

.agent-eval-methodology-summary {
  cursor: pointer;
  list-style: none;
  padding: 0.55rem 0.65rem;
  font-weight: 600;
  color: var(--text);
}

.agent-eval-methodology-summary::-webkit-details-marker {
  display: none;
}

.agent-eval-methodology-summary::before {
  content: "▸";
  display: inline-block;
  margin-right: 0.35rem;
  transition: transform 0.12s ease;
  color: var(--muted);
}

.agent-eval-methodology-details[open] > .agent-eval-methodology-summary::before {
  transform: rotate(90deg);
}

.agent-eval-methodology-summary-title {
  margin-right: 0.35rem;
}

.agent-eval-methodology-summary-hint {
  display: block;
  margin-top: 0.2rem;
  font-weight: 400;
  font-size: 0.82rem;
  line-height: 1.35;
}

.agent-eval-methodology-body {
  padding: 0 0.65rem 0.65rem;
  border-top: 1px solid var(--border);
}

.agent-eval-results-lead {
  margin: 0.65rem 0 0.15rem;
  padding: 0.35rem 0 0;
  font-size: 0.95rem;
  color: var(--text);
  border-top: 1px dashed color-mix(in srgb, var(--border) 80%, transparent);
}

.agent-eval-notes {
  margin: 0.65rem 0 0.65rem;
  padding-left: 1.2rem;
  max-width: 52rem;
}

.agent-eval-notes li {
  margin-bottom: 0.35rem;
}

.agent-eval-output {
  min-height: 2rem;
  margin-top: 0.25rem;
}

.agent-eval-performers {
  margin: 0 0 0.85rem;
  padding: 0.55rem 0.65rem;
  border-radius: 6px;
  border: 1px solid var(--border);
  background: var(--panel);
  font-size: 0.92rem;
  line-height: 1.45;
  color: var(--text);
}

.agent-eval-scenario-summary {
  margin-bottom: 0.5rem;
}

.agent-eval-scenario-summary .agent-eval-head {
  margin: 0 0 0.35rem;
}

.agent-eval-performers--inline {
  margin: 0 0 0.65rem;
}

.agent-eval-perf-stack {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.agent-eval-perf-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem 0.65rem;
  padding: 0.35rem 0.45rem;
  border-radius: 6px;
  border: 1px solid var(--border);
}

.agent-eval-perf-row--top {
  background: color-mix(in srgb, #047857 26%, var(--panel) 74%);
  border-color: color-mix(in srgb, #059669 55%, var(--border) 45%);
  box-shadow: inset 4px 0 0 0 color-mix(in srgb, #10b981 88%, transparent);
}

.agent-eval-perf-row--bottom {
  background: color-mix(in srgb, #9f1239 22%, var(--panel) 78%);
  border-color: color-mix(in srgb, #be123c 50%, var(--border) 50%);
  box-shadow: inset 4px 0 0 0 color-mix(in srgb, #f43f5e 85%, transparent);
}

.agent-eval-perf-row--single {
  background: color-mix(in srgb, var(--border) 10%, var(--panel) 90%);
}

.agent-eval-perf-label {
  flex: 0 0 auto;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted);
}

.agent-eval-perf-row--top .agent-eval-perf-label {
  color: #065f46;
}

.agent-eval-perf-row--bottom .agent-eval-perf-label {
  color: #881337;
}

.agent-eval-perf-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  align-items: center;
  min-width: 0;
}

.agent-eval-perf-pill {
  display: inline-flex;
  align-items: baseline;
  gap: 0.25rem;
  padding: 0.2rem 0.45rem;
  border-radius: 999px;
  font-size: 0.82rem;
  line-height: 1.25;
  border: 1px solid transparent;
}

.agent-eval-perf-pill code {
  font-size: 0.78rem;
  max-width: 14rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.agent-eval-perf-pill--top {
  background: color-mix(in srgb, #34d399 22%, var(--panel) 78%);
  border-color: color-mix(in srgb, #059669 52%, var(--border) 48%);
  color: var(--text);
}

.agent-eval-perf-pill--top.agent-eval-perf-pill--prime {
  background: color-mix(in srgb, #10b981 38%, var(--panel) 62%);
  border-color: #047857;
  box-shadow: 0 0 0 1px color-mix(in srgb, #047857 35%, transparent);
}

.agent-eval-perf-pill--bottom {
  background: color-mix(in srgb, #fda4af 22%, var(--panel) 78%);
  border-color: color-mix(in srgb, #e11d48 48%, var(--border) 52%);
  color: var(--text);
}

.agent-eval-perf-pill--bottom.agent-eval-perf-pill--prime {
  background: color-mix(in srgb, #fb7185 36%, var(--panel) 64%);
  border-color: #be123c;
  box-shadow: 0 0 0 1px color-mix(in srgb, #9f1239 40%, transparent);
}

.agent-eval-perf-pill-score {
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}

.agent-eval-perf-pill-denom {
  font-size: 0.72rem;
  color: var(--muted);
}

.agent-eval-perf-spread {
  margin: 0;
  line-height: 1.45;
}

.agent-eval-perf-spread-pct {
  color: var(--muted);
  font-weight: 500;
}

.agent-eval-perf-spread--tight .agent-eval-perf-tight-hint {
  display: inline;
  color: var(--muted);
  font-style: italic;
}

.agent-eval-perf-note {
  margin: 0;
}

.agent-eval-subhead--tight {
  margin-top: 0;
}

.agent-eval-subhead {
  margin: 0.85rem 0 0.45rem;
  font-size: 0.95rem;
  font-weight: 600;
}

.agent-eval-summary-table-wrap {
  overflow-x: auto;
  margin-bottom: 0.75rem;
  border: 1px solid var(--border);
  border-radius: 8px;
}

.agent-eval-summary-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.86rem;
}

.agent-eval-summary-table th,
.agent-eval-summary-table td {
  padding: 0.4rem 0.5rem;
  border-bottom: 1px solid var(--border);
  text-align: left;
  vertical-align: top;
}

.agent-eval-summary-table th {
  color: var(--muted);
  font-weight: 600;
  font-size: 0.78rem;
  white-space: nowrap;
}

.agent-eval-summary-table thead button.agent-eval-sort {
  display: inline-flex;
  align-items: center;
  gap: 0.15rem;
  margin: 0;
  padding: 0;
  border: none;
  background: none;
  font: inherit;
  font-weight: 600;
  color: inherit;
  cursor: pointer;
  text-align: left;
  white-space: nowrap;
  max-width: 100%;
}

.agent-eval-summary-table thead button.agent-eval-sort:hover {
  color: var(--text);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.agent-eval-summary-table thead button.agent-eval-sort--active {
  color: var(--text);
}

.agent-eval-sort-ind {
  font-size: 0.65rem;
  opacity: 0.85;
  font-weight: 700;
}

.agent-eval-summary-table tbody tr:last-child td {
  border-bottom: none;
}

.agent-eval-summary-table th.agent-eval-th-provider,
.agent-eval-summary-table td.agent-eval-col-provider {
  min-width: 5.5rem;
  max-width: 9rem;
  white-space: nowrap;
}

.agent-eval-head-weights {
  margin: 0.15rem 0 0.35rem;
}

.agent-eval-summary-table th.agent-eval-th-model,
.agent-eval-summary-table td.agent-eval-col-model {
  width: 9.5rem;
  min-width: 7rem;
  max-width: 11rem;
  box-sizing: border-box;
}

.agent-eval-model-code {
  display: block;
  font-size: 0.78rem;
  line-height: 1.35;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.agent-eval-summary-table td.agent-eval-num,
.agent-eval-summary-table thead tr:nth-child(2) th:nth-child(n + 8) {
  text-align: right;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.agent-eval-assumptions-row .agent-eval-assumptions-th {
  font-weight: normal;
  text-align: left;
  vertical-align: top;
  padding: 0.5rem 0.55rem;
  background: color-mix(in srgb, var(--panel) 88%, var(--border) 12%);
}

.agent-eval-assumptions-stack {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.agent-eval-proj-lead-compact {
  margin: 0;
  max-width: none;
  line-height: 1.45;
}

.agent-eval-proj-controls--compact {
  margin: 0;
  max-width: none;
  grid-template-columns: repeat(auto-fill, minmax(7.75rem, max-content));
  gap: 0.35rem 0.45rem;
  justify-content: start;
}

.agent-eval-proj-controls--compact .agent-eval-proj-field {
  max-width: 9.5rem;
}

.agent-eval-proj-controls--compact .agent-eval-proj-field span {
  font-size: 0.76rem;
  hyphens: auto;
  overflow-wrap: break-word;
}

.agent-eval-proj-controls--compact .agent-eval-proj-field input {
  width: 3.5rem;
  min-width: 3.5rem;
  max-width: 3.5rem;
  padding: 0.25rem 0.2rem;
  text-align: center;
  font-variant-numeric: tabular-nums;
}

.agent-eval-proj-actions-inline {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.agent-eval-summary-table-wrap .agent-eval-proj-foot {
  margin: 0.45rem 0.55rem 0.55rem;
  max-width: none;
}

.agent-tests-findings--before-batches {
  margin: 0 0 0.75rem;
}

.agent-eval-summary-table .agent-eval-narrative-cell {
  width: 11rem;
  min-width: 8rem;
  max-width: 13rem;
  line-height: 1.4;
  color: var(--text);
}

.agent-eval-narrative-open {
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0;
  border: none;
  background: none;
  font: inherit;
  color: var(--text);
  text-align: left;
  cursor: pointer;
  line-height: 1.4;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
}

.agent-eval-narrative-open:hover {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.agent-eval-narrative-plain {
  display: block;
  line-height: 1.4;
}

.agent-eval-narrative-dialog {
  max-width: min(42rem, 92vw);
  width: 100%;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--surface);
  color: var(--text);
}

.agent-eval-narrative-dialog::backdrop {
  background: rgba(0, 0, 0, 0.45);
}

.agent-eval-narrative-dialog-inner {
  margin: 0;
  padding: 1rem 1.1rem;
}

.agent-eval-narrative-dialog-title {
  margin: 0 0 0.25rem;
  font-size: 1.05rem;
}

.agent-eval-narrative-dialog-body {
  margin: 0.75rem 0 1rem;
  line-height: 1.5;
  white-space: pre-wrap;
  max-height: min(60vh, 28rem);
  overflow-y: auto;
}

.agent-eval-narrative-dialog-foot {
  display: flex;
  justify-content: flex-end;
}

.agent-eval-summary-table tr.agent-eval-summary-tr {
  cursor: pointer;
}

.agent-eval-summary-table tr.agent-eval-summary-tr:hover td {
  background: color-mix(in srgb, var(--panel) 70%, var(--border) 30%);
}

.agent-eval-summary-table tr.agent-eval-summary-tr--score-top td {
  background: color-mix(in srgb, #059669 24%, var(--panel) 76%);
  box-shadow: inset 5px 0 0 0 #047857;
}

.agent-eval-summary-table tr.agent-eval-summary-tr--score-bottom td {
  background: color-mix(in srgb, #e11d48 18%, var(--panel) 82%);
  box-shadow: inset 5px 0 0 0 #be123c;
}

.agent-eval-summary-table tr.agent-eval-summary-tr--score-top.agent-eval-summary-tr--score-bottom td {
  background: color-mix(in srgb, var(--border) 10%, var(--panel) 90%);
  box-shadow: inset 5px 0 0 0 var(--muted);
}

.agent-eval-summary-table tr.agent-eval-summary-tr--score-top:hover td {
  background: color-mix(in srgb, #047857 32%, var(--panel) 68%);
}

.agent-eval-summary-table tr.agent-eval-summary-tr--score-bottom:hover td {
  background: color-mix(in srgb, #be123c 26%, var(--panel) 74%);
}

.agent-eval-scenario-compare {
  margin-top: 0.35rem;
}

.agent-eval-scenario-compare .agent-test-chart-toolbar.agent-eval-chart-toolbar--top {
  margin-top: 0;
}

.agent-eval-scenario-compare .agent-test-chart-toolbar {
  margin-top: 0.25rem;
}

.agent-eval-scenario-compare .agent-test-chart-panel {
  margin-top: 0.35rem;
}

.agent-eval-scenario-compare .agent-test-chart-canvas {
  min-height: 320px;
}

.agent-eval-proj-lead {
  margin: 0 0 0.5rem;
  max-width: 52rem;
  line-height: 1.45;
}

.agent-eval-proj-controls {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(11rem, 1fr));
  gap: 0.45rem 0.65rem;
  align-items: end;
  margin-bottom: 0.45rem;
  max-width: 52rem;
}

.agent-eval-proj-field {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  font-size: 0.8rem;
  color: var(--muted);
}

.agent-eval-proj-field span {
  line-height: 1.25;
}

.agent-eval-proj-field input {
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
  padding: 0.3rem 0.4rem;
  border-radius: 6px;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  font-size: 0.9rem;
}

.agent-eval-proj-actions {
  margin-bottom: 0.55rem;
}

.agent-eval-proj-table-wrap {
  overflow-x: auto;
  margin-bottom: 0.35rem;
  border: 1px solid var(--border);
  border-radius: 8px;
}

.agent-eval-proj-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
}

.agent-eval-proj-table th,
.agent-eval-proj-table td {
  padding: 0.35rem 0.45rem;
  border-bottom: 1px solid var(--border);
  text-align: right;
  white-space: nowrap;
}

.agent-eval-proj-table th:first-child,
.agent-eval-proj-table td:first-child {
  text-align: left;
}

.agent-eval-proj-table th {
  font-weight: 600;
  color: var(--muted);
  font-size: 0.76rem;
}

.agent-eval-proj-table tbody tr:last-child td {
  border-bottom: none;
}

.agent-eval-proj-foot {
  margin: 0 0 0.35rem;
  max-width: 52rem;
}

.agent-eval-detail-cards {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

details.agent-eval-model-details {
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--panel);
}

details.agent-eval-model-details > summary {
  list-style: none;
  cursor: pointer;
  padding: 0.55rem 0.75rem;
  font-weight: 500;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.35rem 0.75rem;
}

details.agent-eval-model-details > summary::-webkit-details-marker {
  display: none;
}

details.agent-eval-model-details > summary::before {
  content: "▸";
  display: inline-block;
  width: 1em;
  color: var(--muted);
  transition: transform 0.12s ease;
}

details.agent-eval-model-details[open] > summary::before {
  transform: rotate(90deg);
}

.agent-eval-model-details-body {
  padding: 0 0.85rem 0.85rem;
  border-top: 1px solid var(--border);
}

.agent-eval-head {
  margin: 0 0 0.75rem;
}

.agent-eval-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

.agent-eval-card {
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 0.75rem 1rem;
  background: var(--panel);
}

.agent-eval-card-h {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.5rem 1rem;
  margin-bottom: 0.65rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--border);
}

.agent-eval-model {
  font-size: 0.95rem;
}

.agent-eval-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
  gap: 0.65rem 1rem;
  margin-bottom: 0.65rem;
}

.agent-eval-k {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--muted);
  margin-bottom: 0.2rem;
}

.agent-eval-summary {
  margin: 0 0 0.75rem;
  line-height: 1.5;
  font-size: 0.92rem;
  color: var(--text);
}

.agent-eval-two-col {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
  gap: 1rem;
  margin-bottom: 0.5rem;
}

.agent-eval-two-col h5,
.agent-eval-card > h5,
.agent-eval-model-details-body h5 {
  margin: 0 0 0.4rem;
  font-size: 0.88rem;
  font-weight: 600;
}

.agent-eval-bullets {
  margin: 0;
  padding-left: 1.1rem;
  line-height: 1.45;
  font-size: 0.88rem;
}

.agent-eval-bullets li {
  margin-bottom: 0.35rem;
}

.agent-eval-headlines {
  margin-bottom: 0.65rem;
}

.agent-eval-dim {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
  margin-top: 0.35rem;
}

.agent-eval-dim th,
.agent-eval-dim td {
  text-align: left;
  padding: 0.35rem 0.5rem;
  border-bottom: 1px solid var(--border);
}

.agent-eval-dim th {
  color: var(--muted);
  font-weight: 600;
  font-size: 0.78rem;
}

#tab-model-tests.admin-tab-panel {
  width: 100%;
  max-width: none;
  min-width: 0;
}

.admin-api-status {
  font-size: 0.9rem;
  line-height: 1.5;
  margin-top: 0.35rem;
}

.admin-api-status-default {
  margin-bottom: 0.35rem;
}

.admin-api-status-list {
  margin: 0.35rem 0 0;
  padding-left: 1.2rem;
}

.admin-api-status-list li {
  margin-bottom: 0.35rem;
}

.admin-api-mark {
  display: inline-block;
  min-width: 1.1em;
}

.admin-api-ok {
  color: var(--text);
}

.admin-api-missing {
  color: var(--muted);
}

.admin-api-footnote {
  margin-top: 0.65rem;
}

.agent-tests-findings .agent-tests-lead {
  margin: 0 0 0.65rem;
  line-height: 1.45;
  color: var(--text);
  font-size: 0.92rem;
}

.agent-tests-bullets {
  margin: 0;
  padding-left: 1.15rem;
  line-height: 1.45;
  font-size: 0.9rem;
  color: var(--text);
}

.agent-tests-bullets li {
  margin-bottom: 0.45rem;
}

.agent-tests-batches {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  margin-top: 0.5rem;
}

.agent-tests-batch-scenario-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 0.75rem;
  margin: 0 0 0.65rem;
  padding: 0.5rem 0.65rem;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: var(--panel);
}

.agent-tests-batch-scenario-label {
  margin: 0;
  font-weight: 600;
  color: var(--text);
}

.agent-tests-batch-scenario-bar .runs-filter {
  min-width: 14rem;
  max-width: min(100%, 24rem);
}

.agent-tests-batch-scenario-hint {
  margin: 0;
  flex: 1 1 12rem;
  min-width: 0;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.4;
}

.agent-registry-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
  margin-top: 0.5rem;
}

.agent-reg-list {
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--bg);
  max-height: 360px;
  overflow: auto;
  padding: 0.5rem 0.6rem;
  font-size: 0.82rem;
}

.agent-reg-item {
  display: flex;
  gap: 0.5rem;
  justify-content: space-between;
  align-items: baseline;
  border-bottom: 1px solid var(--border);
  padding: 0.25rem 0;
}

.agent-reg-item:last-child {
  border-bottom: none;
}

.agent-reg-item code {
  font-size: 0.78rem;
}

@media (max-width: 980px) {
  .agent-registry-grid {
    grid-template-columns: 1fr;
  }
}

.agent-test-batch-row {
  display: flex;
  align-items: stretch;
  gap: 0;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--bg);
  margin-bottom: 0.5rem;
}

.agent-test-batch-row > .agent-test-batch-cb-label {
  flex-shrink: 0;
  padding: 0.55rem 0 0.55rem 0.75rem;
  align-self: flex-start;
}

.agent-test-batch-row > .agent-test-batch {
  border: none;
  border-radius: 0;
  flex: 1;
  min-width: 0;
}

.agent-test-batch {
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 0;
  background: var(--bg);
}

details.agent-test-batch > summary.agent-test-batch-summary {
  list-style: none;
  cursor: pointer;
  padding: 0.55rem 0.75rem 0.45rem;
  border-radius: 12px;
}

details.agent-test-batch > summary.agent-test-batch-summary::-webkit-details-marker {
  display: none;
}

details.agent-test-batch[open] > summary.agent-test-batch-summary {
  border-bottom: 1px solid var(--border);
  border-radius: 12px 12px 0 0;
}

.agent-test-batch-sum-row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 0.35rem 0.55rem;
  width: 100%;
}

.agent-test-batch-cb-label {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  margin-top: 0.08rem;
  cursor: pointer;
  user-select: none;
}

.agent-test-batch-cb-label input[type="checkbox"] {
  width: 1rem;
  height: 1rem;
  cursor: pointer;
}

.agent-test-batch-sum-top {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.35rem 0.65rem;
  flex: 1;
  min-width: 0;
}

.agent-test-chev {
  display: inline-block;
  width: 0.85rem;
  flex-shrink: 0;
  color: var(--muted);
  font-size: 0.7rem;
  line-height: 1;
}

details.agent-test-batch:not([open]) > summary .agent-test-chev::before {
  content: "▸";
}

details.agent-test-batch[open] > summary .agent-test-chev::before {
  content: "▾";
}

.agent-test-batch-inner {
  padding: 0 0.65rem 0.65rem;
}

.agent-test-sub {
  margin-top: 0.5rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface);
  padding: 0;
}

.agent-test-sub > summary.agent-test-sub-summary {
  list-style: none;
  cursor: pointer;
  padding: 0.45rem 0.65rem;
  font-size: 0.84rem;
  font-weight: 650;
  color: var(--text);
}

.agent-test-sub > summary.agent-test-sub-summary::-webkit-details-marker {
  display: none;
}

.agent-test-sub[open] > summary.agent-test-sub-summary {
  border-bottom: 1px solid var(--border);
}

.agent-test-sub .agent-test-batch-compare {
  margin: 0;
  padding: 0.45rem 0.55rem 0.55rem;
}

.agent-test-sub .agent-test-batch-models {
  margin-top: 0;
  border-top: none;
  padding: 0.35rem 0.55rem 0.55rem;
  max-height: min(52vh, 520px);
}

.agent-tests-help-details,
.agent-tests-registry-details {
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 0;
  background: var(--surface);
}

.agent-tests-help-summary,
.agent-tests-registry-summary {
  list-style: none;
  cursor: pointer;
  padding: 0.5rem 0.75rem;
  font-weight: 650;
  font-size: 0.88rem;
  color: var(--text);
}

.agent-tests-help-summary::-webkit-details-marker,
.agent-tests-registry-summary::-webkit-details-marker {
  display: none;
}

.agent-tests-help-body {
  padding: 0 0.75rem 0.75rem;
}

.agent-tests-registry-details > .run-meta {
  margin: 0 0.75rem 0.5rem;
}

.agent-tests-registry-details .agent-registry-grid {
  margin: 0 0.75rem 0.75rem;
}

.agent-test-row-hint {
  grid-column: 1 / -1;
  font-size: 0.78rem;
  line-height: 1.35;
}

.agent-test-batch-aggregate {
  margin: 0.5rem 0 0.65rem;
  padding: 0.55rem 0.65rem;
  border-radius: 10px;
  background: rgba(82, 154, 255, 0.06);
  border: 1px solid rgba(82, 154, 255, 0.2);
  font-size: 0.86rem;
  line-height: 1.45;
}

.agent-test-batch-aggregate h4 {
  margin: 0 0 0.35rem;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
  font-weight: 700;
}

.agent-test-agg-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 0.35rem 0.75rem;
  margin-bottom: 0.45rem;
}

.agent-test-agg-kv strong {
  color: var(--text);
}

.agent-test-error-buckets {
  margin-top: 0.35rem;
  font-size: 0.8rem;
  color: var(--muted);
}

.agent-test-score-pill {
  font-size: 0.78rem;
  font-weight: 650;
  color: var(--text);
}

.agent-test-score-pill {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 0.82rem;
  word-break: break-all;
}

.agent-test-batch-stats {
  font-size: 0.85rem;
  color: var(--muted);
}

.agent-test-batch-times {
  width: 100%;
  flex-basis: 100%;
  margin-top: 0.1rem;
  font-size: 0.8rem;
}

.agent-test-batch-compare {
  margin: 0 0 0.55rem;
}

.agent-test-batch-compare h4 {
  margin: 0 0 0.35rem;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
  font-weight: 700;
}

.agent-test-chart-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.6rem;
  margin-bottom: 0.45rem;
  font-size: 0.78rem;
}

.agent-test-chart-toolbar .secondary {
  font-size: 0.76rem;
  padding: 0.25rem 0.5rem;
}

.agent-test-chart-toolbar-label {
  margin-left: 0.15rem;
}

.agent-test-chart-type-wrap {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin-left: 0.15rem;
  color: var(--text);
}

.agent-test-chart-type {
  font-size: 0.76rem;
  padding: 0.22rem 0.5rem;
  border-radius: 6px;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--text);
  max-width: 14rem;
}

.agent-test-chart-heatmap-gradient {
  display: inline-block;
  width: 120px;
  height: 10px;
  border-radius: 4px;
  border: 1px solid var(--border);
  vertical-align: middle;
  background: linear-gradient(90deg, hsl(158, 38%, 36%), hsl(103, 80%, 70%));
}

.agent-test-chart-dim-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem 0.65rem;
  align-items: center;
  width: 100%;
}

.agent-test-chart-dim-label {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  cursor: pointer;
  color: var(--text);
  font-size: 0.74rem;
}

.agent-test-chart-dim-label input {
  margin: 0;
}

.agent-test-chart-panel {
  margin-bottom: 0.5rem;
  padding: 0.45rem 0.5rem;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--surface);
}

.agent-test-chart-panel.hidden {
  display: none;
}

.agent-test-chart-canvas-wrap {
  position: relative;
}

.agent-test-chart-canvas {
  width: 100%;
  height: 300px;
  display: block;
  vertical-align: top;
}

.agent-test-chart-tooltip {
  position: absolute;
  z-index: 6;
  min-width: 10rem;
  max-width: 22rem;
  padding: 0.45rem 0.55rem;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  font-size: 0.74rem;
  line-height: 1.35;
  box-shadow: 0 6px 24px rgba(0, 0, 0, 0.12);
  pointer-events: none;
}

.agent-test-chart-tooltip.hidden {
  display: none;
}

.agent-test-chart-tooltip-block + .agent-test-chart-tooltip-block {
  margin-top: 0.45rem;
  padding-top: 0.45rem;
  border-top: 1px solid var(--border);
}

.agent-test-chart-tooltip-ul {
  margin: 0.25rem 0 0;
  padding-left: 1rem;
}

.agent-test-chart-tooltip-ul li {
  margin: 0.12rem 0;
}

.agent-test-chart-tooltip-overlap {
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--accent);
}

.agent-test-chart-tooltip-swatch {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 2px;
  margin-right: 0.35rem;
  vertical-align: middle;
  border: 1px solid rgba(0, 0, 0, 0.12);
}

.agent-test-chart-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem 0.85rem;
  margin-top: 0.45rem;
  font-size: 0.72rem;
  align-items: center;
}

.agent-test-chart-legend-item {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
}

.agent-test-chart-swatch {
  width: 10px;
  height: 10px;
  border-radius: 2px;
  flex-shrink: 0;
  border: 1px solid rgba(0, 0, 0, 0.15);
}

.agent-test-chart-th {
  width: 2rem;
  text-align: center;
}

.agent-test-chart-td {
  text-align: center;
  vertical-align: middle;
}

.agent-test-compare-tr {
  cursor: pointer;
}

.agent-test-compare-scroll {
  overflow-x: auto;
  border: 1px solid var(--border);
  border-radius: 8px;
  max-width: 100%;
  -webkit-overflow-scrolling: touch;
}

.agent-test-compare-table {
  width: max-content;
  min-width: 100%;
  border-collapse: collapse;
  font-size: 0.72rem;
}

.agent-test-compare-table th,
.agent-test-compare-table td {
  padding: 0.35rem 0.45rem;
  text-align: left;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}

.agent-test-compare-table th {
  position: sticky;
  top: 0;
  background: var(--surface);
  z-index: 1;
  font-weight: 650;
  color: var(--muted);
}

.agent-test-compare-sortable {
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
}

.agent-test-compare-sortable:hover {
  color: var(--accent);
}

.agent-test-compare-sortable .agent-test-sort-ind {
  font-size: 0.68em;
  opacity: 0.55;
  margin-left: 0.15em;
}

.agent-test-compare-sortable.sorted-asc .agent-test-sort-ind::after {
  content: " ▲";
}

.agent-test-compare-sortable.sorted-desc .agent-test-sort-ind::after {
  content: " ▼";
}

.agent-test-compare-table tbody tr:hover {
  background: rgba(82, 154, 255, 0.05);
}

.agent-test-batch-models {
  margin-top: 0.45rem;
  max-height: 220px;
  overflow: auto;
  font-size: 0.82rem;
  border-top: 1px solid var(--border);
  padding-top: 0.45rem;
}

.agent-test-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.35rem 0.65rem;
  padding: 0.2rem 0;
  border-bottom: 1px solid var(--border);
}

.agent-test-row:last-child {
  border-bottom: none;
}

.agent-test-row code {
  font-size: 0.78rem;
}

.agent-test-row a {
  color: var(--accent);
  text-decoration: none;
  font-size: 0.8rem;
}

.agent-test-row a:hover {
  text-decoration: underline;
}

.agent-test-ok {
  color: #2e9e5b;
}

.agent-test-bad {
  color: #c94a4a;
}

.agent-test-warn {
  color: #b8860b;
}

.admin-left {
  border-right: 1px solid var(--border);
  background: var(--surface);
  padding: 0.75rem;
  overflow: auto;
}

.admin-right {
  padding: 0.75rem;
  min-width: 0;
  max-width: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  background: var(--bg);
}

.admin-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
  min-width: 0;
  max-width: 100%;
}

.admin-panel {
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--surface);
  padding: 0.75rem;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
}

.admin-panel-title {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  margin-bottom: 0.5rem;
}

.admin-panel-title-row {
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  align-items: center;
}

.admin-runs {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.runs-controls {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.4rem;
  margin-bottom: 0.6rem;
}

.runs-filters-details {
  margin-bottom: 0.45rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  padding: 0;
}

.runs-filters-details > summary {
  list-style: none;
  cursor: pointer;
  padding: 0.4rem 0.55rem;
  font-weight: 650;
  font-size: 0.88rem;
  color: var(--text);
  user-select: none;
}

.runs-filters-details > summary::-webkit-details-marker {
  display: none;
}

.runs-filters-summary-hint {
  font-weight: 500;
  color: var(--muted);
  font-size: 0.82rem;
}

.runs-filters-details[open] > summary {
  border-bottom: 1px solid var(--border);
  margin-bottom: 0.35rem;
}

.runs-filters-details .runs-controls {
  margin-bottom: 0.45rem;
  padding: 0 0.45rem 0.45rem;
}

.runs-controls--compact {
  gap: 0.32rem;
}

@media (min-width: 640px) {
  .runs-controls--compact {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .runs-controls--compact .runs-participant-filters {
    grid-column: 1 / -1;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .runs-controls--compact .runs-sort,
  .runs-controls--compact > select.runs-sort {
    min-width: 0;
  }

  .runs-controls--compact .runs-controls-row {
    grid-column: 1 / -1;
  }
}

.settings-provider-refresh-note {
  margin-top: 0.65rem;
  margin-bottom: 0.35rem;
}

.admin-api-status + .settings-provider-refresh-note {
  margin-top: 0.55rem;
}

#settings-provider-accounts.mc-provider-accounts {
  grid-column: unset;
  margin-top: 0.25rem;
}

.runs-participant-filters {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.4rem;
}

.modelcost-controls {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.5rem;
  align-items: end;
  margin-bottom: 0.6rem;
}

.modelcost-controls--filters {
  margin-bottom: 0.45rem;
  grid-template-columns:
    minmax(0, min(100%, 15rem))
    minmax(0, 6.5rem)
    minmax(0, 6.5rem)
    minmax(11rem, 15rem)
    auto;
  max-width: 58rem;
  align-items: end;
}

.modelcost-field--sort .runs-sort {
  width: 100%;
  min-width: 11rem;
}

.modelcost-field--refresh {
  display: flex;
  flex-direction: column;
  gap: 0.28rem;
  justify-content: flex-end;
}

.modelcost-field--refresh .modelcost-refresh-label {
  font-size: 0.85rem;
  line-height: 1.25;
  color: var(--muted);
}

.modelcost-field--refresh button {
  white-space: nowrap;
}

.modelcost-field--search {
  max-width: min(100%, 18rem);
}

  margin: 0 0 0.5rem;
  line-height: 1.45;
}

.modelcost-meta-line {
  margin: 0.35rem 0 0.75rem;
}

.modelcost-top-lead {
  margin: 0 0 0.75rem;
  line-height: 1.45;
  max-width: 48rem;
  font-size: 0.9rem;
  color: var(--muted);
}

.modelcost-subsection-title {
  margin: 1.25rem 0 0.45rem;
  padding-top: 0.5rem;
  border-top: 1px solid var(--border);
  font-size: 1.05rem;
  font-weight: 750;
  line-height: 1.25;
  color: var(--text);
}

.modelcost-batch-panel {
  margin-top: 0;
  margin-bottom: 0.5rem;
  padding: 0.85rem 1rem;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: color-mix(in srgb, var(--accent) 5%, var(--surface));
  width: 100%;
  max-width: none;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

.modelcost-batch-scenario-block {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.35rem;
  width: 100%;
}

.modelcost-batch-scenario-block .modelcost-batch-outcome {
  margin-top: 0.25rem;
}

.modelcost-batch-field-label {
  margin: 0;
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
}

.modelcost-batch-scenario-select {
  width: 100%;
  max-width: none;
  box-sizing: border-box;
  min-height: 2.25rem;
}

.modelcost-batch-persona-row {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.35rem 0.65rem;
  font-size: 0.88rem;
  line-height: 1.4;
}

.modelcost-batch-persona-key {
  font-weight: 700;
  color: var(--muted);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.modelcost-batch-persona-value {
  color: var(--text);
  font-weight: 600;
}

.modelcost-batch-preflight-hint {
  margin: 0;
  padding: 0.55rem 0.7rem;
  border-radius: 10px;
  border-left: 3px solid color-mix(in srgb, var(--accent) 55%, var(--border));
  background: color-mix(in srgb, var(--accent) 6%, var(--surface));
  font-size: 0.84rem;
  line-height: 1.5;
  color: var(--muted);
  width: 100%;
  box-sizing: border-box;
}

.modelcost-batch-preflight-hint p {
  margin: 0;
}

.modelcost-batch-params {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(7.5rem, 1fr));
  gap: 0.6rem 1rem;
  width: 100%;
  align-items: end;
  box-sizing: border-box;
}

.modelcost-batch-params .modelcost-field--api {
  grid-column: 1 / -1;
  max-width: min(100%, 20rem);
}

.modelcost-batch-params .modelcost-field--api select {
  width: 100%;
}

.modelcost-batch-params .modelcost-field--check-row {
  grid-column: 1 / -1;
  max-width: min(100%, 38rem);
}

.modelcost-batch-stack {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  width: 100%;
  align-items: stretch;
  margin-top: 1rem;
}

.modelcost-batch-stack .modelcost-actions {
  margin: 0;
}

.modelcost-input-compact {
  width: 100%;
  max-width: 5rem;
  box-sizing: border-box;
}

.modelcost-input-tokens {
  width: 100%;
  max-width: 6.5rem;
  box-sizing: border-box;
}

.modelcost-field--tight span,
.modelcost-field--reps span {
  white-space: nowrap;
}

.modelcost-field--locked span {
  color: var(--muted);
}

.modelcost-field--locked input:disabled,
.modelcost-field--locked select:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  background: color-mix(in srgb, var(--muted) 8%, var(--surface));
}

.modelcost-batch-outcome {
  margin-top: 0.6rem;
  padding: 0.45rem 0.55rem;
  border-radius: 8px;
  border: 1px solid var(--border);
  line-height: 1.45;
  min-height: 2.25rem;
}

.modelcost-batch-outcome.mc-batch-outcome--ok {
  border-color: rgba(46, 160, 67, 0.45);
  background: color-mix(in srgb, #2ea043 10%, var(--surface));
}

.modelcost-batch-outcome.mc-batch-outcome--error {
  border-color: rgba(248, 81, 73, 0.5);
  background: color-mix(in srgb, #f85149 10%, var(--surface));
}

body[data-theme="light"] .modelcost-batch-outcome.mc-batch-outcome--ok {
  background: rgba(46, 160, 67, 0.08);
}

body[data-theme="light"] .modelcost-batch-outcome.mc-batch-outcome--error {
  background: rgba(248, 81, 73, 0.08);
}

.mc-batch-spinner-wrap {
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
  margin-top: 0.55rem;
  padding: 0.55rem 0.65rem;
  border-radius: 8px;
  border: 1px solid color-mix(in srgb, var(--accent) 35%, var(--border));
  background: color-mix(in srgb, var(--accent) 8%, var(--surface));
  min-height: 1.5rem;
}

.mc-batch-spinner-wrap--hidden {
  display: none;
}

.mc-batch-spinner-ring {
  width: 1rem;
  height: 1rem;
  border-radius: 50%;
  border: 2px solid var(--border);
  border-top-color: color-mix(in srgb, var(--accent) 75%, var(--border));
  animation: mc-batch-spin 0.72s linear infinite;
  flex-shrink: 0;
}

.mc-batch-spinner-text {
  margin: 0;
  line-height: 1.45;
  max-width: 52rem;
}

.admin-right .scorecard {
  grid-template-columns: 1fr;
}

.admin-right .scorecard > .card {
  min-width: 0;
}

.admin-individual-radar-wrap {
  margin-bottom: 0.65rem;
  grid-column: 1 / -1;
  min-width: 0;
  max-width: 100%;
  width: 100%;
  box-sizing: border-box;
}

.admin-individual-radar-layout {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  min-width: 0;
  max-width: 100%;
}

.admin-individual-radar-chart {
  width: 100%;
  max-width: min(100%, 300px);
  margin: 0 auto;
  min-width: 0;
}

.admin-individual-radar-wrap .agent-test-chart-canvas-wrap {
  width: 100%;
  max-width: 100%;
  min-height: 0;
  overflow: hidden;
  aspect-ratio: 1.15 / 1;
}

.admin-individual-radar-wrap .admin-individual-radar-canvas {
  width: 100% !important;
  max-width: 100%;
  height: 100% !important;
  display: block;
}

.admin-individual-radar-table {
  width: 100%;
  max-width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
}

.admin-individual-radar-caption {
  caption-side: top;
  text-align: left;
  font-size: 0.78rem;
  color: var(--muted);
  margin: 0 0 0.35rem;
  padding: 0;
}

.admin-individual-radar-thead th {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted);
  font-weight: 600;
}

.admin-individual-radar-table th,
.admin-individual-radar-table td {
  padding: 0.35rem 0.45rem;
  text-align: left;
  border-bottom: 1px solid var(--border);
  overflow-wrap: anywhere;
}

.admin-individual-radar-table tbody th {
  font-weight: 600;
  color: var(--text);
}

@keyframes mc-batch-spin {
  to {
    transform: rotate(360deg);
  }
}

.admin-settings-human-end {
  margin-top: 1.75rem;
  padding-top: 1.1rem;
  border-top: 1px solid var(--border);
}

.modelcost-span2 {
  grid-column: span 2;
}

.mc-exec-provider-summary {
  width: 100%;
  box-sizing: border-box;
  margin: 0;
  padding: 0.55rem 0.7rem;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--accent) 6%, var(--surface));
  color: var(--text);
  font-size: 0.88rem;
  line-height: 1.45;
}

.mc-exec-provider-summary .mc-exec-provider-line strong {
  color: var(--text);
  font-weight: 700;
}

.mc-exec-provider-summary .mc-exec-provider-kicker {
  margin-top: 0.35rem;
  font-size: 0.8rem;
  color: var(--muted);
}

.mc-provider-accounts {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 0.6rem;
  margin: 0.35rem 0 0.15rem;
}

.mc-provider-account-card {
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 0.55rem 0.7rem;
  background: var(--surface);
  font-size: 0.86rem;
  line-height: 1.45;
  color: var(--text);
}

.mc-provider-account-card h4 {
  margin: 0 0 0.35rem;
  font-size: 0.95rem;
  font-weight: 700;
}

.mc-provider-account-status {
  font-size: 0.82rem;
  color: var(--muted);
  margin-bottom: 0.35rem;
}

.mc-provider-account-line {
  margin-top: 0.25rem;
  font-size: 0.84rem;
}

.mc-provider-account-detail {
  margin-top: 0.35rem;
}

.modelcost-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}

.modelcost-actions button {
  min-height: 40px;
}

.modelcost-batch-estimate {
  margin: 0;
}

.modelcost-batch-estimate--card {
  padding: 0.7rem 0.85rem;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--panel);
  width: 100%;
  box-sizing: border-box;
}

.modelcost-batch-estimate-inner {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.modelcost-batch-estimate-title {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text);
}

.modelcost-batch-estimate-amount {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text);
}

.modelcost-batch-estimate-amount--muted {
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--muted);
}

.modelcost-batch-estimate-meta {
  margin: 0;
  font-size: 0.86rem;
  line-height: 1.45;
  color: var(--muted);
}

.modelcost-batch-estimate-lead {
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.45;
  color: var(--text);
}

.modelcost-batch-estimate-assumptions {
  margin: 0;
  font-size: 0.84rem;
  line-height: 1.5;
  color: var(--muted);
}

.modelcost-batch-estimate-foot {
  margin: 0;
  font-size: 0.8rem;
  line-height: 1.45;
  color: var(--muted);
  font-style: italic;
}

.modelcost-batch-estimate-list {
  margin: 0;
  padding-left: 1.25rem;
  font-size: 0.84rem;
  line-height: 1.55;
  color: var(--muted);
}

.modelcost-batch-estimate-list li {
  margin-bottom: 0.25rem;
}

.modelcost-batch-estimate-list li:last-child {
  margin-bottom: 0;
}

.modelcost-batch-gateway-hint {
  margin: 0;
  line-height: 1.45;
  font-size: 0.88rem;
}

.modelcost-batch-gateway-hint--bad {
  margin: 0 0 0.4rem;
  color: var(--text);
  border-left: 3px solid #c45a4a;
  padding: 0.35rem 0.5rem 0.35rem 0.65rem;
  background: color-mix(in srgb, #c45a4a 12%, transparent);
  border-radius: 0 6px 6px 0;
}

body[data-theme="light"] .modelcost-batch-gateway-hint--bad {
  background: color-mix(in srgb, #c45a4a 10%, var(--surface));
}

.modelcost-batch-gateway-hint--unknown {
  margin: 0;
  opacity: 0.9;
  font-style: italic;
}

.modelcost-batch-gateway-hint .modelcost-batch-gateway-actions {
  margin-top: 0.35rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}

.modelcost tbody tr.mc-row-batch-mismatch {
  background: color-mix(in srgb, #c45a4a 14%, transparent);
}

body[data-theme="light"] .modelcost tbody tr.mc-row-batch-mismatch {
  background: color-mix(in srgb, #c45a4a 8%, var(--surface));
}

.modelcost tbody tr.mc-row-batch-unknown td.mc-callable-via {
  text-decoration: underline dotted;
  text-underline-offset: 2px;
}

.modelcost tbody tr.mc-row-user-batch-disabled {
  opacity: 0.48;
  background: color-mix(in srgb, var(--muted) 10%, transparent);
}

.modelcost tbody tr.mc-row-user-batch-disabled:hover {
  background: color-mix(in srgb, var(--muted) 12%, transparent);
}

.modelcost tbody tr.mc-row-user-batch-disabled td {
  color: var(--muted);
}

.modelcost tbody tr.mc-row-user-batch-disabled .mc-check {
  cursor: not-allowed;
}

.modelcost tbody tr.mc-row-user-batch-disabled .mc-model-id {
  color: var(--muted);
}

.mc-admin-only-tag {
  font-size: 0.78rem;
  color: var(--muted);
  font-style: italic;
  font-weight: normal;
}

.modelcost-help {
  margin: 0.35rem 0 0.55rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 0.35rem 0.65rem;
  background: var(--surface);
}

.modelcost-help summary {
  cursor: pointer;
  font-weight: 600;
  color: var(--text);
  font-size: 0.88rem;
}

.modelcost-help-body {
  margin-top: 0.45rem;
}

.modelcost-help-body p {
  margin: 0 0 0.5rem;
  line-height: 1.45;
}

.modelcost-help-body p:last-child {
  margin-bottom: 0;
}

.modelcost-pricing-meta {
  margin: 0.35rem 0 0.6rem;
  padding: 0.45rem 0.65rem;
  border-radius: 10px;
  border: 1px dashed var(--border);
  line-height: 1.45;
  font-size: 0.85rem;
  color: var(--muted);
}

.modelcost-pricing-meta--help {
  margin: 1rem 0 0;
}

.modelcost-field {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  font-size: 0.8rem;
  color: var(--muted);
}

.modelcost-skip-preflight > span {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.45rem;
  color: var(--text);
}

.modelcost {
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: auto;
  max-height: 55vh;
}

.modelcost table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.modelcost th,
.modelcost td {
  padding: 0.55rem 0.65rem;
  border-bottom: 1px solid var(--border);
  text-align: left;
  vertical-align: top;
}

.modelcost th {
  position: sticky;
  top: 0;
  background: var(--surface);
  z-index: 1;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
}

.modelcost th.mc-th-sortable {
  cursor: pointer;
  user-select: none;
}

.modelcost th.mc-th-sortable:hover {
  color: var(--text);
  background: rgba(128, 128, 128, 0.07);
}

.modelcost th.mc-th-sortable:focus-visible {
  outline: 2px solid var(--accent, #529aff);
  outline-offset: -2px;
}

.modelcost th.mc-th-callable,
.modelcost td.mc-callable-via {
  font-size: 0.82rem;
  letter-spacing: normal;
  text-transform: none;
  color: var(--text);
  max-width: 12rem;
  line-height: 1.35;
}

.modelcost th .mc-sort-ind {
  font-size: 0.68rem;
  opacity: 0.9;
}

.modelcost th.mc-th-model,
.modelcost td.mc-col-model {
  min-width: 12rem;
  max-width: 28rem;
}

.modelcost td.mc-col-model .mc-model-id {
  display: block;
  font-size: 0.85em;
  white-space: normal;
  word-break: break-word;
  overflow-wrap: anywhere;
  line-height: 1.35;
}

.modelcost td.mc-col-provider {
  white-space: nowrap;
}

.modelcost td code {
  font-size: 0.85em;
}

.agent-test-compare-table td.agent-compare-col-model,
.agent-test-compare-table th:nth-child(3) {
  width: 9rem;
  min-width: 6.5rem;
  max-width: 12rem;
  white-space: nowrap;
}

.agent-test-compare-table .agent-compare-model-code {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: block;
  max-width: 100%;
}

.agent-test-compare-table td.agent-compare-col-provider {
  white-space: nowrap;
}

@media (max-width: 640px) {
  .modelcost-controls {
    grid-template-columns: 1fr;
  }
  .modelcost-controls--filters {
    grid-template-columns: 1fr;
    max-width: none;
  }
  .modelcost-batch-params {
    grid-template-columns: 1fr;
  }
  .modelcost-batch-params .modelcost-field--api {
    grid-column: auto;
    max-width: none;
  }
  .modelcost-span2 {
    grid-column: auto;
  }
}

.runs-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-top: 0.6rem;
  padding-top: 0.6rem;
  border-top: 1px solid var(--border);
}

.runs-controls-row {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  justify-content: space-between;
}

.run-row {
  display: grid;
  grid-template-columns: 22px 1fr;
  gap: 0.55rem;
  align-items: start;
}

.run-card-lead {
  font-size: 0.9rem;
  line-height: 1.35;
  margin-bottom: 0.2rem;
  color: var(--text);
}

.run-card-lead strong {
  font-weight: 650;
}

.run-check {
  margin-top: 0.2rem;
}

.runs-filter,
.runs-sort {
  width: 100%;
  padding: 0.5rem 0.6rem;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
}

.runs-filter::placeholder {
  color: var(--muted);
}

.score-hero {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.stars {
  font-size: 1.25rem;
  letter-spacing: 0.12em;
  line-height: 1;
}

.stars .muted {
  color: var(--muted);
}

.score-big {
  font-size: 2rem;
  font-weight: 800;
  line-height: 1;
}

.score-hero,
.scorecard-card-hero {
  min-width: 0;
  max-width: 100%;
}

.score-context {
  margin-top: 0.35rem;
  color: var(--muted);
  font-size: 0.85rem;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.run-item {
  padding: 0.55rem 0.6rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  cursor: pointer;
}

.run-item:hover {
  filter: brightness(1.04);
}

.run-item.active {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(61, 139, 253, 0.15);
}

.run-meta {
  color: var(--muted);
  font-size: 0.85rem;
  margin-top: 0.25rem;
}

.run-title {
  font-weight: 700;
}

.run-id {
  margin-top: 0.25rem;
  font-size: 0.8rem;
  color: var(--muted);
  opacity: 0.9;
  word-break: break-all;
}

.admin-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  min-height: 0;
}

.admin-panel {
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.admin-pre {
  flex: 1;
  min-height: 60vh;
  margin: 0;
  padding: 0.75rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface);
  overflow: auto;
  white-space: pre-wrap;
  color: var(--text);
}

.admin-pre-sm {
  min-height: unset;
  max-height: 180px;
}

.admin-pre.hidden {
  display: none;
}

.scorecard {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.6rem;
  align-items: start;
  min-width: 0;
  max-width: 100%;
  width: 100%;
  box-sizing: border-box;
}

.scorecard > .run-status-banner {
  grid-column: 1 / -1;
}

.scorecard-card-hero,
.scorecard-card-signals,
.scorecard-card-telemetry,
.scorecard-card-analysis {
  grid-column: 1 / -1;
}

.score-signals-body {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.65rem 1.25rem;
}

.score-signals-col {
  min-width: 0;
}

.scorecard-card-telemetry {
  padding: 0.5rem 0.75rem;
}

.scorecard-card-telemetry .card-title {
  font-size: 0.92rem;
}

.scorecard-telemetry-line {
  margin-top: 0.2rem;
  font-size: 0.82rem;
  line-height: 1.45;
}

.card {
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--surface);
  padding: 0.75rem 0.8rem;
}

.card-title {
  font-weight: 700;
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  min-width: 0;
}

.card-title > * {
  min-width: 0;
  overflow-wrap: anywhere;
}

.card-sub {
  margin-top: 0.25rem;
  color: var(--muted);
  font-size: 0.85rem;
}

.bar {
  margin-top: 0.55rem;
  height: 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(127, 127, 127, 0.12);
  overflow: hidden;
}

.bar > div {
  height: 100%;
  background: var(--accent);
}

.pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.15rem 0.45rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  font-size: 0.8rem;
  color: var(--muted);
}

.transcript {
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--surface);
  padding: 0.5rem 0.4rem;
  overflow: auto;
  max-height: 60vh;
}

.verification {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

.v-card {
  width: 240px;
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  background: var(--surface);
}

.v-card img {
  display: block;
  width: 100%;
  height: auto;
}

.v-meta {
  padding: 0.5rem 0.6rem;
  color: var(--muted);
  font-size: 0.85rem;
}

.t-row {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 0.65rem;
  padding: 0.55rem 0.6rem;
  border-radius: 10px;
}

.t-row:hover {
  background: rgba(127, 127, 127, 0.08);
}

.t-meta {
  min-width: 0;
}

.t-who {
  font-weight: 700;
}

.t-when {
  margin-top: 0.15rem;
  font-size: 0.8rem;
  color: var(--muted);
}

.t-msg {
  white-space: pre-wrap;
  line-height: 1.45;
}

.transcript-hl-banner {
  margin: 0 0 0.55rem;
  padding: 0.5rem 0.6rem;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, #d97706 45%, var(--border));
  background: color-mix(in srgb, #d97706 12%, var(--surface));
  font-size: 0.84rem;
  line-height: 1.45;
}

.transcript-hl-banner-line + .transcript-hl-banner-line {
  margin-top: 0.35rem;
}

.transcript-hl-legend {
  margin: 0 0 0.5rem;
  padding: 0.4rem 0.55rem;
  border-radius: 8px;
  border: 1px dashed var(--border);
  background: color-mix(in srgb, var(--panel) 92%, transparent);
}

.transcript-hl-legend-title {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted);
  margin-bottom: 0.35rem;
}

.transcript-hl-legend-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.transcript-hl-chip {
  font-size: 0.72rem;
  padding: 0.15rem 0.45rem;
  border-radius: 6px;
  border: 1px solid var(--border);
  background: var(--surface);
}

.transcript-hl-chip--customer_aggravation {
  border-color: rgba(220, 38, 38, 0.45);
  background: rgba(220, 38, 38, 0.08);
}

.transcript-hl-chip--customer_escalation {
  border-color: rgba(185, 28, 28, 0.5);
  background: rgba(185, 28, 28, 0.1);
}

.transcript-hl-chip--agent_emotional,
.transcript-hl-chip--agent_rude,
.transcript-hl-chip--agent_dismissive {
  border-color: rgba(147, 51, 234, 0.45);
  background: rgba(147, 51, 234, 0.08);
}

.transcript-hl-chip--premature_commitment,
.transcript-hl-chip--premature_root_cause {
  border-color: rgba(217, 119, 6, 0.5);
  background: rgba(217, 119, 6, 0.1);
}

.transcript-hl-chip--agent_weak_empathy,
.transcript-hl-chip--agent_vague_response,
.transcript-hl-chip--agent_helpless {
  border-color: rgba(37, 99, 235, 0.45);
  background: rgba(37, 99, 235, 0.08);
}

.t-row--flagged {
  background: color-mix(in srgb, #d97706 8%, transparent);
  box-shadow: inset 3px 0 0 0 color-mix(in srgb, #d97706 70%, transparent);
}

.t-row--flagged-soft {
  background: color-mix(in srgb, #2563eb 6%, transparent);
  box-shadow: inset 3px 0 0 0 color-mix(in srgb, #2563eb 45%, transparent);
}

.t-flags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem;
  margin-top: 0.25rem;
}

.t-flag {
  font-size: 0.68rem;
  font-weight: 650;
  padding: 0.1rem 0.35rem;
  border-radius: 4px;
  border: 1px solid var(--border);
  color: var(--muted);
  line-height: 1.25;
}

.t-hl {
  padding: 0.05rem 0.12rem;
  border-radius: 3px;
  font-weight: 600;
  color: inherit;
}

.t-hl--customer_aggravation,
.t-hl--customer_escalation {
  background: rgba(220, 38, 38, 0.22);
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

.t-hl--agent_emotional,
.t-hl--agent_rude,
.t-hl--agent_dismissive {
  background: rgba(147, 51, 234, 0.2);
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

.t-hl--premature_commitment,
.t-hl--premature_root_cause {
  background: rgba(217, 119, 6, 0.28);
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

.t-hl--agent_weak_empathy,
.t-hl--agent_vague_response,
.t-hl--agent_helpless {
  background: rgba(37, 99, 235, 0.2);
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

.who-marcus .t-who {
  color: var(--marcus);
}

.who-pm .t-who {
  color: var(--user);
}

.who-instructor .t-who {
  color: var(--accent);
}

@media (max-width: 980px) {
  .admin-main {
    grid-template-columns: 1fr;
  }
  .admin-left {
    border-right: none;
    border-bottom: 1px solid var(--border);
  }
  .admin-pre {
    min-height: 40vh;
  }
  .scorecard {
    grid-template-columns: 1fr;
  }
  .t-row {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .admin-wrap {
    font-size: 16px;
  }

  body:has(.v-sim-bar):has(.admin-wrap) .v-sim-bar {
    flex-shrink: 0;
  }

  body:has(.v-sim-bar):has(.admin-wrap) .admin-tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    flex-wrap: nowrap;
    scrollbar-width: none;
    padding: 0.4rem max(0.65rem, env(safe-area-inset-left, 0px)) 0.45rem
      max(0.65rem, env(safe-area-inset-right, 0px));
    gap: 0.35rem;
    background: var(--surface);
    border-bottom: 1px solid var(--border);
  }

  body:has(.v-sim-bar):has(.admin-wrap) .admin-tabs::-webkit-scrollbar {
    display: none;
  }

  body:has(.v-sim-bar):has(.admin-wrap) .admin-tab-btn {
    flex: 0 0 auto;
    white-space: nowrap;
    padding: 0.42rem 0.72rem;
    font-size: 0.82rem;
  }

  body:has(.v-sim-bar):has(.admin-wrap) .admin-tab-btn.active {
    background: color-mix(in srgb, var(--accent) 12%, var(--surface));
    border-color: color-mix(in srgb, var(--accent) 40%, var(--border));
    color: var(--text);
    box-shadow: none;
  }

  .admin-top {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto auto;
    grid-template-areas:
      "heading heading heading heading"
      "actions actions actions actions";
    align-items: center;
    gap: 0.35rem 0.45rem;
    padding: 0.55rem max(0.75rem, env(safe-area-inset-left, 0px)) 0.6rem
      max(0.75rem, env(safe-area-inset-right, 0px));
    background: var(--surface);
    border-bottom: 1px solid var(--border);
  }

  body:has(.admin-wrap) .admin-top::before {
    display: none;
  }

  .admin-top > div:first-child {
    grid-area: heading;
    min-width: 0;
  }

  body:has(.admin-wrap) .admin-title {
    font-size: 1.02rem;
    line-height: 1.15;
  }

  body:has(.admin-wrap) .admin-sub {
    margin-top: 0.18rem;
    padding: 0;
    border: none;
    background: none;
    color: var(--muted);
    font-size: 0.78rem;
    line-height: 1.35;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    overflow: hidden;
  }

  body:has(.admin-wrap) .admin-status-row {
    background: var(--surface);
    border-bottom-color: var(--border);
    padding-top: 0.2rem;
    padding-bottom: 0.2rem;
  }

  .admin-actions {
    grid-area: actions;
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem;
  }

  body:has(.v-sim-bar):has(.admin-wrap) .admin-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem;
  }

  body:has(.v-sim-bar):has(.admin-wrap) .admin-login-cluster {
    flex: 1 1 100%;
    order: 10;
    padding-top: 0.35rem;
    border-top: 1px dashed var(--border);
  }

  body:has(.v-sim-bar):has(.admin-wrap) .admin-login-cluster.hidden {
    display: none !important;
  }

  body:has(.v-sim-bar):has(.admin-wrap) .admin-login-cluster:not(.hidden) .admin-login-fields {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.35rem;
    width: 100%;
  }

  body:has(.v-sim-bar):has(.admin-wrap) .admin-login-cluster:not(.hidden) .admin-login-remember {
    flex: 1 1 100%;
    min-height: auto;
    font-size: 0.78rem;
  }

  body:has(.v-sim-bar):has(.admin-wrap) .admin-login-cluster:not(.hidden) #admin-login {
    flex: 1 1 auto;
    min-height: 40px;
    padding-inline: 0.85rem;
  }

  body:has(.v-sim-bar):has(.admin-wrap) #admin-refresh {
    flex: 1 1 auto;
    min-width: 5.5rem;
  }

  body:has(.v-sim-bar):has(.admin-wrap) .v-guide-popover {
    flex: 0 0 auto;
  }

  body:has(.v-sim-bar):has(.admin-wrap) #admin-theme,
  body:has(.v-sim-bar):has(.admin-wrap) .admin-open-sim,
  body:has(.v-sim-bar):has(.admin-wrap) .vantage-identity-menu {
    flex: 0 0 auto;
  }

  body:has(.v-sim-bar):has(.admin-wrap) .admin-open-sim {
    margin-left: auto;
  }

  body:has(.v-sim-bar):has(.admin-wrap) .admin-actions:not(:has(.admin-login-cluster:not(.hidden))) #admin-refresh {
    flex: 1 1 auto;
  }

  .admin-actions button,
  .admin-actions .admin-link {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
  }

  .admin-login-cluster {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
  }

  .admin-login-fields {
    flex-direction: column;
    width: 100%;
  }

  .admin-login-input {
    min-width: 0;
    width: 100%;
    font-size: 16px;
    min-height: 44px;
  }

  .admin-login-remember {
    min-height: 44px;
    align-items: center;
  }

  .admin-left,
  .admin-right {
    padding-left: max(0.75rem, env(safe-area-inset-left, 0px));
    padding-right: max(0.75rem, env(safe-area-inset-right, 0px));
  }

  .runs-filter,
  .runs-sort {
    min-height: 44px;
    font-size: 16px;
  }

  .run-item {
    min-height: 44px;
  }

  .v-card {
    width: 100%;
    max-width: 100%;
  }

  .transcript {
    max-height: min(50vh, 400px);
  }

  .runs-footer button {
    min-height: 44px;
  }
}

/* Score analysis (heuristic narrative) */
.score-analysis-card .score-analysis-headline {
  font-weight: 650;
  color: var(--text);
  line-height: 1.45;
  margin-bottom: 0.5rem;
}

.score-analysis-interpretation {
  font-size: 0.9rem;
  line-height: 1.5;
  color: var(--text);
  padding: 0.55rem 0.65rem;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--surface);
  margin-bottom: 0.65rem;
}

.score-analysis-snapshot {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.45rem 0.65rem;
  padding: 0.55rem 0.65rem;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: rgba(82, 154, 255, 0.06);
  margin-bottom: 0.75rem;
  line-height: 1.45;
}

.score-analysis-snapshot-total {
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: var(--text);
}

.score-analysis-snapshot-label {
  font-weight: 750;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted);
}

.score-analysis-snapshot-summary {
  flex: 1 1 220px;
  color: var(--text);
  font-size: 0.9rem;
}

.score-analysis-good-bad {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 0.85rem;
}

.score-analysis-subhead {
  font-weight: 750;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--muted);
  margin-bottom: 0.45rem;
}

.score-analysis-gb-col {
  width: 100%;
  box-sizing: border-box;
  padding: 0.55rem 0.65rem;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--surface);
}

.score-analysis-gb-good {
  border-color: rgba(46, 160, 67, 0.35);
  background: rgba(46, 160, 67, 0.06);
}

.score-analysis-gb-watch {
  border-color: rgba(210, 153, 34, 0.45);
  background: rgba(210, 153, 34, 0.07);
}

.score-analysis-gb-row + .score-analysis-gb-row {
  margin-top: 0.55rem;
  padding-top: 0.55rem;
  border-top: 1px dashed var(--border);
}

.score-analysis-gb-title {
  font-weight: 700;
  font-size: 0.88rem;
  color: var(--text);
  margin-bottom: 0.2rem;
}

.score-analysis-gb-text {
  font-size: 0.86rem;
  line-height: 1.45;
  color: var(--muted);
}

.score-analysis-signals {
  margin-bottom: 0.65rem;
  line-height: 1.45;
}

.score-analysis-dimensions {
  display: grid;
  gap: 0.55rem;
  margin-bottom: 0.75rem;
}

.score-analysis-dim {
  padding: 0.5rem 0.6rem;
  border-radius: 9px;
  border: 1px solid var(--border);
  background: var(--surface);
}

.score-analysis-dim-title {
  font-weight: 700;
  font-size: 0.88rem;
  margin-bottom: 0.2rem;
}

.score-analysis-dim-text {
  font-size: 0.86rem;
  line-height: 1.45;
  color: var(--muted);
}

.score-analysis-caveats {
  padding: 0.55rem 0.65rem;
  border-radius: 10px;
  border: 1px dashed rgba(210, 153, 34, 0.5);
  background: rgba(210, 153, 34, 0.05);
}

.score-analysis-caveats-title {
  font-weight: 750;
  font-size: 0.82rem;
  margin-bottom: 0.35rem;
  color: var(--text);
}

.score-analysis-caveat {
  font-size: 0.86rem;
  line-height: 1.45;
  color: var(--muted);
}

.score-analysis-caveat + .score-analysis-caveat {
  margin-top: 0.35rem;
}

.score-bullets-label {
  font-weight: 700;
  font-size: 0.82rem;
  margin: 0.5rem 0 0.25rem;
  color: var(--muted);
}

.score-bullets-label:first-child {
  margin-top: 0;
}

.score-bullet {
  font-size: 0.88rem;
  line-height: 1.45;
  padding: 0.35rem 0.45rem;
  border-radius: 8px;
  margin-top: 0.35rem;
}

.score-bullet-good {
  background: rgba(46, 160, 67, 0.08);
  border-left: 3px solid rgba(46, 160, 67, 0.65);
}

.score-bullet-bad {
  background: rgba(200, 60, 60, 0.07);
  border-left: 3px solid rgba(200, 60, 60, 0.55);
}

/* Run list: failed-run explanation */
.run-error-hint {
  font-size: 0.82rem;
  line-height: 1.45;
  color: var(--text);
  margin-top: 0.35rem;
  padding: 0.45rem 0.55rem;
  border-radius: 8px;
  border-left: 3px solid rgba(200, 80, 80, 0.65);
  background: rgba(200, 60, 60, 0.08);
}

/* Scorecard: prominent error banner */
.run-status-banner {
  padding: 0.65rem 0.75rem;
  border-radius: 10px;
  margin-bottom: 0.75rem;
  border: 1px solid var(--border);
}

.run-status-error {
  border-color: rgba(200, 80, 80, 0.45);
  background: rgba(200, 60, 60, 0.09);
}

.run-status-info {
  border-color: rgba(59, 130, 246, 0.45);
  background: rgba(59, 130, 246, 0.08);
}

.run-status-banner-title {
  font-weight: 750;
  font-size: 0.92rem;
  margin-bottom: 0.35rem;
  color: var(--text);
}

.run-status-banner-body {
  font-size: 0.88rem;
  line-height: 1.5;
  color: var(--text);
}

.run-status-banner-raw {
  margin-top: 0.45rem;
  font-size: 0.78rem;
  line-height: 1.45;
  color: var(--muted);
  word-break: break-word;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

/* Settings: clients & rubric weights */
.admin-clients-add-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.75rem;
  align-items: center;
  margin-bottom: 0.75rem;
}

.admin-clients-list {
  margin: 0.5rem 0 1rem;
}

.admin-client-row {
  margin: 0 0 1.35rem;
  padding: 0.65rem 0.75rem 0.85rem;
  border-radius: 8px;
  border: 1px solid color-mix(in srgb, var(--border) 85%, transparent);
  background: color-mix(in srgb, var(--surface) 92%, var(--bg));
}

.admin-client-row:last-of-type {
  margin-bottom: 0;
  padding-bottom: 0.75rem;
}

.admin-client-row-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.45rem;
}

.admin-client-row-title {
  min-width: 0;
}

.admin-client-delete-btn {
  flex-shrink: 0;
}

.admin-client-assignments-scroll {
  overflow-x: auto;
  margin-top: 0.1rem;
}

.admin-client-assignments-wrap {
  min-width: min(100%, 36rem);
}

.admin-client-assignments-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.84rem;
  margin: 0;
}

.admin-client-assignments-table th,
.admin-client-assignments-table td {
  border: 1px solid color-mix(in srgb, var(--border) 80%, transparent);
  padding: 0.28rem 0.45rem;
  vertical-align: middle;
}

.admin-client-assignments-table thead th {
  background: color-mix(in srgb, var(--surface) 88%, var(--bg));
  font-weight: 650;
}

.admin-client-assignments-table tbody th[scope="row"] {
  font-weight: 500;
  text-align: left;
}

.admin-client-assignments-table .num {
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.admin-client-asg-actions {
  text-align: right;
  white-space: nowrap;
  width: 1%;
}

.admin-client-edit-asg-btn {
  font-size: 0.78rem;
  padding: 0.18rem 0.42rem;
}

.admin-client-no-assigns {
  margin: 0.25rem 0 0;
  max-width: 42rem;
}

.admin-client-save-overwrite-hint {
  margin: 0.45rem 0 0;
  max-width: 44rem;
  line-height: 1.45;
}

.admin-client-weight-row {
  padding-bottom: 1.15rem;
  margin-bottom: 0.85rem;
  border-bottom: 1px solid color-mix(in srgb, var(--border) 55%, transparent);
}

.admin-client-weight-row:last-of-type {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}

.admin-client-weight-title {
  font-weight: 650;
  margin: 0 0 0.2rem;
  font-size: 0.98rem;
}

.admin-client-weight-desc {
  margin: 0 0 0.45rem;
  max-width: 36rem;
  line-height: 1.4;
  font-size: 0.86rem;
}

.admin-client-weights-radar-wrap {
  display: flex;
  justify-content: center;
  margin: 0.15rem 0 1.1rem;
}

#admin-client-weights-radar {
  display: block;
  max-width: 100%;
}

.admin-client-weight-slider-row {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  margin-top: 0.35rem;
  width: 100%;
  max-width: min(100%, 28rem);
}

.admin-client-weight-slider {
  flex: 1;
  min-width: 0;
  height: 1.4rem;
  accent-color: #529aff;
}

.admin-client-weight-value {
  flex: 0 0 auto;
  min-width: 3.5rem;
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-size: 0.9rem;
  color: var(--text);
}

.admin-client-input-compact {
  max-width: 14rem;
  width: 100%;
}

.admin-client-select-compact {
  max-width: min(100%, 22rem);
  width: 100%;
}

.admin-client-batch-scenario-hint {
  margin: 0.1rem 0 0.45rem;
  max-width: 40rem;
  line-height: 1.45;
  color: var(--muted);
  font-size: 0.88rem;
}

.admin-client-weights-total {
  margin: 0.35rem 0 0.75rem;
  padding: 0.45rem 0.6rem;
  border-radius: 6px;
  background: rgba(82, 154, 255, 0.08);
  border: 1px solid rgba(82, 154, 255, 0.2);
}

.admin-client-assign-details {
  margin-top: 0.75rem;
}

.admin-client-assign-grid {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-top: 0.5rem;
}

.admin-run-ask-panel {
  grid-column: 1 / -1;
}

.admin-run-ask-hint {
  margin: 0 0 0.5rem;
}

.admin-run-ask-messages {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  max-height: min(42vh, 320px);
  overflow-y: auto;
  padding: 0.55rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: color-mix(in srgb, var(--bg) 40%, var(--surface));
  margin-bottom: 0.55rem;
}

.admin-run-ask-empty {
  margin: 0.35rem 0;
}

.admin-run-ask-msg {
  max-width: 95%;
  padding: 0.45rem 0.6rem;
  border-radius: 10px;
  border: 1px solid var(--border);
}

.admin-run-ask-msg--user {
  align-self: flex-end;
  background: color-mix(in srgb, var(--accent) 12%, var(--surface));
  border-color: color-mix(in srgb, var(--accent) 35%, var(--border));
}

.admin-run-ask-msg--assistant {
  align-self: flex-start;
  background: var(--surface);
}

.admin-run-ask-msg-label {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted);
  margin-bottom: 0.2rem;
}

.admin-run-ask-msg-body {
  font-size: 0.86rem;
  line-height: 1.45;
  white-space: pre-wrap;
  word-break: break-word;
}

.admin-run-ask-form {
  display: flex;
  gap: 0.5rem;
  align-items: flex-end;
}

.admin-run-ask-form textarea {
  flex: 1;
  min-height: 2.6rem;
  resize: vertical;
  padding: 0.45rem 0.55rem;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface);
  color: var(--text);
  font: inherit;
  font-size: 0.88rem;
}

.admin-run-ask-form textarea:disabled {
  opacity: 0.55;
}

.admin-run-ask-form button {
  flex-shrink: 0;
}

/* ——— Platform activity admin ——— */
body.activity-admin-page {
  --bg: var(--v-band, #f5f5f5);
  --surface: var(--v-white, #ffffff);
  --border: var(--v-border, #e5e5e5);
  --text: var(--v-ink, #171717);
  --muted: var(--v-muted, #525252);
  --admin-bg: var(--bg);
}

.admin-wrap--activity {
  width: 100%;
  max-width: none;
}

.activity-main {
  flex: 1;
  min-width: 0;
  width: 100%;
  max-width: 72rem;
  margin: 0 auto;
  padding: 0.75rem 1rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.activity-toolbar {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 0.85rem 1rem;
}

.activity-controls {
  display: grid;
  grid-template-columns: minmax(7.5rem, 10.5rem) minmax(7.5rem, 10.5rem) minmax(0, 1fr);
  gap: 0.75rem;
  margin: 0;
  align-items: end;
}

.activity-filter {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  min-width: 0;
}

.activity-filter select.secondary,
.activity-filter input.secondary {
  width: 100%;
  min-width: 0;
}

.activity-filter--search {
  min-width: 0;
}

.activity-filter-label {
  font-size: 0.72rem;
  font-weight: 650;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.activity-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin: 0.65rem 0 0;
  padding-top: 0.65rem;
  border-top: 1px solid var(--border);
}

.activity-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.22rem 0.55rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--surface);
  font-size: 0.78rem;
  color: var(--muted);
}

.activity-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface);
}

.activity-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.84rem;
}

.activity-table th,
.activity-table td {
  padding: 0.55rem 0.65rem;
  border-bottom: 1px solid var(--border);
  text-align: left;
  vertical-align: top;
}

.activity-table th {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted);
  background: color-mix(in srgb, var(--bg) 70%, var(--surface));
}

.activity-table tr:last-child td {
  border-bottom: none;
}

.activity-empty {
  color: var(--muted);
  text-align: center;
  padding: 1.25rem !important;
}

.activity-product {
  display: block;
  font-weight: 650;
  text-transform: capitalize;
}

.activity-type {
  display: block;
  font-size: 0.72rem;
  color: var(--muted);
}

.activity-identity {
  display: block;
  font-weight: 550;
  word-break: break-word;
}

.activity-id-kind {
  display: inline-block;
  margin-top: 0.15rem;
  font-size: 0.68rem;
  color: var(--muted);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 0.05rem 0.4rem;
}

.activity-ref {
  font-size: 0.75rem;
}

@media (max-width: 720px) {
  .activity-main {
    padding-inline: 0.75rem;
  }

  .activity-controls {
    grid-template-columns: 1fr;
  }
}
