:root {
  --bg-top: #08111d;
  --bg-mid: #0d1625;
  --bg-bottom: #111f31;
  --surface: rgba(11, 22, 37, 0.72);
  --surface-strong: rgba(16, 28, 45, 0.88);
  --surface-soft: rgba(14, 24, 38, 0.84);
  --surface-card: linear-gradient(180deg, rgba(20, 34, 54, 0.92), rgba(11, 22, 37, 0.84));
  --surface-card-soft: linear-gradient(180deg, rgba(16, 30, 48, 0.84), rgba(10, 20, 34, 0.78));
  --surface-button: rgba(255, 255, 255, 0.08);
  --surface-button-strong: rgba(255, 255, 255, 0.12);
  --input-bg: rgba(255, 255, 255, 0.08);
  --preview-bg: linear-gradient(180deg, rgba(8, 15, 26, 0.92), rgba(12, 23, 38, 0.86));
  --ink: #bdd2ea;
  --ink-strong: #f7fbff;
  --muted: #8ea7c4;
  --line: rgba(189, 210, 234, 0.14);
  --line-strong: rgba(189, 210, 234, 0.22);
  --brand: #2f6fb2;
  --brand-strong: #204f87;
  --brand-soft: rgba(47, 111, 178, 0.16);
  --accent: #d73745;
  --accent-soft: rgba(215, 55, 69, 0.12);
  --success: #228a5b;
  --success-soft: rgba(34, 138, 91, 0.14);
  --warning: #b88518;
  --warning-soft: rgba(184, 133, 24, 0.15);
  --danger: #c94b56;
  --danger-soft: rgba(201, 75, 86, 0.15);
  --shadow: 0 28px 80px rgba(2, 8, 16, 0.38);
  --shadow-soft: 0 12px 32px rgba(2, 8, 16, 0.26);
}

body[data-theme="light"] {
  --bg-top: #edf3fa;
  --bg-mid: #f8fbff;
  --bg-bottom: #e7eef8;
  --surface: rgba(255, 255, 255, 0.72);
  --surface-strong: rgba(255, 255, 255, 0.84);
  --surface-soft: rgba(245, 249, 255, 0.78);
  --surface-card: linear-gradient(180deg, rgba(255, 255, 255, 0.82), rgba(244, 249, 255, 0.72));
  --surface-card-soft: linear-gradient(180deg, rgba(255, 255, 255, 0.88), rgba(247, 250, 255, 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(239, 245, 252, 0.96), rgba(226, 236, 248, 0.9));
  --ink: #20476e;
  --ink-strong: #153754;
  --muted: #5f7490;
  --line: rgba(32, 71, 110, 0.12);
  --line-strong: rgba(32, 71, 110, 0.22);
  --brand: #1f5a94;
  --brand-strong: #174678;
  --brand-soft: rgba(31, 90, 148, 0.1);
  --shadow: 0 28px 80px rgba(16, 44, 71, 0.12);
  --shadow-soft: 0 12px 32px rgba(16, 44, 71, 0.08);
}

* {
  box-sizing: border-box;
}

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

body {
  font-family: "SF Pro Display", "SF Pro Text", "Segoe UI", sans-serif;
  color: var(--ink);
  background-color: var(--bg-bottom);
  background-image:
    radial-gradient(circle at top left, rgba(47, 111, 178, 0.24), transparent 28%),
    radial-gradient(circle at top right, rgba(215, 55, 69, 0.18), transparent 24%),
    radial-gradient(circle at bottom right, rgba(215, 55, 69, 0.08), transparent 30%),
    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.1), transparent 14%),
    radial-gradient(circle at 84% 8%, rgba(215, 55, 69, 0.1), transparent 16%),
    radial-gradient(circle at 78% 78%, rgba(47, 111, 178, 0.12), transparent 18%);
}

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

h1 {
  font-size: clamp(1.15rem, 1.6vw, 1.35rem);
  line-height: 1.15;
  letter-spacing: -0.03em;
  text-wrap: balance;
}

h2 {
  font-size: clamp(0.95rem, 1.3vw, 1.1rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
  text-wrap: balance;
}

h3 {
  font-size: 0.88rem;
  line-height: 1.2;
  letter-spacing: -0.02em;
}

.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:
    inset 0 0 80px rgba(215, 55, 69, 0.09),
    inset 0 0 180px rgba(215, 55, 69, 0.06),
    inset 0 0 400px rgba(215, 55, 69, 0.03);
  background:
    radial-gradient(ellipse at top right, rgba(215, 55, 69, 0.06), transparent 50%),
    radial-gradient(ellipse at bottom left, rgba(215, 55, 69, 0.04), transparent 50%),
    radial-gradient(ellipse at center, rgba(215, 55, 69, 0.015), transparent 70%);
}

.glass-panel {
  background: linear-gradient(180deg, var(--surface-strong), var(--surface));
  border: 1px solid var(--line);
  box-shadow: var(--shadow), 0 0 60px rgba(215, 55, 69, 0.018);
  backdrop-filter: blur(16px) saturate(140%);
}

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

.topbar {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  padding: 8px 14px;
}

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

.viaero-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}

.brand-mark {
  display: grid;
  place-items: center;
  width: clamp(180px, 18vw, 240px);
  min-height: 64px;
  padding: 14px 18px;
  border-radius: 10px;
  background: linear-gradient(140deg, rgba(18, 48, 78, 0.96), rgba(31, 90, 148, 0.92));
  border: 1px solid rgba(255, 255, 255, 0.18);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.16),
    0 10px 24px rgba(18, 48, 78, 0.22);
}

.viaero-logo {
  width: min(100%, 200px);
  height: auto;
  display: block;
}

.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(31, 90, 148, 0.12);
  background: rgba(31, 90, 148, 0.08);
  color: var(--brand-strong);
  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(34, 138, 91, 0.2);
}

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

.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 walkthrough steps */
.intake-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  padding: 10px 0 6px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 10px;
}
.intake-step {
  display: flex;
  gap: 8px;
  align-items: flex-start;
  padding: 8px 10px;
  border-radius: 6px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--line);
  transition: border-color 0.2s, background 0.2s;
}
.intake-step.is-active {
  border-color: var(--accent, #3b82f6);
  background: rgba(59,130,246,0.08);
}
.intake-step.is-done {
  border-color: var(--green, #34d399);
  background: rgba(52,211,153,0.06);
}
.intake-step.is-done .intake-step-num {
  background: var(--green, #34d399);
}
.intake-step-num {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--accent, #3b82f6);
  color: #fff;
  font-size: 0.7rem;
  font-weight: 700;
  display: grid;
  place-items: center;
  line-height: 1;
}
.intake-step-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.intake-step-text strong {
  font-size: 0.75rem;
  color: var(--ink-strong);
}
.intake-step-text small {
  font-size: 0.68rem;
  color: var(--muted);
  line-height: 1.4;
}
.intake-step-text kbd {
  display: inline-block;
  padding: 1px 4px;
  border-radius: 3px;
  background: rgba(255,255,255,0.1);
  border: 1px solid var(--line);
  font-family: inherit;
  font-size: 0.65rem;
}
.intake-step-text em {
  font-style: normal;
  color: var(--accent, #3b82f6);
  font-weight: 600;
}
/* intake-steps responsive — handled in consolidated responsive section */

/* Intake action row — buttons with step numbers */
.intake-action-row {
  display: flex;
  gap: 6px;
  align-items: center;
}
.btn-step-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: rgba(255,255,255,0.15);
  font-size: 0.65rem;
  font-weight: 700;
  line-height: 1;
  margin-right: 2px;
  flex-shrink: 0;
}

.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;
}

.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: 520px;
  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, #3b82f6);
  line-height: 1;
}

.preview-placeholder-link {
  display: inline-block;
  margin-top: 6px;
  padding: 6px 14px;
  border-radius: 6px;
  background: var(--accent, #3b82f6);
  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, 20, 35, 0.96), rgba(16, 46, 81, 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(34, 138, 91, 0.12);
  border-color: rgba(34, 138, 91, 0.3);
  box-shadow: 0 0 12px rgba(34, 138, 91, 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-body {
  display: grid;
  place-items: center;
  padding: 24px;
}

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

.login-panel {
  padding: 26px;
}

.login-form {
  display: grid;
  gap: 14px;
  margin-top: 22px;
}

.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;
}

.preview-stage-body.show-pathwave {
  grid-template-columns: 1fr 1fr;
}

.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;
}

.preview-pathwave-side {
  border-left: 1px solid var(--line);
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 0;
  padding: 0;
  background: var(--surface);
  overflow: hidden;
}

.preview-pathwave-side .preview-frame-header {
  padding: 8px 12px;
  border-bottom: 1px solid var(--line);
}

.pathwave-live-frame {
  position: relative;
  min-height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.pathwave-live-frame .preview-placeholder {
  padding: 24px;
  color: var(--muted);
  text-align: center;
  font-size: 0.82rem;
  line-height: 1.5;
}

.pathwave-iframe {
  width: 100%;
  height: 100%;
  border: none;
  position: absolute;
  inset: 0;
}

/* ── Audit Companion Panel (right side of preview stage) ── */
.ac-panel {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 16px 14px;
  width: 100%;
  height: 100%;
  overflow-y: auto;
}
.ac-counter {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
}
.ac-counter-num {
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--ink-strong, #f7fbff);
  letter-spacing: -0.02em;
}
.ac-rs {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--accent, #3b82f6);
  background: rgba(59,130,246,0.12);
  padding: 2px 8px;
  border-radius: 4px;
}
.ac-desc {
  font-size: 0.85rem;
  color: var(--ink, #d0dbe8);
  line-height: 1.4;
}
.ac-divider {
  height: 1px;
  background: var(--line, rgba(255,255,255,0.06));
  margin: 2px 0;
}
.ac-section-label {
  font-size: 0.68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted, #8899aa);
}
.ac-logic {
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}
.ac-logic-header {
  display: flex;
  align-items: center;
  gap: 10px;
}
.ac-verdict {
  font-size: 0.82rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 4px;
  background: var(--surface-strong, rgba(30,42,56,0.95));
  color: var(--ink, #d0dbe8);
}
.ac-verdict--pass {
  background: rgba(52,199,89,0.15);
  color: #34c759;
}
.ac-verdict--deny {
  background: rgba(255,59,48,0.15);
  color: #ff3b30;
}
.ac-confidence {
  font-size: 0.75rem;
  color: var(--muted, #8899aa);
}
.ac-note {
  font-size: 0.8rem;
  color: var(--ink, #d0dbe8);
  line-height: 1.5;
  background: var(--surface-strong, rgba(30,42,56,0.95));
  padding: 10px 12px;
  border-radius: 6px;
  border-left: 3px solid var(--accent, #3b82f6);
}
.ac-punches {
  font-size: 0.78rem;
  color: #ff9f0a;
  line-height: 1.4;
}
.ac-punches strong {
  color: var(--muted, #8899aa);
}
.ac-logic--waiting {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.ac-waiting-msg {
  font-size: 0.8rem;
  color: var(--muted, #8899aa);
  text-align: center;
  line-height: 1.5;
}
.ac-open-tab {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.76rem;
  color: var(--accent, #3b82f6);
  text-decoration: none;
  align-self: center;
  padding: 4px 0;
}
.ac-open-tab:hover {
  text-decoration: underline;
}
.ac-ready-badge {
  display: inline-block;
  padding: 4px 12px;
  border-radius: 4px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  background: rgba(52,199,89,0.15);
  color: #34c759;
  align-self: flex-start;
}
.ac-site-summary {
  display: flex;
  flex-direction: column;
  gap: 3px;
  font-size: 0.78rem;
  line-height: 1.4;
}
.ac-site-row {
  color: var(--ink, #d0dbe8);
}
.ac-site-label {
  color: var(--muted, #8899aa);
  font-weight: 600;
  margin-right: 4px;
}
.ac-site-label::after {
  content: ":";
}

.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(52,199,89,0.08) 0%, rgba(52,199,89,0.02) 100%); border-color: rgba(52,199,89,0.2); }
.an-kpi--positive::before { background: linear-gradient(135deg, rgba(52,199,89,0.12), transparent 60%); }
.an-kpi--positive:hover { box-shadow: 0 4px 20px rgba(52,199,89,0.12); }
.an-kpi--positive .an-kpi-val { color: #34c759; }
.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(52,199,89,0.15); color: #34c759; }
.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(52,199,89,0.06) 0%, transparent 60%); border-color: rgba(52,199,89,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(52,199,89,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(52,199,89,0.15); color: #34c759; }
.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: #34c759; }
.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, #34c759, #30d158); }
.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, #0a84ff, #409cff); 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: #34c759; box-shadow: 0 0 6px rgba(52,199,89,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(52,199,89,0.12); color: #34c759; }
.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: #34c759; }
.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(52,199,89,0.06); color: #34c759; }
.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: #3b82f6;
  --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: #22c55e;
  --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(.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(.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(.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,24,38,0.98), rgba(12,18,30,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,24,38,0.98), rgba(12,18,30,0.98));
  border: 1px solid var(--v2-border-strong);
  box-shadow: 0 24px 80px rgba(0,0,0,0.4);
}

/* ---------------------------------------------------------------------------
   30. Login Panel
   --------------------------------------------------------------------------- */
.login-panel {
  background: var(--v2-surface);
  border: 1px solid var(--v2-border);
}

.login-form input[type="text"],
.login-form input[type="password"] {
  height: 44px;
  border-radius: var(--v2-radius-md);
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
}

.login-form input:focus {
  border-color: var(--v2-primary);
  box-shadow: var(--v2-primary-glow);
  outline: none;
}

.login-form button {
  height: 44px;
  font-size: 0.88rem;
  font-weight: 600;
}

.login-note {
  border-radius: var(--v2-radius-md);
  border-color: rgba(59,130,246,0.15);
  background: var(--v2-primary-soft);
}

.login-error {
  border-radius: var(--v2-radius-md);
  border-color: rgba(239,68,68,0.15);
  background: var(--v2-danger-soft);
}

.login-links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-size: 0.8rem;
}
.login-links a {
  color: var(--v2-primary);
  text-decoration: none;
  opacity: 0.85;
  transition: opacity 0.15s;
}
.login-links a:hover { opacity: 1; text-decoration: underline; }
.login-link-sep { color: var(--muted); opacity: 0.4; }

.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
   --------------------------------------------------------------------------- */
.tab-panel:not(#view-dashboard) .intake-step {
  background: var(--v2-surface);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-md);
}

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

.tab-panel:not(#view-dashboard) .intake-step.is-done {
  border-color: var(--v2-success);
  background: var(--v2-success-soft);
}

/* ---------------------------------------------------------------------------
   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, #60a5fa, #3b82f6); }
.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: #60a5fa; 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: #60a5fa; }
.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); }

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

/* Agent responsive — in consolidated section */


/* ═══════════════════════════════════════════════════════════════════
   PATHWAVE TAB — Form grid, log stream, scorecard, pipeline flow
   ═══════════════════════════════════════════════════════════════════ */

/* Form grid */
.pw-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px 14px;
  margin-bottom: 14px;
}
.pw-field { display: flex; flex-direction: column; gap: 4px; }
.pw-field--url { grid-column: 1 / -1; }
.pw-field--sm { max-width: 8rem; }
.pw-field-label {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-2, #8899aa);
}
.pw-input {
  padding: 8px 12px;
  border-radius: 8px;
  border: 1px solid var(--line, rgba(255,255,255,.08));
  background: var(--surface-1, rgba(255,255,255,.04));
  color: var(--text-1, #e8eaed);
  font-size: 0.85rem;
  font-family: inherit;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.pw-input:focus {
  outline: none;
  border-color: var(--accent, #60a5fa);
  box-shadow: 0 0 0 2px rgba(96, 165, 250, 0.15);
}
.pw-input::placeholder { color: var(--text-3, rgba(255,255,255,.25)); }
select.pw-input { cursor: pointer; }

/* Batch controls */
.pw-batch-controls {
  display: flex;
  gap: 16px;
  align-items: flex-end;
  margin-bottom: 14px;
  flex-wrap: wrap;
}
.pw-checkbox-field {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.82rem;
  color: var(--text-2, #8899aa);
  cursor: pointer;
  padding-bottom: 4px;
}
.pw-checkbox-field input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--accent, #60a5fa);
  cursor: pointer;
}

/* Log stream */
.pw-log-stream {
  display: none;
  max-height: 22rem;
  overflow-y: auto;
  font-size: 0.78rem;
  font-family: 'JetBrains Mono', 'Fira Code', 'Cascadia Code', monospace;
  line-height: 1.55;
  background: var(--surface-0, rgba(0,0,0,.25));
  border: 1px solid var(--line, rgba(255,255,255,.06));
  border-radius: 10px;
  padding: 12px 14px;
  margin-top: 8px;
}
.pw-log-stream > div {
  padding: 2px 0;
  border-bottom: 1px solid rgba(255,255,255,.03);
}
.pw-log-stream > div:last-child { border-bottom: none; }

/* Progress bar area */
.pw-progress-bar:not(:empty) {
  padding: 6px 0;
  font-size: 0.82rem;
  font-weight: 500;
}

/* 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; }

/* 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)); }
  .intake-steps { grid-template-columns: repeat(4, 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)); }
  .pw-form-grid { grid-template-columns: 1fr 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); }

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

  /* 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; }

  /* Pathwave form: still 2-col on iPad */
  .pw-form-grid { grid-template-columns: 1fr 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%; }
  .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-body.show-pathwave { grid-template-columns: 1fr; }
  .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; }
  .viaero-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;
  }

  /* Steps: single column */
  .intake-steps { grid-template-columns: 1fr; }
  .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; }

  /* Pathwave form: single column */
  .pw-form-grid { grid-template-columns: 1fr; }
  .pw-field--sm { max-width: none; }
  .pw-batch-controls { flex-direction: column; align-items: stretch; }

  /* 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-body.show-pathwave { grid-template-columns: 1fr; }
  .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; }
}
