:root {
  /* ═══════════════════════════════════════════════════════════════
     VAIRIFEYE DESIGN SYSTEM — Defense-grade. Metallic. Technical.
     Steel/Navy/Silver palette. Color reserved for STATUS ONLY.
     ═══════════════════════════════════════════════════════════════ */

  /* ── Environment — Near-black field, navy as undertone only ── */
  --bg-top: #04060E;
  --bg-mid: #06091A;
  --bg-bottom: #080C1E;

  /* ── Surfaces — Black-navy glass panels ── */
  --surface: rgba(8, 10, 24, 0.82);
  --surface-strong: rgba(10, 13, 30, 0.92);
  --surface-soft: rgba(8, 10, 24, 0.70);
  --surface-card: linear-gradient(180deg, rgba(10, 13, 30, 0.90) 0%, rgba(8, 10, 24, 0.85) 100%);
  --surface-card-soft: linear-gradient(180deg, rgba(10, 13, 30, 0.85) 0%, rgba(8, 10, 24, 0.78) 100%);
  --surface-button: rgba(255, 255, 255, 0.04);
  --surface-button-strong: rgba(255, 255, 255, 0.07);
  --input-bg: rgba(255, 255, 255, 0.03);
  --preview-bg: linear-gradient(180deg, rgba(4, 6, 14, 0.94) 0%, rgba(8, 10, 24, 0.88) 100%);

  /* ── Typography — Silver selective, high contrast ── */
  --ink: #9CA3BF;            /* Muted silver — body text */
  --ink-strong: #E2E4EB;     /* Bright silver — headings, emphasis */
  --muted: #555D7A;          /* Deep dimmed — labels, captions */

  /* ── Borders — engineered chrome edges ── */
  --line: rgba(226, 228, 235, 0.06);
  --line-strong: rgba(226, 228, 235, 0.10);
  --line-glow: rgba(44, 125, 255, 0.04);

  /* ── Brand — Verification Blue (from brand board #2C7DFF) ── */
  --brand: #2C7DFF;
  --brand-strong: #1B65E0;
  --brand-soft: rgba(44, 125, 255, 0.08);
  --brand-glow: 0 0 12px rgba(44, 125, 255, 0.10);

  /* ── Glow — minimal, not decorative ── */
  --glow-primary: rgba(44, 125, 255, 0.04);
  --glow-secondary: rgba(44, 125, 255, 0.02);
  --glow-subtle: rgba(44, 125, 255, 0.01);
  --glow-accent: rgba(44, 125, 255, 0.03);

  /* ── Action — Verification Blue ── */
  --accent: #2C7DFF;
  --accent-soft: rgba(44, 125, 255, 0.06);

  /* ── Signal — Sensor Green (from brand board #79BF43) ── */
  --signal-optic: #79BF43;
  --signal-optic-soft: rgba(121, 191, 67, 0.06);

  /* ── Shell — tenant override ── */
  --shell-accent: #2C7DFF;
  --shell-accent-soft: rgba(44, 125, 255, 0.06);

  /* ── Status — semantic only (green = Sensor Green from brand) ── */
  --success: #79BF43;
  --success-soft: rgba(121, 191, 67, 0.06);
  --warning: #f59e0b;
  --warning-soft: rgba(245, 158, 11, 0.06);
  --danger: #ef4444;
  --danger-soft: rgba(239, 68, 68, 0.06);
  --optic-ring: rgba(160, 5, 6, 0.25);

  /* ── Depth — deep black shadows, no decorative glow ── */
  --shadow: 0 24px 80px rgba(0, 0, 0, 0.6);
  --shadow-soft: 0 10px 32px rgba(0, 0, 0, 0.4);
  --shadow-glow: none;
  --shadow-panel: 0 6px 24px rgba(0, 0, 0, 0.35), 0 1px 4px rgba(0, 0, 0, 0.25);

  /* ── Glass — engineered panels, specular top edges ── */
  --glass-blur: blur(16px) saturate(130%);
  --glass-border: 1px solid rgba(226, 228, 235, 0.05);
  --glass-border-active: 1px solid rgba(44, 125, 255, 0.18);
  --glass-border-glow: 1px solid rgba(44, 125, 255, 0.06);

  /* ── Typography ── */
  --font-display: "Montserrat", "Arial Narrow", Arial, sans-serif;
  --font-body: "IBM Plex Sans", "Segoe UI", sans-serif;
  --font-mono: "IBM Plex Mono", "SF Mono", Consolas, monospace;

  /* ── Motion ── */
  --ease: cubic-bezier(0.22, 0.68, 0, 1);
  --speed: 0.15s;
}

body[data-theme="light"] {
  --bg-top: #E8ECF2;
  --bg-mid: #F2F4F8;
  --bg-bottom: #E0E4EC;
  --surface: rgba(255, 255, 255, 0.78);
  --surface-strong: rgba(255, 255, 255, 0.88);
  --surface-soft: rgba(245, 248, 252, 0.78);
  --surface-card: linear-gradient(180deg, rgba(255, 255, 255, 0.85), rgba(248, 250, 253, 0.75));
  --surface-card-soft: linear-gradient(180deg, rgba(255, 255, 255, 0.88), rgba(248, 250, 253, 0.78));
  --surface-button: rgba(255, 255, 255, 0.64);
  --surface-button-strong: rgba(255, 255, 255, 0.9);
  --input-bg: rgba(255, 255, 255, 0.88);
  --preview-bg: linear-gradient(180deg, rgba(242, 244, 248, 0.96), rgba(232, 236, 242, 0.9));
  --ink: #3A4556;
  --ink-strong: #1A2433;
  --muted: #6B7685;
  --line: rgba(26, 36, 51, 0.10);
  --line-strong: rgba(26, 36, 51, 0.18);
  --line-glow: rgba(44, 125, 255, 0.04);
  --brand: #2C7DFF;
  --brand-strong: #1B65E0;
  --brand-soft: rgba(44, 125, 255, 0.08);
  --shadow: 0 20px 60px rgba(0, 0, 0, 0.08);
  --shadow-soft: 0 8px 24px rgba(0, 0, 0, 0.05);
  --shadow-glow: none;
  --shadow-panel: 0 4px 16px rgba(0, 0, 0, 0.06);
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100vh;
  background-color: var(--bg-bottom);
}

body {
  font-family: var(--font-body);
  color: var(--ink);
  background-color: var(--bg-bottom);
  background-image:
    linear-gradient(180deg, var(--bg-top), var(--bg-mid) 48%, var(--bg-bottom));
  background-attachment: fixed;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 16% 18%, rgba(255, 255, 255, 0.02), transparent 14%),
    radial-gradient(circle at 84% 8%, rgba(44, 125, 255, 0.02), transparent 16%);
}

h1,
h2,
h3,
p,
pre {
  margin: 0;
}

h1 {
  font-family: var(--font-display);
  font-size: clamp(1.15rem, 1.6vw, 1.35rem);
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: 0.01em;
  text-wrap: balance;
}

h2 {
  font-family: var(--font-display);
  font-size: clamp(0.95rem, 1.3vw, 1.1rem);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: 0.01em;
  text-wrap: balance;
}

h3 {
  font-family: var(--font-display);
  font-size: 0.88rem;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.01em;
}

.shell {
  position: relative;
  z-index: 1;
  max-width: 1520px;
  margin: 0 auto;
  padding: 10px 14px 24px;
}

.shell::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  box-shadow: none;
  background:
    radial-gradient(ellipse at top right, rgba(44, 125, 255, 0.015), transparent 50%);
}

.glass-panel {
  background: linear-gradient(180deg, var(--surface-strong), var(--surface));
  border: var(--glass-border);
  box-shadow:
    var(--shadow-panel),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
  backdrop-filter: var(--glass-blur);
}

.topbar,
.hero,
.panel,
.report-stage,
.saved-runs-panel,
.login-panel,
.modal-panel,
.launch-bar {
  border-radius: 16px;
}

/* ──────────────────────────────────────────────
   HERO — SLIM METRICS STRIP
   ────────────────────────────────────────────── */
.hero-slim {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 6px 16px;
}
.hero-slim .hero-main,
.hero-slim .hero-metrics {
  display: none;
}
.hero-slim #hero-brief {
  display: none !important;
}
.hero-slim-label {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  color: var(--muted);
  white-space: nowrap;
}
.hero-metrics-row {
  display: flex;
  gap: 18px;
  margin-left: auto;
}
.metric-pill {
  font-size: 0.76rem;
  color: var(--muted);
}
.metric-pill strong {
  color: var(--ink-strong);
  margin-left: 3px;
}

/* ──────────────────────────────────────────────
   LAUNCH BAR — PRIMARY ACTION SURFACE
   ────────────────────────────────────────────── */
.launch-bar {
  padding: 12px 16px 10px;
  margin-bottom: 8px;
}
.launch-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.launch-shell {
  width: auto;
  min-width: 110px;
  flex-shrink: 0;
}
.launch-lookup {
  flex: 1;
  min-width: 180px;
  position: relative;
}
.launch-lookup input {
  width: 100%;
}
.launch-pull {
  flex-shrink: 0;
}
.launch-divider {
  width: 1px;
  height: 26px;
  background: var(--line);
  flex-shrink: 0;
}
.launch-dots {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}
.ls-dot {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.7rem;
  color: var(--muted);
  padding: 2px 8px;
  border-radius: 20px;
  background: var(--surface-button);
  border: 1px solid var(--line);
  white-space: nowrap;
}
.ls-dot::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--muted);
  flex-shrink: 0;
}
.ls-dot.ls-ok::before { background: var(--success); }
.ls-dot.ls-warn::before { background: var(--warning); }
.ls-dot.ls-err::before { background: var(--danger); }

.launch-bar .mode-toggle-bar {
  margin: 0;
  flex-shrink: 0;
}
.launch-go {
  padding: 8px 22px;
  font-size: 0.88rem;
  font-weight: 600;
  background: linear-gradient(135deg, var(--accent), var(--brand-strong));
  flex-shrink: 0;
  border: 1px solid rgba(44, 125, 255, 0.3);
  box-shadow: 0 4px 18px rgba(44, 125, 255, 0.2);
}
.launch-go:hover {
  box-shadow: 0 6px 28px rgba(44, 125, 255, 0.35);
  border-color: rgba(44, 125, 255, 0.5);
}

.launch-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 8px;
  font-size: 0.74rem;
  color: var(--muted);
  flex-wrap: wrap;
}
.launch-hint {
  font-size: 0.74rem;
  color: var(--muted);
  margin: 0;
}
.launch-status-text {
  margin-left: auto;
  font-size: 0.74rem;
  color: var(--muted);
}

/* ──────────────────────────────────────────────
   COLLAPSIBLE PANELS
   ────────────────────────────────────────────── */
[data-tab-panel="dashboard"] .panel.is-collapsed > *:not(.panel-header) {
  display: none !important;
}
[data-tab-panel="dashboard"] .panel > .panel-header {
  cursor: pointer;
  user-select: none;
}
[data-tab-panel="dashboard"] .panel > .panel-header .section-label::before {
  content: "\25B6";
  display: inline-block;
  margin-right: 6px;
  font-size: 0.55rem;
  transition: transform 0.2s ease;
  vertical-align: middle;
}
[data-tab-panel="dashboard"] .panel:not(.is-collapsed) > .panel-header .section-label::before {
  transform: rotate(90deg);
}

/* Override workspace to single column on dashboard */
[data-tab-panel="dashboard"] .workspace {
  display: block;
}
[data-tab-panel="dashboard"] .workspace-main,
[data-tab-panel="dashboard"] .workspace-side {
  display: block;
}
[data-tab-panel="dashboard"] .panel-stack {
  display: grid;
  gap: 8px;
}
[data-tab-panel="dashboard"] .workspace-side {
  margin-top: 8px;
  display: grid;
  gap: 8px;
}

.topbar {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-end;
  padding: 12px 20px;
  background: linear-gradient(180deg, rgba(10, 13, 30, 0.95), rgba(8, 10, 24, 0.90));
  border-bottom: 1px solid rgba(226, 228, 235, 0.04);
}

.brand-lockup,
.brand-copy,
.hero-copy,
.panel-header > div,
.login-copy {
  display: grid;
  gap: 5px;
  min-width: 0;
}

/* ── Vairifeye Brand — command bar identity ── */
.vairifeye-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}
.vairifeye-brand .brand-mark {
  width: 150px;
  height: auto;
  min-height: unset;
  padding: 0;
  border-radius: 0;
  background: none;
  border: none;
  box-shadow: none;
  display: flex;
  align-items: center;
  justify-content: center;
}
.vairifeye-mark {
  width: 150px;
  height: auto;
  display: block;
  filter: drop-shadow(0 2px 12px rgba(0, 0, 0, 0.5));
}
.vairifeye-wordmark {
  display: none; /* Wordmark is now part of the lockup image */
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.35rem;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--ink-strong);
  margin: 0;
  line-height: 1;
}
.shell-brand-bar {
  display: flex;
  align-items: center;
  gap: 6px;
}
.shell-badge-inline {
  display: inline-flex;
  align-items: center;
  padding: 2px 7px;
  border-radius: 4px;
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  background: rgba(155, 163, 175, 0.08);
  border: 1px solid rgba(155, 163, 175, 0.12);
}

/* ── Vairifeye Login — vector lockup on dark panel ── */
.login-lockup {
  display: block;
  width: 100%;
  max-width: 380px;
  height: auto;
  margin: 0 auto 8px;
}
.login-tagline {
  font-family: var(--font-body);
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--muted);
  margin: 0;
}
.login-shell-badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 12px;
  border-radius: 999px;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  background: rgba(155, 163, 175, 0.06);
  border: 1px solid rgba(155, 163, 175, 0.12);
}

/* Legacy compat — keeps old references from breaking */
.brand-mark {
  display: grid;
  place-items: center;
}

.brand-chip,
.section-label,
.eyebrow,
.identity-label,
.header-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: fit-content;
  max-width: 100%;
  padding: 3px 8px;
  border-radius: 4px;
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border: 1px solid rgba(44, 125, 255, 0.12);
  background: rgba(44, 125, 255, 0.08);
  color: var(--brand);
  text-align: center;
}

.header-status,
.topbar-actions,
.panel-actions,
.chip-row,
.history-actions,
.reference-actions,
.file-bar,
.history-scoreline {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.topbar-actions {
  justify-content: flex-end;
}

.header-badge.subtle {
  background: var(--surface-button);
  color: var(--muted);
}

.header-badge.is-connected {
  background: var(--success-soft);
  color: var(--success);
  border-color: rgba(95, 150, 52, 0.2);
}

.header-badge.is-warning {
  background: var(--warning-soft);
  color: var(--warning);
  border-color: rgba(184, 133, 24, 0.18);
}

.header-badge.shell-badge {
  background: rgba(37, 99, 235, 0.12);
  color: #6ba5ed;
  border: 1px solid rgba(37, 99, 235, 0.28);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.identity {
  display: flex;
  gap: 6px;
  align-items: center;
  min-width: 0;
  padding: 6px 10px;
  border-radius: 6px;
  background: var(--surface-button);
  border: 1px solid var(--line);
  font-size: 0.8rem;
}

.identity strong {
  color: var(--ink-strong);
  overflow-wrap: anywhere;
}

.lede,
.panel-copy,
.report-meta,
.status,
.reference-item small,
.login-note,
.login-error {
  color: var(--muted);
  line-height: 1.58;
}

.lede,
.panel-copy {
  max-width: 58ch;
  font-size: 0.8rem;
}

.hero-copy .panel-copy {
  max-width: 44ch;
}

/* intake-steps removed — browser-scraping workflow was removed */

/* Intake action row — buttons with step numbers */
.intake-action-row {
  display: flex;
  gap: 6px;
  align-items: center;
}
/* .btn-step-num removed — was part of intake-steps workflow */

.hero {
  margin-top: 8px;
  padding: 10px 14px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
}

.hero-main,
.hero-metrics,
.workspace-main,
.workspace-side,
.panel-stack {
  display: grid;
  gap: 8px;
}

.hero-brief,
.hero-metrics,
.summary-grid,
.scoreboard,
.toggle-grid {
  display: grid;
  gap: 6px;
}

.summary-grid.compact {
  display: none;
}

#intake-status {
  display: none;
}

.hero-brief {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.hero-metrics {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.brief-card,
.metric-card,
.summary-card,
.score,
.history-item,
.reference-item,
.toggle-card {
  min-width: 0;
  overflow: hidden;
  background: var(--surface-card);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-soft);
}

.brief-card,
.metric-card,
.summary-card,
.score,
.toggle-card {
  border-radius: 6px;
  padding: 8px 10px;
}

.brief-card strong,
.metric-card strong,
.summary-card strong,
.score strong {
  display: block;
  margin-top: 2px;
  font-size: 0.88rem;
  color: var(--ink-strong);
  line-height: 1.2;
  overflow-wrap: anywhere;
}

.brief-title,
.metric-card span,
.summary-card span,
.score span,
label span {
  display: block;
  font-size: 0.72rem;
  color: var(--muted);
}

.brief-card small {
  display: block;
  margin-top: 4px;
  font-size: 0.72rem;
  color: var(--muted);
  line-height: 1.4;
}

.summary-card.pass strong,
.score.pass strong {
  color: var(--success);
}

.summary-card.fail strong,
.score.fail strong {
  color: var(--danger);
}

.summary-card.warning strong,
.score.warning strong {
  color: var(--warning);
}

.summary-card.default strong,
.score.na strong {
  color: var(--ink-strong);
}

.view-tabs {
  display: inline-flex;
  gap: 4px;
  margin: 8px 0 0;
  padding: 3px;
  border-radius: 6px;
  background: var(--surface-button);
  border: 1px solid var(--line);
}

.view-tab,
button,
.ghost-button,
.file-pill,
.mode-choice {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: 0;
  border-radius: 6px;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  text-decoration: none;
  transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.view-tab,
.ghost-button {
  padding: 6px 12px;
  background: transparent;
  color: var(--muted);
  border: 1px solid transparent;
  font-size: 0.82rem;
}

.view-tab.is-active {
  background: var(--surface-button-strong);
  color: var(--ink-strong);
  border-color: var(--line);
  box-shadow: 0 10px 22px rgba(16, 44, 71, 0.08);
}

button,
.file-pill {
  padding: 7px 14px;
  background: linear-gradient(135deg, var(--brand-strong), var(--brand));
  color: white;
  font-size: 0.82rem;
  box-shadow: 0 8px 18px rgba(23, 70, 120, 0.14);
}

.ghost-button {
  background: var(--surface-button);
  color: var(--ink-strong);
  border-color: var(--line);
}

.compact-button {
  padding: 5px 10px;
  font-size: 0.78rem;
}

.danger-button {
  color: var(--danger);
}

.disabled-link {
  pointer-events: none;
  opacity: 0.5;
}

button:disabled {
  opacity: 0.48;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

button:hover,
.ghost-button:hover,
.file-pill:hover,
.mode-choice:hover,
.view-tab:hover {
  transform: translateY(-1px);
}

.tab-panel {
  display: none;
}

.tab-panel.is-active {
  display: block;
}

/* ──────────────────────────────────────────────
   SETTINGS SUB-TABS
   ────────────────────────────────────────────── */
.settings-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 2px;
  padding: 4px;
  margin: 0 0 6px;
  border-radius: 8px;
  background: var(--surface-button);
  border: 1px solid var(--line);
}

.settings-tab {
  padding: 7px 16px;
  background: transparent;
  color: var(--muted);
  border: 1px solid transparent;
  border-radius: 6px;
  font: inherit;
  font-size: 0.78rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.settings-tab:hover {
  background: var(--surface-button-strong);
  color: var(--ink);
}

.settings-tab.is-active {
  background: var(--surface-button-strong);
  color: var(--ink-strong);
  border-color: var(--line);
  box-shadow: 0 2px 8px rgba(16, 44, 71, 0.1);
}

.settings-panel {
  display: none;
}

.settings-panel.is-active {
  display: block;
}

/* ── Audit log table ── */
.ent-audit-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.76rem;
}
.ent-audit-table th {
  text-align: left;
  font-weight: 600;
  color: var(--muted);
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 8px 10px;
  border-bottom: 1px solid var(--line-strong);
  white-space: nowrap;
}
.ent-audit-table td {
  padding: 6px 10px;
  border-bottom: 1px solid var(--line);
  color: var(--ink);
  vertical-align: top;
}
.ent-audit-table tbody tr:hover {
  background: var(--surface-button);
}
.ent-log-type {
  font-family: "SF Mono", "Consolas", monospace;
  font-size: 0.7rem;
  padding: 1px 6px;
  border-radius: 4px;
  background: var(--surface-button);
  color: var(--brand);
}

.workspace {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(280px, 0.6fr);
  gap: 10px;
  margin-top: 8px;
}
.workspace.workspace-full {
  grid-template-columns: 1fr;
}

.panel,
.report-stage,
.saved-runs-panel,
.login-panel {
  padding: 14px;
}

.panel-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
}

.autocomplete-wrap {
  position: relative;
}

.autocomplete-list {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  z-index: 200;
  margin: 2px 0 0;
  padding: 4px 0;
  list-style: none;
  max-height: 260px;
  overflow-y: auto;
  background: var(--surface-strong);
  backdrop-filter: blur(18px);
  border: 1px solid var(--line-strong);
  border-radius: 6px;
  box-shadow: var(--shadow);
}

.autocomplete-list.is-open {
  display: block;
}

.autocomplete-list li {
  padding: 6px 10px;
  font-size: 0.78rem;
  color: var(--ink);
  cursor: pointer;
  border-bottom: 1px solid var(--line);
}

.autocomplete-list li:last-child {
  border-bottom: none;
}

.autocomplete-list li:hover,
.autocomplete-list li.is-active {
  background: var(--brand-soft);
  color: var(--ink-strong);
}

.autocomplete-list li .ac-label {
  font-weight: 600;
  color: var(--ink-strong);
}

.autocomplete-list li .ac-meta {
  display: block;
  font-size: 0.7rem;
  color: var(--muted);
  margin-top: 1px;
}

.stack-field {
  display: grid;
  gap: 5px;
  margin-top: 8px;
}

.preview-stage {
  display: grid;
  grid-template-columns: 7fr 3fr;
  gap: 10px;
  margin-top: 8px;
}

.preview-card {
  display: grid;
  gap: 12px;
  min-width: 0;
}

.preview-frame-header {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: center;
  color: var(--muted);
  font-size: 0.75rem;
  font-weight: 700;
}

.preview-caption {
  overflow-wrap: anywhere;
  text-align: right;
}

.preview-frame {
  background: var(--preview-bg);
  border: 1px solid var(--line);
  border-radius: 10px;
  min-height: 520px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  position: relative;
  box-shadow: var(--shadow-soft);
}

.preview-frame img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

.preview-image {
  width: 100%;
  height: 100%;
  min-height: 520px;
  object-fit: contain;
  display: block;
}

.preview-placeholder {
  min-height: 180px;
  display: grid;
  place-items: center;
  gap: 8px;
  padding: 20px;
  text-align: center;
  color: var(--muted);
  font-size: 0.8rem;
}

.preview-placeholder strong {
  color: var(--ink-strong);
  font-size: 0.9rem;
}

.preview-placeholder--staged {
  gap: 6px;
  justify-content: center;
}

.preview-placeholder-num {
  font-size: 2.2rem;
  font-weight: 700;
  letter-spacing: 2px;
  color: var(--accent, #1B65E0);
  line-height: 1;
}

.preview-placeholder-link {
  display: inline-block;
  margin-top: 6px;
  padding: 6px 14px;
  border-radius: 6px;
  background: var(--accent, #1B65E0);
  color: #fff;
  text-decoration: none;
  font-size: 0.78rem;
  font-weight: 600;
  transition: opacity 0.15s;
}
.preview-placeholder-link:hover { opacity: 0.85; }

/* pathwave-iframe styles are in the preview-stage section below */

.preview-card:first-child .preview-frame,
.preview-card:first-child .preview-image,
.preview-card:first-child .preview-placeholder {
  min-height: 520px;
}

.preview-queue {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 8px 0;
  margin-top: 14px;
  scrollbar-width: thin;
}

.preview-chip {
  padding: 5px 10px;
  border-radius: 4px;
  border: 1px solid var(--line);
  background: var(--surface-button);
  color: var(--ink);
  font-weight: 700;
  font-size: 0.75rem;
  box-shadow: none;
}

.preview-chip.is-active {
  background: var(--brand-soft);
  color: var(--ink-strong);
  border-color: rgba(47, 111, 178, 0.34);
}

textarea,
pre,
input[type="text"],
input[type="url"],
input[type="email"],
input[type="tel"],
input[type="password"],
input[type="number"],
select {
  width: 100%;
  min-width: 0;
  padding: 8px 10px;
  border-radius: 6px;
  border: 1px solid var(--line);
  background: var(--input-bg);
  color: var(--ink-strong);
  font: inherit;
  font-size: 0.82rem;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2399aabb' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 28px;
}

input[type="url"],
input[type="text"] {
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
}

select option {
  background: var(--bg-bottom, #0c1825);
  color: var(--ink-strong, #f7fbff);
}

input.is-autofill,
select.is-autofill,
textarea.is-autofill {
  color: var(--muted);
  background: color-mix(in srgb, var(--input-bg) 72%, transparent);
  border-style: dashed;
}

::placeholder {
  color: color-mix(in srgb, var(--muted) 88%, transparent);
}

textarea,
pre {
  font-family: "SF Mono", Consolas, monospace;
  line-height: 1.55;
}

textarea:focus,
input[type="text"]:focus,
input[type="url"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="password"]:focus,
input[type="number"]:focus,
select:focus {
  outline: 2px solid var(--brand);
  outline-offset: 1px;
  border-color: rgba(31, 90, 148, 0.32);
  box-shadow: none;
}

.compact-textarea {
  min-height: 48px;
  max-height: 64px;
  resize: vertical;
}

.inventory-editor {
  min-height: 100px;
}

pre {
  min-height: 240px;
  margin-top: 8px;
  overflow: auto;
  background: linear-gradient(180deg, rgba(8, 12, 30, 0.96), rgba(13, 18, 48, 0.92));
  color: #eef7ff;
  font-size: 0.78rem;
}

input[type="file"] {
  display: none;
}

.selected-file {
  margin-top: 10px;
  color: var(--muted);
  font-size: 0.92rem;
  overflow-wrap: anywhere;
}

.checkbox-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 4px;
  background: var(--surface-button);
  border: 1px solid var(--line);
  color: var(--ink-strong);
  font-size: 0.8rem;
}

.toggle-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 14px;
}

.toggle-card {
  display: flex;
  align-items: center;
  gap: 12px;
}

.permission-toggle-grid {
  margin-top: 12px;
}

.inline-checks {
  margin-top: 12px;
}

.flow-strip {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 6px;
}

.flow-step {
  display: flex;
  align-items: center;
  gap: 6px;
  min-height: 30px;
  padding: 4px 8px;
  text-align: left;
  border-radius: 5px;
  border: 1px solid var(--line);
  background: var(--surface-card-soft);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.flow-step.is-complete {
  background: rgba(95, 150, 52, 0.12);
  border-color: rgba(95, 150, 52, 0.3);
  box-shadow: 0 0 12px rgba(95, 150, 52, 0.15);
}

.flow-step.is-complete .step-index {
  background: var(--success);
  color: #fff;
}

.flow-step.is-partial {
  background: rgba(184, 133, 24, 0.1);
  border-color: rgba(184, 133, 24, 0.25);
  box-shadow: 0 0 10px rgba(184, 133, 24, 0.12);
}

.flow-step.is-partial .step-index {
  background: var(--warning);
  color: #fff;
}

.flow-step.is-active {
  box-shadow:
    0 0 0 4px rgba(31, 90, 148, 0.08),
    0 14px 24px rgba(16, 44, 71, 0.08);
}

.step-index {
  display: grid;
  place-items: center;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.12);
  color: var(--ink-strong);
  font-size: 0.65rem;
  font-weight: 800;
}

.step-label {
  font-size: 0.72rem;
  line-height: 1.2;
  color: var(--ink-strong);
  overflow-wrap: anywhere;
}

.summary-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 14px;
}

.scoreboard {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-top: 16px;
}

.chip {
  padding: 8px 12px;
  border-radius: 6px;
  background: var(--surface-button);
  border: 1px solid var(--line);
  font-size: 0.84rem;
  overflow-wrap: anywhere;
}

.chip.available,
.mini-tag.is-current {
  background: var(--success-soft);
  color: var(--success);
}

.chip.unavailable,
.mini-tag.is-archived {
  background: var(--surface-button);
  color: var(--muted);
}

.mini-tag,
.mini-score {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 7px 12px;
  border-radius: 6px;
  border: 1px solid var(--line);
  background: var(--surface-button);
  font-size: 0.84rem;
  font-weight: 700;
  overflow-wrap: anywhere;
}

.mini-tag.is-empty {
  color: var(--muted);
  opacity: 0.82;
}

.mini-score.pass {
  color: var(--success);
}

.mini-score.fail {
  color: var(--danger);
}

.mini-score.warning {
  color: var(--warning);
}

.mini-score.na {
  color: var(--ink);
}

.reference-list,
.history-list {
  display: grid;
  gap: 12px;
  margin-top: 14px;
}

.reference-group {
  display: grid;
  gap: 10px;
}

.list-heading {
  font-size: 0.88rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.reference-group-list {
  display: grid;
  gap: 10px;
}

.reference-item,
.history-item {
  border-radius: 10px;
  padding: 14px 16px;
}

.reference-item.editing {
  border: 1px solid var(--accent);
}

.edit-form-grid {
  display: grid;
  gap: 10px;
}

.edit-form-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 10px;
}

.admin-stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
}

.stat-card {
  background: var(--card-bg);
  border-radius: 8px;
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.stat-card span {
  font-size: 0.75rem;
  opacity: 0.7;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.stat-card strong {
  font-size: 1.3rem;
}

.admin-table-wrap {
  overflow-x: auto;
}

.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
}

.admin-table th,
.admin-table td {
  padding: 8px 10px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}

.admin-table th {
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.7rem;
  letter-spacing: 0.04em;
  opacity: 0.7;
}

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

.walkthrough-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(4px);
}

.walkthrough-overlay.hidden {
  display: none;
}

.walkthrough-panel {
  max-width: 540px;
  width: 90vw;
  padding: 28px 32px;
  border-radius: 16px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.walkthrough-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.walkthrough-header h2 {
  font-size: 1.2rem;
  margin: 0;
}

.walkthrough-body {
  min-height: 120px;
  font-size: 0.92rem;
  line-height: 1.6;
}

.walkthrough-body h3 {
  margin: 0 0 8px 0;
  font-size: 1rem;
}

.walkthrough-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.walkthrough-footer span {
  font-size: 0.78rem;
  opacity: 0.6;
}

.walkthrough-nav {
  display: flex;
  gap: 8px;
}

.reference-item-header,
.history-main {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
}

.reference-item-header > *,
.history-main > * {
  min-width: 0;
}

.item-primary,
.history-primary {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.reference-item-meta,
.history-meta-line {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 10px;
  color: var(--muted);
  font-size: 0.84rem;
}

.history-item {
  display: grid;
  gap: 14px;
}

.history-item.is-selected {
  border-color: rgba(31, 90, 148, 0.26);
}

.history-main {
  align-items: center;
}

.history-scoreline {
  justify-content: flex-end;
}

.history-actions,
.reference-actions {
  justify-content: flex-end;
}

.saved-runs-panel {
  margin-top: 18px;
}

.status {
  min-height: 1.2em;
  margin-top: 6px;
  font-size: 0.75rem;
}

.status:empty {
  display: none;
}

.status.loading {
  color: var(--brand);
}

.status.success {
  color: var(--success);
}

.status.warning {
  color: var(--warning);
}

.status.error {
  color: var(--danger);
}

.empty-state {
  padding: 16px;
  border: 1px dashed var(--line-strong);
  border-radius: 10px;
  color: var(--muted);
}

/* ═══════════════════════════════════════════════════════════════════
   LOGIN — Enterprise Sign-In Experience
   ═══════════════════════════════════════════════════════════════════ */
.login-body {
  display: grid;
  place-items: center;
  min-height: 100vh;
  padding: 32px 24px;
  background: #030510;
  background-image:
    radial-gradient(ellipse 60% 50% at 50% 40%, rgba(44, 125, 255, 0.04), transparent 70%),
    linear-gradient(180deg, #020408, #030510 40%, #04060E);
}

.login-shell {
  width: min(100%, 400px);
}

.login-panel {
  padding: 48px 40px 36px;
  background: linear-gradient(
    180deg,
    rgba(10, 13, 30, 0.94) 0%,
    rgba(6, 9, 22, 0.97) 100%
  );
  border: 1px solid rgba(226, 228, 235, 0.06);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 16px;
  box-shadow:
    0 40px 100px rgba(0, 0, 0, 0.7),
    0 0 1px rgba(255, 255, 255, 0.05),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(20px) saturate(140%);
}

.login-copy {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0;
  margin-bottom: 4px;
}

.login-lockup {
  display: block;
  width: min(100%, 320px);
  height: auto;
  margin: 0 auto 6px;
}

.login-tagline {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
  margin: 0;
  opacity: 0.55;
}

.login-form {
  display: grid;
  gap: 16px;
  margin-top: 28px;
}

.login-form label {
  display: grid;
  gap: 6px;
}

.login-form label > span {
  font-family: var(--font-body);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
}

.login-body .login-form input[type="text"],
.login-body .login-form input[type="password"] {
  height: 46px;
  padding: 0 16px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(226, 228, 235, 0.08);
  color: var(--ink-strong);
  font-family: var(--font-body);
  font-size: 0.88rem;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.login-body .login-form input:focus {
  border-color: rgba(44, 125, 255, 0.5);
  box-shadow: 0 0 0 3px rgba(44, 125, 255, 0.12);
  outline: none;
  background: rgba(255, 255, 255, 0.08);
}

.login-body .login-form input::placeholder {
  color: var(--muted);
  opacity: 0.5;
}

.login-body .login-form button[type="submit"] {
  height: 46px;
  margin-top: 8px;
  font-family: var(--font-display);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #fff;
  background: #2C7DFF;
  border: 1px solid rgba(44, 125, 255, 0.4);
  border-radius: 6px;
  cursor: pointer;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.3);
  transition: background 0.15s, box-shadow 0.2s, transform 0.15s;
}

.login-body .login-form button[type="submit"]:hover {
  background: #3A8AFF;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4), 0 0 20px rgba(44, 125, 255, 0.15);
  transform: translateY(-1px);
}

.login-body .login-form button[type="submit"]:active {
  transform: translateY(0);
  background: #1B65E0;
}

/* Divider between brand and form */
.login-copy::after {
  content: "";
  display: block;
  width: 48px;
  height: 1px;
  margin: 16px auto 0;
  background: linear-gradient(90deg, transparent, rgba(44, 125, 255, 0.15), transparent);
}

.remember-me {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 0.78rem;
  color: var(--muted);
  cursor: pointer;
  flex-direction: row;
}

.login-links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-top: 2px;
  font-size: 0.75rem;
}

.login-links a {
  color: rgba(44, 125, 255, 0.7);
  text-decoration: none;
  transition: color 0.15s;
}

.login-links a:hover {
  color: #2C7DFF;
  text-decoration: none;
}

.login-note,
.login-error {
  margin-top: 16px;
  padding: 14px 16px;
  border-radius: 20px;
  border: 1px solid var(--line);
}

.demo-account-list {
  display: grid;
  gap: 10px;
  margin-top: 16px;
}

.demo-account-card {
  display: grid;
  gap: 8px;
  padding: 14px 16px;
  border-radius: 10px;
  background: var(--surface-card-soft);
  border: 1px solid var(--line);
}

.demo-account-card code {
  color: var(--ink-strong);
  overflow-wrap: anywhere;
}

.login-note {
  background: var(--brand-soft);
}

.login-error {
  background: var(--danger-soft);
  color: var(--danger);
}

.login-note code,
.demo-account-row code {
  padding: 4px 8px;
  border-radius: 6px;
  background: var(--surface-button);
  color: var(--ink-strong);
  font-family: "SF Mono", Consolas, monospace;
}

.demo-account-list {
  display: grid;
  gap: 10px;
  margin-top: 10px;
}

.demo-account-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 8px;
  align-items: center;
}

.demo-fill-button {
  min-width: 122px;
}

.modal {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 18px;
  background: rgba(14, 34, 58, 0.28);
  z-index: 30;
}

.modal.hidden {
  display: none;
}

.modal-panel {
  width: min(760px, 100%);
  padding: 22px;
}

.mode-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 12px;
}

.mode-choice {
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  padding: 18px;
  border-radius: 28px;
  background: var(--surface-card-soft);
  border: 1px solid var(--line);
  color: var(--ink-strong);
}

.mode-title {
  font-weight: 800;
}

.mode-copy {
  color: var(--muted);
  line-height: 1.55;
}

.mode-toggle-bar {
  display: inline-flex;
  gap: 4px;
  padding: 3px;
  border-radius: 6px;
  background: var(--surface-button);
  border: 1px solid var(--line);
  margin-bottom: 6px;
}

.mode-toggle {
  flex: 1;
  padding: 6px 12px;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  background: transparent;
  color: var(--muted);
  border: 1px solid transparent;
  border-radius: 4px;
  cursor: pointer;
  transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.mode-toggle:hover {
  background: var(--surface-button);
  transform: translateY(-1px);
}

.mode-toggle.is-active {
  background: var(--surface-button-strong);
  color: var(--ink-strong);
  border-color: var(--line);
  box-shadow: 0 10px 22px rgba(16, 44, 71, 0.08);
  border-radius: 4px;
}

.maturity-ladder {
  margin-top: 14px;
  padding-top: 10px;
  border-top: 1px solid var(--line);
}

.ladder-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
  margin-top: 6px;
}

.ladder-step {
  padding: 5px 6px;
  font-size: 0.62rem;
  line-height: 1.3;
  color: var(--muted);
  background: var(--surface-button);
  border: 1px solid var(--line);
  border-radius: 4px;
  opacity: 0.5;
}

.ladder-step strong {
  display: block;
  font-size: 0.58rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink);
  margin-bottom: 1px;
}

.ladder-step.is-active {
  opacity: 1;
  background: var(--brand-soft);
  border-color: rgba(47, 111, 178, 0.2);
  color: var(--ink-strong);
  box-shadow: 0 0 8px rgba(47, 111, 178, 0.1);
}

/* =========================================================
   Full-Width Preview Stage — Samsung-style photo editor
   ========================================================= */

.preview-stage-fullwidth {
  width: 100%;
  max-width: none;
  padding: 0;
  overflow: hidden;
  border-radius: 14px;
}

.preview-stage-topbar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 16px;
  background: var(--surface-strong, rgba(30, 42, 56, 0.95));
  border-bottom: 1px solid var(--line);
  flex-wrap: wrap;
}

.preview-stage-title {
  display: flex;
  align-items: baseline;
  gap: 10px;
  min-width: 0;
}

.preview-stage-title .section-label {
  margin: 0;
  white-space: nowrap;
}

.preview-stage-title .preview-caption {
  font-size: 0.78rem;
  color: var(--muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 280px;
}

.preview-stage-nav {
  display: flex;
  align-items: center;
  gap: 8px;
}

.preview-counter {
  font-size: 0.75rem;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
  min-width: 50px;
  text-align: center;
}

.preview-stage-tools {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-left: auto;
  flex-wrap: wrap;
}

.tool-group {
  display: flex;
  align-items: center;
  gap: 3px;
}

.tool-divider {
  width: 1px;
  height: 22px;
  background: var(--line);
  margin: 0 4px;
}

.tool-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 30px;
  padding: 0 8px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--surface);
  color: var(--ink);
  font-size: 0.72rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  white-space: nowrap;
}

.tool-btn:hover {
  background: var(--brand-soft);
  border-color: var(--brand);
}

.tool-btn.is-active {
  background: var(--brand);
  color: #fff;
  border-color: var(--brand);
}

.tool-btn--accent {
  background: var(--brand);
  color: #fff;
  border-color: var(--brand);
}

.tool-btn--accent:hover {
  filter: brightness(1.1);
}

.tool-color-wrap {
  display: inline-flex;
  align-items: center;
  cursor: pointer;
}

.tool-color-wrap input[type="color"] {
  width: 28px;
  height: 28px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: none;
  padding: 0;
  cursor: pointer;
  -webkit-appearance: none;
}

.tool-color-wrap input[type="color"]::-webkit-color-swatch-wrapper {
  padding: 2px;
}

.tool-color-wrap input[type="color"]::-webkit-color-swatch {
  border: none;
  border-radius: 4px;
}

.tool-select {
  height: 30px;
  padding: 0 8px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--surface);
  color: var(--ink);
  font-size: 0.72rem;
  font-weight: 600;
  cursor: pointer;
}

/* Preview stage body — photo + optional pathwave side */
.preview-stage-body {
  display: grid;
  grid-template-columns: 1fr;
  min-height: 620px;
  background: #0a0a0a;
  position: relative;
}

/* .show-pathwave split-view removed — Pathwave side panel was removed */

.preview-canvas-wrap {
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 620px;
  cursor: grab;
  user-select: none;
  -webkit-user-select: none;
}

.editor-toolbar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  background: var(--surface-strong, rgba(30, 42, 56, 0.95));
  border-bottom: 1px solid var(--line);
  flex-wrap: wrap;
  flex-shrink: 0;
  z-index: 25;
}

.preview-canvas-wrap.is-panning {
  cursor: grabbing;
}

.preview-canvas-wrap.tool-draw,
.preview-canvas-wrap.tool-arrow,
.preview-canvas-wrap.tool-rect,
.preview-canvas-wrap.tool-circle {
  cursor: crosshair;
}

.preview-canvas-wrap.tool-text {
  cursor: text;
}

.preview-canvas-wrap .preview-frame {
  position: relative;
  border: none;
  border-radius: 0;
  flex: 1;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  box-shadow: none;
  transform-origin: center center;
}

.preview-canvas-wrap .preview-frame img {
  max-width: none;
  max-height: none;
  display: block;
  pointer-events: none;
}

.markup-canvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 10;
}

.markup-canvas.is-active {
  pointer-events: auto;
}

.preview-zoom-indicator {
  position: absolute;
  bottom: 12px;
  left: 12px;
  background: rgba(0, 0, 0, 0.7);
  color: #fff;
  padding: 4px 10px;
  border-radius: 6px;
  font-size: 0.72rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  z-index: 20;
  pointer-events: none;
}

/* .pathwave-iframe removed — browser-scraping panel was removed */

/* Audit Companion Panel (ac-*) removed — browser-preview panel was removed with scraping workflow */

.preview-queue-bar {
  padding: 8px 16px;
  background: var(--surface-strong, rgba(30, 42, 56, 0.95));
  border-top: 1px solid var(--line);
}

.preview-stage-fullwidth .status {
  padding: 6px 16px;
  margin: 0;
  border-top: 1px solid var(--line);
  background: var(--surface-strong, rgba(30, 42, 56, 0.95));
  font-size: 0.72rem;
}

/* Fullscreen mode for the entire preview stage */
.preview-stage-fullwidth.is-fullscreen {
  position: fixed;
  inset: 0;
  z-index: 1000;
  width: 100vw;
  margin-left: 0;
  border-radius: 0;
}

.preview-stage-fullwidth.is-fullscreen .preview-stage-body {
  flex: 1;
  min-height: 0;
}

.preview-stage-fullwidth.is-fullscreen .preview-canvas-wrap {
  min-height: 0;
  flex: 1;
}

.pref-high-contrast {
  --bg-top: #ffffff;
  --bg-mid: #f5f5f5;
  --bg-bottom: #ebebeb;
  --surface: rgba(255, 255, 255, 0.98);
  --surface-strong: #ffffff;
  --surface-soft: rgba(248, 248, 248, 0.96);
  --surface-card: linear-gradient(180deg, #ffffff, #f8f8f8);
  --surface-card-soft: linear-gradient(180deg, #fafafa, #f4f4f4);
  --surface-button: rgba(0, 0, 0, 0.06);
  --surface-button-strong: rgba(0, 0, 0, 0.10);
  --input-bg: #ffffff;
  --preview-bg: linear-gradient(180deg, #f7f7f7, #eeeeee);
  --ink: #000000;
  --ink-strong: #000000;
  --muted: #333333;
  --line: rgba(0, 0, 0, 0.30);
  --line-strong: rgba(0, 0, 0, 0.50);
  --brand: #0a4a8a;
  --brand-strong: #063366;
  --brand-soft: rgba(10, 74, 138, 0.14);
  --accent: #b5202e;
  --accent-soft: rgba(181, 32, 46, 0.14);
  --success: #116b3a;
  --success-soft: rgba(17, 107, 58, 0.14);
  --warning: #8a5f00;
  --warning-soft: rgba(138, 95, 0, 0.15);
  --danger: #a11a24;
  --danger-soft: rgba(161, 26, 36, 0.15);
  --shadow: 0 4px 16px rgba(0, 0, 0, 0.20);
  --shadow-soft: 0 2px 8px rgba(0, 0, 0, 0.14);
}

.pref-high-contrast .glass-panel {
  border: 2px solid var(--line-strong);
}

.pref-high-contrast .ghost-button {
  border: 1px solid var(--ink);
  color: var(--ink);
}

.pref-high-contrast .view-tab {
  border: 1px solid transparent;
}

.pref-high-contrast .view-tab.is-active {
  border-color: var(--brand);
  background: var(--brand-soft);
  font-weight: 700;
}

.pref-large-text {
  font-size: 18px;
}

.pref-reduced-motion *,
.pref-reduced-motion *::before,
.pref-reduced-motion *::after {
  animation: none !important;
  transition: none !important;
}

.pref-screen-reader .section-label,
.pref-screen-reader .brand-chip,
.pref-screen-reader .eyebrow {
  letter-spacing: 0.04em;
}

/* =========================================================
   Results Table — item-level verdict overrides
   ========================================================= */

.results-table-wrap {
  margin-top: 12px;
}

.results-table-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}

.result-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 10px;
  border-bottom: 1px solid var(--line);
  font-size: 0.82rem;
}

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

.result-rs {
  font-weight: 600;
  min-width: 64px;
  color: var(--ink-strong);
}

.result-desc {
  flex: 1;
  color: var(--muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.verdict-pill {
  display: inline-block;
  padding: 2px 10px;
  border-radius: 10px;
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  min-width: 56px;
  text-align: center;
}

.verdict-pill.pass { background: var(--success-soft); color: var(--success); }
.verdict-pill.fail { background: var(--danger-soft); color: var(--danger); }
.verdict-pill.na   { background: var(--brand-soft); color: var(--brand); }
.verdict-pill.warning { background: var(--warning-soft); color: var(--warning); }

.result-override-select {
  width: auto;
  min-width: 80px;
  padding: 3px 6px;
  font-size: 0.78rem;
}

.result-override-btn {
  font-size: 0.72rem;
  padding: 3px 8px;
}

/* =========================================================
   Photo Add Bar
   ========================================================= */

.photo-add-bar {
  display: flex;
  gap: 8px;
  margin-top: 6px;
  align-items: center;
}

.photo-url-input {
  flex: 1;
  font-size: 0.78rem;
  padding: 5px 8px;
}

/* =========================================================
   Agent Findings Digest (dashboard sidebar)
   ========================================================= */

.agent-digest-summary {
  display: flex;
  gap: 6px;
  margin-bottom: 8px;
}

.agent-digest-feed {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.agent-digest-item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 6px 8px;
  border-radius: 6px;
  background: var(--surface-soft);
  font-size: 0.78rem;
}

.agent-digest-item.danger-button {
  background: var(--danger-soft);
}

.agent-digest-avatar {
  font-size: 1rem;
  flex-shrink: 0;
}

.agent-digest-content {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.agent-digest-content strong {
  font-size: 0.78rem;
  color: var(--ink-strong);
}

.agent-digest-content small {
  font-size: 0.68rem;
  color: var(--muted);
}

/* Old scattered breakpoints removed — see consolidated responsive section at bottom */

/* =========================================================
   Live Counter & Manual Review Panel
   ========================================================= */

.live-counter {
  display: flex;
  gap: 20px;
  padding: 8px 16px;
  background: var(--surface-2, rgba(255,255,255,0.06));
  border-radius: 6px;
  font-size: 0.85rem;
  font-weight: 500;
  margin-bottom: 10px;
  align-items: center;
}
.live-counter.hidden { display: none; }
.counter-pass { color: #4caf50; }
.counter-na   { color: #ffc107; }
.counter-deny { color: #f44336; }
.counter-remaining { color: var(--text-muted, #888); }

.manual-review-panel {
  background: var(--surface-2, rgba(255,255,255,0.06));
  border: 1px solid var(--border, rgba(255,255,255,0.12));
  border-radius: 8px;
  padding: 16px;
  margin-bottom: 14px;
}
.manual-review-panel.hidden { display: none; }

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

.manual-nav-buttons {
  display: flex;
  gap: 8px;
}

.manual-item-card {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
  margin-bottom: 12px;
  transition: opacity 0.2s;
}
.manual-item-card.confirmed { opacity: 0.55; }

.mi-row {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 8px;
  align-items: baseline;
  font-size: 0.87rem;
}

.mi-label {
  color: var(--text-muted, #888);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  white-space: nowrap;
}

.mi-row input[type="text"],
.mi-row select {
  font-size: 0.85rem;
  padding: 4px 8px;
  border-radius: 4px;
  background: var(--input-bg, rgba(0,0,0,0.3));
  border: 1px solid var(--border, rgba(255,255,255,0.12));
  color: inherit;
  width: 100%;
}

.manual-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--border, rgba(255,255,255,0.1));
}

.dim { color: var(--text-muted, #888); font-size: 0.82rem; }

/* ============================================================
   ANALYTICS TAB — VAIrify Intelligence (Enterprise overhaul)
   ============================================================ */
.an-section-desc { font-size: 0.72rem; color: var(--muted); line-height: 1.5; margin-top: 2px; max-width: 520px; }
.an-hero-panel { padding-bottom: 20px; }
.an-kpi-hero-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 12px; }
/* an-kpi-hero-row responsive — in consolidated section */
.an-kpi-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(130px, 1fr)); gap: 8px; }
.an-kpi { border-radius: 10px; padding: 16px 18px; display: flex; flex-direction: column; gap: 6px; position: relative; overflow: hidden; transition: box-shadow 0.2s, transform 0.15s; }
.an-kpi:hover { transform: translateY(-1px); }
.an-kpi-label { font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--muted); font-weight: 500; position: relative; z-index: 1; }
.an-kpi-val { font-size: 1.4rem; font-weight: 700; color: var(--ink-strong); letter-spacing: -0.02em; position: relative; z-index: 1; }
.an-kpi-val--hero { font-size: 2rem; line-height: 1.1; }
.an-kpi--primary { padding: 20px 20px 18px; border: 1px solid var(--line); }
.an-kpi--primary::before { content: ''; position: absolute; inset: 0; border-radius: inherit; opacity: 0.08; pointer-events: none; z-index: 0; }
.an-kpi--positive { background: linear-gradient(135deg, rgba(121,191,67,0.08) 0%, rgba(121,191,67,0.02) 100%); border-color: rgba(121,191,67,0.2); }
.an-kpi--positive::before { background: linear-gradient(135deg, rgba(121,191,67,0.12), transparent 60%); }
.an-kpi--positive:hover { box-shadow: 0 4px 20px rgba(121,191,67,0.12); }
.an-kpi--positive .an-kpi-val { color: #79BF43; }
.an-kpi--danger { background: linear-gradient(135deg, rgba(255,59,48,0.08) 0%, rgba(255,59,48,0.02) 100%); border-color: rgba(255,59,48,0.2); }
.an-kpi--danger::before { background: linear-gradient(135deg, rgba(255,59,48,0.12), transparent 60%); }
.an-kpi--danger:hover { box-shadow: 0 4px 20px rgba(255,59,48,0.1); }
.an-kpi--danger .an-kpi-val { color: #ff3b30; }
.an-kpi--warning { background: linear-gradient(135deg, rgba(255,159,10,0.08) 0%, rgba(255,159,10,0.02) 100%); border-color: rgba(255,159,10,0.2); }
.an-kpi--warning::before { background: linear-gradient(135deg, rgba(255,159,10,0.12), transparent 60%); }
.an-kpi--warning:hover { box-shadow: 0 4px 20px rgba(255,159,10,0.1); }
.an-kpi--warning .an-kpi-val { color: #ff9f0a; }
.an-kpi-icon-wrap { width: 32px; height: 32px; border-radius: 8px; display: flex; align-items: center; justify-content: center; margin-bottom: 4px; position: relative; z-index: 1; }
.an-kpi-icon--success { background: rgba(121,191,67,0.15); color: #79BF43; }
.an-kpi-icon--danger  { background: rgba(255,59,48,0.15); color: #ff3b30; }
.an-kpi-icon--warning { background: rgba(255,159,10,0.15); color: #ff9f0a; }
.an-kpi--secondary { background: var(--surface-soft); border: 1px solid var(--line); padding: 12px 14px; }
.an-kpi--secondary .an-kpi-val { font-size: 1.2rem; }
.an-kpi--volume .an-kpi-val { color: var(--brand, #2f6fb2); font-variant-numeric: tabular-nums; }

.an-chart-row { display: flex; gap: 20px; align-items: flex-start; }
.an-bar-chart { flex: 1; display: flex; flex-direction: column; gap: 6px; }
.an-vbar-row { display: flex; align-items: center; gap: 10px; padding: 4px 0; }
.an-vbar-label { width: 70px; font-size: 0.75rem; font-weight: 700; color: var(--ink); text-transform: uppercase; letter-spacing: 0.02em; }
.an-vbar-track { flex: 1; height: 22px; background: rgba(255,255,255,0.04); border-radius: 6px; overflow: hidden; position: relative; }
.an-vbar-fill { height: 100%; border-radius: 6px; transition: width 0.5s cubic-bezier(0.22, 0.61, 0.36, 1); position: relative; }
.an-vbar-fill::after { content: ''; position: absolute; inset: 0; border-radius: inherit; background: linear-gradient(90deg, transparent 60%, rgba(255,255,255,0.1)); }
.an-vbar-val { width: 80px; text-align: right; font-size: 0.75rem; font-weight: 600; color: var(--muted); font-variant-numeric: tabular-nums; }
.an-pie-legend { display: flex; flex-direction: column; gap: 8px; min-width: 130px; }
.an-legend-item { font-size: 0.75rem; display: flex; align-items: center; gap: 8px; color: var(--ink); }
.an-legend-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }

.an-conf-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
/* an-conf-grid responsive — in consolidated section */
.an-conf-card { border-radius: 10px; padding: 16px 18px; display: flex; flex-direction: column; gap: 10px; border: 1px solid var(--line); transition: box-shadow 0.2s; position: relative; overflow: hidden; }
.an-conf-card--high   { background: linear-gradient(160deg, rgba(121,191,67,0.06) 0%, transparent 60%); border-color: rgba(121,191,67,0.15); }
.an-conf-card--medium { background: linear-gradient(160deg, rgba(255,159,10,0.06) 0%, transparent 60%); border-color: rgba(255,159,10,0.15); }
.an-conf-card--low    { background: linear-gradient(160deg, rgba(255,59,48,0.06) 0%, transparent 60%); border-color: rgba(255,59,48,0.15); }
.an-conf-card--high:hover   { box-shadow: 0 2px 16px rgba(121,191,67,0.08); }
.an-conf-card--medium:hover { box-shadow: 0 2px 16px rgba(255,159,10,0.08); }
.an-conf-card--low:hover    { box-shadow: 0 2px 16px rgba(255,59,48,0.08); }
.an-conf-header { display: flex; align-items: center; justify-content: space-between; }
.an-conf-level { font-size: 0.68rem; font-weight: 700; padding: 3px 10px; border-radius: 5px; letter-spacing: 0.04em; }
.ac-conf--high   { background: rgba(121,191,67,0.15); color: #79BF43; }
.ac-conf--medium { background: rgba(255,159,10,0.15); color: #ff9f0a; }
.ac-conf--low    { background: rgba(255,59,48,0.15); color: #ff3b30; }
.an-conf-accuracy-badge { font-size: 0.78rem; color: var(--ink-strong); }
.an-conf-accuracy-badge strong { font-size: 1.1rem; font-weight: 700; letter-spacing: -0.01em; }
.an-conf-stats { display: flex; gap: 16px; font-size: 0.75rem; }
.an-conf-stat-item { display: flex; flex-direction: column; gap: 2px; }
.an-conf-stat-label { font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); }
.an-conf-stat-val { font-size: 1rem; font-weight: 600; color: var(--ink-strong); }
.an-conf-stat-val--good { color: #79BF43; }
.an-conf-stat-val--bad  { color: #ff3b30; }
.an-conf-bar-wrap { height: 6px; background: rgba(255,255,255,0.06); border-radius: 3px; overflow: hidden; margin-top: 2px; }
.an-conf-bar { height: 100%; border-radius: 3px; transition: width 0.5s cubic-bezier(0.22, 0.61, 0.36, 1); }
.an-conf-bar--high   { background: linear-gradient(90deg, #79BF43, #8DD35F); }
.an-conf-bar--medium { background: linear-gradient(90deg, #ff9f0a, #ffb340); }
.an-conf-bar--low    { background: linear-gradient(90deg, #ff3b30, #ff6961); }

.an-punch-list { display: flex; flex-direction: column; gap: 6px; }
.an-punch-row { display: flex; align-items: center; gap: 10px; padding: 4px 0; }
.an-punch-code { width: 90px; font-size: 0.78rem; font-weight: 700; font-family: var(--font-mono, monospace); color: var(--ink); letter-spacing: 0.01em; }
.an-punch-bar-track { flex: 1; height: 14px; background: rgba(255,255,255,0.04); border-radius: 4px; overflow: hidden; }
.an-punch-bar-fill { height: 100%; border-radius: 4px; background: linear-gradient(90deg, #2C7DFF, #4A94FF); transition: width 0.5s cubic-bezier(0.22, 0.61, 0.36, 1); }
.an-punch-count { width: 48px; text-align: right; font-size: 0.75rem; font-weight: 600; color: var(--muted); font-variant-numeric: tabular-nums; }
.an-recommendations { display: flex; flex-direction: column; gap: 8px; }

/* --- Pipeline Status board --- */
.an-sidebar-desc { font-size: 0.68rem; color: var(--muted); margin-top: 1px; }
.an-pipeline-status { display: flex; flex-direction: column; gap: 2px; }
.an-pipe-row { display: flex; justify-content: space-between; align-items: center; padding: 8px 10px; font-size: 0.78rem; color: var(--ink); border-radius: 6px; transition: background 0.15s; }
.an-pipe-row:hover { background: rgba(255,255,255,0.03); }
.an-pipe-agent { display: flex; align-items: center; gap: 8px; }
.an-pipe-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.an-pipe-dot--ok   { background: #79BF43; box-shadow: 0 0 6px rgba(121,191,67,0.4); }
.an-pipe-dot--warn { background: #ff9f0a; box-shadow: 0 0 6px rgba(255,159,10,0.4); }
.an-pipe-dot--err  { background: #ff3b30; box-shadow: 0 0 6px rgba(255,59,48,0.4); }
.an-pipe-name { font-weight: 500; }
.an-pipe-badge { font-size: 0.62rem; font-weight: 700; padding: 3px 10px; border-radius: 4px; text-transform: uppercase; letter-spacing: 0.03em; }
.an-pipe--ok   { background: rgba(121,191,67,0.12); color: #79BF43; }
.an-pipe--warn { background: rgba(255,159,10,0.12); color: #ff9f0a; }
.an-pipe--err  { background: rgba(255,59,48,0.12); color: #ff3b30; }

/* --- Integrity Log --- */
.an-integrity-log { display: flex; flex-direction: column; gap: 8px; }
.an-integrity-stat { display: flex; align-items: center; gap: 8px; font-size: 0.78rem; color: var(--ink); }
.an-integrity-stat span { flex: 1; }
.an-integrity-stat strong { font-size: 1rem; font-weight: 700; font-variant-numeric: tabular-nums; }
.an-integ--rejected { color: #ff3b30; }
.an-integrity-indicator { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.an-integrity-indicator--pass { background: #79BF43; }
.an-integrity-indicator--fail { background: #ff3b30; }
.an-integ-entries { display: flex; flex-direction: column; gap: 4px; margin-top: 6px; }
.an-integ-row { display: flex; gap: 8px; align-items: center; font-size: 0.72rem; padding: 4px 8px; border-radius: 4px; }
.an-integ-ok   { background: rgba(121,191,67,0.06); color: #79BF43; }
.an-integ-fail { background: rgba(255,59,48,0.06); color: #ff3b30; }
.an-integ-hash { font-family: var(--font-mono, monospace); font-size: 0.65rem; color: var(--muted); margin-left: auto; }

/* --- Learning Loop --- */
.an-learning { display: flex; flex-direction: column; gap: 8px; }
.an-learning-stat { display: flex; align-items: center; gap: 8px; font-size: 0.78rem; color: var(--ink); }
.an-learning-stat span { flex: 1; }
.an-learning-stat strong { font-size: 1rem; font-weight: 700; font-variant-numeric: tabular-nums; }
.an-learning-indicator { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.an-learning-indicator--danger  { background: #ff3b30; }
.an-learning-indicator--warning { background: #ff9f0a; }
.an-learning-footer { margin-top: 4px; padding-top: 8px; border-top: 1px solid var(--line); }
.an-learning-note { font-size: 0.72rem; color: var(--muted); line-height: 1.5; }

/* --- User metrics --- */
.an-user-metrics { display: flex; flex-direction: column; gap: 4px; padding: 8px; }
.an-user-row { display: flex; align-items: center; gap: 8px; padding: 6px 10px; border-radius: 6px; background: rgba(255,255,255,0.03); font-size: 0.78rem; transition: background 0.15s; }
.an-user-row:hover { background: rgba(255,255,255,0.06); }
.an-user-name { font-weight: 600; color: var(--brand, #2f6fb2); min-width: 90px; }
.an-user-stat { color: var(--muted); font-size: 0.72rem; }

/* --- Analytics empty states --- */
.an-empty-state--chart, .an-empty-state--insights, .an-empty-state--compact { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 8px; padding: 28px 20px; border: 1px dashed var(--line-strong); border-radius: 10px; color: var(--muted); }
.an-empty-state--compact { padding: 20px 16px; gap: 6px; }
.an-empty-icon { color: var(--muted); opacity: 0.6; margin-bottom: 4px; }
.an-empty-icon--sm { margin-bottom: 2px; }
.an-empty-title { font-size: 0.82rem; font-weight: 600; color: var(--ink); display: block; }
.an-empty-hint { font-size: 0.72rem; color: var(--muted); max-width: 280px; line-height: 1.5; display: block; }

/* ================================================================
   ENTERPRISE SETTINGS & INTEGRATIONS OVERHAUL
   ================================================================ */

/* --- Panel section header with description --- */
.ent-panel-header {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.ent-panel-header .ent-title-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.ent-panel-header .ent-title-row h3 {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--ink-strong);
  letter-spacing: -0.01em;
}

.ent-panel-header .ent-section-tag {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: var(--brand-soft);
  color: var(--brand);
  border: 1px solid rgba(47, 111, 178, 0.12);
}

.ent-panel-header .ent-section-tag svg {
  width: 12px;
  height: 12px;
  flex-shrink: 0;
}

.ent-panel-header .ent-section-desc {
  font-size: 0.76rem;
  color: var(--muted);
  line-height: 1.5;
  max-width: 52ch;
  margin-top: 2px;
}

/* --- Form field group cards --- */
.ent-field-group {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 14px;
  margin-top: 8px;
}

.ent-field-group-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 10px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--line);
}

.ent-field-group-label svg {
  width: 14px;
  height: 14px;
  opacity: 0.6;
}

/* Wider first column for important fields */
.form-grid.ent-weighted {
  grid-template-columns: minmax(0, 1.6fr) repeat(2, minmax(0, 1fr));
}

.form-grid.ent-two-col {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

/* --- Toggle switch cards (enterprise polish) --- */
.ent-toggle-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 8px;
}

.ent-toggle-grid.ent-toggle-grid--3col {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ent-toggle-card {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0 10px;
  align-items: start;
  padding: 12px 14px;
  border-radius: 8px;
  background: var(--surface-card-soft);
  border: 1px solid var(--line);
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
}

.ent-toggle-card:hover {
  border-color: var(--line-strong);
  background: var(--surface-card);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.ent-toggle-card:has(input:checked) {
  border-color: rgba(47, 111, 178, 0.3);
  background: rgba(47, 111, 178, 0.06);
}

/* Toggle switch track */
.ent-toggle-card .ent-switch {
  position: relative;
  width: 34px;
  height: 18px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid var(--line-strong);
  transition: background 0.2s, border-color 0.2s;
  margin-top: 1px;
  flex-shrink: 0;
}

.ent-toggle-card .ent-switch::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--muted);
  transition: transform 0.2s, background 0.2s;
}

.ent-toggle-card:has(input:checked) .ent-switch {
  background: var(--brand);
  border-color: var(--brand);
}

.ent-toggle-card:has(input:checked) .ent-switch::after {
  transform: translateX(16px);
  background: #fff;
}

.ent-toggle-card input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}

.ent-toggle-card .ent-toggle-content {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.ent-toggle-card .ent-toggle-label {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--ink-strong);
  line-height: 1.3;
}

.ent-toggle-card .ent-toggle-desc {
  font-size: 0.7rem;
  color: var(--muted);
  line-height: 1.4;
}

/* --- Status bars (enterprise) --- */
.ent-status {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 6px;
  font-size: 0.75rem;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.02);
  border-left: 3px solid var(--line-strong);
  margin-top: 10px;
}

.ent-status svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  opacity: 0.6;
}

.ent-status.ent-status--info {
  border-left-color: var(--brand);
  background: rgba(47, 111, 178, 0.04);
}

.ent-status.ent-status--success {
  border-left-color: var(--success);
  background: var(--success-soft);
}

.ent-status.ent-status--warning {
  border-left-color: var(--warning);
  background: var(--warning-soft);
}

.ent-status.ent-status--locked {
  border-left-color: var(--muted);
  background: rgba(255, 255, 255, 0.02);
}

.ent-status.ent-status--locked svg {
  opacity: 0.4;
}

/* --- Button treatments --- */
.ent-btn-primary {
  padding: 8px 16px;
  background: linear-gradient(135deg, var(--brand-strong), var(--brand));
  color: white;
  font-size: 0.82rem;
  font-weight: 700;
  border: 0;
  border-radius: 6px;
  box-shadow: 0 4px 12px rgba(23, 70, 120, 0.2);
}

.ent-btn-secondary {
  padding: 7px 14px;
  background: var(--surface-button);
  color: var(--ink-strong);
  font-size: 0.82rem;
  font-weight: 600;
  border: 1px solid var(--line-strong);
  border-radius: 6px;
}

.ent-btn-secondary:hover {
  background: var(--surface-button-strong);
  border-color: var(--brand);
}

/* --- Sidebar integration health cards --- */
.ent-health-grid {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 8px;
}

.ent-health-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 10px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--line);
  transition: background 0.15s;
}

.ent-health-row:hover {
  background: rgba(255, 255, 255, 0.04);
}

.ent-health-label {
  font-size: 0.76rem;
  font-weight: 600;
  color: var(--ink);
}

.ent-health-value {
  font-size: 0.72rem;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 4px;
}

.ent-health-value.ent-hv--ok {
  background: var(--success-soft);
  color: var(--success);
}

.ent-health-value.ent-hv--warn {
  background: var(--warning-soft);
  color: var(--warning);
}

.ent-health-value.ent-hv--off {
  background: rgba(255, 255, 255, 0.04);
  color: var(--muted);
}

.ent-health-value.ent-hv--locked {
  background: rgba(255, 255, 255, 0.03);
  color: var(--muted);
  font-style: italic;
}

/* --- Plan tier card --- */
.ent-plan-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.ent-plan-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  width: fit-content;
  padding: 4px 12px;
  border-radius: 6px;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  background: linear-gradient(135deg, var(--brand-soft), rgba(47, 111, 178, 0.08));
  color: var(--brand);
  border: 1px solid rgba(47, 111, 178, 0.18);
}

.ent-plan-features {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.ent-plan-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 6px 0;
  font-size: 0.76rem;
  border-bottom: 1px solid var(--line);
}

.ent-plan-row:last-child {
  border-bottom: none;
}

.ent-plan-row .ent-plan-feat {
  color: var(--ink);
  font-weight: 500;
}

.ent-plan-row .ent-plan-val {
  font-weight: 600;
  color: var(--ink-strong);
}

.ent-plan-row .ent-plan-val.ent-pv--locked {
  color: var(--muted);
  font-size: 0.68rem;
  font-style: italic;
  padding: 1px 6px;
  border-radius: 3px;
  background: rgba(255, 255, 255, 0.03);
}

/* --- Inline checkbox row (Pathwave bridge) --- */
.ent-options-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 8px;
  padding-top: 10px;
  border-top: 1px solid var(--line);
}

/* --- Section divider (enhanced with label) --- */
.ent-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 20px 0 8px;
}

.ent-divider::before,
.ent-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--line-strong), transparent);
}

.ent-divider-label {
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
  white-space: nowrap;
  padding: 3px 10px;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--line);
}

/* --- Disabled overlay for locked features --- */
.ent-locked {
  position: relative;
  opacity: 0.55;
  pointer-events: none;
}

.ent-locked::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: rgba(8, 17, 29, 0.12);
  pointer-events: none;
}

/* Re-enable pointer events on the panel itself so tooltips work */
.ent-locked .ent-status {
  pointer-events: auto;
  opacity: 1;
}

/* toggle grid responsive — in consolidated section */

/* =========================================================
   ENTERPRISE UI OVERHAUL — Users & Admin tabs
   Fieldsets, stat cards, guard rules, empty states
   ========================================================= */

/* --- Fieldset card groups (form section dividers) --- */
.ent-fieldset {
  position: relative;
  background: rgba(255, 255, 255, 0.015);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 16px;
  margin-top: 14px;
  transition: border-color 0.2s;
}

.ent-fieldset:hover {
  border-color: var(--line-strong);
}

.ent-fieldset--compact {
  padding: 12px;
  margin-top: 10px;
}

.ent-fieldset-header {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
}

.ent-fieldset-title {
  font-size: 0.7rem;
  font-weight: 800;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ent-fieldset-desc {
  font-size: 0.72rem;
  color: var(--muted);
  opacity: 0.75;
  line-height: 1.4;
}

.ent-fieldset .form-grid {
  margin-top: 0;
}

/* --- Section-level hint (below h3) --- */
.ent-section-hint {
  margin-top: 2px;
}

/* --- Enhanced stat cards with icons and accent strips --- */
.ent-stats-grid {
  gap: 10px;
}

.ent-stat-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 14px 16px 14px 16px;
  border-radius: 10px;
  background: var(--surface-card);
  border: 1px solid var(--line);
  transition: border-color 0.2s, transform 0.15s, box-shadow 0.2s;
  overflow: hidden;
}

.ent-stat-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--line-strong);
  border-radius: 10px 10px 0 0;
  transition: background 0.2s;
}

.ent-stat-card:hover {
  border-color: var(--line-strong);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.12);
}

.ent-stat-card span {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
  opacity: 1;
}

.ent-stat-card strong {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--ink-strong);
  letter-spacing: -0.02em;
  line-height: 1;
}

/* Accent variants for stat cards */
.ent-stat--primary::before {
  background: var(--brand);
}

.ent-stat--success::before {
  background: var(--success);
}

.ent-stat--success strong {
  color: var(--success);
}

.ent-stat--warn::before {
  background: var(--warning);
}

.ent-stat--warn strong {
  color: var(--warning);
}

.ent-stat--danger::before {
  background: var(--danger);
}

.ent-stat--danger strong {
  color: var(--danger);
}

/* Stat card icon */
.ent-stat-icon {
  color: var(--muted);
  opacity: 0.5;
  margin-bottom: 2px;
}

.ent-stat-icon svg {
  display: block;
}

/* --- Enhanced empty states --- */
.ent-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 28px 20px;
  text-align: center;
  border: 1px dashed var(--line-strong);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.01);
}

.ent-empty-state span:first-of-type {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--ink);
}

.ent-empty-icon {
  color: var(--muted);
  opacity: 0.4;
  margin-bottom: 4px;
}

.ent-empty-hint {
  font-size: 0.72rem;
  color: var(--muted);
  opacity: 0.7;
  max-width: 36ch;
  line-height: 1.4;
}

/* --- Permission toggle grid (Users tab) --- */
.ent-permission-grid {
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 8px;
}

.ent-permission-grid .ent-toggle-card {
  border-left: 3px solid var(--line);
  transition: border-left-color 0.2s, border-color 0.2s, background 0.2s;
}

.ent-permission-grid .ent-toggle-card:has(input:checked) {
  border-left-color: var(--brand);
}

/* --- Policy toggle grid (Admin tab) --- */
.ent-policy-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

/* --- Guard rules checklist (Admin tab) --- */
.ent-guard-panel {
  /* slight visual distinction for safety-critical section */
}

.ent-guard-checklist {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 4px;
}

.ent-guard-rule {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 10px 14px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.015);
  border: 1px solid var(--line);
  border-left: 3px solid var(--success);
  transition: border-color 0.2s, background 0.15s;
}

.ent-guard-rule:has(input:not(:checked)) {
  border-left-color: var(--line-strong);
  opacity: 0.65;
}

.ent-guard-rule:hover {
  background: rgba(255, 255, 255, 0.03);
}

.ent-guard-item {
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
  margin: 0;
}

.ent-guard-desc {
  font-size: 0.7rem;
  color: var(--muted);
  opacity: 0.7;
  line-height: 1.4;
  padding-left: 0;
}

/* --- User list polish --- */
.ent-user-list {
  max-height: 340px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--line-strong) transparent;
}

/* --- Table wrap polish --- */
.ent-table-wrap {
  border-radius: 8px;
  overflow: hidden;
}

/* --- Leaderboard panel --- */
.ent-leaderboard-panel {
  background: var(--surface-card);
}

/* enterprise responsive — in consolidated section */

/* =============================================================================
   ENTERPRISE DESIGN SYSTEM v2 — Vairifeye Non-Dashboard Tabs
   Datadog / Linear / Vercel aesthetic. APPEND-ONLY overrides.
   ============================================================================= */

/* ---------------------------------------------------------------------------
   0. Enterprise Design Tokens (v2)
   --------------------------------------------------------------------------- */
:root {
  --v2-bg: #0a0e1a;
  --v2-surface: rgba(255,255,255,0.03);
  --v2-surface-elevated: rgba(255,255,255,0.05);
  --v2-surface-hover: rgba(255,255,255,0.07);
  --v2-border: rgba(255,255,255,0.06);
  --v2-border-strong: rgba(255,255,255,0.10);
  --v2-primary: #1B65E0;
  --v2-primary-hover: #2563eb;
  --v2-primary-soft: rgba(59,130,246,0.10);
  --v2-primary-glow: 0 0 0 3px rgba(59,130,246,0.15);
  --v2-success: #79BF43;
  --v2-success-soft: rgba(34,197,94,0.10);
  --v2-warning: #f59e0b;
  --v2-warning-soft: rgba(245,158,11,0.10);
  --v2-danger: #ef4444;
  --v2-danger-soft: rgba(239,68,68,0.10);
  --v2-text: rgba(255,255,255,0.85);
  --v2-text-muted: rgba(255,255,255,0.5);
  --v2-text-strong: #ffffff;
  --v2-radius-sm: 6px;
  --v2-radius-md: 8px;
  --v2-radius-lg: 12px;
  --v2-speed: 0.15s ease;
}

/* ---------------------------------------------------------------------------
   1. Panel Headers — separator, muted section-label, clean h3
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .panel-header {
  padding-bottom: 12px;
  border-bottom: 1px solid var(--v2-border);
  margin-bottom: 16px;
}

.tab-panel:not(#view-dashboard) .panel-header .section-label {
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--v2-text-muted);
  background: transparent;
  border: none;
  padding: 0;
}

.tab-panel:not(#view-dashboard) .panel-header h3 {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--v2-text-strong);
  letter-spacing: -0.02em;
  line-height: 1.3;
}

.tab-panel:not(#view-dashboard) .panel-header > div {
  gap: 4px;
}

/* ---------------------------------------------------------------------------
   2. Form Fields — 40px height, 8px radius, focus glow
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) input[type="text"],
.tab-panel:not(#view-dashboard) input[type="email"],
.tab-panel:not(#view-dashboard) input[type="tel"],
.tab-panel:not(#view-dashboard) input[type="password"],
.tab-panel:not(#view-dashboard) input[type="number"],
.tab-panel:not(#view-dashboard) select {
  height: 40px;
  padding: 8px 12px;
  border-radius: var(--v2-radius-md);
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  color: var(--v2-text);
  font-size: 0.82rem;
  transition: border-color var(--v2-speed), box-shadow var(--v2-speed);
}

.tab-panel:not(#view-dashboard) textarea {
  padding: 10px 12px;
  border-radius: var(--v2-radius-md);
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  color: var(--v2-text);
  font-size: 0.82rem;
  transition: border-color var(--v2-speed), box-shadow var(--v2-speed);
}

.tab-panel:not(#view-dashboard) input[type="text"]:focus,
.tab-panel:not(#view-dashboard) input[type="email"]:focus,
.tab-panel:not(#view-dashboard) input[type="tel"]:focus,
.tab-panel:not(#view-dashboard) input[type="password"]:focus,
.tab-panel:not(#view-dashboard) input[type="number"]:focus,
.tab-panel:not(#view-dashboard) select:focus,
.tab-panel:not(#view-dashboard) textarea:focus {
  border-color: var(--v2-primary);
  box-shadow: var(--v2-primary-glow);
  outline: none;
}

.tab-panel:not(#view-dashboard) label > span {
  display: block;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--v2-text-muted);
  margin-bottom: 5px;
}

/* ---------------------------------------------------------------------------
   3. Toggle Cards — switch-card with CSS toggle, checked accent
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .toggle-card {
  background: var(--v2-surface);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-md);
  padding: 12px 14px;
  transition: background var(--v2-speed), border-color var(--v2-speed);
  cursor: pointer;
}

.tab-panel:not(#view-dashboard) .toggle-card:hover {
  background: var(--v2-surface-hover);
  border-color: var(--v2-border-strong);
}

.tab-panel:not(#view-dashboard) .toggle-card label {
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  width: 100%;
}

.tab-panel:not(#view-dashboard) .toggle-card label span {
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--v2-text);
  text-transform: none;
  letter-spacing: 0;
}

.tab-panel:not(#view-dashboard) .toggle-card label small {
  display: block;
  font-size: 0.7rem;
  color: var(--v2-text-muted);
  margin-top: 2px;
  line-height: 1.4;
}

/* CSS toggle switch for checkboxes */
.tab-panel:not(#view-dashboard) .toggle-card input[type="checkbox"] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  width: 36px;
  height: 20px;
  min-width: 36px;
  background: rgba(255,255,255,0.10);
  border-radius: 10px;
  position: relative;
  cursor: pointer;
  transition: background var(--v2-speed);
  border: none;
  outline: none;
  flex-shrink: 0;
}

.tab-panel:not(#view-dashboard) .toggle-card input[type="checkbox"]::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: rgba(255,255,255,0.45);
  transition: transform var(--v2-speed), background var(--v2-speed);
}

.tab-panel:not(#view-dashboard) .toggle-card input[type="checkbox"]:checked {
  background: var(--v2-primary);
}

.tab-panel:not(#view-dashboard) .toggle-card input[type="checkbox"]:checked::after {
  transform: translateX(16px);
  background: #fff;
}

/* Checked card accent */
.tab-panel:not(#view-dashboard) .toggle-card:has(input:checked) {
  border-left: 3px solid var(--v2-primary);
  background: var(--v2-primary-soft);
}

/* ---------------------------------------------------------------------------
   4. Status Messages — left accent bar, tinted bg
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .status {
  padding: 8px 12px;
  border-radius: var(--v2-radius-sm);
  font-size: 0.8rem;
  line-height: 1.5;
  color: var(--v2-text-muted);
  border-left: 4px solid transparent;
  margin-top: 10px;
  background: transparent;
}

.tab-panel:not(#view-dashboard) .status:not(:empty) {
  display: block;
}

.tab-panel:not(#view-dashboard) .status.loading {
  background: var(--v2-primary-soft);
  border-left-color: var(--v2-primary);
  color: var(--v2-primary);
}

.tab-panel:not(#view-dashboard) .status.success {
  background: var(--v2-success-soft);
  border-left-color: var(--v2-success);
  color: var(--v2-success);
}

.tab-panel:not(#view-dashboard) .status.warning {
  background: var(--v2-warning-soft);
  border-left-color: var(--v2-warning);
  color: var(--v2-warning);
}

.tab-panel:not(#view-dashboard) .status.error {
  background: var(--v2-danger-soft);
  border-left-color: var(--v2-danger);
  color: var(--v2-danger);
}

/* ---------------------------------------------------------------------------
   5. Buttons — primary, ghost, danger, compact
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) button:not(.tool-btn):not(.view-tab):not(.settings-tab):not(.mode-toggle):not(.preview-chip):not(.ent-btn-primary):not(.ent-btn-secondary) {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  height: 38px;
  padding: 0 18px;
  border-radius: var(--v2-radius-md);
  font-size: 0.82rem;
  font-weight: 500;
  border: none;
  cursor: pointer;
  transition: background var(--v2-speed), transform var(--v2-speed), box-shadow var(--v2-speed);
  background: var(--v2-primary);
  color: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}

.tab-panel:not(#view-dashboard) button:not(.tool-btn):not(.view-tab):not(.settings-tab):not(.mode-toggle):not(.preview-chip):hover {
  background: var(--v2-primary-hover);
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(59,130,246,0.25);
}

.tab-panel:not(#view-dashboard) button:not(.tool-btn):not(.view-tab):not(.settings-tab):not(.mode-toggle):not(.preview-chip):active {
  transform: translateY(0);
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}

.tab-panel:not(#view-dashboard) .ghost-button {
  background: transparent;
  color: var(--v2-text);
  border: 1px solid var(--v2-border-strong);
  box-shadow: none;
  height: 38px;
  padding: 0 18px;
  border-radius: var(--v2-radius-md);
  font-weight: 500;
}

.tab-panel:not(#view-dashboard) .ghost-button:hover {
  background: var(--v2-surface-hover);
  border-color: rgba(255,255,255,0.16);
  box-shadow: none;
}

.tab-panel:not(#view-dashboard) .compact-button {
  height: 32px;
  padding: 0 12px;
  font-size: 0.76rem;
}

.tab-panel:not(#view-dashboard) .danger-button {
  background: var(--v2-danger-soft);
  color: var(--v2-danger);
  border: 1px solid rgba(239,68,68,0.2);
  box-shadow: none;
}

.tab-panel:not(#view-dashboard) .danger-button:hover {
  background: rgba(239,68,68,0.18);
  border-color: rgba(239,68,68,0.3);
  box-shadow: none;
}

/* ---------------------------------------------------------------------------
   6. Stat Cards — subtle border, 1.8rem number, muted label
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .stat-card {
  background: var(--v2-surface);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-md);
  padding: 16px 18px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  transition: border-color var(--v2-speed);
}

.tab-panel:not(#view-dashboard) .stat-card:hover {
  border-color: var(--v2-border-strong);
}

.tab-panel:not(#view-dashboard) .stat-card span {
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--v2-text-muted);
  opacity: 1;
}

.tab-panel:not(#view-dashboard) .stat-card strong {
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--v2-text-strong);
  letter-spacing: -0.02em;
  line-height: 1.1;
}

/* Color accent left-border */
.tab-panel:not(#view-dashboard) .stat-card--accent  { border-left: 3px solid var(--v2-primary); }
.tab-panel:not(#view-dashboard) .stat-card--success { border-left: 3px solid var(--v2-success); }
.tab-panel:not(#view-dashboard) .stat-card--warning { border-left: 3px solid var(--v2-warning); }
.tab-panel:not(#view-dashboard) .stat-card--danger  { border-left: 3px solid var(--v2-danger); }

/* ---------------------------------------------------------------------------
   7. KPI Row (.an-kpi) — 2rem+ value, danger tint
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .an-kpi-row {
  gap: 10px;
}

.tab-panel:not(#view-dashboard) .an-kpi {
  background: var(--v2-surface);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-md);
  padding: 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  transition: border-color var(--v2-speed), background var(--v2-speed);
}

.tab-panel:not(#view-dashboard) .an-kpi:hover {
  border-color: var(--v2-border-strong);
}

.tab-panel:not(#view-dashboard) .an-kpi-label {
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--v2-text-muted);
}

.tab-panel:not(#view-dashboard) .an-kpi-val {
  font-size: 2.2rem;
  font-weight: 700;
  color: var(--v2-text-strong);
  letter-spacing: -0.02em;
  line-height: 1;
}

.tab-panel:not(#view-dashboard) .an-kpi--danger {
  background: var(--v2-danger-soft);
  border-color: rgba(239,68,68,0.15);
}

.tab-panel:not(#view-dashboard) .an-kpi--danger .an-kpi-val {
  color: var(--v2-danger);
}

.tab-panel:not(#view-dashboard) .an-kpi--danger .an-kpi-label {
  color: rgba(239,68,68,0.7);
}

/* ---------------------------------------------------------------------------
   8. Reference Items — card, hover elevation, tag badges
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .reference-item {
  background: var(--v2-surface);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-lg);
  padding: 16px 18px;
  transition: border-color var(--v2-speed), background var(--v2-speed), box-shadow var(--v2-speed);
}

.tab-panel:not(#view-dashboard) .reference-item:hover {
  border-color: var(--v2-border-strong);
  background: var(--v2-surface-elevated);
  box-shadow: 0 6px 20px rgba(0,0,0,0.12);
}

.tab-panel:not(#view-dashboard) .reference-item h3 {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--v2-text-strong);
}

.tab-panel:not(#view-dashboard) .reference-item small {
  font-size: 0.75rem;
  color: var(--v2-text-muted);
  line-height: 1.5;
}

.tab-panel:not(#view-dashboard) .reference-actions {
  display: flex;
  gap: 6px;
  align-items: center;
}

.tab-panel:not(#view-dashboard) .reference-actions button {
  height: 32px;
  padding: 0 12px;
  font-size: 0.75rem;
}

.tab-panel:not(#view-dashboard) .reference-item .mini-tag {
  font-size: 0.68rem;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 100px;
}

/* ---------------------------------------------------------------------------
   9. Summary Grid — alternating rows, muted labels, white values
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .summary-grid {
  gap: 2px;
  margin-top: 14px;
}

.tab-panel:not(#view-dashboard) .summary-card {
  background: var(--v2-surface);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-sm);
  padding: 10px 14px;
}

.tab-panel:not(#view-dashboard) .summary-card:nth-child(odd) {
  background: var(--v2-surface-elevated);
}

.tab-panel:not(#view-dashboard) .summary-card span {
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--v2-text-muted);
}

.tab-panel:not(#view-dashboard) .summary-card strong {
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--v2-text-strong);
}

/* ---------------------------------------------------------------------------
   10. Form Section Headers
   --------------------------------------------------------------------------- */
.form-section-header {
  margin-top: 22px;
  margin-bottom: 14px;
  padding-top: 18px;
  border-top: 1px solid var(--v2-border);
}

.form-section-header span,
.form-section-header label {
  display: block;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--v2-text-muted);
}

.tab-panel:not(#view-dashboard) .stack-field label span {
  margin-bottom: 5px;
}

.tab-panel:not(#view-dashboard) .form-grid {
  gap: 10px;
}

/* ---------------------------------------------------------------------------
   11. Chip / Badge Styling — pill, color-coded
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .chip {
  border-radius: 100px;
  font-size: 0.76rem;
  font-weight: 600;
  padding: 5px 14px;
  border: 1px solid var(--v2-border);
  background: var(--v2-surface);
  color: var(--v2-text);
}

.tab-panel:not(#view-dashboard) .chip.available {
  background: var(--v2-success-soft);
  color: var(--v2-success);
  border-color: rgba(34,197,94,0.2);
}

.tab-panel:not(#view-dashboard) .chip.unavailable {
  background: var(--v2-surface);
  color: var(--v2-text-muted);
}

.tab-panel:not(#view-dashboard) .header-badge {
  border-radius: 100px;
  font-size: 0.6rem;
  font-weight: 700;
  padding: 3px 10px;
  letter-spacing: 0.08em;
}

.tab-panel:not(#view-dashboard) .header-badge.is-connected {
  background: var(--v2-success-soft);
  color: var(--v2-success);
  border-color: rgba(34,197,94,0.2);
}

.tab-panel:not(#view-dashboard) .header-badge.is-warning {
  background: var(--v2-warning-soft);
  color: var(--v2-warning);
  border-color: rgba(245,158,11,0.2);
}

.tab-panel:not(#view-dashboard) .mini-tag {
  border-radius: 100px;
  font-size: 0.7rem;
  font-weight: 600;
  padding: 4px 12px;
}

.tab-panel:not(#view-dashboard) .mini-tag.is-current {
  background: var(--v2-success-soft);
  color: var(--v2-success);
  border-color: rgba(34,197,94,0.2);
}

.tab-panel:not(#view-dashboard) .mini-tag.is-archived {
  background: var(--v2-surface);
  color: var(--v2-text-muted);
}

.tab-panel:not(#view-dashboard) .an-pipe-badge {
  border-radius: 100px;
  font-size: 0.6rem;
  font-weight: 700;
  padding: 2px 10px;
}

.tab-panel:not(#view-dashboard) .an-conf-level {
  border-radius: 100px;
  font-size: 0.65rem;
  font-weight: 700;
  padding: 3px 12px;
}

/* ---------------------------------------------------------------------------
   12. Empty States — centered, muted, bordered
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .empty-state {
  padding: 36px 28px;
  border: 1px dashed rgba(255,255,255,0.1);
  border-radius: var(--v2-radius-lg);
  color: var(--v2-text-muted);
  text-align: center;
  font-size: 0.85rem;
  line-height: 1.6;
  background: var(--v2-surface);
}

.tab-panel:not(#view-dashboard) .empty-state strong {
  display: block;
  color: var(--v2-text);
  font-size: 0.92rem;
  margin-bottom: 6px;
}

/* ---------------------------------------------------------------------------
   13. Permission Toggle Grid — 2-3 column mini-card toggles
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .permission-toggle-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: 14px;
}

.tab-panel:not(#view-dashboard) .permission-toggle-grid .toggle-card {
  border-radius: var(--v2-radius-md);
  padding: 10px 12px;
}

.tab-panel:not(#view-dashboard) .permission-toggle-grid .toggle-card:has(input:checked) {
  border-left: 3px solid var(--v2-primary);
  background: var(--v2-primary-soft);
}

/* permission-toggle-grid responsive — in consolidated section */

/* ---------------------------------------------------------------------------
   14. Admin Table — striped rows, muted header, wrapped border
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .admin-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-md);
  background: var(--v2-surface);
}

.tab-panel:not(#view-dashboard) .admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
}

.tab-panel:not(#view-dashboard) .admin-table th {
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--v2-text-muted);
  background: var(--v2-surface-elevated);
  padding: 10px 14px;
  text-align: left;
  border-bottom: 1px solid var(--v2-border-strong);
  white-space: nowrap;
  opacity: 1;
}

.tab-panel:not(#view-dashboard) .admin-table td {
  padding: 10px 14px;
  color: var(--v2-text);
  border-bottom: 1px solid var(--v2-border);
}

.tab-panel:not(#view-dashboard) .admin-table tbody tr:nth-child(even) {
  background: var(--v2-surface-elevated);
}

.tab-panel:not(#view-dashboard) .admin-table tbody tr {
  transition: background var(--v2-speed);
}

.tab-panel:not(#view-dashboard) .admin-table tbody tr:hover {
  background: var(--v2-surface-hover);
}

.tab-panel:not(#view-dashboard) .admin-table tbody tr:last-child td {
  border-bottom: none;
}

.tab-panel:not(#view-dashboard) .admin-table td.num {
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  color: var(--v2-text-strong);
}

/* ---------------------------------------------------------------------------
   15. Panel Actions — flex gap, vertically centered
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .panel-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.tab-panel:not(#view-dashboard) .panel-actions button {
  height: 34px;
  padding: 0 14px;
  font-size: 0.78rem;
}

/* ---------------------------------------------------------------------------
   16. View Tabs — polished tab bar
   --------------------------------------------------------------------------- */
.view-tabs {
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-md);
  padding: 3px;
}

.view-tab {
  border-radius: var(--v2-radius-sm);
  font-size: 0.78rem;
  font-weight: 500;
  color: var(--v2-text-muted);
  padding: 7px 14px;
  transition: color var(--v2-speed), background var(--v2-speed);
}

.view-tab:hover {
  color: var(--v2-text);
  background: rgba(255,255,255,0.04);
}

.view-tab.is-active {
  background: var(--v2-surface-elevated);
  color: var(--v2-text-strong);
  border-color: var(--v2-border-strong);
  box-shadow: 0 2px 8px rgba(0,0,0,0.12);
}

/* ---------------------------------------------------------------------------
   17. History Items — card, selection state
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .history-item {
  background: var(--v2-surface);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-lg);
  padding: 14px 16px;
  transition: border-color var(--v2-speed), background var(--v2-speed);
}

.tab-panel:not(#view-dashboard) .history-item:hover {
  border-color: var(--v2-border-strong);
  background: var(--v2-surface-elevated);
}

.tab-panel:not(#view-dashboard) .history-item.is-selected {
  border-color: var(--v2-primary);
  background: var(--v2-primary-soft);
}

/* ---------------------------------------------------------------------------
   18. Score Cards — pass/fail/warning accent bars
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .score {
  background: var(--v2-surface);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-sm);
  padding: 10px 12px;
}

.tab-panel:not(#view-dashboard) .score span {
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--v2-text-muted);
}

.tab-panel:not(#view-dashboard) .score.pass       { border-left: 3px solid var(--v2-success); }
.tab-panel:not(#view-dashboard) .score.pass strong { color: var(--v2-success); }
.tab-panel:not(#view-dashboard) .score.fail        { border-left: 3px solid var(--v2-danger); }
.tab-panel:not(#view-dashboard) .score.fail strong  { color: var(--v2-danger); }
.tab-panel:not(#view-dashboard) .score.warning       { border-left: 3px solid var(--v2-warning); }
.tab-panel:not(#view-dashboard) .score.warning strong { color: var(--v2-warning); }

.tab-panel:not(#view-dashboard) .mini-score.pass {
  color: var(--v2-success);
  background: var(--v2-success-soft);
  border-color: rgba(34,197,94,0.2);
}

.tab-panel:not(#view-dashboard) .mini-score.fail {
  color: var(--v2-danger);
  background: var(--v2-danger-soft);
  border-color: rgba(239,68,68,0.2);
}

.tab-panel:not(#view-dashboard) .mini-score.warning {
  color: var(--v2-warning);
  background: var(--v2-warning-soft);
  border-color: rgba(245,158,11,0.2);
}

/* ---------------------------------------------------------------------------
   19. Analytics Surfaces — consistent card treatment
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .an-conf-card {
  background: var(--v2-surface);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-md);
  padding: 14px 16px;
}

.tab-panel:not(#view-dashboard) .an-vbar-track {
  background: rgba(255,255,255,0.05);
  border-radius: var(--v2-radius-sm);
}

.tab-panel:not(#view-dashboard) .an-conf-bar-wrap {
  background: rgba(255,255,255,0.06);
}

.tab-panel:not(#view-dashboard) .an-pipe-row {
  border-bottom-color: var(--v2-border);
  padding: 8px 0;
}

.tab-panel:not(#view-dashboard) .an-user-row {
  background: var(--v2-surface);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-sm);
  padding: 8px 12px;
  margin-bottom: 2px;
  transition: background var(--v2-speed);
}

.tab-panel:not(#view-dashboard) .an-user-row:hover {
  background: var(--v2-surface-hover);
}

/* ---------------------------------------------------------------------------
   20. Brief / Metric Cards
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .brief-card,
.tab-panel:not(#view-dashboard) .metric-card {
  background: var(--v2-surface);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-md);
  padding: 12px 14px;
  transition: border-color var(--v2-speed);
}

.tab-panel:not(#view-dashboard) .brief-card:hover,
.tab-panel:not(#view-dashboard) .metric-card:hover {
  border-color: var(--v2-border-strong);
}

.tab-panel:not(#view-dashboard) .brief-title,
.tab-panel:not(#view-dashboard) .metric-card span {
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--v2-text-muted);
}

/* ---------------------------------------------------------------------------
   21. Section Labels & Eyebrows
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .section-label,
.tab-panel:not(#view-dashboard) .eyebrow {
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--v2-text-muted);
  background: transparent;
  border: none;
  padding: 0;
}

/* ---------------------------------------------------------------------------
   22. Modal Overlays
   --------------------------------------------------------------------------- */
.modal {
  background: rgba(0,0,0,0.5);
  backdrop-filter: blur(4px);
}

.modal-panel {
  background: linear-gradient(180deg, rgba(18, 20, 46, 0.98), rgba(13, 18, 48, 0.98));
  border: 1px solid var(--v2-border-strong);
  border-radius: var(--v2-radius-lg);
  box-shadow: 0 24px 80px rgba(0,0,0,0.4);
}

/* ---------------------------------------------------------------------------
   23. Autocomplete Dropdown
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .autocomplete-list {
  background: rgba(16,22,36,0.98);
  border: 1px solid var(--v2-border-strong);
  border-radius: var(--v2-radius-md);
  box-shadow: 0 12px 40px rgba(0,0,0,0.3);
  backdrop-filter: blur(20px);
}

.tab-panel:not(#view-dashboard) .autocomplete-list li {
  padding: 8px 12px;
  border-bottom-color: var(--v2-border);
  transition: background var(--v2-speed);
}

.tab-panel:not(#view-dashboard) .autocomplete-list li:hover,
.tab-panel:not(#view-dashboard) .autocomplete-list li.is-active {
  background: var(--v2-primary-soft);
}

/* ---------------------------------------------------------------------------
   24. Flow Steps — pipeline indicators
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .flow-step {
  background: var(--v2-surface);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-sm);
  transition: border-color var(--v2-speed), background var(--v2-speed);
}

.tab-panel:not(#view-dashboard) .flow-step.is-complete {
  background: var(--v2-success-soft);
  border-color: rgba(34,197,94,0.25);
}

.tab-panel:not(#view-dashboard) .flow-step.is-partial {
  background: var(--v2-warning-soft);
  border-color: rgba(245,158,11,0.25);
}

.tab-panel:not(#view-dashboard) .flow-step.is-active {
  border-color: var(--v2-primary);
  background: var(--v2-primary-soft);
}

/* ---------------------------------------------------------------------------
   25. Identity Bar
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .identity {
  background: var(--v2-surface);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-md);
}

/* ---------------------------------------------------------------------------
   26. Checkbox Pill
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .checkbox-pill {
  border-radius: var(--v2-radius-sm);
  background: var(--v2-surface);
  border: 1px solid var(--v2-border);
  font-size: 0.78rem;
  font-weight: 500;
  color: var(--v2-text);
  padding: 6px 12px;
  transition: background var(--v2-speed), border-color var(--v2-speed);
}

.tab-panel:not(#view-dashboard) .checkbox-pill:hover {
  background: var(--v2-surface-hover);
  border-color: var(--v2-border-strong);
}

/* ---------------------------------------------------------------------------
   27. Live Counter
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .live-counter {
  background: var(--v2-surface);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-md);
  font-size: 0.82rem;
  font-weight: 600;
}

.tab-panel:not(#view-dashboard) .counter-pass      { color: var(--v2-success); }
.tab-panel:not(#view-dashboard) .counter-deny      { color: var(--v2-danger); }
.tab-panel:not(#view-dashboard) .counter-na        { color: var(--v2-warning); }
.tab-panel:not(#view-dashboard) .counter-remaining { color: var(--v2-text-muted); }

/* ---------------------------------------------------------------------------
   28. Manual Review Panel
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .manual-review-panel {
  background: var(--v2-surface);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-md);
}

.tab-panel:not(#view-dashboard) .mi-label {
  color: var(--v2-text-muted);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.06em;
}

/* ---------------------------------------------------------------------------
   29. Walkthrough Overlay
   --------------------------------------------------------------------------- */
.walkthrough-panel {
  background: linear-gradient(180deg, rgba(18, 20, 46, 0.98), rgba(13, 18, 48, 0.98));
  border: 1px solid var(--v2-border-strong);
  box-shadow: 0 24px 80px rgba(0,0,0,0.4);
}

/* ---------------------------------------------------------------------------
   30. Login Panel
   --------------------------------------------------------------------------- */
.login-form input[type="text"],
.login-form input[type="password"] {
  height: 48px;
  padding: 0 16px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(155, 163, 175, 0.18);
  color: var(--ink-strong);
  font-family: var(--font-body);
  font-size: 0.92rem;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.login-form input:focus {
  border-color: rgba(44, 125, 255, 0.5);
  box-shadow: 0 0 0 3px rgba(44, 125, 255, 0.12);
  outline: none;
  background: rgba(255, 255, 255, 0.08);
}

.pw-reveal-wrap {
  position: relative;
  display: flex;
  align-items: center;
}
.pw-reveal-wrap input {
  flex: 1;
  padding-right: 42px;
}
.pw-reveal-btn {
  position: absolute;
  right: 6px;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  color: rgba(255,255,255,0.4);
  cursor: pointer;
  border-radius: 4px;
  padding: 0;
}
.pw-reveal-btn:hover { color: rgba(255,255,255,0.8); background: rgba(255,255,255,0.06); }

.remember-me {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  color: rgba(255,255,255,0.5);
  cursor: pointer;
  flex-direction: row;
}
.remember-me input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--v2-primary);
  cursor: pointer;
}

.login-form button[type="submit"] {
  height: 48px;
  margin-top: 4px;
  font-family: var(--font-display);
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: #fff;
  background: linear-gradient(135deg, #2C7DFF, #1B65E0);
  border: 1px solid rgba(44, 125, 255, 0.35);
  border-radius: 10px;
  cursor: pointer;
  box-shadow: 0 4px 20px rgba(44, 125, 255, 0.20);
  transition: box-shadow 0.2s, transform 0.15s;
}
.login-form button[type="submit"]:hover {
  box-shadow: 0 6px 28px rgba(44, 125, 255, 0.35);
  transform: translateY(-1px);
}
.login-form button[type="submit"]:active {
  transform: translateY(0);
  box-shadow: 0 2px 12px rgba(44, 125, 255, 0.20);
}

.login-note {
  border-radius: 10px;
  border-color: rgba(44, 125, 255, 0.15);
  background: rgba(44, 125, 255, 0.06);
}

.login-error {
  border-radius: 10px;
  border-color: rgba(201, 75, 86, 0.2);
  background: rgba(201, 75, 86, 0.08);
}

.login-links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-top: 2px;
  font-size: 0.75rem;
}
.login-links a {
  color: rgba(44, 125, 255, 0.7);
  text-decoration: none;
  transition: color 0.15s;
}
.login-links a:hover { color: #2C7DFF; text-decoration: none; }
.login-link-sep { color: var(--muted); opacity: 0.3; }

/* SSO login button — shown only when VCA_SSO_PROVIDER is configured */
.login-sso-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 1rem 0;
  color: var(--muted);
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.login-sso-divider::before,
.login-sso-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--v2-border);
}
.login-sso-button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  height: 44px;
  padding: 0 1rem;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--v2-text);
  background: var(--v2-surface);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-md);
  text-decoration: none;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
.login-sso-button:hover {
  background: var(--v2-surface-hover, rgba(255,255,255,0.08));
  border-color: var(--v2-primary);
}

.demo-account-card {
  background: var(--v2-surface);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-md);
}

/* ---------------------------------------------------------------------------
   31. Mode Choice Cards
   --------------------------------------------------------------------------- */
.mode-choice {
  background: var(--v2-surface);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-lg);
  padding: 20px;
  transition: border-color var(--v2-speed), background var(--v2-speed);
}

.mode-choice:hover {
  border-color: var(--v2-primary);
  background: var(--v2-primary-soft);
}

.mode-title {
  font-weight: 700;
  font-size: 0.92rem;
  color: var(--v2-text-strong);
}

.mode-copy {
  color: var(--v2-text-muted);
  font-size: 0.82rem;
}

/* ---------------------------------------------------------------------------
   32. Maturity Ladder
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .ladder-step {
  background: var(--v2-surface);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-sm);
}

.tab-panel:not(#view-dashboard) .ladder-step.is-active {
  background: var(--v2-primary-soft);
  border-color: rgba(59,130,246,0.2);
  box-shadow: 0 0 10px rgba(59,130,246,0.08);
}

/* 33. Intake Steps — removed (browser-scraping workflow was removed) */

/* ---------------------------------------------------------------------------
   33a. REVIEW WORKSPACE — Three-column audit layout
   LEFT: item list  |  CENTER: photo viewer  |  RIGHT: evaluation panel
   --------------------------------------------------------------------------- */
.review-workspace {
  background: var(--surface);
  border-radius: 14px;
  border: 1px solid var(--line);
  overflow: hidden;
  margin: 0 0 16px;
}

/* Header bar */
.rw-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 16px;
  border-bottom: 1px solid var(--line);
  background: var(--surface-strong);
  gap: 12px;
}
.rw-header-left,
.rw-header-center,
.rw-header-right {
  display: flex;
  align-items: center;
  gap: 8px;
}
.rw-shell-tag {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #6ba5ed;
  background: rgba(37, 99, 235, 0.12);
  border: 1px solid rgba(37, 99, 235, 0.28);
  padding: 3px 10px;
  border-radius: 100px;
}
.rw-job-tag,
.rw-site-tag {
  font-size: 0.74rem;
  color: var(--ink);
  font-weight: 600;
}
.rw-mode-tag {
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Three-column grid */
.rw-columns {
  display: grid;
  grid-template-columns: 240px 1fr 300px;
  min-height: 620px;
  max-height: calc(100vh - 240px);
}

/* LEFT: Item list */
.rw-left {
  display: flex;
  flex-direction: column;
  border-right: 1px solid var(--line);
  background: var(--surface-soft);
}
.rw-left-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 12px;
  border-bottom: 1px solid var(--line);
}
.rw-left-header .section-label {
  margin: 0;
  padding: 0;
}
.rw-progress-text {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--brand);
}
.rw-item-list {
  list-style: none;
  margin: 0;
  padding: 0;
  overflow-y: auto;
  flex: 1;
}
.rw-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 7px 12px;
  font-size: 0.76rem;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  transition: background 0.1s;
}
.rw-item:hover {
  background: var(--surface-button);
}
.rw-item.is-active {
  background: var(--brand-soft);
  border-left: 3px solid var(--brand);
}
.rw-item-rs {
  font-weight: 600;
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 160px;
}
.rw-item-verdict {
  font-size: 0.66rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  min-width: 36px;
  text-align: center;
}
.rw-item-verdict.pass { color: var(--success); }
.rw-item-verdict.fail { color: var(--danger); }
.rw-item-verdict.na { color: var(--muted); }
.rw-item-verdict.pending { color: var(--muted); opacity: 0.5; }
.rw-left-footer {
  padding: 10px 12px;
  border-top: 1px solid var(--line);
  background: var(--surface-strong);
}
.rw-tally {
  display: flex;
  gap: 12px;
  font-size: 0.7rem;
  font-weight: 600;
}
.rw-tally-pass { color: var(--success); }
.rw-tally-fail { color: var(--danger); }
.rw-tally-remaining { color: var(--muted); }

/* CENTER: Photo viewer */
.rw-center {
  display: flex;
  flex-direction: column;
  background: #0a0a0a;
  overflow: hidden;
}
.rw-photo-wrap {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 400px;
  position: relative;
  overflow: hidden;
}
.rw-photo {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.rw-photo img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}
.rw-photo-placeholder {
  color: var(--muted);
  font-size: 0.82rem;
  opacity: 0.5;
}
.rw-photo-meta {
  padding: 8px 14px;
  border-top: 1px solid rgba(255,255,255,0.08);
  background: rgba(0,0,0,0.6);
}
.rw-description {
  font-size: 0.82rem;
  color: #e2e8f0;
  font-weight: 500;
  line-height: 1.35;
  margin-bottom: 4px;
}
.rw-photo-details {
  display: flex;
  gap: 14px;
  font-size: 0.68rem;
  color: rgba(255,255,255,0.5);
}
.rw-photo-details span.is-ok { color: var(--success); }
.rw-photo-details span.is-warn { color: var(--warning); }
.rw-photo-details span.is-bad { color: var(--danger); }
.rw-photo-thumbs {
  display: flex;
  gap: 4px;
  padding: 6px 14px;
  background: rgba(0,0,0,0.4);
  border-top: 1px solid rgba(255,255,255,0.06);
  overflow-x: auto;
}
.rw-thumb {
  width: 48px;
  height: 48px;
  border-radius: 4px;
  border: 2px solid transparent;
  cursor: pointer;
  object-fit: cover;
  opacity: 0.6;
  transition: opacity 0.15s, border-color 0.15s;
}
.rw-thumb:hover { opacity: 0.85; }
.rw-thumb.is-active {
  border-color: var(--brand);
  opacity: 1;
}

/* RIGHT: Evaluation panel */
.rw-right {
  display: flex;
  flex-direction: column;
  border-left: 1px solid var(--line);
  background: var(--surface-soft);
  overflow-y: auto;
}
.rw-verdict-card {
  padding: 16px;
  text-align: center;
  border-bottom: 1px solid var(--line);
  background: var(--surface-strong);
}
.rw-verdict-label {
  font-size: 0.62rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
  margin-bottom: 4px;
}
.rw-verdict-value {
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--muted);
}
.rw-verdict-value.pass { color: var(--success); }
.rw-verdict-value.fail { color: var(--danger); }
.rw-verdict-value.na { color: var(--warning); }
.rw-verdict-value.missing { color: var(--danger); opacity: 0.7; }
.rw-confidence {
  font-size: 0.72rem;
  color: var(--muted);
  margin-top: 2px;
}

/* Gate results */
.rw-gates {
  padding: 12px 14px;
  border-bottom: 1px solid var(--line);
}
.rw-gates .section-label {
  margin: 0 0 8px;
  padding: 0;
}
.rw-gate-list {
  list-style: none;
  margin: 0;
  padding: 0;
  counter-reset: none;
}
.rw-gate {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 5px 0;
  font-size: 0.74rem;
  border-bottom: 1px solid var(--line);
}
.rw-gate:last-child { border-bottom: none; }
.rw-gate-name {
  color: var(--ink);
  font-weight: 500;
}
.rw-gate-status {
  font-weight: 700;
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.rw-gate-status.pass { color: var(--success); }
.rw-gate-status.fail { color: var(--danger); }
.rw-gate-status.skip { color: var(--muted); opacity: 0.6; }
.rw-gate-status.block { color: var(--danger); font-weight: 800; }

/* Punches */
.rw-punches {
  padding: 12px 14px;
  border-bottom: 1px solid var(--line);
  flex: 1;
}
.rw-punches .section-label {
  margin: 0 0 6px;
  padding: 0;
}
.rw-punch-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.rw-punch-item {
  font-size: 0.74rem;
  color: var(--danger);
  padding: 4px 0;
  border-bottom: 1px solid var(--line);
}
.rw-punch-item:last-child { border-bottom: none; }

/* Action buttons */
.rw-actions {
  display: flex;
  gap: 6px;
  padding: 12px 14px;
  background: var(--surface-strong);
  border-top: 1px solid var(--line);
  flex-wrap: wrap;
}
.rw-btn {
  flex: 1;
  min-width: 0;
  padding: 10px 8px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--surface-button);
  color: var(--ink);
  font-size: 0.76rem;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  text-align: center;
}
.rw-btn:hover { background: var(--surface-button-strong); }
.rw-btn--approve {
  background: var(--success-soft);
  color: var(--success);
  border-color: rgba(95, 150, 52, 0.25);
}
.rw-btn--approve:hover { background: rgba(95, 150, 52, 0.22); }
.rw-btn--override { color: var(--warning); border-color: rgba(184, 133, 24, 0.2); }
.rw-btn--flag { color: var(--muted); }
.rw-btn--next {
  background: var(--brand-soft);
  color: var(--brand);
  border-color: rgba(47, 111, 178, 0.25);
}
.rw-btn--next:hover { background: rgba(47, 111, 178, 0.22); }
.rw-override-wrap {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.rw-override-select {
  padding: 6px 8px;
  border-radius: 6px;
  border: 1px solid var(--line);
  background: var(--input-bg);
  color: var(--ink);
  font-size: 0.74rem;
}

/* Responsive */
@media (max-width: 1200px) {
  .rw-columns {
    grid-template-columns: 200px 1fr 260px;
  }
}
@media (max-width: 900px) {
  .rw-columns {
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr auto;
  }
  .rw-left {
    border-right: none;
    border-bottom: 1px solid var(--line);
    max-height: 180px;
  }
  .rw-right {
    border-left: none;
    border-top: 1px solid var(--line);
  }
}

/* ---------------------------------------------------------------------------
   33b. Diagnostic Form Controls (pw-* classes used in Diagnostic tab)
   --------------------------------------------------------------------------- */
.pw-form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 10px;
  align-items: end;
}
.pw-batch-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: flex-end;
}
.pw-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.pw-field--sm {
  max-width: 160px;
}
.pw-field--url {
  min-width: 200px;
}
.pw-field-label {
  font-size: 0.72rem;
  color: var(--muted);
  font-weight: 600;
  letter-spacing: 0.02em;
}
.pw-input {
  padding: 7px 10px;
  border-radius: 6px;
  border: 1px solid var(--line);
  background: var(--input-bg);
  color: var(--ink);
  font-size: 0.82rem;
  font-family: inherit;
  transition: border-color 0.15s;
}
.pw-input:focus {
  outline: none;
  border-color: var(--brand);
}
.pw-progress-bar {
  font-size: 0.78rem;
  color: var(--muted);
  padding: 4px 0;
  min-height: 1.4em;
}

/* ---------------------------------------------------------------------------
   34. Thin Scrollbars
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) ::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

.tab-panel:not(#view-dashboard) ::-webkit-scrollbar-track {
  background: transparent;
}

.tab-panel:not(#view-dashboard) ::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.08);
  border-radius: 3px;
}

.tab-panel:not(#view-dashboard) ::-webkit-scrollbar-thumb:hover {
  background: rgba(255,255,255,0.16);
}

/* ---------------------------------------------------------------------------
   35. Responsive for v2 Enterprise
   --------------------------------------------------------------------------- */
/* enterprise v2 responsive — in consolidated section */

/* ---------------------------------------------------------------------------
   36. Print / PDF
   --------------------------------------------------------------------------- */
@media print {
  .tab-panel:not(#view-dashboard) .status {
    border-left-width: 3px;
  }

  .tab-panel:not(#view-dashboard) .toggle-card input[type="checkbox"] {
    -webkit-appearance: auto;
    appearance: auto;
  }
}

/* ---------------------------------------------------------------------------
   37. Agents Tab
   --------------------------------------------------------------------------- */
/* Agent Tier Groups */
.agent-tier-group { margin-bottom: 1.5rem; }
.agent-tier-label { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--muted); margin-bottom: 0.6rem; font-weight: 600; display: flex; align-items: center; gap: 6px; }
.agent-tier-count { font-size: 0.6rem; background: var(--v2-surface); padding: 1px 6px; border-radius: 8px; color: var(--v2-primary); font-weight: 700; }

/* Agent Card Grid — tier 0/1 get wider cards */
.agent-card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 10px; }
.agent-card-grid--t0, .agent-card-grid--t1 { grid-template-columns: 1fr; max-width: 480px; }

/* Agent Card — glass surface with left accent bar */
.agent-card { display: flex; background: var(--v2-surface); border: 1px solid var(--v2-border); border-radius: 10px; overflow: hidden; transition: border-color 0.2s, box-shadow 0.2s; }
.agent-card:hover { border-color: var(--v2-primary); box-shadow: 0 2px 12px rgba(99,179,237,0.08); }
.agent-card--active { border-color: var(--v2-success); }
.agent-card--error { border-color: var(--v2-danger); }
.agent-card--idle { border-color: var(--v2-border); }

/* Accent bar — colored by tier */
.agent-card-accent { width: 4px; flex-shrink: 0; }
.agent-card-accent--t0 { background: linear-gradient(180deg, #ffd700, #f59e0b); }
.agent-card-accent--t1 { background: linear-gradient(180deg, #2C7DFF, #1B65E0); }
.agent-card-accent--t2 { background: linear-gradient(180deg, var(--v2-primary), #4a90d9); }
.agent-card-accent--t3 { background: linear-gradient(180deg, #8b5cf6, #7c3aed); }

/* Card body */
.agent-card-body { flex: 1; padding: 10px 12px; min-width: 0; }
.agent-card-top { margin-bottom: 6px; }

/* Name row: name + badges + state */
.agent-card-name-row { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.agent-card-name { font-size: 0.88rem; font-weight: 700; color: var(--v2-text, #e2e8f0); }
.agent-card--t0 .agent-card-name { color: #ffd700; font-size: 0.95rem; }
.agent-card--t1 .agent-card-name { color: #2C7DFF; font-size: 0.92rem; }
.agent-veto-badge { font-size: 0.5rem; background: var(--v2-danger); color: #fff; padding: 1px 5px; border-radius: 3px; text-transform: uppercase; letter-spacing: 0.05em; font-weight: 700; }
.agent-card-state { font-size: 0.6rem; margin-left: auto; white-space: nowrap; letter-spacing: 0.02em; }
.agent-card-state--active { color: var(--v2-success); }
.agent-card-state--error { color: var(--v2-danger); }
.agent-card-state--running { color: var(--v2-warning); }
.agent-card-state--idle { color: var(--muted); }

/* Title line */
.agent-card-title { font-size: 0.68rem; color: var(--muted); line-height: 1.3; margin-top: 2px; }

/* Health bar */
.agent-card-health-row { display: flex; align-items: center; gap: 6px; margin-bottom: 6px; }
.agent-card-health-bar { flex: 1; height: 4px; background: rgba(255,255,255,0.06); border-radius: 2px; overflow: hidden; }
.agent-card-health-fill { height: 100%; border-radius: 2px; transition: width 0.4s ease; }
.agent-card-health-val { font-size: 0.65rem; font-weight: 700; min-width: 30px; text-align: right; }

/* Stats row */
.agent-card-stats { display: flex; gap: 8px; font-size: 0.62rem; color: var(--muted); flex-wrap: wrap; margin-bottom: 4px; }
.agent-card-stat { white-space: nowrap; }
.agent-stat--open { color: var(--v2-warning); font-weight: 600; }
.agent-stat--clear { color: var(--v2-success); }
.agent-card-reports { color: var(--v2-primary); opacity: 0.7; }

/* Core rule — italic, subtle */
.agent-card-rule { font-size: 0.62rem; color: var(--muted); font-style: italic; line-height: 1.35; margin-top: 4px; opacity: 0.7; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Per-agent scheduler indicator row */
.agent-sched-row { display: flex; align-items: center; gap: 6px; margin-top: 5px; padding: 3px 0; font-size: 0.6rem; letter-spacing: 0.02em; }
.agent-sched-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.agent-sched-label { font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; }
.agent-sched-issues { color: var(--muted); }
.agent-sched-next { color: var(--muted); opacity: 0.7; }
.agent-sched-err { color: var(--v2-danger); font-size: 0.55rem; opacity: 0.8; }

/* Scheduler states */
.agent-sched--working .agent-sched-dot { background: var(--v2-primary); box-shadow: 0 0 6px var(--v2-primary); animation: sched-pulse 1.5s ease-in-out infinite; }
.agent-sched--working .agent-sched-label { color: var(--v2-primary); }
.agent-sched--critical .agent-sched-dot { background: var(--v2-danger); box-shadow: 0 0 8px var(--v2-danger); animation: sched-pulse 0.8s ease-in-out infinite; }
.agent-sched--critical .agent-sched-label { color: var(--v2-danger); }
.agent-sched--idle .agent-sched-dot { background: var(--v2-success); opacity: 0.6; }
.agent-sched--idle .agent-sched-label { color: var(--v2-success); opacity: 0.7; }
.agent-sched--error .agent-sched-dot { background: var(--v2-danger); }
.agent-sched--error .agent-sched-label { color: var(--v2-danger); }

@keyframes sched-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }

/* Scheduler header status spans */
.sched-online { color: var(--v2-success); font-weight: 600; }
.sched-working { color: var(--v2-primary); font-weight: 600; }
.sched-idle { color: var(--muted); }

/* Last message */
.agent-card-msg { font-size: 0.62rem; color: var(--muted); margin-top: 4px; border-top: 1px solid var(--v2-border); padding-top: 4px; line-height: 1.3; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Expand chevron on card header */
.agent-card-header { position: relative; }
.agent-card-chevron { position: absolute; top: 10px; right: 0; font-size: 0.55rem; color: var(--muted); opacity: 0.5; transition: transform 0.2s, opacity 0.2s; }
.agent-card--expanded .agent-card-chevron { transform: rotate(90deg); opacity: 0.8; }
.agent-card:hover .agent-card-chevron { opacity: 0.8; }

/* Expanded detail panel — hidden by default */
.ac-detail { display: none; margin-top: 8px; padding-top: 10px; border-top: 1px solid var(--v2-border); }
.agent-card--expanded .ac-detail { display: block; }
.agent-card--expanded { grid-column: 1 / -1; }
.agent-card--expanded .agent-card-rule { white-space: normal; opacity: 0.85; }

/* Core rule in expanded — big and bold */
.ac-detail-rule { font-size: 0.82rem; font-weight: 600; color: var(--v2-text); line-height: 1.45; padding: 8px 12px; background: rgba(255,255,255,0.03); border-radius: 6px; border-left: 3px solid var(--v2-primary); margin-bottom: 10px; }
.agent-card--t0.agent-card--expanded .ac-detail-rule { border-left-color: #ffd700; color: #ffd700; }
.agent-card--t1.agent-card--expanded .ac-detail-rule { border-left-color: #2C7DFF; }
.agent-card--t3.agent-card--expanded .ac-detail-rule { border-left-color: #8b5cf6; }

/* Detail sections */
.ac-detail-section { margin-bottom: 8px; }
.ac-detail-label { font-size: 0.6rem; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 4px; }
.ac-detail-behavior { font-size: 0.72rem; color: var(--v2-text); line-height: 1.4; font-style: italic; opacity: 0.85; }

/* Pills for owns / can / cannot */
.ac-detail-pills { display: flex; flex-wrap: wrap; gap: 4px; }
.ac-pill { font-size: 0.58rem; padding: 2px 7px; border-radius: 3px; background: rgba(99,179,237,0.1); color: var(--v2-primary); border: 1px solid rgba(99,179,237,0.15); white-space: nowrap; text-transform: capitalize; }
.ac-detail-pills--can .ac-pill { background: rgba(0,200,100,0.08); color: var(--v2-success); border-color: rgba(0,200,100,0.15); }
.ac-detail-pills--cant .ac-pill { background: rgba(255,80,80,0.08); color: var(--v2-danger); border-color: rgba(255,80,80,0.12); opacity: 0.8; }
.ac-detail-pills--gate .ac-pill { background: rgba(255,180,0,0.1); color: var(--v2-warning); border-color: rgba(255,180,0,0.15); }

/* Authority badges */
.ac-detail-authorities { display: flex; gap: 6px; }
.ac-auth-badge { font-size: 0.6rem; font-weight: 700; padding: 3px 10px; border-radius: 4px; text-transform: uppercase; letter-spacing: 0.04em; }
.ac-auth--veto { background: rgba(255,80,80,0.15); color: var(--v2-danger); border: 1px solid rgba(255,80,80,0.25); }
.ac-auth--final { background: rgba(255,215,0,0.12); color: #ffd700; border: 1px solid rgba(255,215,0,0.2); }

/* Detail footer stats */
.ac-detail-footer { display: flex; flex-wrap: wrap; gap: 12px; font-size: 0.62rem; color: var(--muted); margin-top: 10px; padding-top: 8px; border-top: 1px solid var(--v2-border); }

/* Detail last message */
.ac-detail-msg { font-size: 0.68rem; color: var(--v2-text); margin-top: 8px; padding: 8px 10px; background: rgba(255,255,255,0.02); border-radius: 5px; line-height: 1.45; border-left: 2px solid var(--muted); opacity: 0.8; }

.agent-findings-feed { display: flex; flex-direction: column; gap: 2px; }
.agent-finding-item { border-radius: 6px; background: var(--v2-surface); font-size: 0.85rem; overflow: visible; color: var(--v2-text, #bdd2ea); }
.agent-finding-item[data-status="acknowledged"] { opacity: 0.8; }
.agent-finding-item[data-status="resolved"], .agent-finding-item[data-status="dismissed"] { opacity: 0.55; }
.agent-finding-header { display: flex; align-items: center; gap: 10px; padding: 8px 10px; cursor: pointer; transition: background 0.15s; line-height: 1.4; }
.agent-finding-header:hover { background: rgba(255,255,255,0.04); }
.agent-finding-severity { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.agent-finding-sev-label { font-size: 0.7rem; font-weight: 700; letter-spacing: 0.04em; min-width: 58px; }
.agent-finding-agent { font-weight: 600; min-width: 90px; color: var(--v2-primary); white-space: nowrap; }
.agent-finding-title { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.agent-finding-ts { color: var(--muted); font-size: 0.75rem; min-width: 65px; text-align: right; white-space: nowrap; }
.agent-finding-status-badge { font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.04em; padding: 2px 8px; border-radius: 3px; white-space: nowrap; }
.agent-finding-status-badge--open { color: var(--v2-warning); background: rgba(255,180,0,0.12); }
.agent-finding-status-badge--acknowledged { color: var(--v2-info, #6aa1e0); background: rgba(106,161,224,0.12); }
.agent-finding-status-badge--resolved { color: var(--v2-success); background: rgba(0,200,100,0.12); }
.agent-finding-status-badge--dismissed { color: var(--muted); background: rgba(128,128,128,0.12); }
.agent-finding-chevron { color: var(--muted); font-size: 0.75rem; transition: transform 0.15s; align-self: center; }
.agent-finding-item.is-expanded .agent-finding-chevron { transform: rotate(90deg); }
.agent-finding-detail { display: none; padding: 4px 12px 10px 30px; }
.agent-finding-item.is-expanded .agent-finding-detail { display: block; }
.agent-finding-detail-body { padding: 8px 0; }
.agent-finding-detail-text { color: var(--v2-text); font-size: 0.82rem; line-height: 1.6; margin-bottom: 6px; white-space: pre-wrap; }
.agent-finding-rec { color: var(--v2-success); font-size: 0.78rem; margin-top: 6px; line-height: 1.4; }
.agent-finding-cat { color: var(--muted); font-size: 0.72rem; margin-top: 4px; }
.agent-finding-resolved-by { color: var(--muted); font-size: 0.72rem; margin-top: 4px; }
.agent-finding-actions { display: flex; gap: 8px; padding-top: 8px; border-top: 1px solid var(--v2-border); flex-wrap: wrap; }
.agent-finding-reopen { opacity: 0.7; }
.agent-finding-assign { color: var(--v2-primary); font-weight: 600; }
.agent-finding-assigned { font-size: 0.68rem; color: var(--v2-primary); background: rgba(99,179,237,0.1); padding: 1px 6px; border-radius: 3px; white-space: nowrap; }
.agent-finding-assigned-detail { color: var(--v2-primary); font-size: 0.72rem; margin-top: 4px; }

.agent-msg-row { display: flex; align-items: center; gap: 4px; padding: 3px 0; font-size: 0.65rem; border-bottom: 1px solid var(--v2-border); }
.agent-msg-from { font-weight: 600; color: var(--v2-primary); min-width: 50px; }
.agent-msg-arrow { color: var(--muted); }
.agent-msg-to { font-weight: 500; min-width: 40px; }
.agent-msg-text { flex: 1; color: var(--muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.agent-msg-ts { color: var(--muted); font-size: 0.6rem; }

.badge--danger { background: rgba(239, 68, 68, 0.15); color: var(--v2-danger); }

/* Hierarchy indent levels — replaces inline padding-left styles */
.an-pipe-row--l1 { padding-left: 12px; }
.an-pipe-row--l2 { padding-left: 24px; }
.an-pipe-row--l3 { padding-left: 36px; font-size: 0.85em; opacity: 0.85; }

/* Agent header flex layout — replaces inline flex style */
.panel-header > .an-header-actions { display: flex; gap: 8px; align-items: center; }

/* Muted status label — replaces inline font-size/color */
.an-status-label { font-size: 0.65rem; color: var(--muted); }

/* 38. Performance Tracker */
.agent-performance { overflow-x: auto; }
.perf-summary { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 12px; }
.perf-kpi { display: flex; flex-direction: column; align-items: center; padding: 8px 16px; background: var(--v2-surface); border-radius: 6px; min-width: 80px; }
.perf-kpi-val { font-size: 1.3rem; font-weight: 700; color: var(--v2-primary); }
.perf-kpi-label { font-size: 0.65rem; color: var(--muted); text-transform: uppercase; letter-spacing: 0.03em; }
.perf-scheduler-info { font-size: 0.72rem; color: var(--muted); margin-bottom: 10px; padding: 4px 8px; background: var(--v2-surface); border-radius: 4px; display: inline-block; }
.perf-table-wrap { overflow-x: auto; border-radius: 6px; border: 1px solid var(--v2-border); }
.perf-table { width: 100%; border-collapse: collapse; font-size: 0.75rem; }
.perf-table th { background: var(--v2-surface); padding: 6px 8px; text-align: left; font-weight: 600; font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.03em; color: var(--muted); white-space: nowrap; border-bottom: 1px solid var(--v2-border); }
.perf-table td { padding: 5px 8px; border-bottom: 1px solid var(--v2-border); white-space: nowrap; }
.perf-table tbody tr:hover { background: rgba(255,255,255,0.02); }
.perf-agent-name { font-weight: 600; color: var(--v2-primary); }
.perf-role { color: var(--muted); font-size: 0.7rem; max-width: 150px; overflow: hidden; text-overflow: ellipsis; }
.perf-state { font-size: 0.6rem; padding: 1px 5px; border-radius: 3px; text-transform: uppercase; }
.perf-state--active { color: var(--v2-success); background: rgba(0,200,100,0.1); }
.perf-state--idle { color: var(--muted); background: rgba(128,128,128,0.1); }
.perf-state--error { color: var(--v2-danger); background: rgba(239,68,68,0.1); }
.perf-state--running { color: var(--v2-warning); background: rgba(255,180,0,0.1); }
.perf-critical { color: var(--v2-danger); font-weight: 700; }
.perf-warning { color: var(--v2-warning); font-weight: 600; }
.perf-improving { color: var(--v2-success); }
.perf-declining { color: var(--v2-danger); }
.perf-date { font-size: 0.65rem; color: var(--muted); }
.perf-spark { display: flex; align-items: flex-end; gap: 2px; height: 24px; }
.perf-spark-bar { width: 6px; border-radius: 1px; min-height: 4px; transition: height 0.2s; }
.agent-scheduler--active { background: var(--v2-success); color: var(--bg); }

/* 39. Agent Finding Groups — tight, polished layout */
.afg-card { background: var(--v2-surface); border-radius: 8px; margin-bottom: 4px; overflow: hidden; border: 1px solid var(--v2-border); transition: border-color 0.2s, box-shadow 0.2s; }
.afg-card:hover { border-color: var(--v2-primary); box-shadow: 0 1px 8px rgba(99,179,237,0.06); }
.afg-card-header { display: flex; gap: 0; padding: 0; cursor: pointer; user-select: none; }
.afg-severity-bar { width: 3px; flex-shrink: 0; }
.afg-header-content { flex: 1; min-width: 0; padding: 7px 12px; }

/* Top row: avatar + name + role + badges + count + chevron */
.afg-header-top { display: flex; align-items: center; gap: 6px; min-width: 0; }
.afg-agent-avatar { font-size: 1rem; flex-shrink: 0; line-height: 1; }
.afg-agent-name { font-size: 0.82rem; font-weight: 700; color: var(--v2-text, #e2e8f0); white-space: nowrap; }
.afg-agent-role { font-size: 0.58rem; color: var(--muted); white-space: nowrap; padding: 1px 5px; background: rgba(255,255,255,0.04); border-radius: 3px; flex-shrink: 0; }

/* Severity badge chips */
.afg-badges { display: flex; gap: 3px; margin-left: auto; flex-shrink: 0; flex-wrap: nowrap; }
.afg-badge { font-size: 0.52rem; font-weight: 700; padding: 2px 5px; border-radius: 3px; white-space: nowrap; letter-spacing: 0.02em; text-transform: uppercase; }
.afg-badge--critical { color: #fff; background: var(--v2-danger); }
.afg-badge--warning { color: #1a1a2e; background: var(--v2-warning); }
.afg-badge--info { color: var(--v2-info, #6aa1e0); background: rgba(106,161,224,0.15); }
.afg-badge--success { color: var(--v2-success); background: rgba(0,200,100,0.12); }

/* Finding count pill */
.afg-finding-count { font-size: 0.55rem; font-weight: 700; color: var(--muted); background: rgba(255,255,255,0.06); padding: 1px 5px; border-radius: 8px; flex-shrink: 0; }
.afg-chevron { color: var(--muted); font-size: 0.7rem; transition: transform 0.2s; flex-shrink: 0; }
.afg-card.is-expanded .afg-chevron { transform: rotate(90deg); }

/* Briefing line — single line, truncated */
.afg-header-briefing { font-size: 0.65rem; color: var(--muted); margin-top: 3px; line-height: 1.3; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; opacity: 0.7; }
.afg-card.is-expanded .afg-header-briefing { white-space: normal; opacity: 1; }

/* Expanded body */
.afg-card-body { display: none; padding: 0 14px 10px; }
.afg-card.is-expanded .afg-card-body { display: block; }

/* Agent Briefing — the primary content */
.afg-briefing { background: rgba(255,255,255,0.02); border-radius: 8px; padding: 14px 16px; margin-bottom: 12px; border-left: 3px solid var(--v2-primary); }
.afg-briefing-para { font-size: 0.82rem; color: var(--v2-text); line-height: 1.65; margin: 0 0 8px; }
.afg-briefing-para:last-child { margin-bottom: 0; }
.afg-briefing-heading { display: block; font-size: 0.72rem; letter-spacing: 0.04em; margin: 12px 0 6px; padding-top: 8px; border-top: 1px solid var(--v2-border); }
.afg-briefing-heading--critical { color: var(--v2-danger); }
.afg-briefing-heading--warning { color: var(--v2-warning); }
.afg-briefing-heading--info { color: var(--v2-info, #6aa1e0); }
.afg-briefing-heading--success { color: var(--v2-success); }
.afg-briefing-rec { color: var(--v2-success); font-style: normal; font-weight: 600; }
.afg-briefing-why { color: var(--v2-info, #6aa1e0); font-style: normal; font-weight: 600; }
.afg-briefing-bottom { color: var(--v2-primary); font-style: normal; font-weight: 700; }

/* AI Deep Analysis (Claude API) */
.afg-ai-summary { margin-bottom: 10px; }
.afg-summary-placeholder { font-size: 0.75rem; color: var(--muted); font-style: italic; padding: 6px 0; }
.afg-summary-loading { font-size: 0.78rem; color: var(--v2-primary); padding: 8px 0; }
.afg-summary-content { background: rgba(106,161,224,0.06); border: 1px solid rgba(106,161,224,0.15); border-radius: 6px; padding: 10px 12px; }
.afg-summary-header { font-size: 0.7rem; font-weight: 700; color: var(--v2-primary); margin-bottom: 6px; display: flex; justify-content: space-between; }
.afg-summary-tokens { font-weight: 400; color: var(--muted); }
.afg-summary-text { font-size: 0.78rem; color: var(--v2-text); line-height: 1.5; }
.afg-summary-text p { margin: 0 0 6px; }
.afg-summary-text strong { color: var(--v2-primary); }
.afg-summary-error { font-size: 0.78rem; color: var(--v2-danger); padding: 6px 0; }

/* Group actions */
.afg-card-actions { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 12px; padding-bottom: 12px; border-bottom: 1px solid var(--v2-border); }

/* Raw findings toggle */
.afg-raw-findings { margin-top: 8px; }
.afg-raw-toggle { font-size: 0.72rem; color: var(--muted); cursor: pointer; padding: 4px 0; user-select: none; }
.afg-raw-toggle:hover { color: var(--v2-text); }
.afg-raw-findings[open] .afg-raw-toggle { color: var(--v2-text); margin-bottom: 8px; }

/* Individual findings within raw view */
.afg-findings-list { display: flex; flex-direction: column; gap: 6px; }
.afg-finding { padding: 8px 10px; background: rgba(255,255,255,0.02); border-radius: 5px; border: 1px solid var(--v2-border); }
.afg-finding[data-status="resolved"] { opacity: 0.5; }
.afg-finding[data-status="dismissed"] { opacity: 0.4; }
.afg-finding-header { display: flex; align-items: center; gap: 6px; }
.afg-sev-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.afg-sev-label { font-size: 0.62rem; font-weight: 700; min-width: 50px; }
.afg-finding-title { flex: 1; font-size: 0.8rem; color: var(--v2-text); }
.afg-finding-body { margin-top: 6px; padding-top: 6px; border-top: 1px solid rgba(255,255,255,0.04); }
.afg-finding-body p { font-size: 0.75rem; color: var(--muted); margin: 0 0 4px; line-height: 1.4; }
.afg-rec { color: var(--v2-success) !important; }
.afg-meta { font-size: 0.7rem !important; }

/* Suppress (known issue) button */
.afg-finding-actions { margin-top: 6px; display: flex; gap: 6px; }
.afg-suppress-btn { font-size: 0.62rem; padding: 3px 10px; border-radius: 4px; border: 1px solid rgba(255,180,0,0.25); background: rgba(255,180,0,0.08); color: var(--v2-warning); cursor: pointer; transition: all 0.15s; }
.afg-suppress-btn:hover { background: rgba(255,180,0,0.15); border-color: rgba(255,180,0,0.4); }
.afg-suppress-btn:disabled { cursor: default; opacity: 0.6; }
.afg-suppress-btn--done { border-color: rgba(0,200,100,0.25); background: rgba(0,200,100,0.08); color: var(--v2-success); }

/* ---------------------------------------------------------------------------
   Security Event Timeline
   --------------------------------------------------------------------------- */
.agent-security-summary { margin-bottom: 8px; }
.sec-summary-row { display: flex; flex-wrap: wrap; gap: 8px; }
.sec-stat { font-size: 0.72rem; padding: 4px 10px; border-radius: 6px; background: var(--v2-surface); border: 1px solid var(--v2-border); color: var(--muted); }
.sec-stat strong { font-weight: 700; margin-right: 2px; }
.sec-stat--critical strong { color: var(--v2-danger); }
.sec-stat--warning strong { color: var(--v2-warning); }
.sec-stat--success strong { color: var(--v2-success); }
.sec-stat--info strong { color: var(--v2-info, #6aa1e0); }

.agent-security-timeline { max-height: 400px; overflow-y: auto; scrollbar-width: thin; }
.sec-event { display: flex; align-items: flex-start; gap: 8px; padding: 6px 0; border-bottom: 1px solid var(--v2-border); }
.sec-event:last-child { border-bottom: none; }
.sec-event-dot { width: 6px; height: 6px; border-radius: 50%; margin-top: 6px; flex-shrink: 0; }
.sec-event-content { flex: 1; min-width: 0; }
.sec-event-header { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; font-size: 0.72rem; }
.sec-event-label { font-weight: 700; text-transform: uppercase; font-size: 0.62rem; letter-spacing: 0.03em; }
.sec-event-actor { color: var(--v2-text, #e2e8f0); font-weight: 500; }
.sec-event-ip { color: var(--muted); font-family: monospace; font-size: 0.65rem; }
.sec-event-ts { color: var(--muted); font-size: 0.6rem; margin-left: auto; }
.sec-event-detail { font-size: 0.65rem; color: var(--muted); margin-top: 2px; }
.sec-event-outcome { font-size: 0.58rem; text-transform: uppercase; letter-spacing: 0.04em; padding: 1px 6px; border-radius: 3px; margin-top: 2px; display: inline-block; }
.sec-event-outcome--fail { color: var(--v2-danger); background: rgba(239,68,68,0.1); }

/* ---------------------------------------------------------------------------
   Active Fix Queue
   --------------------------------------------------------------------------- */
.agent-fix-queue-stats { margin-bottom: 8px; }
.fq-stats-row { display: flex; flex-wrap: wrap; gap: 8px; }
.fq-stat { font-size: 0.72rem; padding: 4px 10px; border-radius: 6px; background: var(--v2-surface); border: 1px solid var(--v2-border); color: var(--muted); }
.fq-stat strong { font-weight: 700; margin-right: 2px; }
.fq-stat--critical strong { color: var(--v2-danger); }
.fq-stat--warning strong { color: var(--v2-warning); }

.agent-fix-queue { max-height: 500px; overflow-y: auto; scrollbar-width: thin; }
.fq-item { display: flex; gap: 0; margin-bottom: 4px; border-radius: 6px; border: 1px solid var(--v2-border); background: var(--v2-surface); overflow: hidden; transition: border-color 0.15s; }
.fq-item:hover { border-color: var(--v2-primary); }
.fq-item-priority { writing-mode: vertical-lr; text-orientation: mixed; font-size: 0.6rem; font-weight: 800; letter-spacing: 0.06em; color: #fff; padding: 6px 4px; display: flex; align-items: center; justify-content: center; min-width: 22px; }
.fq-item-content { flex: 1; padding: 8px 10px; min-width: 0; }
.fq-item-header { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.fq-item-title { font-size: 0.78rem; color: var(--v2-text, #e2e8f0); }
.fq-item-agent { font-size: 0.62rem; color: var(--v2-primary); background: rgba(99,179,237,0.08); padding: 1px 6px; border-radius: 3px; white-space: nowrap; }
.fq-item-status { font-size: 0.6rem; text-transform: uppercase; letter-spacing: 0.04em; padding: 1px 6px; border-radius: 3px; white-space: nowrap; }
.fq-item-status--open { color: var(--v2-warning); background: rgba(255,180,0,0.12); }
.fq-item-status--acknowledged { color: var(--v2-info, #6aa1e0); background: rgba(106,161,224,0.12); }
.fq-item-detail { font-size: 0.68rem; color: var(--muted); margin-top: 4px; line-height: 1.35; }
.fq-item-rec { font-size: 0.68rem; color: var(--v2-success); margin-top: 3px; line-height: 1.35; }
.fq-item-meta { font-size: 0.6rem; color: var(--muted); margin-top: 4px; display: flex; gap: 12px; }
.fq-item-actions { margin-top: 6px; display: flex; gap: 6px; }
.fq-item-actions button { font-size: 0.62rem; padding: 3px 10px; }

/* ---------------------------------------------------------------------------
   Conversation Threads
   --------------------------------------------------------------------------- */
.conv-thread { padding: 6px 0; border-bottom: 1px solid var(--v2-border); cursor: pointer; }
.conv-thread:last-child { border-bottom: none; }
.conv-thread:hover { background: rgba(255,255,255,0.02); }
.conv-thread.is-expanded { background: rgba(99,179,237,0.04); }
.conv-thread-header { display: flex; align-items: center; gap: 6px; font-size: 0.68rem; }
.conv-thread-participants { font-weight: 600; color: var(--v2-text, #e2e8f0); }
.conv-thread-count { font-size: 0.58rem; color: var(--muted); background: rgba(255,255,255,0.05); padding: 1px 5px; border-radius: 3px; }
.conv-thread-ts { margin-left: auto; font-size: 0.58rem; color: var(--muted); }
.conv-thread-preview { font-size: 0.62rem; color: var(--muted); margin-top: 2px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.conv-thread-messages { padding: 4px 0 4px 12px; border-left: 2px solid var(--v2-border); margin-top: 4px; }
.conv-msg { display: flex; align-items: baseline; gap: 4px; font-size: 0.62rem; padding: 2px 0; }
.conv-msg-from { font-weight: 600; color: var(--v2-primary); }
.conv-msg-arrow { color: var(--muted); font-size: 0.55rem; }
.conv-msg-to { font-weight: 500; color: var(--v2-text, #e2e8f0); }
.conv-msg-text { flex: 1; color: var(--muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.conv-msg-ts { color: var(--muted); font-size: 0.55rem; flex-shrink: 0; }

/* ---------------------------------------------------------------------------
   40. Responsive — Desktop (1280+), iPad (768-1279), Mobile (< 768)
   Optimized separately so sliding/scrolling never breaks layout.
   --------------------------------------------------------------------------- */

/* Agent responsive — in consolidated section */


/* Scorecard result */
#pw-audit-scorecard .glass-panel {
  margin-top: 10px;
  border: 1px solid var(--line, rgba(255,255,255,.08));
}

/* Queue table */
#pw-queue-table table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
}
#pw-queue-table th {
  text-align: left;
  padding: 8px 10px;
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-2, #8899aa);
  border-bottom: 1px solid var(--line, rgba(255,255,255,.1));
}
#pw-queue-table td {
  padding: 7px 10px;
  border-bottom: 1px solid var(--line, rgba(255,255,255,.05));
  color: var(--text-1, #e8eaed);
}
#pw-queue-table tr:hover td {
  background: rgba(255,255,255,.02);
}

/* Sidebar integration entries (reuse from agents tab) */
.an-integ-entry {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 6px 0;
  border-bottom: 1px solid var(--line, rgba(255,255,255,.05));
  font-size: 0.8rem;
}
.an-integ-entry:last-child { border-bottom: none; }
.an-integ-label { color: var(--text-2, #8899aa); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.03em; }
.an-integ-value { color: var(--text-1, #e8eaed); font-weight: 500; }

/* ═══════════════════════════════════════════════════════════════════════════
   METRICS WORKSPACE — Operations + Quality split view
   ═══════════════════════════════════════════════════════════════════════════ */

/* Sub-navigation toggle */
.metrics-subnav {
  display: flex; gap: 4px; padding: 4px; margin: 0 0 16px;
  background: var(--surface-soft, rgba(255,255,255,0.04));
  border-radius: 10px; width: fit-content;
}
.metrics-subtab {
  padding: 7px 20px; border-radius: 7px; font-size: 0.78rem; font-weight: 600;
  background: transparent; border: none; color: var(--muted, #8899aa);
  cursor: pointer; transition: all 0.15s ease; letter-spacing: 0.02em;
}
.metrics-subtab:hover { color: var(--ink, #e8eaed); background: rgba(255,255,255,0.04); }
.metrics-subtab.is-active {
  background: var(--brand, #2563eb); color: #fff;
  box-shadow: 0 2px 8px rgba(37,99,235,0.25);
}

/* View toggle */
.metrics-view { display: none; }
.metrics-view.is-active { display: block; }

/* Hero summary strip */
.metrics-hero-strip {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 10px; margin-bottom: 18px;
}
.mh-card {
  padding: 12px 16px; border-radius: 8px; display: flex; flex-direction: column; gap: 3px;
  background: var(--surface-soft, rgba(255,255,255,0.03)); border: 1px solid var(--line, rgba(255,255,255,0.06));
  transition: box-shadow 0.2s;
}
.mh-card:hover { box-shadow: 0 2px 10px rgba(0,0,0,0.15); }
.mh-label { font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--muted, #8899aa); font-weight: 500; }
.mh-val { font-size: 1.1rem; font-weight: 700; color: var(--ink-strong, #fff); letter-spacing: -0.01em; }
.mh-val--ok { color: #79BF43; }
.mh-val--warning { color: #ff9f0a; }
.mh-val--danger { color: #ff3b30; }

/* SLO cards */
.ops-slo-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 12px; }
.ops-slo-card {
  padding: 16px 18px; border-radius: 10px; display: flex; flex-direction: column; gap: 8px;
  border: 1px solid var(--line); transition: box-shadow 0.2s;
}
.ops-slo-card--ok { background: linear-gradient(160deg, rgba(121,191,67,0.06) 0%, transparent 60%); border-color: rgba(121,191,67,0.15); }
.ops-slo-card--danger { background: linear-gradient(160deg, rgba(255,59,48,0.06) 0%, transparent 60%); border-color: rgba(255,59,48,0.15); }
.ops-slo-card--ok:hover { box-shadow: 0 2px 16px rgba(121,191,67,0.08); }
.ops-slo-card--danger:hover { box-shadow: 0 2px 16px rgba(255,59,48,0.08); }
.ops-slo-top { display: flex; align-items: center; justify-content: space-between; }
.ops-slo-name { font-size: 0.78rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.03em; color: var(--ink); }
.ops-slo-status { font-size: 0.68rem; font-weight: 700; padding: 2px 8px; border-radius: 4px; }
.ops-slo-status--ok { background: rgba(121,191,67,0.15); color: #79BF43; }
.ops-slo-status--danger { background: rgba(255,59,48,0.15); color: #ff3b30; }
.ops-slo-pct { font-size: 1.8rem; font-weight: 700; color: var(--ink-strong); letter-spacing: -0.02em; line-height: 1.1; }
.ops-slo-target { font-size: 0.78rem; font-weight: 500; color: var(--muted); }
.ops-slo-budget { display: flex; flex-direction: column; gap: 3px; }
.ops-slo-budget-label { font-size: 0.68rem; color: var(--muted); }
.ops-slo-meta { font-size: 0.68rem; color: var(--muted); }

/* Alert list */
.ops-alert-list { display: flex; flex-direction: column; gap: 6px; }
.ops-alert-ok {
  display: flex; align-items: center; gap: 8px; padding: 12px 16px;
  background: rgba(121,191,67,0.06); border-radius: 8px; font-size: 0.82rem; color: #79BF43; font-weight: 500;
}
.ops-alert-ok-dot {
  width: 8px; height: 8px; border-radius: 50%; background: #79BF43;
  box-shadow: 0 0 6px rgba(121,191,67,0.5); animation: pulse-dot 2s infinite;
}
@keyframes pulse-dot { 0%, 100% { opacity: 1; } 50% { opacity: 0.5; } }
.ops-alert-item {
  display: flex; align-items: center; gap: 10px; padding: 10px 14px;
  border-radius: 8px; font-size: 0.78rem;
}
.ops-alert-item--danger { background: rgba(255,59,48,0.08); border: 1px solid rgba(255,59,48,0.15); }
.ops-alert-item--warning { background: rgba(255,159,10,0.08); border: 1px solid rgba(255,159,10,0.15); }
.ops-alert-item--info { background: rgba(10,132,255,0.08); border: 1px solid rgba(10,132,255,0.15); }
.ops-alert-sev { font-size: 0.62rem; font-weight: 700; padding: 2px 6px; border-radius: 3px; letter-spacing: 0.04em; }
.ops-alert-sev--danger { background: rgba(255,59,48,0.2); color: #ff3b30; }
.ops-alert-sev--warning { background: rgba(255,159,10,0.2); color: #ff9f0a; }
.ops-alert-sev--info { background: rgba(10,132,255,0.2); color: #2C7DFF; }
.ops-alert-msg { flex: 1; color: var(--ink); }
.ops-alert-age { font-size: 0.68rem; color: var(--muted); white-space: nowrap; }

/* Endpoint table */
.ops-ep-list { display: flex; flex-direction: column; gap: 6px; }
.ops-ep-row { display: flex; align-items: center; gap: 10px; padding: 4px 0; }
.ops-ep-path { width: 200px; font-size: 0.72rem; font-family: var(--font-mono, monospace); color: var(--ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ops-ep-stats { font-size: 0.68rem; color: var(--muted); white-space: nowrap; min-width: 180px; text-align: right; }

/* Alert history sidebar */
.ops-alert-history { display: flex; flex-direction: column; gap: 4px; }
.ops-hist-row { display: flex; align-items: center; gap: 6px; font-size: 0.72rem; padding: 3px 0; }
.ops-hist-name { flex: 1; color: var(--ink); }
.ops-hist-state { font-size: 0.65rem; color: var(--muted); text-transform: uppercase; letter-spacing: 0.03em; }

/* Header badge variants */
.header-badge--ok { background: rgba(121,191,67,0.15); color: #79BF43; }
.header-badge--danger { background: rgba(255,59,48,0.15); color: #ff3b30; }

/* Responsive — hero strip stacks on mobile */
@media (max-width: 768px) {
  .metrics-hero-strip { grid-template-columns: repeat(3, 1fr); }
  .ops-slo-grid { grid-template-columns: 1fr; }
  .ops-ep-path { width: 120px; }
  .ops-ep-stats { min-width: 100px; font-size: 0.62rem; }
}
@media (max-width: 480px) {
  .metrics-hero-strip { grid-template-columns: repeat(2, 1fr); }
}

/* pathwave form responsive — in consolidated section */

/* ═══════════════════════════════════════════════════════════════════════════
   CONSOLIDATED RESPONSIVE — Three dedicated device layers
   Desktop (≥1024px) · iPad (768–1023px) · Mobile (<768px)
   No overlapping breakpoints. Each device gets its own workspace.
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─────────────────────────────────────────────────────────────────────────
   DESKTOP — ≥ 1024px
   Full two-column workspace, multi-column grids, inline nav.
   ───────────────────────────────────────────────────────────────────────── */
@media (min-width: 1024px) {
  .shell { max-width: 1520px; padding: 10px 24px 24px; }
  .workspace { grid-template-columns: minmax(0, 1.4fr) minmax(280px, 0.6fr); gap: 12px; }
  .hero { grid-template-columns: minmax(0, 1fr) auto; }
  .hero-brief { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .an-kpi-hero-row { grid-template-columns: repeat(4, 1fr); }
  .an-conf-grid { grid-template-columns: repeat(3, 1fr); }
  .ent-toggle-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ent-toggle-grid--3col { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .ent-permission-grid { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }
  .ent-policy-grid { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
  .permission-toggle-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .agent-card-grid { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 10px; }
  .agent-card-grid--t0,
  .agent-card-grid--t1 { grid-template-columns: 1fr; max-width: 500px; }
  .view-tabs { display: inline-flex; width: auto; }
}

/* ─────────────────────────────────────────────────────────────────────────
   IPAD — 768px to 1023px
   Dedicated tablet workspace. Not stretched desktop. Not squished mobile.
   ───────────────────────────────────────────────────────────────────────── */
@media (min-width: 768px) and (max-width: 1023px) {
  /* Shell: full width, tablet padding */
  .shell { max-width: 100%; padding: 10px 20px 24px; }

  /* Layout: single column — sidebar stacks below main */
  .workspace { grid-template-columns: 1fr; gap: 12px; }
  .hero { grid-template-columns: 1fr; gap: 10px; }

  /* Hero: 2-column brief cards */
  .hero-brief { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .hero-metrics { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }

  /* Nav: horizontal scroll, no wrap */
  .view-tabs {
    display: flex;
    width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    gap: 3px;
    padding: 4px;
  }
  .view-tab {
    flex-shrink: 0;
    font-size: 0.76rem;
    padding: 7px 12px;
    white-space: nowrap;
  }

  /* Header: wrap on tablet */
  .topbar { flex-wrap: wrap; gap: 8px; padding: 10px 14px; }
  .brand-mark { width: clamp(140px, 16vw, 200px); }

  /* Flow strip: compact */
  .flow-strip { grid-template-columns: repeat(auto-fit, minmax(100px, 1fr)); }

  /* Panels: tighter */
  .glass-panel { padding: 12px; }
  .panel-stack { gap: 10px; }
  .panel, .report-stage, .saved-runs-panel { padding: 12px; }

  /* KPI rows: 2 columns */
  .an-kpi-hero-row { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .an-conf-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }

  /* Toggle / permission grids: 2 columns */
  .ent-toggle-grid,
  .ent-toggle-grid--3col { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ent-permission-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ent-policy-grid { grid-template-columns: 1fr; }
  .permission-toggle-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }

  /* Enterprise */
  .ent-fieldset { padding: 14px; }
  .ent-stat-card strong { font-size: 1.3rem; }

  /* Agent cards: 2 columns */
  .agent-card-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
  .agent-card-grid--t0,
  .agent-card-grid--t1 { grid-template-columns: 1fr; max-width: 100%; }
  .agent-card-msg { white-space: normal; max-height: 4em; overflow-y: auto; }
  .agent-card-rule { white-space: normal; }
  .afg-card-info { flex-direction: column; gap: 4px; }
  .afg-briefing { font-size: 0.78rem; padding: 10px; }

  /* Preview stage: single column */
  .preview-stage { grid-template-columns: 1fr; }
  .preview-stage-fullwidth { width: 100%; margin-left: 0; }
  .preview-stage-topbar { gap: 8px; padding: 8px 10px; }
  .preview-stage-tools {
    margin-left: 0;
    width: 100%;
    overflow-x: auto;
    flex-wrap: nowrap;
    scrollbar-width: thin;
  }

  /* Scoreboard / mode grids */
  .scoreboard { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .mode-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .toggle-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .form-grid { grid-template-columns: 1fr; }
  .summary-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }

  /* KPI font sizes */
  .tab-panel:not(#view-dashboard) .an-kpi-val { font-size: 1.6rem; }
}

/* ─────────────────────────────────────────────────────────────────────────
   MOBILE — < 768px
   Dedicated phone workspace. Full-width, stacked, touch-optimized.
   ───────────────────────────────────────────────────────────────────────── */
@media (max-width: 767px) {
  /* Shell: full width, tight padding */
  .shell { max-width: 100%; padding: 8px 10px 20px; }

  /* Layout: everything single column */
  .workspace { grid-template-columns: 1fr; gap: 10px; }
  .hero { grid-template-columns: 1fr; padding: 10px; }

  /* Hero: stack everything */
  .hero-brief { grid-template-columns: 1fr; }
  .hero-metrics { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 6px; }

  /* Header: stack vertically */
  .topbar { flex-direction: column; align-items: stretch; padding: 10px; gap: 8px; }
  .brand-lockup { flex-direction: column; align-items: flex-start; }
  .vairifeye-brand { flex-direction: column; }
  .brand-mark { width: min(100%, 200px); min-height: 60px; }
  .topbar-actions { flex-direction: column; align-items: flex-start; gap: 6px; }

  /* Nav: scrollable, compact */
  .view-tabs {
    display: flex;
    width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    gap: 2px;
    padding: 3px;
    margin: 6px 0 0;
  }
  .view-tabs::-webkit-scrollbar { display: none; }
  .view-tab {
    flex-shrink: 0;
    font-size: 0.72rem;
    padding: 8px 10px;
    min-height: 36px;
    white-space: nowrap;
  }
  .command-nav {
    gap: 1px;
    padding: 3px;
    margin: 6px 0 0;
    border-radius: 8px;
  }
  .command-nav::-webkit-scrollbar { display: none; }
  .command-nav { scrollbar-width: none; }
  .command-nav-item {
    flex-shrink: 0;
    font-size: 0.7rem;
    padding: 7px 10px;
    gap: 4px;
  }
  .command-nav-icon { font-size: 0.75rem; }
  .command-nav-spacer { flex: 0; width: 0; }
  .vairifeye-brand .brand-mark { width: min(100%, 200px); }
  .vairifeye-mark { width: min(100%, 200px); }

  /* Steps: single column */
  .flow-strip { grid-template-columns: 1fr; }
  .flow-step { min-height: 28px; padding: 4px 6px; font-size: 0.7rem; }

  /* Panels: compact */
  .glass-panel { padding: 10px; border-radius: 10px; }
  .panel, .report-stage, .saved-runs-panel, .login-panel, .modal-panel {
    padding: 10px; border-radius: 12px;
  }
  .panel-stack { gap: 8px; }
  .panel-header { flex-direction: column; align-items: stretch; gap: 8px; }
  .section-label { font-size: 0.75rem; }

  /* Headings: smaller */
  h1 { font-size: 1.5rem; }
  h2 { font-size: 1.15rem; }

  /* Forms: single column, touch-friendly */
  .form-grid, .summary-grid { grid-template-columns: 1fr; }
  input[type="text"], input[type="email"], input[type="tel"], input[type="password"], input[type="number"], select, textarea {
    padding: 12px 14px;
    border-radius: 10px;
    font-size: 16px; /* prevents iOS zoom */
  }

  /* KPI rows: 2 columns compact */
  .an-kpi-hero-row { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .an-conf-grid { grid-template-columns: 1fr; gap: 8px; }
  .tab-panel:not(#view-dashboard) .an-kpi-val { font-size: 1.4rem; }
  .tab-panel:not(#view-dashboard) .stat-card strong { font-size: 1.2rem; }

  /* Toggle / permission grids: single column */
  .ent-toggle-grid,
  .ent-toggle-grid--3col { grid-template-columns: 1fr; }
  .ent-permission-grid { grid-template-columns: 1fr; }
  .ent-policy-grid { grid-template-columns: 1fr; }
  .permission-toggle-grid { grid-template-columns: 1fr; }

  /* Enterprise: compact */
  .ent-fieldset { padding: 10px; margin-top: 10px; }
  .ent-stat-card strong { font-size: 1.1rem; }
  .ent-divider { margin: 12px 0 6px; }
  .ent-guard-rule { padding: 8px 10px; }

  /* Buttons: touch targets */
  button, .file-pill { padding: 12px 14px; font-size: 0.9rem; min-height: 44px; }
  .ghost-button { padding: 10px 12px; min-height: 40px; }
  .compact-button { padding: 10px 12px; min-height: 38px; }

  /* Agent cards: full width single column */
  .agent-card-grid { grid-template-columns: 1fr; gap: 6px; }
  .agent-card-grid--t0, .agent-card-grid--t1 { max-width: 100%; }
  .agent-card-body { padding: 8px 10px; }
  .agent-card-stats { flex-direction: column; gap: 2px; }
  .agent-card-msg { font-size: 0.6rem; white-space: normal; max-height: 3em; }
  .agent-card-rule { white-space: normal; }

  .afg-card { margin: 6px 0; border-radius: 8px; }
  .afg-card-info { flex-direction: column; }
  .afg-agent-avatar { font-size: 1.2rem; }
  .afg-briefing { padding: 8px; font-size: 0.75rem; max-height: 300px; overflow-y: auto; }
  .afg-raw-findings { font-size: 0.7rem; }

  /* Reference / history */
  .reference-item-header, .history-main { flex-direction: column; align-items: stretch; }
  .reference-item, .history-item { border-radius: 12px; padding: 10px 12px; }
  .identity { min-width: auto; width: 100%; }

  /* Preview: stacked, shorter */
  .preview-stage { grid-template-columns: 1fr; }
  .preview-stage-fullwidth { width: 100%; margin-left: 0; }
  .preview-stage-topbar { gap: 6px; padding: 6px 8px; }
  .preview-stage-tools { margin-left: 0; width: 100%; overflow-x: auto; scrollbar-width: thin; }
  .preview-frame, .preview-image, .preview-placeholder { min-height: 240px; }

  /* Scoreboard / mode grids: single column */
  .scoreboard, .mode-grid, .toggle-grid { grid-template-columns: 1fr; }
  .live-counter { flex-wrap: wrap; gap: 8px; font-size: 0.78rem; }
  .mi-row { grid-template-columns: 80px 1fr; font-size: 0.8rem; }
  .manual-nav-buttons { flex-wrap: wrap; }

  /* Modal: full width */
  .modal { padding: 8px; }
  .modal-panel { width: 100%; }

  /* Prevent horizontal overflow */
  .tab-panel { overflow-x: hidden; }
  pre, code, table { overflow-x: auto; max-width: 100%; }
}

/* ─────────────────────────────────────────────────────────────────────────
   SMALL MOBILE — < 480px (refinements over mobile base)
   ───────────────────────────────────────────────────────────────────────── */
@media (max-width: 479px) {
  .shell { padding: 6px 8px 16px; }
  .agent-card-name { font-size: 0.78rem; }
  .agent-card-title { font-size: 0.6rem; }
  .agent-card-stats { font-size: 0.56rem; }
  .afg-briefing { max-height: 200px; }
  .afg-finding-title { font-size: 0.72rem; }
  .brief-card, .metric-card, .summary-card, .score, .toggle-card {
    border-radius: 10px; padding: 10px 12px;
  }
  .hero-metrics { grid-template-columns: 1fr; }
  .an-kpi-hero-row { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════
   METRICS TAB — Trend chart, test card, validation log, history
   ═══════════════════════════════════════════════════════════════ */

/* Trend chart bars */
.met-trend-chart { display: flex; flex-direction: column; gap: 6px; margin-top: 12px; }
.met-trend-row { display: flex; align-items: center; gap: 8px; font-size: .78rem; }
.met-trend-label { width: 72px; text-align: right; color: var(--muted); font-variant-numeric: tabular-nums; flex-shrink: 0; }
.met-trend-bar-wrap { flex: 1; height: 18px; background: var(--surface-button); border-radius: 4px; overflow: hidden; }
.met-trend-bar { height: 100%; border-radius: 4px; transition: width .4s ease; }
.met-trend-bar--ok  { background: var(--success); }
.met-trend-bar--warn { background: var(--warning); }
.met-trend-bar--crit { background: var(--danger); }
.met-trend-pct { width: 48px; text-align: right; font-weight: 600; color: var(--ink-strong); font-variant-numeric: tabular-nums; }
.met-trend-n { width: 48px; color: var(--muted); font-size: .72rem; }

/* Auto-training test card */
.met-test-card {
  background: var(--surface-card);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 16px;
  margin-top: 12px;
}
.met-test-descriptions { display: flex; flex-direction: column; gap: 10px; margin-bottom: 14px; }
.met-test-field { display: flex; flex-direction: column; gap: 3px; }
.met-test-label { font-size: .72rem; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); font-weight: 600; }
.met-test-value { font-size: .85rem; color: var(--ink-strong); line-height: 1.35; }
.met-test-verdicts { display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 10px; }
.met-test-verdict { display: flex; flex-direction: column; gap: 3px; align-items: center; min-width: 80px; }
.met-test-score { font-size: .72rem; color: var(--muted); }
.met-test-meta { display: flex; gap: 10px; font-size: .72rem; color: var(--muted); }

/* Verdict badges */
.met-verdict-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 6px;
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .03em;
}
.met-badge--match { background: var(--success-soft); color: var(--success); }
.met-badge--miss  { background: var(--danger-soft); color: var(--danger); }
.met-badge--pass  { background: var(--success-soft); color: var(--success); }
.met-badge--deny  { background: var(--accent-soft); color: var(--accent); }

/* Brain reasoning display */
.met-test-reasoning {
  margin-top: 12px; padding-top: 12px;
  border-top: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 8px;
}
.met-reason-score {
  display: flex; align-items: center; gap: 8px;
}
.met-reason-bar-wrap { flex: 1; height: 14px; background: var(--surface-button); border-radius: 4px; overflow: hidden; }
.met-reason-bar { height: 100%; border-radius: 4px; transition: width .3s; }
.met-reason-pct { font-weight: 700; font-size: .82rem; min-width: 48px; text-align: right; color: var(--ink-strong); }
.met-reason-row { display: flex; align-items: flex-start; gap: 8px; }
.met-reason-label { font-size: .72rem; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); font-weight: 600; min-width: 64px; flex-shrink: 0; padding-top: 2px; }
.met-reason-tags { display: flex; flex-wrap: wrap; gap: 4px; }
.met-tag { display: inline-block; padding: 2px 8px; border-radius: 4px; font-size: .72rem; font-weight: 600; }
.met-tag--match { background: var(--success-soft); color: var(--success); }
.met-tag--miss  { background: var(--danger-soft); color: var(--danger); }
.met-reason-issues { font-size: .78rem; color: var(--warning); line-height: 1.4; }
.met-reason-explain { font-size: .75rem; color: var(--muted); font-style: italic; padding-top: 4px; }

/* Auto-loop toggle */
.met-auto-loop-toggle.is-active {
  background: var(--danger) !important; color: #fff;
  animation: met-pulse 1.5s ease-in-out infinite;
}
@keyframes met-pulse { 0%,100% { opacity: 1; } 50% { opacity: .7; } }

/* Validation log rows */
.met-validation-log { display: flex; flex-direction: column; gap: 4px; margin-top: 12px; max-height: 360px; overflow-y: auto; }
.met-val-row {
  display: grid;
  grid-template-columns: 24px 56px 1fr 56px 56px 80px 64px;
  gap: 8px;
  align-items: center;
  padding: 6px 10px;
  border-radius: 6px;
  font-size: .78rem;
  background: var(--surface-button);
  transition: background .15s;
}
.met-val-row:hover { background: var(--surface-button-strong); }
.met-val-header {
  font-weight: 700; text-transform: uppercase; font-size: .7rem;
  letter-spacing: .04em; color: var(--muted); background: transparent;
  border-bottom: 1px solid var(--line); border-left: none;
}
.met-val--match { border-left: 3px solid var(--success); }
.met-val--miss  { border-left: 3px solid var(--danger); }
.met-val-icon { font-weight: 700; text-align: center; }
.met-val--match .met-val-icon { color: var(--success); }
.met-val--miss  .met-val-icon { color: var(--danger); }
.met-val-type { font-weight: 600; text-transform: uppercase; font-size: .7rem; letter-spacing: .03em; color: var(--muted); }
.met-val-desc { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--ink); }
.met-val-brain, .met-val-human { font-weight: 600; font-size: .72rem; text-align: center; }
.met-val-by { color: var(--muted); font-size: .72rem; }
.met-val-time { color: var(--muted); font-size: .7rem; text-align: right; font-variant-numeric: tabular-nums; }

/* Validation history table */
.met-history-table { display: flex; flex-direction: column; gap: 2px; }
.met-hist-row {
  display: grid;
  grid-template-columns: 82px 1fr 60px 72px 72px 72px 36px 36px 80px;
  gap: 10px;
  align-items: center;
  padding: 7px 12px;
  font-size: .78rem;
  border-radius: 5px;
  min-width: 0;
}
.met-hist-row > span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.met-hist-header {
  font-weight: 700;
  text-transform: uppercase;
  font-size: .7rem;
  letter-spacing: .04em;
  color: var(--muted);
  background: transparent;
  border-bottom: 1px solid var(--line);
  padding-bottom: 8px;
  margin-bottom: 4px;
}
.met-hist-row:not(.met-hist-header) { background: var(--surface-button); }
.met-hist-row:not(.met-hist-header):hover { background: var(--surface-button-strong); }

/* Accuracy color classes */
.met-acc--ok   { color: var(--success); font-weight: 700; }
.met-acc--warn { color: var(--warning); font-weight: 700; }
.met-acc--crit { color: var(--danger); font-weight: 700; }

/* Responsive */
@media (max-width: 768px) {
  .met-val-row { grid-template-columns: 24px 48px 1fr 48px 48px; }
  .met-val-by, .met-val-time { display: none; }
  .met-hist-row { grid-template-columns: 72px 64px 44px 60px 60px 60px; font-size: .7rem; }
  .met-hist-row span:nth-child(n+7) { display: none; }
  .met-test-verdicts { flex-direction: column; gap: 8px; }
}

/* History search bar */
.history-search {
  width: 100%; padding: 8px 12px; margin-bottom: 10px;
  background: var(--surface-strong); border: 1px solid var(--line);
  border-radius: 8px; color: var(--ink); font-size: 0.84rem;
}
.history-search::placeholder { color: var(--muted); }
#history-show-all { width: 100%; margin-top: 8px; text-align: center; }

/* Rendered report markdown */
.report-stage .report-text { max-height: 600px; overflow-y: auto; }
.report-stage .report-text h1 { font-size: 1.1rem; font-weight: 700; margin: 16px 0 8px; color: var(--ink-strong); }
.report-stage .report-text h2 { font-size: 0.95rem; font-weight: 700; margin: 14px 0 6px; color: var(--ink-strong); border-bottom: 1px solid var(--line); padding-bottom: 4px; }
.report-stage .report-text h3 { font-size: 0.88rem; font-weight: 600; margin: 10px 0 4px; color: var(--ink); }
.report-stage .report-text table { width: 100%; border-collapse: collapse; font-size: 0.82rem; margin: 8px 0; }
.report-stage .report-text th { background: rgba(255,255,255,0.06); font-weight: 700; text-align: left; padding: 6px 8px; border: 1px solid var(--line); }
.report-stage .report-text td { padding: 5px 8px; border: 1px solid var(--line); vertical-align: top; }
.report-stage .report-text hr { border: none; border-top: 1px solid var(--line); margin: 12px 0; }
.report-stage .report-text p { margin: 4px 0; line-height: 1.5; }
.report-stage .report-text strong { color: var(--ink-strong); }

/* Collapsible item results dropdown */
.results-collapse {
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
}
.results-collapse-header {
  cursor: pointer;
  padding: 10px 14px;
  background: rgba(255,255,255,0.04);
  list-style: none;
  display: flex;
  align-items: center;
  gap: 12px;
}
.results-collapse-header::-webkit-details-marker { display: none; }
.results-collapse-header::before {
  content: "▶";
  font-size: 0.72rem;
  color: var(--muted);
  transition: transform 0.2s;
  flex-shrink: 0;
}
.results-collapse[open] .results-collapse-header::before { transform: rotate(90deg); }
.results-collapse-title {
  font-weight: 600;
  font-size: 0.88rem;
  color: var(--ink-strong);
}
.results-collapse-pills {
  margin-left: auto;
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}
.results-collapse-pills .verdict-pill { font-size: 0.68rem; padding: 1px 8px; }
.results-collapse-body {
  border-top: 1px solid var(--line);
  max-height: 400px;
  overflow-y: auto;
}

/* Toast notifications */
.toast-container {
  position: fixed; bottom: 24px; right: 24px; z-index: 9999;
  display: flex; flex-direction: column-reverse; gap: 8px;
  pointer-events: none;
}
.toast {
  padding: 12px 20px; border-radius: 8px; font-size: .82rem; font-weight: 600;
  color: #fff; opacity: 0; transform: translateY(12px);
  transition: opacity .3s, transform .3s; pointer-events: auto;
  max-width: 400px; box-shadow: 0 8px 24px rgba(0,0,0,.3);
}
.toast--visible { opacity: 1; transform: translateY(0); }
.toast--success { background: var(--success); }
.toast--error { background: var(--danger); }
.toast--warning { background: var(--warning); }
.toast--info { background: var(--brand); }

/* Button loading & disabled states */
.is-loading { opacity: .6; cursor: wait; }
.launch-bar button:disabled,
.launch-bar .btn-primary:disabled {
  opacity: .35; cursor: not-allowed; pointer-events: none;
  filter: grayscale(.5);
}

/* Skip-to-content link */
.skip-link {
  position: absolute; top: -100px; left: 16px; z-index: 10000;
  background: var(--brand); color: #fff; padding: 8px 16px; border-radius: 4px;
  text-decoration: none; font-weight: 600;
}
.skip-link:focus { top: 16px; }

/* Idle timeout warning banner */
.idle-warning-banner {
  position: fixed; top: 0; left: 0; right: 0; z-index: 99999;
  background: var(--warning, #f59e0b); color: #000;
  padding: 10px 20px; text-align: center; font-weight: 600;
  display: flex; align-items: center; justify-content: center; gap: 12px;
  box-shadow: 0 2px 8px rgba(0,0,0,.3);
}
.idle-warning-banner button {
  background: rgba(0,0,0,.2); border: none; color: #000;
  padding: 4px 12px; border-radius: 4px; cursor: pointer; font-weight: 600;
}

/* ═══════════════════════════════════════════════════════════════════════════
   COMPREHENSIVE RESPONSIVE / MOBILE ENHANCEMENT
   Appended styles that layer on top of existing responsive rules.
   Targets: 1024px (tablet landscape), 768px (tablet portrait), 480px (phone)
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─────────────────────────────────────────────────────────────────────────
   TABLET LANDSCAPE — max-width: 1024px
   Slightly compressed desktop. Two columns collapse to one in places.
   ───────────────────────────────────────────────────────────────────────── */
@media (max-width: 1024px) {
  /* Shell: relax max-width, tighten padding */
  .shell {
    max-width: 100%;
    padding: 10px 16px 24px;
  }

  /* Workspace: single column for main + sidebar */
  .workspace {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  /* Hero: stack vertically */
  .hero {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  /* Hero metrics: 2x2 instead of 4 across */
  .hero-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
  }

  /* Hero brief: 2 columns instead of 3 */
  .hero-brief {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  /* Form grids: 2 columns on landscape tablet */
  .form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  /* Enterprise two-col stays 2-col */
  .form-grid.ent-two-col {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  /* Summary grid: 2 columns */
  .summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  /* Scoreboard: 2 columns */
  .scoreboard {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  /* Preview stage: ensure full width */
  .preview-stage {
    grid-template-columns: 1fr;
  }

  /* Preview stage body: reduce minimum height */
  .preview-stage-body {
    min-height: 440px;
  }
  .preview-canvas-wrap {
    min-height: 440px;
  }

  /* Topbar: allow wrapping */
  .topbar {
    flex-wrap: wrap;
    gap: 8px;
  }

  /* Brand mark: slightly smaller */
  .brand-mark {
    width: clamp(140px, 16vw, 200px);
  }

  /* Nav tabs: scrollable */
  .view-tabs {
    display: flex;
    width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    gap: 3px;
    padding: 4px;
  }
  .view-tab {
    flex-shrink: 0;
    white-space: nowrap;
  }

  /* Toggle grids: 2 columns */
  .toggle-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .ent-toggle-grid,
  .ent-toggle-grid--3col {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  /* Mode grid: 2 columns */
  .mode-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  /* Ladder: 2 columns */
  .ladder-steps {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Agent cards: 2 columns */
  .agent-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }
  .agent-card-grid--t0,
  .agent-card-grid--t1 {
    grid-template-columns: 1fr;
    max-width: 100%;
  }

  /* Editor toolbar: allow wrapping */
  .editor-toolbar {
    flex-wrap: wrap;
    gap: 4px;
    padding: 6px 8px;
  }
  .tool-divider {
    height: 16px;
  }

  /* KPI rows: 2 columns */
  .an-kpi-hero-row {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }
  .an-conf-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }

  /* Results table: horizontal scroll */
  .results-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  /* Validation log: horizontal scroll */
  .met-validation-log {
    overflow-x: auto;
  }

  /* History table: horizontal scroll */
  .met-history-table {
    overflow-x: auto;
  }

  /* Login: full width */
  .login-shell {
    width: min(100%, 680px);
  }

  /* Walkthrough: wider on tablet */
  .walkthrough-panel {
    width: 92vw;
    max-width: 560px;
    padding: 22px 24px;
  }

  /* Toast: slightly smaller */
  .toast-container {
    right: 16px;
    bottom: 16px;
  }
  .toast {
    max-width: 340px;
  }

  /* File bars: wrap */
  .file-bar {
    flex-wrap: wrap;
    gap: 8px;
  }

  /* Manual review: smaller grid */
  .mi-row {
    grid-template-columns: 100px 1fr;
  }

  /* Idle banner: wrap on small screens */
  .idle-warning-banner {
    flex-wrap: wrap;
    padding: 8px 14px;
  }

  /* Photo add bar: stack on smaller screens */
  .photo-add-bar {
    flex-wrap: wrap;
  }
  .photo-url-input {
    min-width: 200px;
  }

  /* Admin stats: 2 columns */
  .admin-stats-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  /* Conversations: allow text wrapping */
  .conv-thread-preview {
    white-space: normal;
  }

  /* Permission / policy grids */
  .ent-permission-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .ent-policy-grid {
    grid-template-columns: 1fr;
  }
}

/* ─────────────────────────────────────────────────────────────────────────
   TABLET PORTRAIT — max-width: 768px
   Single column everywhere. Compact spacing. Touch-friendly.
   ───────────────────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  /* Ensure readable base font size (prevents iOS zoom on focus) */
  html {
    font-size: 16px;
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
  }

  /* Shell: tighter */
  .shell {
    max-width: 100%;
    padding: 8px 12px 20px;
  }

  /* Layout: single column everywhere */
  .workspace {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  /* Hero: stacked */
  .hero {
    grid-template-columns: 1fr;
    padding: 10px 12px;
  }
  .hero-brief {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .hero-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
  }

  /* Topbar: wrap into column */
  .topbar {
    flex-wrap: wrap;
    gap: 8px;
    padding: 10px 12px;
  }
  .topbar-actions {
    width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 6px;
  }
  .brand-mark {
    width: min(100%, 180px);
    min-height: 56px;
  }
  .header-status {
    width: 100%;
    gap: 6px;
  }

  /* Nav tabs: horizontal scroll, hidden scrollbar */
  .view-tabs {
    display: flex;
    width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    gap: 2px;
    padding: 3px;
    margin: 6px 0 0;
  }
  .view-tabs::-webkit-scrollbar {
    display: none;
  }
  .view-tab {
    flex-shrink: 0;
    font-size: 0.74rem;
    padding: 8px 12px;
    min-height: 40px;
    white-space: nowrap;
  }

  /* Panels: compact */
  .glass-panel {
    padding: 10px;
    border-radius: 12px;
  }
  .panel,
  .report-stage,
  .saved-runs-panel,
  .login-panel {
    padding: 10px;
    border-radius: 12px;
  }
  .panel-stack {
    gap: 8px;
  }
  .panel-header {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }
  .panel-actions {
    width: 100%;
    justify-content: flex-start;
  }

  /* Forms: single column, touch sizes */
  .form-grid {
    grid-template-columns: 1fr;
    gap: 8px;
  }
  .form-grid.ent-two-col {
    grid-template-columns: 1fr;
  }
  input[type="text"],
  input[type="email"],
  input[type="tel"],
  input[type="password"],
  input[type="number"],
  input[type="url"],
  select,
  textarea {
    padding: 12px 14px;
    border-radius: 10px;
    font-size: 16px; /* prevents iOS zoom */
    min-height: 44px;
  }

  /* Summary grid: single column */
  .summary-grid {
    grid-template-columns: 1fr;
  }

  /* Scoreboard: single column */
  .scoreboard {
    grid-template-columns: 1fr;
  }

  /* Mode grid: single column */
  .mode-grid {
    grid-template-columns: 1fr;
  }

  /* Toggle grids: single column */
  .toggle-grid {
    grid-template-columns: 1fr;
  }
  .ent-toggle-grid,
  .ent-toggle-grid--3col {
    grid-template-columns: 1fr;
  }

  /* Toggle cards: proper touch target */
  .ent-toggle-card,
  .toggle-card {
    min-height: 44px;
    padding: 10px 14px;
  }

  /* Permission/Policy grids */
  .ent-permission-grid {
    grid-template-columns: 1fr;
  }
  .ent-policy-grid {
    grid-template-columns: 1fr;
  }
  .permission-toggle-grid {
    grid-template-columns: 1fr;
  }

  /* Buttons: full-width on mobile, touch targets */
  button,
  .file-pill {
    padding: 12px 14px;
    font-size: 0.88rem;
    min-height: 44px;
    border-radius: 10px;
  }
  .ghost-button {
    padding: 10px 14px;
    min-height: 44px;
  }
  .compact-button {
    padding: 10px 12px;
    min-height: 40px;
  }
  .mode-toggle {
    padding: 10px 12px;
    min-height: 40px;
    font-size: 0.72rem;
  }

  /* Make action buttons full-width in panels */
  .panel-header button,
  .panel-actions button,
  .intake-action-row button {
    width: 100%;
  }

  /* Mode toggle bar: full width */
  .mode-toggle-bar {
    display: flex;
    width: 100%;
  }
  .mode-toggle {
    flex: 1;
  }

  /* Flow strip: 2 columns instead of 5 */
  .flow-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .flow-step {
    min-height: 36px;
    padding: 6px 8px;
    font-size: 0.72rem;
  }

  /* Preview stage: compact */
  .preview-stage {
    grid-template-columns: 1fr;
  }
  .preview-stage-fullwidth {
    width: 100%;
    margin-left: 0;
    border-radius: 10px;
  }
  .preview-stage-topbar {
    flex-wrap: wrap;
    gap: 6px;
    padding: 8px 10px;
  }
  .preview-stage-title {
    width: 100%;
    flex-wrap: wrap;
    gap: 4px;
  }
  .preview-stage-title .preview-caption {
    max-width: 100%;
  }
  .preview-stage-nav {
    width: 100%;
    justify-content: center;
  }
  .preview-stage-tools {
    margin-left: 0;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    flex-wrap: nowrap;
    padding-bottom: 4px;
  }
  .preview-stage-body {
    min-height: 320px;
  }
  .preview-canvas-wrap {
    min-height: 320px;
  }
  .preview-frame,
  .preview-image,
  .preview-placeholder {
    min-height: 260px;
  }

  /* Editor toolbar: wrap tools, scroll on small screens */
  .editor-toolbar {
    flex-wrap: wrap;
    gap: 4px;
    padding: 6px 8px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .tool-btn {
    min-width: 36px;
    height: 36px;
    padding: 0 8px;
    font-size: 0.7rem;
  }
  .tool-select {
    height: 36px;
  }
  .tool-color-wrap input[type="color"] {
    width: 34px;
    height: 34px;
  }
  .tool-divider {
    height: 18px;
    margin: 0 2px;
  }

  /* Preview queue: scrollable */
  .preview-queue-bar {
    padding: 6px 10px;
  }
  .preview-queue {
    gap: 6px;
    padding: 6px 0;
  }
  .preview-chip {
    padding: 8px 12px;
    font-size: 0.72rem;
    min-height: 36px;
  }

  /* Photo add bar: stack */
  .photo-add-bar {
    flex-direction: column;
    gap: 6px;
  }
  .photo-url-input {
    width: 100%;
    min-width: 0;
    min-height: 44px;
    font-size: 16px;
  }

  /* Results table: horizontal scroll wrapper */
  .results-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .result-row {
    min-width: 400px;
  }

  /* Live counter: wrap */
  .live-counter {
    flex-wrap: wrap;
    gap: 8px;
    font-size: 0.8rem;
    padding: 8px 12px;
  }

  /* Manual review: mobile layout */
  .manual-item-header {
    flex-direction: column;
    gap: 8px;
    align-items: stretch;
  }
  .manual-nav-buttons {
    flex-wrap: wrap;
    gap: 6px;
    width: 100%;
  }
  .manual-nav-buttons button {
    flex: 1;
    min-width: 80px;
  }
  .mi-row {
    grid-template-columns: 80px 1fr;
    font-size: 0.82rem;
    gap: 6px;
  }
  .manual-footer {
    display: flex;
    flex-direction: column;
    gap: 8px;
    align-items: stretch;
  }
  .manual-footer button {
    width: 100%;
  }

  /* File bar: wrap fully */
  .file-bar {
    flex-wrap: wrap;
    gap: 6px;
  }
  .file-bar > * {
    flex-shrink: 0;
  }
  .checkbox-pill {
    min-height: 40px;
    padding: 8px 12px;
  }

  /* Reference/History items */
  .reference-item-header,
  .history-main {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }
  .reference-item,
  .history-item {
    border-radius: 12px;
    padding: 10px 12px;
  }
  .history-actions,
  .reference-actions {
    flex-wrap: wrap;
    gap: 6px;
  }
  .history-scoreline {
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  /* Identity: full width */
  .identity {
    min-width: auto;
    width: 100%;
  }

  /* Admin table: horizontal scroll */
  .admin-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .admin-table {
    min-width: 500px;
  }
  .admin-stats-grid {
    grid-template-columns: 1fr;
  }

  /* KPI rows: 2 columns */
  .an-kpi-hero-row {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
  .an-conf-grid {
    grid-template-columns: 1fr;
    gap: 8px;
  }
  .an-kpi {
    padding: 12px 14px;
  }
  .an-kpi-val {
    font-size: 1.3rem;
  }
  .an-kpi-val--hero {
    font-size: 1.6rem;
  }
  .an-kpi--primary {
    padding: 14px 16px;
  }

  /* Agent cards: single column */
  .agent-card-grid {
    grid-template-columns: 1fr;
    gap: 6px;
  }
  .agent-card-grid--t0,
  .agent-card-grid--t1 {
    max-width: 100%;
  }
  .agent-card-body {
    padding: 8px 10px;
  }
  .agent-card-msg {
    white-space: normal;
    max-height: 4em;
    overflow-y: auto;
  }
  .agent-card-rule {
    white-space: normal;
  }
  .agent-card-stats {
    flex-direction: column;
    gap: 2px;
  }

  /* Agent findings: compact */
  .agent-finding-header {
    flex-wrap: wrap;
    gap: 6px;
    padding: 8px 8px;
  }
  .agent-finding-title {
    white-space: normal;
    flex-basis: 100%;
    order: 5;
  }
  .agent-finding-detail {
    padding: 4px 8px 10px 16px;
  }
  .agent-finding-actions {
    flex-wrap: wrap;
    gap: 6px;
  }

  /* Validation log: compact columns */
  .met-val-row {
    grid-template-columns: 24px 48px 1fr 48px 48px;
    font-size: 0.74rem;
    padding: 6px 8px;
  }
  .met-val-by,
  .met-val-time {
    display: none;
  }

  /* History table: compact */
  .met-hist-row {
    grid-template-columns: 70px 60px 44px 56px 56px 56px;
    font-size: 0.7rem;
    padding: 6px 8px;
  }
  .met-hist-row span:nth-child(n+7) {
    display: none;
  }

  /* Test verdicts: stack */
  .met-test-verdicts {
    flex-direction: column;
    gap: 8px;
  }

  /* Modal: full screen on mobile */
  .modal {
    padding: 8px;
  }
  .modal-panel {
    width: 100%;
    max-width: 100%;
    max-height: 90vh;
    overflow-y: auto;
    border-radius: 14px;
  }

  /* Walkthrough: full width */
  .walkthrough-panel {
    width: 96vw;
    max-width: none;
    padding: 20px;
  }
  .walkthrough-body {
    font-size: 0.88rem;
  }

  /* Login: compact */
  .login-body {
    padding: 12px;
  }
  .login-shell {
    width: 100%;
  }
  .login-panel {
    padding: 18px;
    border-radius: 14px;
  }
  .login-form {
    gap: 10px;
    margin-top: 16px;
  }
  .demo-account-card {
    padding: 10px 12px;
  }
  .vairifeye-brand-login {
    gap: 8px;
  }
  .login-hero-img {
    max-width: 260px;
  }

  /* Ladder: 2 columns */
  .ladder-steps {
    grid-template-columns: repeat(2, 1fr);
    gap: 4px;
  }
  .ladder-step {
    padding: 6px 8px;
    font-size: 0.64rem;
  }

  /* Headings: readable sizes */
  h1 {
    font-size: 1.35rem;
    line-height: 1.2;
  }
  h2 {
    font-size: 1.1rem;
    line-height: 1.2;
  }
  h3 {
    font-size: 0.92rem;
  }

  /* Prevent any horizontal overflow */
  .tab-panel {
    overflow-x: hidden;
  }
  pre,
  code {
    overflow-x: auto;
    max-width: 100%;
  }
  table {
    overflow-x: auto;
    display: block;
    max-width: 100%;
  }

  /* Enterprise field groups: tighter spacing */
  .ent-field-group {
    padding: 12px;
    margin: 8px 0;
  }
  .ent-fieldset {
    padding: 10px;
    margin-top: 8px;
  }

  /* Enterprise divider */
  .ent-divider {
    margin: 10px 0 4px;
  }

  /* Guard rules: compact */
  .ent-guard-rule {
    padding: 8px 10px;
  }

  /* Stat cards: tighter */
  .ent-stat-card strong {
    font-size: 1.15rem;
  }
  .stat-card {
    padding: 10px 12px;
  }
  .stat-card strong {
    font-size: 1.1rem;
  }

  /* Conversations: compact */
  .conv-thread-header {
    flex-wrap: wrap;
    gap: 4px;
  }
  .conv-thread-messages {
    padding-left: 8px;
  }
  .conv-msg {
    flex-wrap: wrap;
    gap: 2px;
  }

  /* Toast: adjust for mobile */
  .toast-container {
    right: 10px;
    bottom: 10px;
    left: 10px;
  }
  .toast {
    max-width: 100%;
    font-size: 0.8rem;
    padding: 10px 14px;
  }

  /* Idle banner: compact */
  .idle-warning-banner {
    flex-wrap: wrap;
    padding: 8px 12px;
    font-size: 0.82rem;
    gap: 8px;
  }

  /* Tab panel buttons in enterprise scope: larger on mobile */
  .tab-panel:not(#view-dashboard) button:not(.tool-btn):not(.view-tab):not(.settings-tab):not(.mode-toggle):not(.preview-chip) {
    min-height: 44px;
    padding: 10px 16px;
  }

  /* Edit form row: single column on mobile */
  .edit-form-row {
    grid-template-columns: 1fr;
  }
}

/* ─────────────────────────────────────────────────────────────────────────
   MOBILE PHONE — max-width: 480px
   Very small screens. Everything stacked. Maximum touch friendliness.
   ───────────────────────────────────────────────────────────────────────── */
@media (max-width: 480px) {
  /* Shell: minimum padding */
  .shell {
    padding: 6px 8px 16px;
  }

  /* Topbar: fully stacked */
  .topbar {
    flex-direction: column;
    align-items: stretch;
    padding: 8px;
    gap: 6px;
  }
  .brand-lockup {
    flex-direction: column;
    align-items: flex-start;
  }
  .vairifeye-brand {
    flex-direction: column;
    gap: 8px;
  }
  .brand-mark {
    width: min(100%, 160px);
    min-height: 50px;
    padding: 10px 14px;
  }
  .brand-copy {
    gap: 3px;
  }
  .brand-chip {
    font-size: 0.58rem;
  }
  .topbar-actions {
    flex-direction: column;
    align-items: stretch;
    gap: 4px;
  }
  .header-status {
    flex-direction: column;
    gap: 4px;
  }
  .header-badge {
    width: 100%;
    text-align: center;
    justify-content: center;
    padding: 6px 8px;
    font-size: 0.62rem;
  }

  /* Identity: compact */
  .identity {
    width: 100%;
    padding: 8px;
    font-size: 0.78rem;
    justify-content: space-between;
  }

  /* Hero: minimal */
  .hero {
    padding: 8px;
    gap: 6px;
  }
  .hero-brief {
    grid-template-columns: 1fr;
  }
  .hero-metrics {
    grid-template-columns: 1fr;
    gap: 4px;
  }

  /* Metric cards: compact */
  .brief-card,
  .metric-card,
  .summary-card,
  .score,
  .toggle-card {
    border-radius: 10px;
    padding: 10px 12px;
  }
  .metric-card strong {
    font-size: 0.82rem;
  }

  /* Nav tabs: very compact */
  .view-tab {
    font-size: 0.68rem;
    padding: 8px 10px;
    min-height: 38px;
  }

  /* Flow strip: single column on phones */
  .flow-strip {
    grid-template-columns: 1fr;
  }
  .flow-step {
    min-height: 32px;
    padding: 4px 6px;
    font-size: 0.68rem;
  }

  /* Panels: very compact */
  .glass-panel {
    padding: 8px;
    border-radius: 10px;
  }
  .panel,
  .report-stage,
  .saved-runs-panel,
  .login-panel {
    padding: 8px;
  }

  /* Section labels: slightly smaller */
  .section-label,
  .eyebrow {
    font-size: 0.6rem;
  }

  /* Headings: mobile sizes */
  h1 {
    font-size: 1.2rem;
  }
  h2 {
    font-size: 1rem;
  }
  h3 {
    font-size: 0.88rem;
  }

  /* Buttons: full width, stacked */
  button,
  .file-pill {
    width: 100%;
    padding: 12px;
    min-height: 48px;
    font-size: 0.88rem;
  }
  .ghost-button {
    width: 100%;
    padding: 12px;
    min-height: 44px;
  }
  .compact-button {
    width: 100%;
    padding: 10px;
    min-height: 42px;
  }

  /* Inline buttons in panels: stack */
  .panel-header button {
    width: 100%;
  }
  .panel-actions {
    flex-direction: column;
    width: 100%;
    gap: 4px;
  }
  .intake-action-row {
    flex-direction: column;
    width: 100%;
    gap: 4px;
  }

  /* File bar: fully stacked */
  .file-bar {
    flex-direction: column;
    gap: 4px;
  }
  .file-bar > * {
    width: 100%;
  }
  .checkbox-pill {
    width: 100%;
    justify-content: center;
    min-height: 44px;
  }

  /* Preview stage: minimum heights */
  .preview-stage-body {
    min-height: 240px;
  }
  .preview-canvas-wrap {
    min-height: 240px;
  }
  .preview-frame,
  .preview-image,
  .preview-placeholder {
    min-height: 200px;
  }
  .preview-stage-fullwidth {
    border-radius: 8px;
  }

  /* Preview topbar: fully stacked */
  .preview-stage-topbar {
    flex-direction: column;
    align-items: stretch;
    gap: 4px;
    padding: 6px 8px;
  }
  .preview-stage-title {
    flex-direction: column;
    gap: 2px;
  }
  .preview-stage-title .preview-caption {
    max-width: 100%;
    font-size: 0.72rem;
  }
  .preview-stage-nav {
    justify-content: space-between;
  }
  .preview-stage-tools {
    overflow-x: auto;
    padding-bottom: 4px;
    gap: 4px;
  }

  /* Tool buttons: slightly larger for touch */
  .tool-btn {
    min-width: 38px;
    height: 38px;
    font-size: 0.68rem;
  }
  .tool-select {
    height: 38px;
    font-size: 0.68rem;
  }

  /* Preview queue: scrollable thumbnails */
  .preview-queue-bar {
    padding: 4px 8px;
  }
  .preview-chip {
    padding: 8px 10px;
    font-size: 0.68rem;
    min-height: 38px;
  }

  /* Photo add bar: fully stacked */
  .photo-add-bar {
    flex-direction: column;
    gap: 4px;
  }
  .photo-url-input {
    width: 100%;
    min-height: 48px;
  }
  .photo-add-bar button {
    width: 100%;
  }

  /* Results: card-style reflow */
  .result-row {
    flex-direction: column;
    align-items: stretch;
    gap: 4px;
    padding: 10px;
    border-bottom: 1px solid var(--line);
    min-width: 0;
  }
  .result-rs {
    min-width: auto;
  }
  .result-desc {
    white-space: normal;
    overflow: visible;
  }

  /* Manual review: stacked */
  .mi-row {
    grid-template-columns: 1fr;
    gap: 2px;
  }
  .mi-label {
    font-weight: 600;
    color: var(--muted);
  }
  .manual-nav-buttons {
    flex-direction: column;
    gap: 4px;
  }
  .manual-nav-buttons button {
    width: 100%;
  }
  .manual-footer button {
    width: 100%;
  }

  /* KPI: single column */
  .an-kpi-hero-row {
    grid-template-columns: 1fr;
    gap: 6px;
  }
  .an-kpi-val {
    font-size: 1.2rem;
  }
  .an-kpi-val--hero {
    font-size: 1.4rem;
  }
  .an-conf-grid {
    grid-template-columns: 1fr;
  }

  /* Agent cards: super compact */
  .agent-card-name {
    font-size: 0.78rem;
  }
  .agent-card-title {
    font-size: 0.6rem;
  }
  .agent-card-stats {
    font-size: 0.56rem;
  }
  .agent-card-body {
    padding: 6px 8px;
  }
  .agent-card-health-row {
    gap: 4px;
  }

  /* Agent findings: stacked header */
  .agent-finding-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    padding: 8px;
  }
  .agent-finding-title {
    white-space: normal;
    order: 0;
  }
  .agent-finding-ts {
    text-align: left;
  }
  .agent-finding-detail {
    padding: 4px 6px 8px 12px;
  }
  .agent-finding-actions {
    flex-direction: column;
    gap: 4px;
  }
  .agent-finding-actions button {
    width: 100%;
  }

  /* Expanded agent detail: compact */
  .ac-detail {
    padding-top: 8px;
  }
  .ac-detail-rule {
    font-size: 0.76rem;
    padding: 6px 10px;
  }
  .ac-detail-pills {
    gap: 3px;
  }
  .ac-pill {
    font-size: 0.55rem;
    padding: 2px 5px;
  }

  /* Validation log: minimal */
  .met-val-row {
    grid-template-columns: 20px 1fr 44px;
    font-size: 0.7rem;
    gap: 4px;
    padding: 6px;
  }
  .met-val-type {
    display: none;
  }
  .met-val-by,
  .met-val-time {
    display: none;
  }
  .met-val-brain,
  .met-val-human {
    display: none;
  }

  /* History table: minimal */
  .met-hist-row {
    grid-template-columns: 64px 1fr 44px;
    font-size: 0.66rem;
    gap: 4px;
    padding: 6px;
  }
  .met-hist-row span:nth-child(n+4) {
    display: none;
  }

  /* Test card: compact */
  .met-test-card {
    padding: 10px;
  }

  /* Modal: full screen takeover */
  .modal {
    padding: 0;
  }
  .modal-panel {
    width: 100%;
    height: 100vh;
    max-height: 100vh;
    border-radius: 0;
    overflow-y: auto;
  }

  /* Walkthrough: full width */
  .walkthrough-panel {
    width: 100%;
    border-radius: 0;
    padding: 16px;
  }
  .walkthrough-body {
    min-height: 80px;
    font-size: 0.85rem;
  }
  .walkthrough-footer {
    flex-direction: column;
    gap: 8px;
  }
  .walkthrough-nav {
    width: 100%;
  }
  .walkthrough-nav button {
    flex: 1;
  }

  /* Login: full mobile */
  .login-body {
    padding: 8px;
  }
  .login-panel {
    padding: 14px;
    border-radius: 12px;
  }
  .login-form {
    gap: 8px;
  }
  .demo-account-card {
    padding: 8px 10px;
  }
  .demo-fill-button {
    min-width: auto;
    width: 100%;
  }
  .demo-account-row {
    flex-direction: column;
    gap: 6px;
    align-items: stretch;
  }
  .lede {
    font-size: 0.78rem;
  }

  /* Empty states: compact */
  .empty-state,
  .ent-empty-state {
    padding: 14px 12px;
  }

  /* Ladder: single column */
  .ladder-steps {
    grid-template-columns: 1fr;
  }

  /* Conversations: compact */
  .conv-thread-header {
    font-size: 0.64rem;
  }
  .conv-msg {
    font-size: 0.58rem;
  }

  /* Enterprise stat cards */
  .ent-stat-card strong {
    font-size: 1rem;
  }

  /* Report pre: compact */
  pre {
    min-height: 160px;
    font-size: 0.72rem;
  }

  /* Compact textarea: more room on mobile */
  .compact-textarea {
    min-height: 56px;
    max-height: 120px;
  }

  /* Inventory editor: more height on mobile */
  .inventory-editor {
    min-height: 80px;
  }

  /* Saved runs: compact */
  .saved-runs-panel {
    margin-top: 10px;
  }

  /* Report stage: compact */
  .report-stage {
    border-radius: 10px;
  }

  /* Live counter: stacked */
  .live-counter {
    flex-direction: column;
    gap: 4px;
    padding: 8px 10px;
    font-size: 0.78rem;
  }

  /* Agent scheduler row: wrap */
  .agent-sched-row {
    flex-wrap: wrap;
    gap: 4px;
    font-size: 0.56rem;
  }

  /* Digest items: compact */
  .agent-digest-item {
    padding: 6px;
    font-size: 0.74rem;
  }
  .agent-digest-avatar {
    font-size: 0.88rem;
  }

  /* Toast: bottom banner style */
  .toast-container {
    right: 0;
    bottom: 0;
    left: 0;
    padding: 8px;
  }
  .toast {
    max-width: 100%;
    border-radius: 6px;
  }

  /* Idle banner: compact stacked */
  .idle-warning-banner {
    flex-direction: column;
    gap: 6px;
    padding: 8px 10px;
    font-size: 0.78rem;
  }
  .idle-warning-banner button {
    width: 100%;
    padding: 8px 12px;
  }
}

/* ─────────────────────────────────────────────────────────────────────────
   SAFE AREA / NOTCH SUPPORT — for iOS devices with notch
   ───────────────────────────────────────────────────────────────────────── */
@supports (padding-top: env(safe-area-inset-top)) {
  .shell {
    padding-left: max(env(safe-area-inset-left), 8px);
    padding-right: max(env(safe-area-inset-right), 8px);
  }
  .topbar {
    padding-top: max(env(safe-area-inset-top), 8px);
  }
  .toast-container {
    bottom: max(env(safe-area-inset-bottom), 10px);
  }
  .idle-warning-banner {
    padding-top: max(env(safe-area-inset-top), 10px);
  }
  .modal {
    padding-bottom: max(env(safe-area-inset-bottom), 8px);
  }
}

/* ─────────────────────────────────────────────────────────────────────────
   TOUCH DEVICE ENHANCEMENTS — hover-free environments
   ───────────────────────────────────────────────────────────────────────── */
@media (hover: none) and (pointer: coarse) {
  /* Remove hover-lift effects on touch devices (cause visual jank) */
  button:hover,
  .ghost-button:hover,
  .file-pill:hover,
  .mode-choice:hover,
  .view-tab:hover {
    transform: none;
  }

  /* Increase tap targets for checkboxes and radios */
  input[type="checkbox"],
  input[type="radio"] {
    min-width: 20px;
    min-height: 20px;
  }

  /* Larger scrollbar touch target for scrollable areas */
  .preview-queue,
  .view-tabs,
  .editor-toolbar,
  .preview-stage-tools {
    scrollbar-width: thin;
  }

  /* Active state instead of hover for touch feedback */
  button:active,
  .ghost-button:active,
  .file-pill:active,
  .view-tab:active {
    transform: scale(0.97);
    opacity: 0.9;
  }
}

/* ─────────────────────────────────────────────────────────────────────────
   LANDSCAPE PHONE — short but wide
   ───────────────────────────────────────────────────────────────────────── */
@media (max-height: 500px) and (orientation: landscape) {
  /* Minimize vertical space in landscape phone */
  .hero {
    display: none;
  }
  .topbar {
    padding: 4px 10px;
  }
  .brand-mark {
    display: none;
  }
  .view-tabs {
    margin-top: 4px;
  }
  .preview-stage-body {
    min-height: 200px;
  }
  .preview-canvas-wrap {
    min-height: 200px;
  }
  .preview-frame,
  .preview-image {
    min-height: 180px;
  }
}


/* ═══════════════════════════════════════════════════════════════════════════
   VAIRIFEYE COCKPIT — Premium Enterprise Design System
   ═══════════════════════════════════════════════════════════════════════════ */

/* ---------------------------------------------------------------------------
   COMMAND NAV — Premium horizontal navigation
   --------------------------------------------------------------------------- */
.command-nav {
  display: flex;
  align-items: center;
  gap: 2px;
  margin: 10px 0 0;
  padding: 4px;
  border-radius: 12px;
  background: linear-gradient(180deg, var(--surface-strong), var(--surface));
  border: 1px solid var(--line);
  backdrop-filter: blur(16px) saturate(140%);
  box-shadow: var(--shadow-soft), 0 0 40px rgba(59, 158, 255, 0.015);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
}
.command-nav-item {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 9px 18px;
  border-radius: 8px;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  color: var(--muted);
  background: transparent;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: nowrap;
}
.command-nav-item:hover {
  color: var(--ink);
  background: rgba(255, 255, 255, 0.05);
}
.command-nav-item.is-active {
  color: var(--ink-strong);
  background: var(--surface-button-strong);
  border-color: var(--line);
  box-shadow: 0 4px 14px rgba(2, 8, 16, 0.18), 0 0 20px rgba(59, 158, 255, 0.03);
  font-weight: 700;
}
.command-nav-item.is-active::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 24px;
  height: 2px;
  border-radius: 1px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
  opacity: 0.7;
}
.command-nav-icon {
  font-size: 0.9rem;
  opacity: 0.7;
}
.command-nav-item.is-active .command-nav-icon {
  opacity: 1;
}
.command-nav-spacer {
  flex: 1;
}
.command-nav-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 9px;
  font-size: 0.62rem;
  font-weight: 700;
  background: var(--danger);
  color: #fff;
  line-height: 1;
}

/* ---------------------------------------------------------------------------
   ROLE SELECTOR — Topbar mode switch
   --------------------------------------------------------------------------- */
.role-selector {
  display: flex;
  align-items: center;
  gap: 2px;
  padding: 3px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--line);
}
.role-btn {
  padding: 5px 12px;
  border-radius: 6px;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--muted);
  background: transparent;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all 0.2s var(--ease);
}
.role-btn:hover {
  color: var(--ink);
  background: rgba(255, 255, 255, 0.04);
}
.role-btn.is-active {
  color: var(--ink-strong);
  background: var(--accent-soft);
  border-color: rgba(59, 158, 255, 0.18);
}

/* ---------------------------------------------------------------------------
   TOPBAR UPGRADE — Premium header bar
   --------------------------------------------------------------------------- */
.topbar {
  position: relative;
  overflow: hidden;
}
.topbar::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 5%;
  right: 5%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(59, 158, 255, 0.12), transparent);
}
/* brand-mark: transparent — logo carries its own presence */
.brand-mark {
  background: transparent;
  border: none;
  box-shadow: none;
}

/* ---------------------------------------------------------------------------
   MANAGER DASHBOARD — Meeting-ready executive view
   --------------------------------------------------------------------------- */
.manager-dashboard {
  display: grid;
  gap: 12px;
  padding: 4px 0;
}
.mgr-kpi-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 10px;
}
.mgr-kpi {
  position: relative;
  padding: 18px 20px;
  border-radius: 14px;
  background: linear-gradient(180deg, var(--surface-strong), var(--surface));
  border: var(--glass-border);
  backdrop-filter: var(--glass-blur);
  box-shadow: var(--shadow-soft), 0 0 30px rgba(59, 158, 255, 0.012);
  overflow: hidden;
}
.mgr-kpi::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  border-radius: 14px 14px 0 0;
}
.mgr-kpi.kpi-pass::before { background: linear-gradient(90deg, var(--success), transparent); }
.mgr-kpi.kpi-risk::before { background: linear-gradient(90deg, var(--danger), transparent); }
.mgr-kpi.kpi-volume::before { background: linear-gradient(90deg, var(--brand), transparent); }
.mgr-kpi.kpi-trend::before { background: linear-gradient(90deg, var(--warning), transparent); }
.mgr-kpi-label {
  font-size: 0.68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  margin-bottom: 6px;
}
.mgr-kpi-value {
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--ink-strong);
  line-height: 1;
}
.mgr-kpi-delta {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  margin-top: 6px;
  font-size: 0.72rem;
  font-weight: 600;
}
.mgr-kpi-delta.up { color: var(--success); }
.mgr-kpi-delta.down { color: var(--danger); }
.mgr-kpi-delta.flat { color: var(--muted); }

.mgr-section {
  padding: 18px 20px;
  border-radius: 14px;
  background: linear-gradient(180deg, var(--surface-strong), var(--surface));
  border: var(--glass-border);
  backdrop-filter: var(--glass-blur);
  box-shadow: var(--shadow-soft);
}
.mgr-section-title {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  margin-bottom: 12px;
}
.mgr-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.mgr-risk-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--line);
}
.mgr-risk-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.mgr-risk-dot.high { background: var(--danger); box-shadow: 0 0 8px var(--danger-soft); }
.mgr-risk-dot.medium { background: var(--warning); box-shadow: 0 0 8px var(--warning-soft); }
.mgr-risk-dot.low { background: var(--success); box-shadow: 0 0 8px var(--success-soft); }
.mgr-risk-label {
  font-size: 0.78rem;
  color: var(--ink);
  font-weight: 500;
}
.mgr-risk-meta {
  margin-left: auto;
  font-size: 0.7rem;
  color: var(--muted);
}

/* ---------------------------------------------------------------------------
   IT SYSTEM VIEW — Telemetry and control
   --------------------------------------------------------------------------- */
.system-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.sys-card {
  padding: 16px 18px;
  border-radius: 14px;
  background: linear-gradient(180deg, var(--surface-strong), var(--surface));
  border: var(--glass-border);
  backdrop-filter: var(--glass-blur);
}
.sys-card-title {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  margin-bottom: 10px;
}
.sys-metric-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 0;
  border-bottom: 1px solid var(--line);
}
.sys-metric-row:last-child { border-bottom: none; }
.sys-metric-label {
  font-size: 0.78rem;
  color: var(--ink);
}
.sys-metric-value {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--ink-strong);
}
.sys-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 0.68rem;
  font-weight: 600;
}
.sys-status-badge.ok { background: var(--success-soft); color: var(--success); }
.sys-status-badge.warn { background: var(--warning-soft); color: var(--warning); }
.sys-status-badge.err { background: var(--danger-soft); color: var(--danger); }
.sys-status-badge::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}

/* ---------------------------------------------------------------------------
   CONFIDENCE SCREEN — Post-audit intelligence
   --------------------------------------------------------------------------- */
.confidence-screen {
  display: none;
  gap: 12px;
  padding: 4px 0;
}
.confidence-screen.is-visible {
  display: grid;
}
.conf-hero {
  position: relative;
  padding: 28px 24px;
  border-radius: 16px;
  background: linear-gradient(180deg, var(--surface-strong), var(--surface));
  border: var(--glass-border);
  backdrop-filter: var(--glass-blur);
  box-shadow: var(--shadow);
  text-align: center;
  overflow: hidden;
}
.conf-hero::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
}
.conf-hero.pass::before { background: linear-gradient(90deg, transparent, var(--success), transparent); }
.conf-hero.fail::before { background: linear-gradient(90deg, transparent, var(--danger), transparent); }
.conf-hero.mixed::before { background: linear-gradient(90deg, transparent, var(--warning), transparent); }
.conf-verdict-big {
  font-size: 3rem;
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 1;
  margin-bottom: 6px;
}
.conf-verdict-big.pass { color: var(--success); }
.conf-verdict-big.fail { color: var(--danger); }
.conf-verdict-big.mixed { color: var(--warning); }
.conf-subtitle {
  font-size: 0.82rem;
  color: var(--muted);
  font-weight: 500;
}
.conf-stats-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
}
.conf-stat {
  padding: 16px 18px;
  border-radius: 12px;
  background: linear-gradient(180deg, var(--surface-strong), var(--surface));
  border: var(--glass-border);
  text-align: center;
}
.conf-stat-value {
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--ink-strong);
}
.conf-stat-label {
  font-size: 0.68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
  margin-top: 4px;
}
.conf-section {
  padding: 18px 20px;
  border-radius: 14px;
  background: linear-gradient(180deg, var(--surface-strong), var(--surface));
  border: var(--glass-border);
  backdrop-filter: var(--glass-blur);
}
.conf-section-title {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  margin-bottom: 12px;
}
.conf-talking-point {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid var(--line);
}
.conf-talking-point:last-child { border-bottom: none; }
.conf-tp-icon {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  margin-top: 6px;
  flex-shrink: 0;
  box-shadow: 0 0 6px rgba(59, 158, 255, 0.3);
}
.conf-tp-text {
  font-size: 0.82rem;
  color: var(--ink);
  line-height: 1.5;
}
.conf-punch-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--line);
  margin-bottom: 6px;
}
.conf-punch-code {
  font-weight: 600;
  font-size: 0.78rem;
  color: var(--ink-strong);
}
.conf-punch-desc {
  font-size: 0.76rem;
  color: var(--ink);
  flex: 1;
  margin: 0 12px;
}
.conf-punch-severity {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 4px;
}
.conf-punch-severity.critical { background: var(--danger-soft); color: var(--danger); }
.conf-punch-severity.major { background: var(--warning-soft); color: var(--warning); }
.conf-punch-severity.minor { background: var(--success-soft); color: var(--muted); }

/* ---------------------------------------------------------------------------
   WHITE-LABEL SHELL — Client branding system
   --------------------------------------------------------------------------- */
.shell-brand-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 3px 0;
}
.shell-client-logo {
  height: 28px;
  width: auto;
  opacity: 0.9;
}
.shell-powered-by {
  font-size: 0.58rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--muted);
  opacity: 0.6;
}
/* ── TENANT SHELL OVERRIDES ── */
/* Viaero Shell — Crimson atmosphere, applied via shell theming */
body[data-shell="viaero"] {
  /* Shell accent — crimson for framing, badges, trim */
  --shell-accent: #d73745;
  --shell-accent-soft: rgba(215, 55, 69, 0.12);
  /* UI overrides — shell colors the chrome, not the product mark */
  --accent: #d73745;
  --accent-soft: rgba(215, 55, 69, 0.12);
  /* NOTE: --brand stays Vairifeye check-blue (#2C7DFF) — never overridden */
  --glow-primary: rgba(215, 55, 69, 0.10);
  --glow-secondary: rgba(215, 55, 69, 0.06);
  --glow-subtle: rgba(215, 55, 69, 0.03);
  --line-glow: rgba(215, 55, 69, 0.08);
  --shadow-glow: 0 0 60px rgba(215, 55, 69, 0.025);
  --shadow-panel: 0 28px 80px rgba(2, 2, 12, 0.42), 0 0 80px rgba(215, 55, 69, 0.02);
  --glass-border-active: 1px solid rgba(215, 55, 69, 0.22);
  --glass-border-glow: 1px solid rgba(215, 55, 69, 0.10);
}
/* Shell color overrides via data attribute — white-label system */
body[data-shell-color="blue"] {
  --accent: #1B65E0;
  --accent-soft: rgba(59, 130, 246, 0.12);
  --glow-primary: rgba(59, 130, 246, 0.10);
  --glow-secondary: rgba(59, 130, 246, 0.06);
}
body[data-shell-color="green"] {
  --accent: #10b981;
  --accent-soft: rgba(16, 185, 129, 0.12);
  --glow-primary: rgba(16, 185, 129, 0.10);
  --glow-secondary: rgba(16, 185, 129, 0.06);
}
body[data-shell-color="purple"] {
  --accent: #8b5cf6;
  --accent-soft: rgba(139, 92, 246, 0.12);
  --glow-primary: rgba(139, 92, 246, 0.10);
  --glow-secondary: rgba(139, 92, 246, 0.06);
}
body[data-shell-color="orange"] {
  --accent: #f97316;
  --accent-soft: rgba(249, 115, 22, 0.12);
  --glow-primary: rgba(249, 115, 22, 0.10);
  --glow-secondary: rgba(249, 115, 22, 0.06);
}

/* ---------------------------------------------------------------------------
   REVIEW WORKSPACE UPGRADE — Cockpit feel
   --------------------------------------------------------------------------- */
.review-workspace {
  border-radius: 16px;
  border: var(--glass-border);
  box-shadow: var(--shadow-panel);
  overflow: hidden;
}
.rw-header {
  background: linear-gradient(180deg, rgba(18, 32, 54, 0.95), rgba(14, 25, 42, 0.90));
  border-bottom: 1px solid rgba(59, 158, 255, 0.08);
}
.rw-verdict-card {
  position: relative;
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(18, 32, 54, 0.92), rgba(14, 25, 42, 0.85));
  border: 1px solid var(--line);
  padding: 16px;
  text-align: center;
  overflow: hidden;
}
.rw-verdict-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
}
.rw-verdict-card[data-verdict="pass"]::before { background: var(--success); }
.rw-verdict-card[data-verdict="fail"]::before { background: var(--danger); }
.rw-verdict-card[data-verdict="pending"]::before { background: var(--muted); }

.rw-btn {
  padding: 10px 20px;
  border-radius: 10px;
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s var(--ease);
  border: 1px solid transparent;
}
.rw-btn--approve {
  background: linear-gradient(135deg, #059669, var(--success));
  color: #fff;
  border-color: rgba(16, 185, 129, 0.3);
}
.rw-btn--approve:hover {
  box-shadow: 0 6px 20px rgba(16, 185, 129, 0.25);
}
.rw-btn--override {
  background: rgba(245, 158, 11, 0.12);
  color: var(--warning);
  border-color: rgba(245, 158, 11, 0.2);
}
.rw-btn--flag {
  background: rgba(239, 68, 68, 0.10);
  color: var(--danger);
  border-color: rgba(239, 68, 68, 0.18);
}
.rw-btn--next {
  background: var(--accent-soft);
  color: var(--accent);
  border-color: rgba(59, 158, 255, 0.18);
}

/* ---------------------------------------------------------------------------
   AMBIENT GLOW EFFECTS — Subtle life indicators
   --------------------------------------------------------------------------- */
@keyframes pulse-glow {
  0%, 100% { opacity: 0.5; }
  50% { opacity: 1; }
}
.glow-active {
  animation: pulse-glow 2s ease-in-out infinite;
}
.status-live::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--success);
  margin-right: 6px;
  animation: pulse-glow 2s ease-in-out infinite;
}

/* ---------------------------------------------------------------------------
   MODE-SPECIFIC LAYOUTS — Body class drives view adaptation
   --------------------------------------------------------------------------- */
body[data-role="auditor"] .mgr-only,
body[data-role="auditor"] .sys-only { display: none !important; }
body[data-role="manager"] .aud-only,
body[data-role="manager"] .sys-only { display: none !important; }
body[data-role="system"] .aud-only,
body[data-role="system"] .mgr-only { display: none !important; }

/* Hide old view-tabs when command-nav is present */
.command-nav ~ .view-tabs { display: none; }

/* ===========================================================================
   VAIRIFEYE DESIGN SYSTEM — vf-* namespaced components
   Phase 2: Data tables, verdict pills, state badges, findings chips
   =========================================================================== */

/* ---------------------------------------------------------------------------
   VF-TABLE — Sortable, paginated data table
   --------------------------------------------------------------------------- */
.vf-table-wrap {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: 12px;
  border: var(--glass-border);
  background: var(--surface);
  backdrop-filter: var(--glass-blur);
}
.vf-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-body);
  font-size: 0.82rem;
  line-height: 1.45;
  color: var(--ink);
}
.vf-table thead {
  position: sticky;
  top: 0;
  z-index: 2;
}
.vf-table th {
  padding: 10px 14px;
  text-align: left;
  font-family: var(--font-body);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted);
  background: var(--surface-strong);
  border-bottom: 1px solid var(--line-strong);
  white-space: nowrap;
  user-select: none;
}
.vf-table th:first-child { border-radius: 12px 0 0 0; }
.vf-table th:last-child  { border-radius: 0 12px 0 0; }

/* Sort indicators */
.vf-table th.vf-sortable { cursor: pointer; }
.vf-table th.vf-sortable:hover { color: var(--ink-strong); }
.vf-table th.vf-sortable::after {
  content: "⇅";
  margin-left: 6px;
  opacity: 0.3;
  font-size: 0.72rem;
}
.vf-table th.vf-sort-asc::after  { content: "↑"; opacity: 0.8; color: var(--accent); }
.vf-table th.vf-sort-desc::after { content: "↓"; opacity: 0.8; color: var(--accent); }

/* Rows */
.vf-table td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--line);
  vertical-align: middle;
  transition: background var(--speed) var(--ease);
}
.vf-table tbody tr:hover td {
  background: rgba(44, 125, 255, 0.04);
}
.vf-table tbody tr:nth-child(even) td {
  background: rgba(255, 255, 255, 0.015);
}
.vf-table tbody tr:nth-child(even):hover td {
  background: rgba(44, 125, 255, 0.05);
}
.vf-table tbody tr:last-child td { border-bottom: none; }

/* Cell variants */
.vf-table td.vf-cell-mono {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: -0.01em;
}
.vf-table td.vf-cell-muted {
  color: var(--muted);
  font-size: 0.78rem;
}
.vf-table td.vf-cell-strong {
  color: var(--ink-strong);
  font-weight: 500;
}
.vf-table td.vf-cell-compact {
  padding: 6px 14px;
}
.vf-table td.vf-cell-actions {
  text-align: right;
  white-space: nowrap;
}

/* Empty state */
.vf-table-empty {
  padding: 48px 24px;
  text-align: center;
  color: var(--muted);
  font-size: 0.85rem;
}
.vf-table-empty strong {
  display: block;
  color: var(--ink);
  font-size: 0.92rem;
  margin-bottom: 6px;
}

/* Pagination */
.vf-table-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  border-top: 1px solid var(--line);
  font-size: 0.75rem;
  color: var(--muted);
}
.vf-table-pagination .vf-page-info {
  display: flex;
  align-items: center;
  gap: 6px;
}
.vf-table-pagination .vf-page-nav {
  display: flex;
  align-items: center;
  gap: 2px;
}
.vf-page-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 30px;
  height: 30px;
  padding: 0 8px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: transparent;
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 0.75rem;
  cursor: pointer;
  transition: all var(--speed) var(--ease);
}
.vf-page-btn:hover:not(:disabled) {
  background: var(--surface-button);
  color: var(--ink-strong);
  border-color: var(--line-strong);
}
.vf-page-btn.active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
  font-weight: 600;
}
.vf-page-btn:disabled {
  opacity: 0.35;
  cursor: default;
}
.vf-page-size {
  margin-left: 12px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.vf-page-size select {
  padding: 4px 8px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--surface);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 0.75rem;
}

/* Responsive: horizontal scroll on narrow viewports */
@media (max-width: 768px) {
  .vf-table th,
  .vf-table td {
    padding: 8px 10px;
    font-size: 0.78rem;
  }
}

/* ---------------------------------------------------------------------------
   VF-VERDICT — 4-state verdict pill (PASS / FAIL / N/A / MISSING)
   --------------------------------------------------------------------------- */
.vf-verdict {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 100px;
  font-family: var(--font-body);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  white-space: nowrap;
  line-height: 1.4;
}
.vf-verdict--pass {
  background: var(--success-soft);
  color: #79BF43;
  border: 1px solid rgba(95, 150, 52, 0.22);
}
.vf-verdict--fail {
  background: var(--danger-soft);
  color: #f87171;
  border: 1px solid rgba(201, 75, 86, 0.22);
}
.vf-verdict--na {
  background: var(--warning-soft);
  color: #fbbf24;
  border: 1px solid rgba(184, 133, 24, 0.22);
}
.vf-verdict--missing {
  background: rgba(138, 145, 161, 0.12);
  color: var(--muted);
  border: 1px solid rgba(138, 145, 161, 0.18);
}
.vf-verdict--review {
  background: rgba(44, 125, 255, 0.12);
  color: var(--accent);
  border: 1px solid rgba(44, 125, 255, 0.22);
}

/* Light theme overrides */
body[data-theme="light"] .vf-verdict--pass  { color: #059669; }
body[data-theme="light"] .vf-verdict--fail  { color: #dc2626; }
body[data-theme="light"] .vf-verdict--na    { color: #d97706; }
body[data-theme="light"] .vf-verdict--missing { color: #6b7280; }
body[data-theme="light"] .vf-verdict--review  { color: #2563eb; }

/* ---------------------------------------------------------------------------
   VF-STATE — 5-state review queue badge
   --------------------------------------------------------------------------- */
.vf-state {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 100px;
  font-family: var(--font-body);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  white-space: nowrap;
  line-height: 1.4;
}
.vf-state--pending {
  background: rgba(138, 145, 161, 0.12);
  color: var(--muted);
  border: 1px solid rgba(138, 145, 161, 0.18);
}
.vf-state--assigned {
  background: rgba(44, 125, 255, 0.12);
  color: #2C7DFF;
  border: 1px solid rgba(44, 125, 255, 0.22);
}
.vf-state--in_progress {
  background: var(--warning-soft);
  color: #fbbf24;
  border: 1px solid rgba(184, 133, 24, 0.22);
}
.vf-state--completed {
  background: var(--success-soft);
  color: #79BF43;
  border: 1px solid rgba(95, 150, 52, 0.22);
}
.vf-state--skipped {
  background: rgba(100, 100, 120, 0.10);
  color: rgba(138, 145, 161, 0.7);
  border: 1px solid rgba(100, 100, 120, 0.14);
}

/* State dot indicator */
.vf-state::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}
.vf-state--pending::before    { background: var(--muted); }
.vf-state--assigned::before   { background: #2C7DFF; }
.vf-state--in_progress::before { background: #fbbf24; }
.vf-state--completed::before  { background: #79BF43; }
.vf-state--skipped::before    { background: rgba(138, 145, 161, 0.5); }

/* Light theme */
body[data-theme="light"] .vf-state--assigned { color: #2563eb; }
body[data-theme="light"] .vf-state--in_progress { color: #d97706; }
body[data-theme="light"] .vf-state--completed { color: #059669; }

/* ---------------------------------------------------------------------------
   VF-FINDING — Punch/finding chip with severity bar
   --------------------------------------------------------------------------- */
.vf-finding {
  display: flex;
  flex-direction: column;
  padding: 10px 14px 10px 18px;
  border-radius: 10px;
  background: var(--surface);
  border: 1px solid var(--line);
  position: relative;
  transition: border-color var(--speed) var(--ease);
  cursor: default;
}
.vf-finding:hover {
  border-color: var(--line-strong);
}
/* Left severity bar */
.vf-finding::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  bottom: 8px;
  width: 4px;
  border-radius: 2px;
}
.vf-finding--critical::before { background: var(--danger); }
.vf-finding--major::before    { background: #f59e0b; }
.vf-finding--minor::before    { background: var(--warning); }
.vf-finding--info::before     { background: var(--accent); }

/* Title row */
.vf-finding-head {
  display: flex;
  align-items: center;
  gap: 8px;
}
.vf-finding-title {
  font-family: var(--font-body);
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--ink-strong);
  line-height: 1.35;
}
.vf-finding-code {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.04);
  padding: 2px 7px;
  border-radius: 4px;
  border: 1px solid var(--line);
  white-space: nowrap;
}
.vf-finding-authority {
  font-size: 0.72rem;
  color: var(--muted);
  margin-top: 4px;
  line-height: 1.35;
}

/* Expandable detail */
.vf-finding-detail {
  font-size: 0.78rem;
  color: var(--ink);
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid var(--line);
  line-height: 1.55;
  display: none;
}
.vf-finding.expanded .vf-finding-detail {
  display: block;
}

/* Compact mode for table cells */
.vf-finding--compact {
  flex-direction: row;
  align-items: center;
  padding: 4px 10px 4px 14px;
  gap: 8px;
  border-radius: 6px;
}
.vf-finding--compact::before {
  top: 4px;
  bottom: 4px;
}
.vf-finding--compact .vf-finding-head {
  flex: 1;
}
.vf-finding--compact .vf-finding-authority {
  margin-top: 0;
  margin-left: auto;
  white-space: nowrap;
}
.vf-finding--compact .vf-finding-detail { display: none; }

/* ---------------------------------------------------------------------------
   VF-CITATION — Standards citation block
   --------------------------------------------------------------------------- */
.vf-citation {
  padding: 12px 16px;
  border-radius: 8px;
  border-left: 3px solid var(--accent);
  background: rgba(44, 125, 255, 0.06);
  font-size: 0.8rem;
  line-height: 1.55;
  color: var(--ink);
}
.vf-citation-source {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  color: var(--muted);
  margin-top: 6px;
}

/* ---------------------------------------------------------------------------
   VF-TIMELINE — Vertical audit trail
   --------------------------------------------------------------------------- */
.vf-timeline {
  position: relative;
  padding-left: 28px;
}
.vf-timeline::before {
  content: "";
  position: absolute;
  left: 10px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: var(--line);
}
.vf-timeline-item {
  position: relative;
  padding: 8px 0 16px;
}
.vf-timeline-item::before {
  content: "";
  position: absolute;
  left: -22px;
  top: 12px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--surface-strong);
  border: 2px solid var(--accent);
}
.vf-timeline-item--verdict::before { border-color: var(--success); }
.vf-timeline-item--override::before { border-color: var(--warning); }
.vf-timeline-item--escalated::before { border-color: var(--danger); }
.vf-timeline-time {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  color: var(--muted);
  margin-bottom: 3px;
}
.vf-timeline-text {
  font-size: 0.8rem;
  color: var(--ink);
  line-height: 1.45;
}
.vf-timeline-actor {
  font-weight: 500;
  color: var(--ink-strong);
}

/* ---------------------------------------------------------------------------
   VF-PROGRESS-RING — Circular completion indicator
   --------------------------------------------------------------------------- */
.vf-progress-ring {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.vf-progress-ring svg {
  transform: rotate(-90deg);
}
.vf-progress-ring circle {
  fill: none;
  stroke-width: 4;
  stroke-linecap: round;
}
.vf-progress-ring .vf-ring-bg {
  stroke: var(--line);
}
.vf-progress-ring .vf-ring-fill {
  stroke: var(--accent);
  transition: stroke-dashoffset 0.6s var(--ease);
}
.vf-progress-ring .vf-ring-label {
  position: absolute;
  font-family: var(--font-body);
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--ink-strong);
}

/* ---------------------------------------------------------------------------
   VF-EVIDENCE — Split panel (photo + trace)
   --------------------------------------------------------------------------- */
.vf-evidence {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  border-radius: 12px;
  overflow: hidden;
}
.vf-evidence-photo {
  background: var(--bg-top);
  border-radius: 12px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 320px;
  border: 1px solid var(--line);
}
.vf-evidence-photo img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}
.vf-evidence-trace {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
@media (max-width: 900px) {
  .vf-evidence { grid-template-columns: 1fr; }
}

/* ---------------------------------------------------------------------------
   VF-DIFF — AI vs Human verdict comparison
   --------------------------------------------------------------------------- */
.vf-diff {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-radius: 10px;
  background: var(--surface);
  border: 1px solid var(--line);
}
.vf-diff-label {
  font-size: 0.68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted);
  text-align: center;
  margin-bottom: 4px;
}
.vf-diff-arrow {
  font-size: 1.1rem;
  color: var(--muted);
  opacity: 0.5;
}
.vf-diff-match { border-color: rgba(95, 150, 52, 0.22); }
.vf-diff-mismatch { border-color: rgba(201, 75, 86, 0.22); }

/* =====================================================================
   1. Command Center Layout
   ===================================================================== */
.vf-command-center {
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 100%;
  min-height: 0;
}

/* =====================================================================
   2. Nerve Center — THE SCREEN. Not a card. Not a panel.
   60%+ viewport. Hard edges. System authority.
   ===================================================================== */
.vf-nerve {
  background: linear-gradient(180deg, rgba(10, 13, 30, 0.95), rgba(6, 9, 22, 0.92));
  border: 1px solid rgba(226, 228, 235, 0.05);
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 6px;
  padding: 0;
  backdrop-filter: var(--glass-blur);
  box-shadow:
    0 12px 48px rgba(0, 0, 0, 0.5),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
  position: relative;
  overflow: hidden;
  z-index: 3;
  min-height: 50vh;
  display: flex;
  flex-direction: column;
}

/* ── Nerve Header — state bar + monitor ── */
.vf-nerve-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 28px 12px;
  border-bottom: 1px solid rgba(155, 163, 175, 0.06);
}
.vf-nerve-state {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.vf-nerve-indicators {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.vf-nerve-monitor {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.72rem;
  color: var(--muted);
  font-style: italic;
  white-space: nowrap;
}

/* ── Nerve Body — directive title + blocking issue ── */
.vf-nerve-body {
  padding: 36px 36px 24px;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.vf-nerve-title {
  font-family: var(--font-display);
  font-size: 2.1rem;
  font-weight: 800;
  color: var(--ink-strong);
  margin: 0 0 10px;
  line-height: 1.15;
  letter-spacing: -0.02em;
  text-transform: uppercase;
}
.vf-nerve--critical .vf-nerve-title {
  color: #f87171;
}
.vf-nerve-subtitle {
  font-size: 0.9rem;
  color: var(--muted);
  margin: 0 0 28px;
  line-height: 1.5;
  max-width: 680px;
}

/* ── THE blocking issue — single row: icon + text + CTA ── */
.vf-nerve-blocking {
  margin-bottom: 12px;
}
.vf-nerve-issue-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 20px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(155, 163, 175, 0.08);
  border-left: 3px solid rgba(155, 163, 175, 0.15);
  transition: border-color 0.2s var(--ease), background 0.2s var(--ease);
}
.vf-nerve-issue-row.critical {
  background: rgba(255, 255, 255, 0.02);
  border-color: rgba(155, 163, 175, 0.08);
  border-left: 3px solid #ef4444;
}
.vf-nerve-issue-row.warning {
  background: rgba(255, 255, 255, 0.02);
  border-color: rgba(155, 163, 175, 0.08);
  border-left: 3px solid #f59e0b;
}
.vf-nerve-issue-row.ready {
  background: rgba(255, 255, 255, 0.02);
  border-color: rgba(155, 163, 175, 0.08);
  border-left: 3px solid #79BF43;
}
.vf-nerve-issue-icon {
  font-size: 1.1rem;
  flex-shrink: 0;
  width: 24px;
  text-align: center;
}
.vf-nerve-issue-row.critical .vf-nerve-issue-icon { color: #f87171; }
.vf-nerve-issue-row.warning .vf-nerve-issue-icon  { color: #fbbf24; }
.vf-nerve-issue-row.ready .vf-nerve-issue-icon     { color: #79BF43; }
.vf-nerve-issue-text {
  flex: 1;
  font-size: 0.88rem;
  font-weight: 500;
  color: var(--ink-strong);
  line-height: 1.4;
}

/* ── Primary CTA — machined, deliberate ── */
.vf-nerve-cta {
  flex-shrink: 0;
  padding: 10px 28px;
  font-size: 0.80rem;
  font-weight: 700;
  font-family: var(--font-display);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border-radius: 5px;
  border: none;
  cursor: pointer;
  color: #fff;
  background: linear-gradient(135deg, var(--accent), var(--brand-strong));
  box-shadow: 0 2px 8px rgba(2, 2, 12, 0.25);
  transition: all 0.25s var(--ease);
  white-space: nowrap;
}
.vf-nerve-cta:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(2, 2, 12, 0.35);
}
.vf-nerve-cta:active {
  transform: translateY(0) scale(0.98);
}
.vf-nerve-cta.critical {
  background: linear-gradient(135deg, #ef4444, #dc2626);
  box-shadow: 0 2px 8px rgba(2, 2, 12, 0.25);
}
.vf-nerve-cta.critical:hover {
  box-shadow: 0 4px 16px rgba(2, 2, 12, 0.35);
}
.vf-nerve-cta.warning {
  background: linear-gradient(135deg, #f59e0b, #d97706);
  box-shadow: 0 2px 8px rgba(2, 2, 12, 0.25);
}
.vf-nerve-cta.warning:hover {
  box-shadow: 0 4px 16px rgba(2, 2, 12, 0.35);
}
.vf-nerve-cta.ready {
  background: linear-gradient(135deg, var(--accent), var(--brand-strong));
}

/* ── Secondary issues — compact subordinate list ── */
.vf-nerve-secondary {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.vf-nerve-minor {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  border-radius: 8px;
  font-size: 0.78rem;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.01);
  border: 1px solid rgba(155, 163, 175, 0.05);
  transition: background 0.2s var(--ease), border-color 0.2s var(--ease);
}
.vf-nerve-minor:hover {
  background: rgba(255, 255, 255, 0.03);
  border-color: rgba(155, 163, 175, 0.1);
}
.vf-nerve-minor-icon {
  font-size: 0.85rem;
  width: 18px;
  text-align: center;
  flex-shrink: 0;
}
.vf-nerve-minor.critical .vf-nerve-minor-icon { color: #f87171; }
.vf-nerve-minor.warning .vf-nerve-minor-icon  { color: #fbbf24; }
.vf-nerve-minor-text {
  flex: 1;
  font-weight: 500;
  color: var(--ink);
}
.vf-nerve-minor-action {
  flex-shrink: 0;
  padding: 3px 12px;
  font-size: 0.68rem;
  font-weight: 600;
  font-family: var(--font-body);
  color: var(--muted);
  background: transparent;
  border: 1px solid rgba(155, 163, 175, 0.12);
  border-radius: 6px;
  cursor: pointer;
  transition: all var(--speed) var(--ease);
}
.vf-nerve-minor-action:hover {
  color: var(--accent);
  border-color: rgba(155, 163, 175, 0.2);
  background: rgba(255, 255, 255, 0.04);
}

/* ── Launch Strip — Job ID input inside nerve center ── */
.vf-nerve-launch {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 36px 18px;
  border-top: 1px solid rgba(155, 163, 175, 0.06);
  transition: opacity 0.3s var(--ease);
}
.vf-nerve-input-wrap {
  flex: 1;
  position: relative;
}
.vf-nerve-launch input {
  width: 100%;
  padding: 12px 16px;
  font-size: 0.88rem;
  font-family: var(--font-body);
  color: var(--ink-strong);
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(155, 163, 175, 0.10);
  border-radius: 5px;
  outline: none;
  transition: border-color 0.2s var(--ease), background 0.2s var(--ease);
}
.vf-nerve-launch input:focus {
  border-color: rgba(44, 125, 255, 0.3);
  background: rgba(255, 255, 255, 0.05);
}
.vf-nerve-launch input::placeholder {
  color: var(--muted);
}
.vf-nerve-go {
  flex-shrink: 0;
  padding: 12px 32px;
  font-size: 0.78rem;
  font-weight: 700;
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #fff;
  background: var(--accent);
  border: none;
  border-radius: 5px;
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(2, 2, 12, 0.30);
  transition: all 0.2s var(--ease);
  white-space: nowrap;
}
.vf-nerve-go:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(2, 2, 12, 0.35);
}
.vf-nerve-go:active:not(:disabled) {
  transform: translateY(0) scale(0.98);
}
.vf-nerve-go--sm {
  padding: 8px 20px;
  font-size: 0.78rem;
}

/* ── SYSTEM LOCK — when blocked, lock the launch strip ── */
.vf-locked {
  opacity: 0.25;
  pointer-events: none;
  filter: grayscale(0.5);
}
.vf-locked input,
.vf-locked button {
  cursor: not-allowed !important;
}

/* ── Nerve Footer — compact summary ── */
.vf-nerve-footer {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  padding: 12px 36px 16px;
  border-top: 1px solid rgba(155, 163, 175, 0.06);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  color: var(--muted);
}
.vf-resume-inline {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-left: auto;
}

/* ── Recent audits dimming when system broken ── */
.vf-dimmed {
  opacity: 0.45;
  pointer-events: none;
  transition: opacity 0.4s var(--ease);
}
.vf-dimmed::after {
  content: "Resolve system issues above to continue";
  display: block;
  text-align: center;
  font-size: 0.75rem;
  color: var(--muted);
  margin-top: 12px;
  font-style: italic;
  pointer-events: all;
}
.vf-status-indicator {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.8rem;
  color: var(--ink);
}
.vf-status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--muted);
  flex-shrink: 0;
  transition: background var(--speed) var(--ease), box-shadow var(--speed) var(--ease);
}
.vf-status-dot.active {
  background: var(--success);
  box-shadow: 0 0 6px rgba(95, 150, 52, 0.5);
}
.vf-status-dot.warning {
  background: var(--warning);
  box-shadow: 0 0 6px rgba(184, 133, 24, 0.5);
}
.vf-status-dot.error {
  background: var(--danger);
  box-shadow: 0 0 6px rgba(201, 75, 86, 0.5);
}
.vf-status-dot.neutral {
  background: var(--muted);
}

/* =====================================================================
   3. AI Copilot Sidebar
   ===================================================================== */
.vf-copilot {
  background: var(--surface);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  backdrop-filter: var(--glass-blur);
  box-shadow: var(--shadow-panel);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.vf-copilot-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 20px;
  border-bottom: 1px solid var(--line);
  font-family: var(--font-display);
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--ink-strong);
}
.vf-copilot-header svg,
.vf-copilot-header img {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}
.vf-copilot-body {
  flex: 1;
  overflow-y: auto;
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.vf-copilot-insight {
  background: var(--surface-soft);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px 12px 12px 16px;
  position: relative;
  overflow: hidden;
  transition: border-color var(--speed) var(--ease), box-shadow var(--speed) var(--ease);
}
.vf-copilot-insight:hover {
  border-color: var(--line-strong);
  box-shadow: var(--shadow-soft);
}
.vf-copilot-insight::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  background: var(--brand);
  border-radius: 4px 0 0 4px;
}
.vf-copilot-insight.info::before  { background: var(--brand); }
.vf-copilot-insight.warn::before  { background: var(--warning); }
.vf-copilot-insight.alert::before { background: var(--danger); }
.vf-copilot-insight.tip::before   { background: var(--success); }

.vf-copilot-insight-icon {
  font-size: 1rem;
  margin-bottom: 6px;
}
.vf-copilot-insight-text {
  font-size: 0.8rem;
  color: var(--ink);
  line-height: 1.5;
  margin-bottom: 8px;
}
.vf-copilot-insight-action {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--brand);
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  transition: color var(--speed) var(--ease);
}
.vf-copilot-insight-action:hover {
  color: var(--brand-strong);
}
.vf-copilot-actions {
  padding: 12px;
  border-top: 1px solid var(--line);
  display: flex;
  gap: 8px;
}
.vf-copilot-actions button {
  flex: 1;
  padding: 8px 12px;
  font-size: 0.78rem;
  font-weight: 600;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--surface-soft);
  color: var(--ink);
  cursor: pointer;
  transition: all var(--speed) var(--ease);
}
.vf-copilot-actions button:hover {
  background: var(--surface-strong);
  border-color: var(--line-strong);
  color: var(--ink-strong);
}
.vf-copilot-actions button:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}

/* =====================================================================
   4. Recent Audits Grid
   ===================================================================== */
.vf-recent-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
}
.vf-recent-card {
  background: var(--surface);
  border: 1px solid var(--glass-border);
  border-radius: 8px;
  backdrop-filter: var(--glass-blur);
  padding: 16px;
  transition: transform var(--speed) var(--ease), box-shadow var(--speed) var(--ease), border-color var(--speed) var(--ease);
}
.vf-recent-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow);
  border-color: var(--line-strong);
}
.vf-recent-card:focus-within {
  border-color: var(--brand);
  box-shadow: 0 0 0 2px var(--brand-soft);
}
.vf-recent-site {
  font-weight: 600;
  color: var(--ink-strong);
  font-size: 0.9rem;
  margin-bottom: 6px;
  line-height: 1.3;
}
.vf-recent-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  color: var(--muted);
  font-size: 0.75rem;
  margin-bottom: 12px;
}
.vf-recent-score {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--ink-strong);
  margin-bottom: 12px;
  line-height: 1;
}
/* (recent-actions buttons removed — actions moved to Reports/Manager tabs) */

/* =====================================================================
   5. Photo Viewer
   ===================================================================== */
.vf-photo-viewer {
  width: 100%;
  min-height: 500px;
  background: var(--bg-top);
  border-radius: 12px;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.vf-photo-canvas {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  cursor: grab;
  position: relative;
}
.vf-photo-canvas:active {
  cursor: grabbing;
}
.vf-photo-canvas img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  user-select: none;
  -webkit-user-drag: none;
}
.vf-photo-toolbar {
  position: absolute;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--surface);
  border: 1px solid var(--glass-border);
  backdrop-filter: var(--glass-blur);
  border-radius: 12px;
  padding: 8px 12px;
  display: flex;
  align-items: center;
  gap: 8px;
  box-shadow: var(--shadow-panel);
  z-index: 10;
}
.vf-photo-zoom-btn {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--surface-soft);
  color: var(--ink);
  cursor: pointer;
  font-size: 1rem;
  transition: all var(--speed) var(--ease);
}
.vf-photo-zoom-btn:hover {
  background: var(--surface-strong);
  border-color: var(--line-strong);
  color: var(--ink-strong);
}
.vf-photo-zoom-btn:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}
.vf-photo-verdict-btn {
  padding: 8px 20px;
  font-size: 0.85rem;
  font-weight: 700;
  border-radius: 8px;
  border: none;
  cursor: pointer;
  color: #fff;
  transition: all var(--speed) var(--ease);
}
.vf-photo-verdict-btn.pass {
  background: var(--success);
  box-shadow: 0 0 16px rgba(95, 150, 52, 0.35);
}
.vf-photo-verdict-btn.pass:hover {
  box-shadow: 0 0 24px rgba(95, 150, 52, 0.55);
}
.vf-photo-verdict-btn.fail {
  background: var(--danger);
  box-shadow: 0 0 16px rgba(201, 75, 86, 0.35);
}
.vf-photo-verdict-btn.fail:hover {
  box-shadow: 0 0 24px rgba(201, 75, 86, 0.55);
}
.vf-photo-verdict-btn.na {
  background: var(--warning);
  box-shadow: 0 0 16px rgba(184, 133, 24, 0.35);
}
.vf-photo-verdict-btn.na:hover {
  box-shadow: 0 0 24px rgba(184, 133, 24, 0.55);
}
.vf-photo-verdict-btn.save {
  background: var(--brand);
  box-shadow: 0 0 16px rgba(44, 125, 255, 0.35);
}
.vf-photo-verdict-btn.save:hover {
  box-shadow: 0 0 24px rgba(44, 125, 255, 0.55);
}
.vf-photo-verdict-btn:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 2px;
}
.vf-photo-nav {
  position: absolute;
  top: 16px;
  right: 16px;
  display: flex;
  align-items: center;
  gap: 8px;
  z-index: 10;
}
.vf-photo-counter {
  font-family: var(--font-mono);
  font-size: 0.8rem;
  color: var(--ink);
  background: var(--surface);
  border: 1px solid var(--glass-border);
  backdrop-filter: var(--glass-blur);
  border-radius: 100px;
  padding: 4px 14px;
  box-shadow: var(--shadow-soft);
}
.vf-photo-prev,
.vf-photo-next {
  width: 34px;
  height: 34px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  border: 1px solid var(--glass-border);
  background: var(--surface);
  backdrop-filter: var(--glass-blur);
  color: var(--ink);
  cursor: pointer;
  font-size: 0.9rem;
  box-shadow: var(--shadow-soft);
  transition: all var(--speed) var(--ease);
}
.vf-photo-prev:hover,
.vf-photo-next:hover {
  background: var(--surface-strong);
  border-color: var(--line-strong);
  color: var(--ink-strong);
}
.vf-photo-prev:focus-visible,
.vf-photo-next:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}

@media (max-width: 768px) {
  .vf-photo-viewer {
    min-height: 350px;
  }
  .vf-photo-toolbar {
    left: 8px;
    right: 8px;
    transform: none;
    flex-wrap: wrap;
    justify-content: center;
  }
}

/* =====================================================================
   6. AI Inspection Panel
   ===================================================================== */
.vf-inspection {
  width: 360px;
  background: var(--surface);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  backdrop-filter: var(--glass-blur);
  box-shadow: var(--shadow-panel);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.vf-inspection-verdict {
  text-align: center;
  padding: 24px 20px 16px;
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 700;
}
.vf-inspection-verdict.pass  { color: var(--success); }
.vf-inspection-verdict.fail  { color: var(--danger); }
.vf-inspection-verdict.warn  { color: var(--warning); }

.vf-inspection-confidence {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 0 20px 16px;
}
.vf-inspection-confidence-ring {
  width: 48px;
  height: 48px;
  position: relative;
}
.vf-inspection-confidence-ring svg {
  width: 100%;
  height: 100%;
  transform: rotate(-90deg);
}
.vf-inspection-confidence-ring .ring-bg {
  fill: none;
  stroke: var(--line);
  stroke-width: 4;
}
.vf-inspection-confidence-ring .ring-fill {
  fill: none;
  stroke: var(--brand);
  stroke-width: 4;
  stroke-linecap: round;
  transition: stroke-dashoffset var(--speed) var(--ease);
}
.vf-inspection-confidence-value {
  font-family: var(--font-mono);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--ink-strong);
}

.vf-inspection-reasoning {
  padding: 0 20px 20px;
  font-size: 0.8rem;
  color: var(--ink);
  line-height: 1.6;
  flex: 1;
  overflow-y: auto;
}

.vf-inspection-actions {
  padding: 12px 16px;
  border-top: 1px solid var(--line);
  display: flex;
  gap: 8px;
}
.vf-inspect-accept,
.vf-inspect-override {
  flex: 1;
  padding: 9px 14px;
  font-size: 0.8rem;
  font-weight: 600;
  border-radius: 8px;
  cursor: pointer;
  background: transparent;
  transition: all var(--speed) var(--ease);
}
.vf-inspect-accept {
  border: 1px solid var(--success);
  color: var(--success);
}
.vf-inspect-accept:hover {
  background: rgba(95, 150, 52, 0.1);
}
.vf-inspect-override {
  border: 1px solid var(--warning);
  color: var(--warning);
}
.vf-inspect-override:hover {
  background: rgba(184, 133, 24, 0.1);
}
.vf-inspect-accept:focus-visible,
.vf-inspect-override:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}

@media (max-width: 1100px) {
  .vf-inspection {
    width: 100%;
  }
}

/* =====================================================================
   7. Audit Workspace
   ===================================================================== */
.vf-audit-workspace {
  display: grid;
  grid-template-columns: 1fr 360px;
  grid-template-rows: 1fr auto;
  gap: 0;
  min-height: 0;
}
.vf-audit-workspace > .vf-photo-viewer {
  grid-column: 1;
  grid-row: 1;
  border-radius: 12px 0 0 0;
}
.vf-audit-workspace > .vf-inspection {
  grid-column: 2;
  grid-row: 1;
  border-radius: 0 12px 0 0;
  width: auto;
}
.vf-audit-nav {
  grid-column: 1 / -1;
  grid-row: 2;
  background: var(--surface);
  border: 1px solid var(--glass-border);
  backdrop-filter: var(--glass-blur);
  border-radius: 0 0 12px 12px;
  box-shadow: var(--shadow-panel);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.vf-audit-progress {
  width: 100%;
  height: 4px;
  background: var(--line);
  overflow: hidden;
}
.vf-audit-progress-fill {
  height: 100%;
  background: var(--brand);
  border-radius: 0 2px 2px 0;
  transition: width var(--speed) var(--ease);
}
.vf-audit-nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 16px;
  gap: 12px;
}
.vf-audit-nav-btn {
  padding: 7px 16px;
  font-size: 0.8rem;
  font-weight: 600;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--surface-soft);
  color: var(--ink);
  cursor: pointer;
  transition: all var(--speed) var(--ease);
}
.vf-audit-nav-btn:hover {
  background: var(--surface-strong);
  border-color: var(--line-strong);
  color: var(--ink-strong);
}
.vf-audit-nav-btn:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}
.vf-audit-jump {
  padding: 6px 12px;
  font-size: 0.78rem;
  font-family: var(--font-mono);
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--surface-soft);
  color: var(--ink);
  cursor: pointer;
  transition: all var(--speed) var(--ease);
  appearance: none;
  -webkit-appearance: none;
}
.vf-audit-jump:hover {
  border-color: var(--line-strong);
}
.vf-audit-jump:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}

@media (max-width: 1100px) {
  .vf-audit-workspace {
    grid-template-columns: 1fr;
    grid-template-rows: minmax(350px, 1fr) auto auto;
  }
  .vf-audit-workspace > .vf-photo-viewer {
    grid-column: 1;
    border-radius: 12px 12px 0 0;
  }
  .vf-audit-workspace > .vf-inspection {
    grid-column: 1;
    grid-row: 2;
    border-radius: 0;
    width: 100%;
  }
  .vf-audit-nav {
    grid-column: 1;
    grid-row: 3;
    border-radius: 0 0 12px 12px;
  }
}

/* =====================================================================
   8. Quick Stats Row
   ===================================================================== */
.vf-stats-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.vf-stat-card {
  background: var(--surface);
  border: 1px solid var(--glass-border);
  border-radius: 8px;
  backdrop-filter: var(--glass-blur);
  padding: 16px 20px;
  flex: 1;
  min-width: 140px;
  transition: border-color var(--speed) var(--ease), box-shadow var(--speed) var(--ease);
}
.vf-stat-card:hover {
  border-color: var(--line-strong);
  box-shadow: var(--shadow-soft);
}
.vf-stat-value {
  font-family: var(--font-display);
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--ink-strong);
  line-height: 1.1;
  margin-bottom: 4px;
}
.vf-stat-label {
  font-size: 0.7rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  line-height: 1.4;
}
.vf-stat-delta {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 600;
  margin-top: 4px;
  padding: 1px 6px;
  border-radius: 100px;
}
.vf-stat-delta.positive {
  color: var(--success);
  background: rgba(95, 150, 52, 0.1);
}
.vf-stat-delta.negative {
  color: var(--danger);
  background: rgba(201, 75, 86, 0.1);
}

@media (max-width: 768px) {
  .vf-stats-row {
    gap: 8px;
  }
  .vf-stat-card {
    min-width: 120px;
    padding: 12px 14px;
  }
  .vf-stat-value {
    font-size: 1.4rem;
  }
}


/* =====================================================================
   9. PHASE 2 — VISUAL HIERARCHY & LIFE
   Command center dominance, breathing indicators, visual weight
   ===================================================================== */

/* ── (old hero overrides removed — nerve center styles in section 2) ── */

/* ── Primary CTA Glow — "Start Audit" demands attention ── */
.vf-hero-btn.primary {
  padding: 12px 32px;
  font-size: 0.82rem;
  font-weight: 700;
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  border-radius: 5px;
  border: none;
  cursor: pointer;
  color: #fff;
  background: var(--accent);
  box-shadow: 0 2px 8px rgba(2, 2, 12, 0.30);
  transition: all 0.25s var(--ease);
  position: relative;
  overflow: hidden;
}
.vf-hero-btn.primary::after {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: 7px;
  background: linear-gradient(135deg, rgba(44, 125, 255, 0.15), transparent 60%);
  opacity: 0;
  transition: opacity 0.3s var(--ease);
  z-index: -1;
}
.vf-hero-btn.primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(2, 2, 12, 0.35);
}
.vf-hero-btn.primary:hover::after {
  opacity: 1;
}
.vf-hero-btn.primary:active {
  transform: translateY(0);
}

/* Secondary hero buttons */
.vf-hero-btn.secondary,
.vf-hero-btn.accent {
  padding: 10px 24px;
  font-size: 0.76rem;
  font-weight: 600;
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  border-radius: 5px;
  cursor: pointer;
  transition: all var(--speed) var(--ease);
}
.vf-hero-btn.secondary {
  background: transparent;
  border: 1px solid var(--line-strong);
  color: var(--ink);
}
.vf-hero-btn.secondary:hover {
  background: var(--surface-button);
  border-color: var(--accent);
  color: var(--ink-strong);
}
.vf-hero-btn.accent {
  background: rgba(44, 125, 255, 0.12);
  border: 1px solid rgba(44, 125, 255, 0.22);
  color: var(--accent);
}
.vf-hero-btn.accent:hover {
  background: rgba(44, 125, 255, 0.18);
  border-color: rgba(44, 125, 255, 0.35);
}

/* ── Status dots breathe when active ── */
@keyframes vf-breathe {
  0%, 100% { box-shadow: 0 0 4px currentColor; opacity: 1; }
  50%      { box-shadow: 0 0 10px currentColor; opacity: 0.8; }
}
.vf-status-dot.active {
  animation: vf-breathe 3s ease-in-out infinite;
  color: rgba(95, 150, 52, 0.5);
}

/* ── Stat Cards — Add top accent bars + depth ── */
.vf-stat-card {
  position: relative;
  overflow: hidden;
  padding: 20px 22px;
  border-radius: 12px;
  transition: border-color var(--speed) var(--ease), box-shadow var(--speed) var(--ease), transform var(--speed) var(--ease);
}
.vf-stat-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--brand), transparent);
  border-radius: 12px 12px 0 0;
}
.vf-stat-card:nth-child(2)::before {
  background: linear-gradient(90deg, var(--success), transparent);
}
.vf-stat-card:nth-child(3)::before {
  background: linear-gradient(90deg, var(--warning), transparent);
}
.vf-stat-card:nth-child(4)::before {
  background: linear-gradient(90deg, var(--danger), transparent);
}
.vf-stat-card:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-soft);
}
.vf-stat-value {
  font-size: 2rem;
  margin-bottom: 6px;
}

/* ── (Copilot sidebar merged into Nerve Center) ── */

/* ── Recent cards — severity accent on left border ── */
.vf-recent-card {
  position: relative;
  overflow: hidden;
  border-radius: 12px;
  padding: 18px 20px;
}
.vf-recent-card::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  bottom: 8px;
  width: 3px;
  border-radius: 0 2px 2px 0;
  background: var(--brand);
}
.vf-recent-card[data-severity="pass"]::before { background: var(--success); }
.vf-recent-card[data-severity="fail"]::before { background: var(--danger); }
.vf-recent-card[data-severity="review"]::before { background: var(--warning); }

/* ── Section headers — uppercase label treatment ── */
.vf-section-title {
  font-family: var(--font-display);
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
}
.vf-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}

/* ── Launch bar subordination — compact, not competing with hero ── */
.launch-bar {
  padding: 10px 14px 8px;
  border-radius: 12px;
  background: var(--surface-strong);
  border: 1px solid rgba(155, 163, 175, 0.08);
  box-shadow: 0 8px 24px rgba(2, 2, 12, 0.2);
}

/* ── Resume card treatment ── */
.vf-resume-card {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 14px 18px;
  border-radius: 10px;
  margin-top: 16px;
}
.vf-resume-site {
  font-weight: 600;
  color: var(--ink-strong);
  font-size: 0.88rem;
}
.vf-resume-progress {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: var(--muted);
  margin-left: auto;
}

/* ── Onboarding empty state ── */
.vf-onboarding {
  text-align: center;
  padding: 48px 32px;
  border: 2px dashed rgba(44, 125, 255, 0.15);
  border-radius: 16px;
  background: radial-gradient(ellipse at center, rgba(44, 125, 255, 0.04) 0%, transparent 70%);
}
.vf-onboarding-title {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--ink-strong);
  margin-bottom: 8px;
}
.vf-onboarding-text {
  font-size: 0.85rem;
  color: var(--muted);
  line-height: 1.6;
  max-width: 420px;
  margin: 0 auto 20px;
}
.vf-onboarding-steps {
  display: flex;
  gap: 24px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 24px;
}
.vf-onboard-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  min-width: 120px;
}
.vf-onboard-step-num {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--brand-soft);
  color: var(--accent);
  font-family: var(--font-display);
  font-size: 0.85rem;
  font-weight: 700;
  border: 1px solid rgba(44, 125, 255, 0.22);
}
.vf-onboard-step-label {
  font-size: 0.78rem;
  color: var(--ink);
  font-weight: 500;
}
.vf-step-done .vf-onboard-step-num {
  background: rgba(95, 150, 52, 0.15);
  color: #79BF43;
  border-color: rgba(95, 150, 52, 0.3);
}
.vf-step-done .vf-onboard-step-label {
  color: var(--muted);
  text-decoration: line-through;
  text-decoration-color: rgba(155, 163, 175, 0.3);
}

/* ── Audit empty state polish ── */
.audit-empty-state {
  background: linear-gradient(180deg, var(--surface-strong), var(--surface));
  border: var(--glass-border);
  backdrop-filter: var(--glass-blur);
  box-shadow: var(--shadow-panel);
}
.audit-empty-state h2 {
  font-family: var(--font-display);
}
.audit-empty-state .launch-go {
  display: inline-block;
}


/* =====================================================================
   10. PHASE 2.5 — SYSTEM PRESENCE & LIFE
   Micro-interactions, entrance animations, system state, depth
   ===================================================================== */

/* ── Entrance animations — panels fade/rise on mount ── */
@keyframes vf-enter-rise {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.vf-enter {
  animation: vf-enter-rise 0.5s var(--ease) both;
}
.vf-command-main > *:nth-child(1) { animation-delay: 0s; }
.vf-command-main > *:nth-child(2) { animation-delay: 0.08s; }
.vf-command-main > *:nth-child(3) { animation-delay: 0.14s; }
.vf-command-main > *:nth-child(4) { animation-delay: 0.2s; }
.vf-command-main > * {
  animation: vf-enter-rise 0.45s var(--ease) both;
}
/* copilot sidebar removed — merged into nerve center */

/* ── System state tag — top of hero ── */
.vf-hero-system-state {
  margin-bottom: 12px;
}
.vf-sys-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  border-radius: 100px;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.vf-sys-tag::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}
.vf-sys-ready {
  background: rgba(95, 150, 52, 0.1);
  color: #79BF43;
  border: 1px solid rgba(95, 150, 52, 0.2);
}
.vf-sys-ready::before {
  background: #79BF43;
  box-shadow: 0 0 6px rgba(95, 150, 52, 0.5);
  animation: vf-breathe 2.5s ease-in-out infinite;
  color: rgba(95, 150, 52, 0.5);
}
.vf-sys-active {
  background: rgba(44, 125, 255, 0.1);
  color: #2C7DFF;
  border: 1px solid rgba(44, 125, 255, 0.2);
}
.vf-sys-active::before {
  background: #2C7DFF;
  box-shadow: 0 0 6px rgba(44, 125, 255, 0.5);
  animation: vf-breathe 1.5s ease-in-out infinite;
  color: rgba(44, 125, 255, 0.5);
}
.vf-sys-warning {
  background: rgba(184, 133, 24, 0.1);
  color: #fbbf24;
  border: 1px solid rgba(184, 133, 24, 0.2);
}
.vf-sys-warning::before {
  background: #fbbf24;
  box-shadow: 0 0 6px rgba(184, 133, 24, 0.5);
}

/* ── Hero summary line ── */
.vf-hero-summary {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.vf-summary-item {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--muted);
  letter-spacing: 0.01em;
}
.vf-summary-sep {
  color: rgba(155, 163, 175, 0.3);
  font-size: 0.9rem;
}

/* ── Status indicators — enhanced with state labels ── */
.vf-status-indicator {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px 5px 8px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(155, 163, 175, 0.06);
  transition: border-color var(--speed) var(--ease), background var(--speed) var(--ease);
}
.vf-status-indicator:hover {
  border-color: rgba(155, 163, 175, 0.12);
  background: rgba(255, 255, 255, 0.03);
}
.vf-status-label {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--ink);
}
.vf-status-state {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* ── Panel depth system — elevation layers ── */
.vf-stats-row {
  z-index: 2;
  position: relative;
}
.vf-recent-section {
  z-index: 1;
  position: relative;
}

/* ── Micro-interactions — hover lift + glow on all interactive panels ── */
.vf-nerve:hover {
  border-color: rgba(155, 163, 175, 0.12);
}
.glass-panel {
  transition: border-color 0.25s var(--ease), box-shadow 0.25s var(--ease), transform 0.25s var(--ease);
}

/* ── Click feedback — quick compress on interactive elements ── */
.vf-hero-btn:active,
.vf-stat-card:active,
.vf-recent-card:active,
.vf-copilot-insight:active {
  transform: scale(0.98);
  transition-duration: 0.08s;
}

/* ── Copilot thinking state ── */
@keyframes vf-copilot-think {
  0%   { opacity: 0.4; }
  50%  { opacity: 1; }
  100% { opacity: 0.4; }
}
.vf-copilot-thinking {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  font-size: 0.78rem;
  color: var(--muted);
  font-style: italic;
}
.vf-copilot-thinking-dots {
  display: flex;
  gap: 3px;
}
.vf-copilot-thinking-dots span {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--brand);
  animation: vf-copilot-think 1.4s ease-in-out infinite;
}
.vf-copilot-thinking-dots span:nth-child(2) { animation-delay: 0.2s; }
.vf-copilot-thinking-dots span:nth-child(3) { animation-delay: 0.4s; }

/* ── Insight entrance — each insight slides in ── */
@keyframes vf-insight-enter {
  from { opacity: 0; transform: translateX(-8px); }
  to   { opacity: 1; transform: translateX(0); }
}
.vf-copilot-insight {
  animation: vf-insight-enter 0.35s var(--ease) both;
}
.vf-copilot-body .vf-copilot-insight:nth-child(1) { animation-delay: 0.05s; }
.vf-copilot-body .vf-copilot-insight:nth-child(2) { animation-delay: 0.12s; }
.vf-copilot-body .vf-copilot-insight:nth-child(3) { animation-delay: 0.19s; }
.vf-copilot-body .vf-copilot-insight:nth-child(4) { animation-delay: 0.26s; }
.vf-copilot-body .vf-copilot-insight:nth-child(5) { animation-delay: 0.33s; }

/* ── Copilot timestamp ── */
.vf-copilot-insight-time {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  color: rgba(138, 145, 161, 0.5);
  margin-top: 6px;
}

/* ── (hero-content/hero-text replaced by nerve-body) ── */


/* =====================================================================
   11. PHASE 3 — DIRECTIVE SYSTEM / DECISION ENGINE
   Urgency states, contextual hero, system tension, action-driven UI
   ===================================================================== */

/* ── System tag — CRITICAL (red pulse) + IDLE (dim) ── */
.vf-sys-critical {
  background: rgba(239, 68, 68, 0.06);
  color: #f87171;
  border: 1px solid rgba(239, 68, 68, 0.15);
}
.vf-sys-critical::before {
  background: #ef4444;
  box-shadow: none;
  animation: vf-breathe 1s ease-in-out infinite;
}
.vf-sys-idle {
  background: rgba(155, 163, 175, 0.06);
  color: #6b7280;
  border: 1px solid rgba(155, 163, 175, 0.1);
}
.vf-sys-idle::before {
  background: #6b7280;
  box-shadow: 0 0 3px rgba(155, 163, 175, 0.25);
}

/* ── Urgency pulse for critical nerve center ── */
@keyframes vf-pulse-urgent {
  0%, 100% { box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.15); }
  50%      { box-shadow: 0 0 0 4px rgba(239, 68, 68, 0); }
}
.vf-nerve--critical .vf-sys-tag {
  animation: vf-pulse-urgent 2s ease-in-out infinite;
}
.vf-nerve--critical {
  border-color: rgba(155, 163, 175, 0.08) !important;
  border-left: 3px solid #ef4444 !important;
  background-image: none !important;
}
.vf-nerve--active {
  border-color: rgba(155, 163, 175, 0.1) !important;
  border-left: 3px solid var(--brand) !important;
}
.vf-nerve--idle {
  border-color: rgba(155, 163, 175, 0.08) !important;
  background-image:
    radial-gradient(ellipse 60% 80% at 50% 50%, rgba(155, 163, 175, 0.03) 0%, transparent 70%) !important;
}
.vf-nerve--idle .vf-nerve-title {
  color: var(--muted);
}

/* ── Summary item urgency coloring (set by JS) ── */
.vf-summary-item[style*="color: var(--danger)"] {
  font-weight: 600;
}

/* ── Hero actions layout ── */
.vf-hero-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 8px;
}
