/* 
   ==========================================================================
   QA-INSIGHT: ENTERPRISE AUDIT INTELLIGENCE CONSOLE
   Lead Product Engineer Redesign (B2B SaaS / Data-Heavy)
   "Modern Console" Aesthetic - Desktop Only (Min 1280px)
   ========================================================================== 
*/

:root {
  /* --- Enterprise Color Palette --- */
  --slate-950: #020617;
  --slate-900: #0f172a; /* Deep Slate */
  --slate-800: #1e293b;
  --slate-700: #334155;
  --slate-600: #475569;
  --slate-500: #64748b;
  --slate-400: #94a3b8;
  --slate-300: #cbd5e1;
  --slate-200: #e2e8f0;
  --slate-100: #f1f5f9;
  --slate-50:  #f8fafc;
  
  --blue-500:  #3b82f6;
  --blue-600:  #2563eb; /* High-Contrast Action Blue */
  --blue-700:  #1d4ed8;
  --blue-50:   #eff6ff;
  --blue-100:  #dbeafe;
  --blue-200:  #bfdbfe;

  --red-600:   #dc2626;
  --red-700:   #b91c1c;
  --red-50:    #fef2f2;
  --red-100:   #fee2e2;
  
  --gray-50:   #f8fafc; /* Page Background */
  --gray-100:  #f1f5f9;
  --gray-200:  #e2e8f0; /* Border Gray */
  --gray-300:  #cbd5e1;
  
  --white:     #ffffff; /* Content Cards */
  --surface:   var(--white);
  --border:    var(--gray-200);
  
  /* --- Metrics & Shadows --- */
  --radius:    6px;
  --radius-md: 8px;
  --r-sm:      5px;
  --r:         8px;
  --r-md:      10px;
  --r-lg:      14px;
  --r-xl:      20px;
  --radius-lg: 12px;
  --radius-xl: 20px;
  --shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, 0.06), 0 1px 2px -1px rgba(0, 0, 0, 0.04);
  --shadow-md: 0 4px 8px -2px rgba(0, 0, 0, 0.08), 0 2px 4px -2px rgba(0, 0, 0, 0.04);
  --shadow-lg: 0 10px 20px -4px rgba(0, 0, 0, 0.08), 0 4px 8px -4px rgba(0, 0, 0, 0.04);
  --shadow-xl: 0 20px 30px -8px rgba(0, 0, 0, 0.1), 0 8px 16px -8px rgba(0, 0, 0, 0.06);
  --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.18);
  --shadow-card: 0 1px 4px 0 rgba(15, 23, 42, 0.06);
  --sidebar-w: 240px;

  /* --- Neutral aliases (missing from templates) --- */
  --n-50:      var(--slate-50);
  --n-100:     var(--slate-100);
  --n-200:     var(--slate-200);
  --n-300:     var(--slate-300);
  --text-2:    var(--slate-700);
  --text-muted: var(--slate-500);

  /* --- Typography --- */
  --font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --font-mono: "SFMono-Regular", Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  
  /* Density-optimized font sizes */
  --text-xs:   11px;
  --text-sm:   12px;
  --text-base: 13px;
  --text-lg:   15px;

  /* Semantic Mappings */
  --primary:   var(--blue-600);
  --bg:        var(--gray-50);
  --text:      var(--slate-900);
  --text-soft: var(--slate-600);
  --muted:     var(--slate-500);
  
  --critical:  #dc2626;
  --serious:   #ea580c;
  --moderate:  #d97706;
  --minor:     #059669;
  --success:   var(--minor);
  --danger:    var(--red-600);
  --warning:   var(--serious);
  --info:      var(--blue-600);
  --accent:    var(--primary);
  --secondary: var(--slate-600);
  --severity-danger: var(--danger);
  --severity-warning: var(--warning);
  --severity-warning-light: var(--moderate);
  --severity-info: var(--info);
  --severity-secondary: var(--secondary);
  --severity-accent: var(--accent);
  --severity-success: var(--success);
  --severity-danger-bg: var(--red-50);
  --severity-danger-border: var(--red-100);
  --severity-warning-bg: color-mix(in srgb, var(--severity-warning) 12%, var(--white));
  --severity-warning-border: color-mix(in srgb, var(--severity-warning) 28%, var(--white));
  --severity-warning-light-bg: color-mix(in srgb, var(--severity-warning-light) 12%, var(--white));
  --severity-warning-light-border: color-mix(in srgb, var(--severity-warning-light) 28%, var(--white));
  --severity-info-bg: var(--blue-50);
  --severity-info-border: color-mix(in srgb, var(--severity-info) 28%, var(--white));
  --severity-secondary-bg: var(--gray-100);
  --severity-secondary-border: var(--gray-200);
  --severity-accent-bg: color-mix(in srgb, var(--severity-accent) 12%, var(--white));
  --severity-accent-border: color-mix(in srgb, var(--severity-accent) 28%, var(--white));
  --severity-success-bg: color-mix(in srgb, var(--severity-success) 12%, var(--white));
  --severity-success-border: color-mix(in srgb, var(--severity-success) 28%, var(--white));
}

/* --- Base & Reset --- */
* { 
  box-sizing: border-box; 
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  margin: 0;
  padding: 0;
  font-family: var(--font-sans);
  background-color: var(--gray-50);
  color: var(--text);
  font-size: var(--text-base);
  line-height: 1.5;
  min-width: 1280px; /* Fixed-width desktop constraint */
  overflow-x: auto;
}

button, input, select, textarea {
  font-family: inherit;
  font-size: inherit;
}

/* --- App Shell (Grid Layout) --- */
#app {
  display: grid;
  grid-template-areas: "sidebar main";
  grid-template-columns: var(--sidebar-w) 1fr;
  min-height: 100vh;
}

/* --- Sidebar (Mapped to .header) --- */
.header {
  grid-area: sidebar;
  background-color: var(--white);
  color: var(--slate-900);
  height: 100vh;
  position: sticky;
  top: 0;
  padding: 28px 0 24px;
  display: flex;
  flex-direction: column;
  border-right: 1px solid var(--gray-200);
  z-index: 100;
}

.header-left {
  padding: 0 22px;
  margin-bottom: 52px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.header-logo {
  height: 30px;
  max-width: 160px;
  width: auto;
  align-self: flex-start;
  object-fit: contain;
}

.header-title {
  display: block;
  max-width: 170px;
  font-size: 12px;
  line-height: 1.35;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--blue-600);
}

.header-chip {
  font-size: 10px;
  background: var(--gray-100);
  color: var(--slate-500);
  padding: 2px 8px;
  border-radius: 99px;
  width: fit-content;
  border: 1px solid var(--gray-200);
}

.header-right {
  display: flex;
  flex-direction: column;
  flex: 1;
}

.header-nav {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 0 12px;
}

.nav-link {
  display: flex;
  align-items: center;
  padding: 10px 12px;
  color: var(--slate-600);
  text-decoration: none;
  font-weight: 500;
  font-size: var(--text-base);
  border-radius: var(--radius);
  transition: all 0.15s ease;
  background: transparent;
  border: none;
  width: 100%;
  text-align: left;
  cursor: pointer;
}

.nav-link svg {
  margin-right: 12px;
  opacity: 0.7;
}

.nav-link:hover { 
  color: var(--blue-600); 
  background: var(--blue-50); 
}

.nav-link.active { 
  color: var(--white); 
  background: var(--blue-600); 
  font-weight: 600;
}

.nav-link.active svg { opacity: 1; }

.header-divider {
  height: 1px;
  background: var(--gray-200);
  margin: 14px 20px 12px;
}

.auth-btn {
  margin: 0 12px;
  background: var(--gray-50);
  border: 1px solid var(--gray-200);
  color: var(--slate-600);
  padding: 10px 12px;
  font-size: var(--text-xs);
  font-weight: 600;
  border-radius: var(--radius);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 10px;
  transition: all 0.2s;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.auth-btn:hover { 
  background: var(--gray-100); 
  color: var(--slate-900); 
}

.auth-dot { 
  width: 6px; 
  height: 6px; 
  background: var(--blue-600); 
  border-radius: 50%; 
  box-shadow: 0 0 8px var(--blue-600);
}

/* --- Main Content Area --- */
.main {
  grid-area: main;
  padding: 32px 40px;
  overflow-y: auto;
  max-width: 1440px; /* Comfortable reading width while min is 1280 */
}

/* --- Breadcrumbs (Tree-view Logic) --- */
.content-header {
  margin-bottom: 24px;
}

.breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: var(--text-sm);
  color: var(--muted);
}

.breadcrumb-item { 
  cursor: pointer; 
  transition: color 0.2s;
}

.breadcrumb-item:hover { color: var(--blue-600); }

.breadcrumb-item:last-child {
  font-weight: 600;
  color: var(--text);
  cursor: default;
}

.breadcrumb-item.breadcrumb-link {
  cursor: pointer;
}

.breadcrumb-item.breadcrumb-link:last-child {
  color: var(--muted);
  cursor: pointer;
}

.breadcrumb-item.breadcrumb-link:last-child:hover {
  color: var(--blue-600);
}

.breadcrumb-current {
  font-weight: 600;
  color: var(--text);
  cursor: default;
}

.breadcrumb-current:hover {
  color: var(--text);
}

.breadcrumb-sep { 
  color: var(--gray-200); 
  font-family: var(--font-mono);
}

/* --- Audit Cards --- */
.dash-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
  gap: 16px;
}

.pagination-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: 18px;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: var(--r);
  background: var(--white);
  box-shadow: var(--shadow-card);
}

.pagination-summary {
  color: var(--slate-500);
  font-size: 12px;
  font-weight: 700;
}

.pagination-controls {
  display: flex;
  align-items: center;
  gap: 6px;
}

.pagination-btn,
.pagination-page {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 30px;
  padding: 0 10px;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--white);
  color: var(--slate-700);
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
}

.pagination-btn:hover:not(:disabled),
.pagination-page:hover {
  border-color: var(--blue-200);
  background: var(--blue-50);
  color: var(--blue-700);
}

.pagination-page.active {
  border-color: var(--blue-600);
  background: var(--blue-600);
  color: var(--white);
}

.pagination-btn:disabled {
  opacity: .45;
  cursor: not-allowed;
}

.dash-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 20px;
  box-shadow: var(--shadow-card);
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
  display: flex;
  flex-direction: column;
  position: relative;
}

.dash-card:hover {
  border-color: var(--blue-600);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
  transform: translateY(-1px);
}

.dash-card.selected {
  border-color: var(--blue-600);
  background: var(--blue-50);
}

.dash-check {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 16px;
  height: 16px;
  accent-color: var(--blue-600);
  cursor: pointer;
}

.dash-score {
  width: 40px;
  height: 40px;
  border-radius: 6px;
  border: 1px solid var(--gray-200);
  background: var(--gray-50);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
  font-weight: 700;
}

.dash-info {
  flex: 1;
}

.dash-site-name {
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--slate-900);
  margin-bottom: 2px;
  display: block;
}

.dash-status {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 12px;
}

.dash-status-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--slate-300); }
.dash-status.done { color: var(--success); }
.dash-status.done .dash-status-dot { background: #22c55e; }
.dash-status.running { color: var(--blue-600); }
.dash-status.running .dash-status-dot { background: var(--blue-600); animation: pulse 1.5s infinite; }

.dash-date {
  font-size: var(--text-xs);
  color: var(--muted);
  margin-bottom: 16px;
}

.dash-progress-track {
  width: 100%;
  height: 4px;
  background: var(--gray-100);
  border-radius: 2px;
  overflow: hidden;
  margin: 12px 0;
}

.dash-progress-fill {
  height: 100%;
  background: var(--blue-600);
}

.dash-progress-meta {
  font-size: 11px;
  font-weight: 600;
  color: var(--slate-500);
  display: flex;
  justify-content: space-between;
}

.dash-sev {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 12px;
}

.dash-sev-item {
  font-size: 10px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 4px;
  background: var(--gray-100);
  color: var(--slate-600);
  border: 1px solid transparent;
}

.dash-sev-item.critical { background: var(--severity-danger-bg); color: var(--severity-danger); border-color: var(--severity-danger-border); }
.dash-sev-item.serious  { background: var(--severity-warning-bg); color: var(--severity-warning); border-color: var(--severity-warning-border); }
.dash-sev-item.moderate { background: var(--severity-warning-light-bg); color: var(--severity-warning-light); border-color: var(--severity-warning-light-border); }
.dash-sev-item.minor    { background: var(--severity-info-bg); color: var(--severity-info); border-color: var(--severity-info-border); }
.dash-sev-item.manual-review,
.dash-sev-item.manual { background: var(--severity-secondary-bg); color: var(--severity-secondary); border-color: var(--severity-secondary-border); }
.dash-sev-item.alert { background: var(--severity-accent-bg); color: var(--severity-accent); border-color: var(--severity-accent-border); }
.dash-sev-item.visual-total { background: var(--slate-100); color: var(--slate-700); border-color: var(--border); }

.dash-actions {
  display: flex;
  gap: 8px;
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--gray-100);
}

/* --- Data Tables (Zebra-striped, Sticky, High Density) --- */
.table-container {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm); /* 12px for high density */
  text-align: left;
}

th {
  background: var(--gray-50);
  color: var(--slate-600);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 10px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 10;
}

td {
  padding: 10px 16px;
  border-bottom: 1px solid var(--gray-100);
  vertical-align: middle;
}

tr:nth-child(even) { background-color: #fafbfd; }
tr:hover { background-color: var(--blue-50); }

/* --- Tree-view / URL Management (Monospace) --- */
.vr-acc-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.vr-acc-item {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}

.vr-acc-header {
  display: flex;
  align-items: center;
  padding: 9px 14px;
  cursor: pointer;
  gap: 12px;
  transition: background 0.1s;
}

.vr-acc-header:hover { background: var(--gray-50); }

.vr-acc-index {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--muted);
  width: 20px;
}

.vr-acc-meta { flex: 1; min-width: 0; }

.vr-acc-path {
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 13px;
  color: var(--slate-900);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.vr-acc-fullurl {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.vr-acc-vp-pills {
  display: flex;
  gap: 4px;
}

.vr-acc-vp-pill {
  font-size: 10px;
  font-weight: 700;
  padding: 2px 6px;
  background: var(--gray-100);
  color: var(--slate-600);
  border-radius: 3px;
}

.cmp-url-body {
  border-top: 1px solid var(--border);
  background: var(--slate-50);
}

.compare-entry {
  background: var(--white);
  border-bottom: 1px solid var(--border);
}

.compare-entry:last-child {
  border-bottom: 0;
}

.compare-entry.selected {
  box-shadow: inset 3px 0 0 var(--primary);
}

.compare-entry-header {
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
  padding: 7px 12px;
  cursor: pointer;
}

.compare-entry-header:hover {
  background: var(--gray-50);
}

.compare-entry-vp {
  flex-shrink: 0;
  font-size: 12px;
  font-weight: 700;
  color: var(--slate-700);
}

.compare-entry-sel {
  min-width: 0;
  max-width: 260px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--muted);
  background: var(--gray-100);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 2px 6px;
}

.compare-entry-chevron,
.vr-acc-chevron {
  flex-shrink: 0;
  display: inline-flex;
  transition: transform .15s ease;
}

.compare-entry-chevron.open,
.vr-acc-chevron.open {
  transform: rotate(180deg);
}

.compare-entry-body {
  padding: 10px 12px 12px;
  border-top: 1px solid var(--gray-100);
  background: #fff;
}

.compare-entry-warning {
  margin-top: 10px;
  padding: 10px 12px;
  border: 1px solid #fed7aa;
  border-radius: 6px;
  background: #fff7ed;
  color: #9a3412;
  font-size: 12px;
  line-height: 1.45;
}

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

.cmp-strip-panel {
  position: relative;
  display: block;
  min-width: 0;
  height: auto;
  overflow: auto;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--slate-950);
  cursor: zoom-in;
  max-height: none;
}

.cmp-strip-panel:hover {
  border-color: var(--primary);
}

.cmp-strip-panel.empty {
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: default;
  background: repeating-linear-gradient(
    45deg,
    #f8fafc,
    #f8fafc 10px,
    #f1f5f9 10px,
    #f1f5f9 20px
  );
}

.cmp-strip-panel.empty:hover {
  border-color: var(--border);
}

.cmp-strip-empty {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.cmp-strip-label {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 1;
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(15, 23, 42, .78);
  color: #fff;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0;
}

.cmp-strip-label.diff {
  background: rgba(124, 58, 237, .85);
}

.cmp-strip-img {
  display: block;
  width: 100%;
  height: auto;
  min-height: 0;
  object-fit: contain;
  object-position: top center;
  background: var(--slate-950);
}

.cmp-selected-viewport {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 3px 10px;
  border-radius: 999px;
  border: 1px solid #bfdbfe;
  background: #eff6ff;
  color: #1d4ed8;
  font-weight: 800;
}

.compare-entry.selected .cmp-selected-viewport {
  border-color: #93c5fd;
  background: #dbeafe;
  color: #1e40af;
}

.compare-review-panel {
  display: grid;
  grid-template-columns: minmax(180px, 240px) minmax(0, 1fr);
  gap: 14px;
  align-items: start;
  margin-top: 12px;
  padding: 14px;
  border: 1px solid #dbeafe;
  background: linear-gradient(180deg, #f8fbff 0%, #ffffff 100%);
  border-radius: 10px;
}

.compare-review-field {
  min-width: 0;
}

.compare-entry-status,
.compare-entry-description {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  color: var(--slate-800);
  font: inherit;
  font-size: 13px;
  outline: none;
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}

.compare-entry-status {
  height: 36px;
  padding: 0 10px;
  font-weight: 800;
}

.compare-entry-status.pass {
  border-color: #86efac;
  background: #f0fdf4;
  color: #166534;
}

.compare-entry-status.fail {
  border-color: #fecaca;
  background: #fef2f2;
  color: #991b1b;
}

.compare-entry-description {
  min-height: 74px;
  resize: vertical;
  padding: 10px 12px;
  line-height: 1.45;
}

.compare-entry-description.readonly {
  white-space: pre-wrap;
  resize: none;
  background: #fff;
}

.review-status-line {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.issue-note-meta {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid #bfdbfe;
  background: #eff6ff;
  color: #1d4ed8;
  font-size: 10px;
  font-weight: 900;
}

.empty-note {
  color: var(--muted);
  font-style: italic;
}

.compare-entry-status:focus,
.compare-entry-description:focus {
  border-color: var(--blue-500);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, .12);
}

@media (max-width: 900px) {
  .compare-review-panel {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .cmp-strip {
    grid-template-columns: 1fr;
  }
}

/* --- Comparison View (Side-by-Side Flex) --- */
.compare-container {
  display: flex;
  gap: 20px;
  align-items: flex-start;
  width: 100%;
}

.compare-panel {
  flex: 1;
  min-width: 0;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  display: flex;
  flex-direction: column;
}

.compare-panel-header {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
  background: var(--gray-50);
  font-weight: 700;
  font-size: var(--text-sm);
}

.cmp-report-heading {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 15px;
  color: var(--slate-950);
  font-size: 22px;
  font-weight: 900;
  line-height: 1.15;
  letter-spacing: 0;
}

.cmp-report-heading::before {
  content: "";
  width: 5px;
  height: 26px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--blue-500), #7c3aed);
  box-shadow: 0 0 0 4px rgba(59, 130, 246, .12);
  flex-shrink: 0;
}

.cmp-report-title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.cmp-report-title-row .cta-group {
  margin-left: auto;
  flex-shrink: 0;
}

.cta-group {
  display: flex;
  align-items: center;
  gap: 10px;
}

/* --- Buttons & Controls --- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 36px;
  padding: 0 16px;
  font-weight: 600;
  font-size: var(--text-sm);
  border-radius: var(--r);
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease, transform 0.1s ease;
  border: 1px solid var(--slate-200);
  gap: 7px;
  background: var(--white);
  color: var(--slate-700);
  white-space: nowrap;
  outline: none;
  box-shadow: 0 1px 2px rgba(15,23,42,0.06);
  line-height: 1;
  letter-spacing: 0.01em;
}

.btn svg {
  display: block;
  flex-shrink: 0;
}

.btn:hover:not(:disabled) {
  border-color: var(--slate-400);
  background: var(--gray-50);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.btn:active:not(:disabled) {
  transform: translateY(0);
  box-shadow: var(--shadow-sm);
}

.btn-primary {
  background: var(--blue-600);
  color: var(--white);
  border-color: var(--blue-700);
}

.btn-primary:hover:not(:disabled) {
  background: var(--blue-700);
  border-color: var(--blue-700);
}

.btn-danger {
  background: var(--red-600);
  color: var(--white);
  border-color: var(--red-700);
}

.btn-danger:hover:not(:disabled) {
  background: var(--red-700);
  border-color: var(--red-700);
}

.btn-danger-outline {
  background: var(--white);
  color: var(--red-600);
  border-color: var(--red-600);
}

.btn-danger-outline:hover:not(:disabled) {
  background: var(--red-600);
  color: var(--white);
  border-color: var(--red-700);
}

.btn-ghost {
  background: transparent;
  border-color: transparent;
  box-shadow: none;
}

.btn-ghost:hover:not(:disabled) {
  background: var(--gray-100);
  border-color: var(--slate-300);
}

.btn-ghost.btn-danger {
  background: transparent;
  border-color: transparent;
  color: var(--red-600);
}

.btn-ghost.btn-danger:hover:not(:disabled) {
  background: var(--red-50);
  border-color: var(--red-100);
  color: var(--red-700);
}

.btn-sm {
  height: 30px;
  padding: 0 12px;
  font-size: var(--text-xs);
}

/* --- Filter Tabs --- */
.compare-filter-tabs {
  display: flex;
  gap: 4px;
  background: var(--gray-100);
  padding: 4px;
  border-radius: 6px;
  width: fit-content;
  margin-bottom: 24px;
}

.cft-tab {
  padding: 6px 12px;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--slate-600);
  border-radius: 4px;
  cursor: pointer;
  border: none;
  background: transparent;
  transition: all 0.15s;
}

.cft-tab:hover { color: var(--slate-900); }
.cft-tab.active {
  background: var(--white);
  color: var(--blue-600);
  box-shadow: var(--shadow-sm);
}

/* --- Visual Elements --- */
/* --- Comparison Help Guide --- */
.vr-how-to {
  display: flex;
  align-items: center;
  gap: 16px;
  background: var(--blue-50);
  border: 1px solid var(--gray-200);
  padding: 12px 20px;
  border-radius: var(--radius);
}

.vr-how-to-step {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1;
}

.vr-how-to-num {
  width: 24px;
  height: 24px;
  background: var(--blue-600);
  color: var(--white);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 11px;
  flex-shrink: 0;
}

.vr-how-to-text {
  font-size: var(--text-sm);
  color: var(--slate-700);
  line-height: 1.4;
}

.vr-how-to-divider {
  width: 1px;
  height: 24px;
  background: var(--gray-200);
}

/* --- Sticky Comparison Action Bar --- */
.compare-bar {
  position: sticky;
  top: 16px;
  z-index: 50;
  background: var(--slate-900);
  color: var(--white);
  padding: 12px 20px;
  border-radius: var(--radius);
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 24px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}

.compare-bar-left {
  display: flex;
  align-items: center;
  gap: 16px;
  font-weight: 600;
  font-size: var(--text-sm);
}

.compare-bar-hint {
  color: var(--slate-400);
  font-weight: 400;
}

.cmp-sel-bar {
  position: sticky;
  bottom: 16px;
  z-index: 80;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 18px;
  padding: 12px 14px;
  border: 1px solid #bfdbfe;
  border-radius: 10px;
  background: rgba(239, 246, 255, .98);
  box-shadow: 0 16px 36px rgba(15, 23, 42, .16);
  backdrop-filter: blur(8px);
}

.cmp-sel-count {
  margin-right: auto;
  color: #1e3a8a;
  font-size: 13px;
  font-weight: 800;
}

.cmp-sel-clear,
.cmp-sel-btn,
.cmp-sel-ai-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 8px;
  border: 1px solid transparent;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
}

.cmp-sel-clear {
  background: #fff;
  border-color: #bfdbfe;
  color: #1d4ed8;
}

.cmp-sel-ai-btn {
  background: #0f172a;
  border-color: #0f172a;
  color: #fff;
}

.cmp-sel-ai-btn:disabled {
  opacity: .72;
  cursor: wait;
}

.cmp-sel-btn {
  background: #475569;
  color: #fff;
}

.cmp-gen-report-btn {
  background: var(--blue-600);
  border-color: var(--blue-700);
  color: #fff;
}

.ai-review-modal {
  border: 1px solid #ddd6fe;
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 24px 70px rgba(15, 23, 42, .22);
}

.ai-review-modal-title {
  color: #4c1d95;
}

.ai-review-modal-sub,
.ai-review-modal-count {
  color: var(--slate-600);
}

.ai-badge,
.diff-badge {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid var(--border);
  font-size: 10px;
  font-weight: 900;
  line-height: 1;
  white-space: nowrap;
}

.ai-badge.loading {
  background: #f5f3ff;
  border-color: #ddd6fe;
  color: #6d28d9;
}

.ai-badge.pass,
.diff-badge.ok {
  background: #f0fdf4;
  border-color: #bbf7d0;
  color: #166534;
}

.ai-badge.fail,
.diff-badge.changed {
  background: #fef2f2;
  border-color: #fecaca;
  color: #991b1b;
}

.ai-badge.error,
.diff-badge.error {
  background: #fff7ed;
  border-color: #fed7aa;
  color: #9a3412;
}

/* --- Badge & Tag refinements --- */
.scan-badge {
  font-size: 10px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 99px;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  background: var(--gray-100);
  color: var(--slate-600);
  border: 1px solid var(--gray-200);
}

.scan-badge.vr { background: #f5f3ff; color: #7c3aed; border-color: #ddd6fe; }
.scan-badge.accessibility { background: #eff6ff; color: #1d4ed8; border-color: #bfdbfe; }
.scan-badge.kbsr { background: #ecfeff; color: #0891b2; border-color: #a5f3fc; }
.scan-badge.security { background: #fff1f2; color: #e11d48; border-color: #fecdd3; }
.scan-badge.custom { background: var(--slate-900); color: var(--white); border-color: var(--slate-900); }

.saved-entry-env {
  font-size: 10px;
  font-weight: 700;
  background: var(--gray-100);
  color: var(--slate-500);
  padding: 1px 6px;
  border-radius: 4px;
  border: 1px solid var(--gray-200);
  text-transform: uppercase;
}

.selected-crawl-lock {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 10px;
  padding: 10px 12px;
  border: 1px solid var(--blue-200);
  border-radius: var(--r);
  background: var(--blue-50);
  color: var(--blue-700);
}

.selected-crawl-lock strong {
  display: block;
  font-size: 12px;
  line-height: 1.3;
}

.selected-crawl-lock span {
  display: block;
  margin-top: 2px;
  font-size: 11px;
  color: var(--slate-600);
}

/* --- Dashboard Card Overrides --- */
.dash-card {
  padding: 16px; /* Slightly tighter */
}

.dash-site-name {
  font-size: 14px;
  margin-bottom: 4px;
}

.dash-meta {
  font-size: 11px;
  color: var(--muted);
  margin-top: 8px;
}

.badge-clear {
  font-size: 10px;
  font-weight: 700;
  color: #15803d;
  background: #f0fdf4;
  padding: 2px 8px;
  border-radius: 4px;
}

.view-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 32px;
  border-bottom: 1px solid var(--gray-200);
  padding-bottom: 24px;
}

.view-title {
  font-size: 20px;
  font-weight: 800;
  letter-spacing: -0.01em;
  margin: 0;
}

.view-subtitle {
  font-size: var(--text-sm);
  color: var(--muted);
  margin-top: 4px;
}

.powered-by-tag {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-top: 7px;
  padding: 3px 9px;
  font-size: 11px;
  font-weight: 500;
  color: var(--slate-500);
  background: var(--slate-100);
  border: 1px solid var(--slate-200);
  border-radius: 99px;
  letter-spacing: 0.01em;
}

.powered-by-tag strong { font-weight: 700; color: var(--slate-700); }

.powered-by-tag svg { flex-shrink: 0; opacity: 0.7; }

.powered-by-accessibility { color: #1e40af; background: #eff6ff; border-color: #bfdbfe; }
.powered-by-accessibility strong { color: #1e40af; }

.powered-by-kbsr { color: #0e7490; background: #ecfeff; border-color: #a5f3fc; }
.powered-by-kbsr strong { color: #0e7490; }

.powered-by-visual { color: #6d28d9; background: #f5f3ff; border-color: #ddd6fe; }
.powered-by-visual strong { color: #6d28d9; }

.powered-by-security { color: #be123c; background: #fff1f2; border-color: #fecdd3; }
.powered-by-security strong { color: #be123c; }

.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 80px 40px;
  text-align: center;
  background: var(--white);
  border: 1px dashed var(--gray-200);
  border-radius: 8px;
}

.empty-state-icon {
  color: var(--gray-200);
  margin-bottom: 20px;
}

.empty-state-title {
  font-weight: 700;
  font-size: var(--text-lg);
  margin-bottom: 8px;
}

.empty-state-body {
  color: var(--muted);
  max-width: 400px;
  margin-bottom: 24px;
}

/* --- Summary Charts (Donuts) --- */
.summary-chart {
  display: flex;
  gap: 24px;
  align-items: center;
  padding: 24px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  margin-top: 24px;
}

.summary-chart-donut {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background: var(--chart-fill);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.summary-chart-hole {
  width: 80px;
  height: 80px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.summary-chart-total { font-size: 20px; font-weight: 800; color: var(--slate-900); }
.summary-chart-label { font-size: 9px; font-weight: 700; color: var(--muted); text-transform: uppercase; }

.summary-chart-meta { flex: 1; }
.summary-chart-title { font-weight: 700; font-size: var(--text-base); margin-bottom: 4px; }
.summary-chart-subtitle { font-size: var(--text-sm); color: var(--muted); margin-bottom: 16px; }

.summary-chart-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(140px, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}

.summary-chart-legend {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 8px;
}

.summary-chart-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 7px 9px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--gray-50);
}

.summary-chart-item-left {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.summary-chart-swatch {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  flex-shrink: 0;
}

.summary-chart-item-label {
  font-size: var(--text-sm);
  color: var(--slate-700);
  font-weight: 600;
}

.summary-chart-item-value {
  font-size: var(--text-sm);
  color: var(--slate-900);
  font-weight: 800;
}

.summary-chart-coverage {
  margin-top: 14px;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--gray-50);
}

.summary-chart-coverage-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}

.summary-chart-coverage-label {
  font-size: 12px;
  font-weight: 800;
  color: var(--slate-700);
}

.summary-chart-coverage-value {
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

.summary-chart-coverage-track {
  height: 8px;
  overflow: hidden;
  border-radius: 999px;
  background: var(--slate-200);
}

.summary-chart-coverage-fill {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #0ea5e9, #22c55e);
}

.summary-chart-coverage-note {
  margin-top: 8px;
  color: var(--slate-500);
  font-size: 12px;
  line-height: 1.45;
}

.kbsr-focus-coverage {
  background: #f8fafc;
  border-color: #cbd5e1;
}

.kbsr-details-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid #bae6fd !important;
  background: #f0f9ff !important;
  color: #0369a1 !important;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.01em;
}

.kbsr-details-btn:hover {
  background: #e0f2fe !important;
  border-color: #7dd3fc !important;
  color: #075985 !important;
}

.stat {
  display: flex;
  flex-direction: column;
}

.stat-n { font-size: 18px; font-weight: 800; color: var(--slate-900); }
/* --- Wizard Stepper --- */
.stepper {
  display: flex;
  align-items: center;
  gap: 0;
  margin-bottom: 32px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.step-item {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 14px 20px;
  background: var(--white);
  color: var(--slate-400);
  font-weight: 600;
  font-size: var(--text-sm);
  position: relative;
  border-right: 1px solid var(--border);
}

.step-item:last-child { border-right: none; }

.step-item.active {
  color: var(--blue-600);
  background: var(--blue-50);
}

.step-item.done {
  color: var(--slate-900);
}

.step-num {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--gray-100);
  color: var(--slate-400);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 800;
  border: 1px solid var(--gray-200);
}

.step-item.active .step-num {
  background: var(--blue-600);
  color: var(--white);
  border-color: var(--blue-700);
}

.step-item.done .step-num {
  background: var(--white);
  color: var(--blue-600);
  border-color: var(--blue-600);
}

/* --- Wizard Form Elements --- */
.wiz-section {
  margin-bottom: 32px;
}

.wiz-section-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--slate-900);
  margin-bottom: 8px;
  display: block;
}

.wiz-section-desc {
  font-size: var(--text-sm);
  color: var(--muted);
  margin-bottom: 20px;
  display: block;
}

.form-group {
  margin-bottom: 20px;
}

.label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--slate-500);
  margin-bottom: 6px;
}

.input, .select, .textarea {
  width: 100%;
  padding: 8px 12px;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius);
  font-size: var(--text-base);
  color: var(--slate-900);
  background: var(--white);
  transition: border-color 0.15s, box-shadow 0.15s;
}

.input:focus, .select:focus, .textarea:focus {
  outline: none;
  border-color: var(--blue-600);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

/* --- Schedule modal inputs (form-input) --- */
.form-input {
  width: 100%;
  height: 36px;
  padding: 8px 12px;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius);
  font-size: 13px;
  color: var(--slate-900);
  background: var(--white);
  transition: border-color 0.15s, box-shadow 0.15s;
}

.form-input:focus {
  outline: none;
  border-color: var(--blue-600);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

select.form-input {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding-right: 36px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 16px 16px;
}

select.form-input::-ms-expand { display: none; }

select.form-input:disabled,
input.form-input:disabled {
  background: var(--slate-50);
  color: var(--slate-500);
  cursor: not-allowed;
}

/* --- Wizard Specific List styles --- */
.saved-list {
  background: var(--gray-50);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius);
  overflow: hidden;
}

.saved-entry {
  display: flex;
  align-items: center;
  padding: 12px 16px;
  border-bottom: 1px solid var(--gray-200);
  background: var(--white);
}

.saved-entry:last-child { border-bottom: none; }

.saved-entry-info { flex: 1; min-width: 0; }

.saved-entry-top { display: flex; align-items: center; gap: 8px; margin-bottom: 2px; }

.saved-entry-name { font-weight: 700; font-size: var(--text-base); color: var(--slate-900); }

.saved-entry-meta { font-size: 11px; color: var(--muted); }

.saved-entry-file { font-family: var(--font-mono); font-size: 10px; color: var(--muted); }

/* --- Checkbox Group --- */
.check-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.check-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius);
  cursor: pointer;
  transition: all 0.15s;
}

.check-item:hover { border-color: var(--blue-600); background: var(--blue-50); }

.check-item.active {
  border-color: var(--blue-600);
  background: var(--blue-50);
}

.check-item input { margin: 0; accent-color: var(--blue-600); }

.check-label { font-weight: 600; font-size: var(--text-sm); }

/* --- Redesigned Console Settings --- */
.settings-container {
  display: flex;
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-lg);
  overflow: hidden;
  min-height: 600px;
  box-shadow: var(--shadow-sm);
}

.settings-sidebar {
  width: 240px;
  background: var(--gray-50);
  border-right: 1px solid var(--gray-200);
  display: flex;
  flex-direction: column;
  padding: 16px 0;
}

.settings-nav-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 20px;
  background: transparent;
  border: none;
  border-left: 3px solid transparent;
  color: var(--slate-600);
  font-size: 14px;
  font-weight: 600;
  text-align: left;
  cursor: pointer;
  transition: all 0.2s;
  width: 100%;
}

.settings-nav-item svg {
  color: var(--slate-400);
  transition: color 0.2s;
}

.settings-nav-item:hover {
  background: var(--gray-100);
  color: var(--slate-900);
}

.settings-nav-item.active {
  background: var(--white);
  color: var(--blue-600);
  border-left-color: var(--blue-600);
}

.settings-nav-item.active svg {
  color: var(--blue-600);
}

.sidebar-footer {
  margin-top: auto;
  padding: 16px 20px;
  border-top: 1px solid var(--gray-200);
}

.settings-main-content {
  flex: 1;
  padding: 40px;
  background: var(--white);
  overflow-y: auto;
}

.settings-section-header {
  margin-bottom: 32px;
}

.settings-section-title {
  font-size: 20px;
  font-weight: 800;
  color: var(--slate-900);
  margin-bottom: 8px;
}

.settings-section-desc {
  font-size: 14px;
  color: var(--muted);
  max-width: 600px;
}

.settings-card {
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius);
  padding: 24px;
  margin-bottom: 24px;
}

.header-row {
  display: flex;
  gap: 12px;
  margin-bottom: 12px;
  align-items: center;
}

.header-inputs {
  flex: 1;
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: 12px;
}

.btn-icon-del {
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  color: var(--slate-400);
  font-size: 20px;
  cursor: pointer;
  border-radius: 4px;
}

.btn-icon-del:hover {
  background: var(--red-50);
  color: var(--critical);
}

.interaction-row {
  display: flex;
  gap: 12px;
  margin-bottom: 12px;
  align-items: center;
}

.interaction-inputs {
  flex: 1;
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 12px;
}

.session-capture-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px;
  background: var(--gray-50);
  border-radius: var(--radius);
  border: 1px solid var(--gray-200);
}

.session-status {
  display: flex;
  align-items: center;
  gap: 10px;
}

.status-indicator {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--gray-300);
}

.status-indicator.active {
  background: var(--success);
  box-shadow: 0 0 8px var(--success);
}

.status-text {
  font-size: 14px;
  font-weight: 600;
  color: var(--slate-700);
}

.session-actions {
  display: flex;
  gap: 12px;
}

.saved-sessions-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.saved-session-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: var(--slate-50);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  transition: all 0.2s;
}

.saved-session-card:hover {
  border-color: var(--blue-300);
  background: var(--blue-50);
}

.saved-session-card.active {
  border-color: var(--blue-600);
  background: var(--blue-50);
  box-shadow: 0 0 0 1px var(--blue-600);
}

.saved-session-icon {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: var(--white);
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--slate-400);
  flex-shrink: 0;
}

.saved-session-card.active .saved-session-icon {
  color: var(--blue-600);
  border-color: var(--blue-200);
}

.saved-session-info {
  flex: 1;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 2px;
  overflow: hidden;
}

.saved-session-name {
  font-weight: 700;
  color: var(--slate-900);
  font-size: 13px;
}

.saved-session-meta {
  font-size: 11px;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

.viewport-group-container {
  background: var(--gray-50);
  padding: 24px;
  border-radius: var(--radius);
  border: 1px solid var(--gray-200);
}

.viewport-group-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
}

.viewport-group-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--slate-800);
}

.viewport-presets-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 16px;
}

.viewport-preset-card {
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius);
  padding: 16px;
  box-shadow: var(--shadow-sm);
}

.vp-preset-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}

.vp-preset-label {
  border: none;
  font-weight: 700;
  font-size: 13px;
  color: var(--slate-900);
  background: transparent;
  width: 100%;
}

.vp-preset-dims {
  display: flex;
  align-items: center;
  gap: 8px;
}

.vp-dim-input {
  width: 100%;
  padding: 6px 10px;
  border: 1px solid var(--gray-200);
  border-radius: 6px;
  font-size: 13px;
  font-weight: 600;
}

.vp-dim-x {
  color: var(--slate-400);
  font-size: 12px;
}

/* --- Wizard Step 2 Accordion & Hierarchy --- */
.group-accordion {
  display: flex;
  flex-direction: column;
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.accordion-item {
  display: flex;
  flex-direction: column;
  border-bottom: 1px solid var(--gray-100);
}

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

.accordion-row {
  display: flex;
  align-items: center;
  padding: 6px 12px;
  gap: 10px;
  cursor: pointer;
  transition: all 0.15s;
  font-size: 12px;
  min-height: 36px;
}

.accordion-row:hover {
  filter: brightness(0.98);
}

/* Level Colors (Strong to Light) */
.accordion-row.level-0 { background: var(--gray-100); border-bottom: 1px solid var(--gray-200); }
.accordion-row.level-1 { background: var(--gray-50); }
.accordion-row.level-2 { background: #fafafa; }
.accordion-row.level-3 { background: #ffffff; }

.accordion-row.selected {
  background: var(--blue-50) !important;
}

.accordion-indent {
  display: flex;
  align-self: stretch;
}

.indent-line {
  width: 16px;
  border-right: 1px solid var(--gray-200);
  margin-right: 4px;
}

.accordion-expander {
  width: 18px;
  height: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--slate-400);
  transition: transform 0.2s;
  cursor: pointer;
}

.accordion-expander.expanded {
  transform: rotate(90deg);
}

.accordion-label {
  flex: 1;
  font-weight: 600;
  color: var(--slate-900);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.accordion-row.is-header .accordion-label {
  font-weight: 700;
  color: var(--slate-700);
}

.accordion-meta {
  font-size: 10px;
  color: var(--muted);
  font-weight: 500;
  background: rgba(0,0,0,0.05);
  padding: 1px 6px;
  border-radius: 10px;
  margin-right: 8px;
}

.step-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--gray-200);
}

.scan-badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 700;
  border: 1.5px solid transparent;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.scan-badge.security { background: #fff1f2; color: #e11d48; border-color: #fecdd3; }
.scan-badge.vr { background: #f5f3ff; color: #7c3aed; border-color: #ddd6fe; }
.scan-badge.accessibility { background: #eff6ff; color: #1d4ed8; border-color: #bfdbfe; }
.scan-badge.kbsr { background: #ecfeff; color: #0891b2; border-color: #a5f3fc; }

.view-title {
  font-size: 20px;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--slate-900);
  margin: 0;
}

.view-subtitle {
  font-size: 13px;
  color: var(--slate-500);
  margin-top: 4px;
  line-height: 1.5;
}

.wizard-run-layout {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

/* --- Wizard Step 3 Header --- */
.wiz3-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 16px;
}

/* --- Step 3 scan type banner --- */
.wiz3-scan-banner {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: var(--slate-50);
  margin-bottom: 24px;
}

.wiz3-scan-banner.banner-accessibility { background: #eff6ff; border-color: #bfdbfe; }
.wiz3-scan-banner.banner-visual        { background: #f5f3ff; border-color: #ddd6fe; }
.wiz3-scan-banner.banner-kbsr          { background: #ecfeff; border-color: #a5f3fc; }
.wiz3-scan-banner.banner-security      { background: #fef2f2; border-color: #fecaca; }

.wiz3-banner-icon {
  width: 38px;
  height: 38px;
  border-radius: var(--r);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background: rgba(255,255,255,0.7);
}

.banner-accessibility .wiz3-banner-icon { color: #2563eb; }
.banner-visual        .wiz3-banner-icon { color: #7c3aed; }
.banner-kbsr          .wiz3-banner-icon { color: #0891b2; }
.banner-security      .wiz3-banner-icon { color: #dc2626; }

.wiz3-banner-copy {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.wiz3-banner-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--slate-900);
}

.wiz3-banner-desc {
  font-size: 12px;
  color: var(--slate-600);
  line-height: 1.45;
}

.wiz3-change-btn {
  flex-shrink: 0;
  border: 1px solid var(--slate-300) !important;
  background: var(--white) !important;
}

/* --- opts-panel / section --- */
.opts-panel {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.opts-section {
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--white);
  overflow: hidden;
}

.opts-section-icon.blue { background: #eff6ff; }
.opts-section-icon.purple { background: #f5f3ff; }
.opts-section-icon.red { background: #fef2f2; }
.opts-section-icon.gray { background: #f8fafc; }
.opts-section-icon.cyan { background: #ecfeff; }

/* --- KBSR check grid --- */
.kbsr-check-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 10px;
  margin-bottom: 16px;
}

.kbsr-check-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r);
}

.kbsr-check-item strong {
  display: block;
  font-size: 12px;
  font-weight: 700;
  color: var(--slate-900);
  margin-bottom: 2px;
}

.kbsr-check-item span {
  font-size: 11px;
  color: var(--muted);
  line-height: 1.45;
}

.kbsr-check-icon {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

/* --- KBSR desktop/mobile mode row --- */
.kbsr-mode-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.kbsr-mode-card {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  border-radius: var(--r);
  border: 1px solid var(--border);
}

.kbsr-mode-card svg { flex-shrink: 0; margin-top: 2px; }

.kbsr-mode-card strong {
  display: block;
  font-size: 12px;
  font-weight: 700;
  margin-bottom: 2px;
}

.kbsr-mode-card span {
  font-size: 11px;
  color: var(--slate-600);
  line-height: 1.45;
}

.wcag-active strong { font-weight: 800; }

.vp-presets-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 4px;
}

.vp-count {
  font-size: 10px;
  background: var(--gray-200);
  color: var(--slate-600);
  padding: 1px 6px;
  border-radius: 10px;
  margin-left: 6px;
  vertical-align: middle;
}

.accordion-actions {
  background: var(--gray-50);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.opts-section-head {
  padding: 16px 20px;
  background: var(--white);
  border-bottom: 1px solid var(--gray-200);
  display: flex;
  align-items: center;
  gap: 16px;
}

.opts-section-icon {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.opts-section-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--slate-900);
  margin: 0;
}

.opts-section-desc {
  font-size: 12px;
  color: var(--muted);
  margin: 2px 0 0 0;
}

.opts-section-body {
  padding: 20px;
}

.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 20px;
}

.form-col label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  color: var(--slate-500);
  margin-bottom: 6px;
  text-transform: uppercase;
}

.form-col select {
  width: 100%;
  padding: 8px 12px;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius);
  font-size: 13px;
  background: var(--white);
}

.wcag-active {
  display: flex;
  gap: 12px;
  padding: 14px;
  background: #f0f9ff;
  border: 1px solid #bae6fd;
  border-radius: 8px;
  font-size: 12px;
  color: #0369a1;
  margin-bottom: 20px;
  line-height: 1.5;
}

.vp-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 20px;
  margin-bottom: 24px;
}

.vp-card {
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: 10px;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  box-shadow: var(--shadow-sm);
}

.vp-card-head {
  display: flex;
  align-items: center;
  gap: 10px;
}

.vp-device-icon {
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--slate-400);
  background: var(--gray-50);
  border-radius: 6px;
}

.vp-device-icon.mobile { color: #7c3aed; background: #f5f3ff; }

.vp-label-input {
  flex: 1;
  border: none;
  font-size: 14px;
  font-weight: 700;
  color: var(--slate-900);
  padding: 4px 0;
  background: transparent;
}

.vp-card-body {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  padding: 4px 0;
}

.dim-input {
  width: 64px;
  padding: 6px;
  border: 1px solid var(--gray-200);
  border-radius: 6px;
  font-size: 13px;
  font-weight: 700;
  text-align: center;
  background: var(--gray-50);
}

.vp-info-tag {
  font-size: 10px;
  font-weight: 700;
  padding: 3px 8px;
  background: var(--gray-100);
  color: var(--slate-500);
  border-radius: 4px;
  text-transform: uppercase;
}

.vp-presets-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.vp-preset-chip {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.15s;
}

.vp-preset-chip:hover { border-color: var(--blue-600); color: var(--blue-600); }

.opts-filter-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--gray-200);
}

.filter-col {
  padding: 20px;
  border-right: 1px solid var(--gray-200);
}

.filter-col:last-child { border-right: none; }

.filter-col-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}

.filter-dot { width: 8px; height: 8px; border-radius: 50%; }

.filter-col-title { font-size: 13px; font-weight: 700; color: var(--slate-900); }

.filter-col-desc { font-size: 11px; color: var(--muted); line-height: 1.4; margin-bottom: 12px; }

.sel-tag-box {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 8px;
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: 6px;
  min-height: 38px;
}

.sel-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  border: 1px solid transparent;
}

.sel-tag-input {
  border: none;
  font-size: 11px;
  flex: 1;
  min-width: 100px;
  outline: none;
}

.info-tip {
  display: flex;
  gap: 12px;
  padding: 16px;
  background: #f8fafc;
  border: 1px solid var(--gray-200);
  border-radius: 12px;
  font-size: 12px;
  color: var(--slate-600);
  line-height: 1.5;
}

.info-tip-icon { flex-shrink: 0; color: var(--blue-600); opacity: 0.8; }

.shared-block {
  border-top: 1px dashed var(--gray-200);
  padding: 16px;
  background: #fcfdfe;
}

.accordion-actions {
  display: flex;
  gap: 4px;
  transition: opacity 0.2s;
}

.accordion-actions .btn {
  border: 1px solid var(--gray-200);
  background: var(--white);
}

.accordion-actions .btn:hover {
  background: var(--gray-50);
  border-color: var(--gray-300);
}

/* URL List Styles */
.accordion-url-list {
  background: var(--white);
  padding: 4px 0;
  border-top: 1px solid var(--gray-50);
}

.accordion-url-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 16px 4px 54px; /* Default deep indent for URLs */
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--slate-500);
  position: relative;
}

.accordion-url-item::before {
  content: "";
  position: absolute;
  left: 36px;
  top: 0;
  bottom: 0;
  width: 1px;
  background: var(--gray-200);
}

.accordion-url-item:hover {
  background: var(--blue-50);
  color: var(--blue-600);
}

.accordion-url-link {
  color: inherit;
  text-decoration: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1;
}

/* --- Spacing Utilities --- */
.mb-4  { margin-bottom: 4px !important; }
.mb-8  { margin-bottom: 8px !important; }
.mb-12 { margin-bottom: 12px !important; }
.mb-16 { margin-bottom: 16px !important; }
.mb-24 { margin-bottom: 24px !important; }
.mb-32 { margin-bottom: 32px !important; }

.mt-4  { margin-top: 4px !important; }
.mt-8  { margin-top: 8px !important; }
.mt-12 { margin-top: 12px !important; }
.mt-16 { margin-top: 16px !important; }
.mt-24 { margin-top: 24px !important; }
.mt-32 { margin-top: 32px !important; }

/* --- Help Text --- */
.help-text {
  font-size: 11px;
  color: var(--muted);
  line-height: 1.5;
}

/* --- Scan Type Selection Cards --- */
.scan-type-group {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 12px;
  margin-bottom: 24px;
}

.scan-type-option {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 16px;
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--r);
  cursor: pointer;
  transition: all 0.15s;
  position: relative;
}

.scan-type-option:hover {
  border-color: var(--blue-600);
  background: var(--blue-50);
}

.scan-type-option.active {
  border-color: var(--blue-600);
  background: var(--blue-50);
  box-shadow: 0 0 0 1px var(--blue-600);
}

.scan-type-icon {
  width: 40px;
  height: 40px;
  border-radius: 8px;
  background: var(--gray-50);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 1px;
}

.scan-type-option.active .scan-type-icon {
  background: var(--white);
}

.scan-type-label {
  display: block;
  font-weight: 700;
  font-size: 13px;
  color: var(--slate-900);
  margin-bottom: 2px;
}

.scan-type-desc {
  display: block;
  font-size: 11px;
  color: var(--muted);
  line-height: 1.5;
  margin-top: 4px;
}

.scan-type-active-indicator {
  position: absolute;
  top: 12px;
  right: 12px;
  color: var(--blue-600);
}

/* --- Modals & Dialogs --- */
.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: rgba(15, 23, 42, 0.6);
  backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2000;
  padding: 20px;
}

.modal {
  background: var(--white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-2xl);
  width: 100%;
  max-width: 480px;
  overflow: hidden;
  animation: modalScale 0.2s ease-out;
  border: 1px solid var(--slate-200);
}

@keyframes modalScale {
  from { transform: scale(0.95); opacity: 0; }
  to { transform: scale(1); opacity: 1; }
}

.modal-header {
  padding: 20px 24px;
  border-bottom: 1px solid var(--slate-100);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--slate-50);
}

.modal-header h2 {
  font-size: 16px;
  font-weight: 800;
  color: var(--slate-900);
  margin: 0;
}

.modal-close {
  background: transparent;
  border: none;
  font-size: 24px;
  color: var(--slate-400);
  cursor: pointer;
  line-height: 1;
  padding: 4px;
  border-radius: 4px;
  transition: all 0.2s;
}

.modal-close:hover {
  background: var(--slate-200);
  color: var(--slate-900);
}

.modal-body {
  padding: 24px;
}

.confirm-modal-message {
  font-size: 14px;
  color: var(--slate-600);
  line-height: 1.6;
  margin: 0;
}

.modal-footer {
  padding: 18px 24px;
  background: var(--slate-50);
  border-top: 1px solid var(--slate-100);
  display: flex;
  justify-content: flex-end;
  gap: 12px;
}

/* --- Accessibility Report Shared Components --- */
.report-shared-header {
  align-items: center;
}

.report-shared-title {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}

.report-meta-grid,
.report-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}

.report-meta-grid {
  margin-bottom: 18px;
}

.report-meta-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid var(--gray-200);
  background: var(--gray-100);
  color: var(--slate-600);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.report-meta-pill.site,
.report-meta-pill.wcag,
.report-meta-pill.viewport {
  background: var(--severity-info-bg);
  color: var(--severity-info);
  border-color: var(--severity-info-border);
}

.report-meta-pill.env,
.report-meta-pill.type,
.report-meta-pill.info {
  background: var(--severity-secondary-bg);
  color: var(--severity-secondary);
  border-color: var(--severity-secondary-border);
}

.report-meta-pill.date {
  background: var(--severity-success-bg);
  color: var(--severity-success);
  border-color: var(--severity-success-border);
}

.report-full-card {
  margin-bottom: 16px;
}

.report-stats-grid {
  grid-template-columns: repeat(3, minmax(150px, 1fr));
  margin-bottom: 0;
}

.report-stat-card {
  border-top: 3px solid var(--gray-200);
}

.report-stat-card.danger { border-top-color: var(--severity-danger); }
.report-stat-card.warning { border-top-color: var(--severity-warning); }
.report-stat-card.info { border-top-color: var(--severity-info); }
.report-stat-card.success { border-top-color: var(--severity-success); }
.report-stat-card.secondary { border-top-color: var(--severity-secondary); }
.report-stat-card.accent { border-top-color: var(--severity-accent); }

.report-stat-card.danger .stat-n { color: var(--severity-danger); }
.report-stat-card.warning .stat-n { color: var(--severity-warning); }
.report-stat-card.info .stat-n { color: var(--severity-info); }
.report-stat-card.success .stat-n { color: var(--severity-success); }
.report-stat-card.secondary .stat-n { color: var(--severity-secondary); }
.report-stat-card.accent .stat-n { color: var(--severity-accent); }

.severity-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid var(--gray-200);
  background: var(--gray-100);
  color: var(--slate-600);
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  white-space: nowrap;
}

.severity-badge.critical,
.impact-badge.critical {
  background: var(--severity-danger-bg);
  color: var(--severity-danger);
  border-color: var(--severity-danger-border);
}

.severity-badge.serious,
.impact-badge.serious {
  background: var(--severity-warning-bg);
  color: var(--severity-warning);
  border-color: var(--severity-warning-border);
}

.severity-badge.moderate,
.impact-badge.moderate {
  background: var(--severity-warning-light-bg);
  color: var(--severity-warning-light);
  border-color: var(--severity-warning-light-border);
}

.severity-badge.minor,
.impact-badge.minor {
  background: var(--severity-info-bg);
  color: var(--severity-info);
  border-color: var(--severity-info-border);
}

.severity-badge.manual-review,
.impact-badge.manual-review {
  background: var(--severity-secondary-bg);
  color: var(--severity-secondary);
  border-color: var(--severity-secondary-border);
}

.severity-badge.alert,
.impact-badge.alert {
  background: var(--severity-accent-bg);
  color: var(--severity-accent);
  border-color: var(--severity-accent-border);
}

.severity-badge.success,
.impact-badge.success {
  background: var(--severity-success-bg);
  color: var(--severity-success);
  border-color: var(--severity-success-border);
}

.chip-critical.active,
.chip-critical:hover {
  background: var(--severity-danger-bg);
  color: var(--severity-danger);
  border-color: var(--severity-danger-border);
}

.chip-serious.active,
.chip-serious:hover {
  background: var(--severity-warning-bg);
  color: var(--severity-warning);
  border-color: var(--severity-warning-border);
}

.chip-moderate.active,
.chip-moderate:hover {
  background: var(--severity-warning-light-bg);
  color: var(--severity-warning-light);
  border-color: var(--severity-warning-light-border);
}

.chip-minor.active,
.chip-minor:hover {
  background: var(--severity-info-bg);
  color: var(--severity-info);
  border-color: var(--severity-info-border);
}

.chip-manual-review.active,
.chip-manual-review:hover,
.chip-manual.active,
.chip-manual:hover {
  background: var(--severity-secondary-bg);
  color: var(--severity-secondary);
  border-color: var(--severity-secondary-border);
}

.chip-alert.active,
.chip-alert:hover {
  background: var(--severity-accent-bg);
  color: var(--severity-accent);
  border-color: var(--severity-accent-border);
}

.chip.active .chip-count {
  background: var(--white);
  color: currentColor;
}

.sev-dot.critical { background: var(--severity-danger); }
.sev-dot.serious { background: var(--severity-warning); }
.sev-dot.moderate { background: var(--severity-warning-light); }
.sev-dot.minor { background: var(--severity-info); }
.sev-dot.manual-review { background: var(--severity-secondary); }
.sev-dot.alert { background: var(--severity-accent); }

.sev-header.critical { border-left: 3px solid var(--severity-danger); }
.sev-header.serious { border-left: 3px solid var(--severity-warning); }
.sev-header.moderate { border-left: 3px solid var(--severity-warning-light); }
.sev-header.minor { border-left: 3px solid var(--severity-info); }
.sev-header.manual-review { border-left: 3px solid var(--severity-secondary); }
.sev-header.alert { border-left: 3px solid var(--severity-accent); }

.report-severity-section summary {
  list-style: none;
}

.report-severity-section summary::-webkit-details-marker {
  display: none;
}

.report-table-wrap {
  box-shadow: none;
  border-radius: 0;
  border-left: none;
  border-right: none;
  border-bottom: none;
}

.report-table th,
.report-table td {
  vertical-align: top;
}

.report-table-title {
  font-weight: 700;
  color: var(--slate-900);
  margin-bottom: 6px;
}

.report-table-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.report-table-copy {
  color: var(--slate-600);
  line-height: 1.45;
}

.report-reference-link {
  display: inline-block;
  margin-top: 4px;
}

.report-accordion-body {
  padding: 0;
  background: var(--surface);
}

.report-detail-modal {
  max-width: 980px;
  width: 92vw;
  max-height: 88vh;
  display: flex;
  flex-direction: column;
}

.report-detail-body {
  overflow-y: auto;
  max-height: calc(88vh - 78px);
  padding: 16px 18px 18px;
  background: var(--gray-50);
}

.report-ai-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
  flex-wrap: wrap;
  padding: 12px 14px;
  border: 1px solid var(--severity-info-border);
  border-radius: var(--radius);
  background: var(--severity-info-bg);
}

/* ── Re-run Modal ────────────────────────────────────────────────────────── */
.rerun-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(15, 23, 42, 0.6);
  backdrop-filter: blur(4px);
}

.rerun-box {
  background: var(--white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-2xl);
  max-width: 760px;
  width: 90%;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid var(--slate-200);
}

.rerun-header {
  padding: 14px 20px;
  border-bottom: 1px solid var(--slate-100);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--slate-50);
}

.rerun-title {
  margin: 0;
  font-size: 18px;
  font-weight: 700;
  color: var(--slate-900);
}

.rerun-close {
  background: transparent;
  border: none;
  font-size: 24px;
  color: var(--slate-400);
  cursor: pointer;
  line-height: 1;
  padding: 4px;
  border-radius: 4px;
  transition: all 0.2s;
}

.rerun-close:hover {
  background: var(--slate-200);
  color: var(--slate-600);
}

.rerun-body {
  padding: 16px 20px;
  overflow-y: auto;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.rerun-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.rerun-visual-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--slate-200);
  border-radius: var(--radius-lg);
  background: var(--slate-50);
}

.rerun-visual-grid .rerun-field:first-child {
  grid-column: 1 / -1;
}

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

.rerun-visual-grid-3col .rerun-field:first-child {
  grid-column: auto;
}

.rerun-selector-textarea {
  min-height: 44px;
  background: var(--white);
}

.rerun-check-row {
  grid-column: 1 / -1;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 11px;
  border: 1px solid var(--slate-200);
  border-radius: var(--radius-md);
  background: var(--white);
  color: var(--slate-700);
  font-size: 12px;
  font-weight: 600;
}

.rerun-check-row input {
  width: 14px;
  height: 14px;
  accent-color: var(--blue-600);
}

.rerun-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--slate-700);
  display: flex;
  align-items: center;
  gap: 6px;
}

.rerun-textarea {
  width: 100%;
  min-height: 86px;
  padding: 10px 12px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--slate-200);
  background: var(--white);
  color: var(--slate-900);
  font-family: var(--font-mono);
  font-size: 12px;
  line-height: 1.5;
  resize: vertical;
  outline: none;
  transition: border-color 0.2s;
}

.rerun-textarea:focus {
  border-color: var(--blue-500);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.rerun-input {
  width: 100%;
  padding: 10px 14px;
  border-radius: var(--radius-md);
  border: 1px solid var(--slate-200);
  background: var(--white);
  color: var(--slate-900);
  font-size: 13px;
  outline: none;
  transition: all 0.2s;
}

.rerun-input:focus {
  border-color: var(--blue-500);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

@media (max-width: 720px) {
  .rerun-visual-grid {
    grid-template-columns: 1fr;
  }
}

.rerun-domain-swap {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px;
  background: var(--slate-50);
  border-radius: var(--radius-lg);
  margin-top: 4px;
  border: 1px solid var(--slate-100);
}

.rerun-domain-swap-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--slate-500);
  white-space: nowrap;
}

.rerun-domain-input {
  flex: 1;
  min-width: 0;
  padding: 8px 10px;
  border-radius: var(--radius-md);
  border: 1px solid var(--slate-200);
  font-size: 12px;
  font-family: var(--font-mono);
}

.rerun-domain-arrow {
  color: var(--slate-400);
  font-weight: 700;
}

.rerun-domain-apply {
  background: var(--white);
  border: 1px solid var(--slate-200);
  padding: 6px 12px;
  border-radius: var(--radius-md);
  font-size: 11px;
  font-weight: 600;
  color: var(--slate-600);
  cursor: pointer;
  transition: all 0.2s;
}

.rerun-domain-apply:hover:not(:disabled) {
  background: var(--slate-100);
  border-color: var(--slate-300);
  color: var(--slate-900);
}

.rerun-domain-apply:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.rerun-footer {
  padding: 12px 20px;
  border-top: 1px solid var(--slate-100);
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  background: var(--slate-50);
}

/* ── CTA & Filter Outlines ──────────────────────────────────────────────── */
.btn,
.btn-pill,
.cft-tab,
.chip,
.rerun-domain-apply,
.rerun-input,
.rerun-textarea {
  border: 1px solid var(--slate-300) !important;
}

.btn-primary {
  border-color: var(--blue-700) !important;
}

.btn-ghost:hover,
.btn-pill:hover,
.chip:hover {
  border-color: var(--slate-400) !important;
}

.btn-pill.active,
.chip.active,
.cft-tab.active {
  border-color: var(--blue-600) !important;
  box-shadow: 0 0 0 1px var(--blue-600);
}

.btn-pill-critical.active { border-color: #fca5a5 !important; }
.btn-pill-serious.active { border-color: #fdba74 !important; }
.btn-pill-moderate.active { border-color: #fde047 !important; }
.btn-pill-manual-review.active,
.btn-pill-manual.active { border-color: #cbd5e1 !important; }
.btn-pill-alert.active { border-color: #f9a8d4 !important; }


.pill-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 2px 8px;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 600;
  background: var(--slate-100);
  color: var(--slate-600);
}

.btn-pill.active .pill-count {
  background: var(--blue-100);
  color: var(--blue-700);
}

/* Severity-specific pill colors when active */
.btn-pill-critical.active { background: #fef2f2; border-color: #fecaca; color: #b91c1c; }
.btn-pill-critical.active .pill-count { background: #fee2e2; color: #b91c1c; }

.btn-pill-serious.active { background: #fff7ed; border-color: #fed7aa; color: #c2410c; }
.btn-pill-serious.active .pill-count { background: #ffedd5; color: #c2410c; }

.btn-pill-moderate.active { background: #fefce8; border-color: #fef08a; color: #a16207; }
.btn-pill-moderate.active .pill-count { background: #fef9c3; color: #a16207; }

.btn-pill-manual-review.active,
.btn-pill-manual.active { background: #f8fafc; border-color: #e2e8f0; color: #334155; }
.btn-pill-manual-review.active .pill-count,
.btn-pill-manual.active .pill-count { background: #f1f5f9; color: #334155; }

.btn-pill-alert.active { background: #fdf2f8; border-color: #fbcfe8; color: #be185d; }
.btn-pill-alert.active .pill-count { background: #fce7f3; color: #be185d; }


/* ── Report Accordion (Severity Blocks) ────────────────────────────────── */
.sev-block {
  border: 1px solid var(--slate-200);
  border-radius: var(--radius-lg);
  background: var(--white);
  overflow: hidden;
  margin-bottom: 16px;
  transition: box-shadow 0.2s;
}

.sev-block:hover {
  box-shadow: var(--shadow-sm);
}

.sev-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  cursor: pointer;
  background: var(--slate-50);
  user-select: none;
}

.sev-header.expanded {
  border-bottom: 1px solid var(--slate-200);
  background: var(--white);
}

.sev-left {
  display: flex;
  align-items: center;
  gap: 12px;
}

.sev-indicator {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--slate-300);
}

.sev-indicator.critical { background: var(--severity-danger); box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1); }
.sev-indicator.serious { background: var(--severity-warning); box-shadow: 0 0 0 3px rgba(245, 158, 11, 0.1); }
.sev-indicator.moderate { background: var(--severity-warning-light); box-shadow: 0 0 0 3px rgba(253, 224, 71, 0.1); }
.sev-indicator.minor { background: var(--severity-info); box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1); }
.sev-indicator.manual-review,
.sev-indicator.manual { background: var(--severity-secondary); box-shadow: 0 0 0 3px rgba(100, 116, 139, 0.1); }
.sev-indicator.alert { background: var(--severity-accent); box-shadow: 0 0 0 3px rgba(236, 72, 153, 0.1); }

.sev-name {
  font-weight: 600;
  color: var(--slate-900);
  font-size: 14px;
}

.sev-right {
  color: var(--slate-400);
  display: flex;
  align-items: center;
}

.sev-body-wrapper {
  background: var(--white);
}

/* ── Full Report URL Blocks ────────────────────────────────────────────── */
.report-url-block {
  border: 1px solid var(--slate-200);
  border-radius: var(--radius-lg);
  background: var(--white);
  margin-bottom: 16px;
}

.url-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  cursor: pointer;
  background: var(--slate-50);
  list-style: none;
}

.url-header::-webkit-details-marker {
  display: none;
}

.url-header-left {
  display: flex;
  align-items: center;
  min-width: 0;
  flex: 1;
}

.url-text {
  font-weight: 600;
  color: var(--slate-900);
  font-size: 14px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.report-full-meta-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 16px;
  padding: 16px;
}

.meta-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.meta-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.025em;
  color: var(--slate-500);
  font-weight: 600;
}

.meta-value {
  font-size: 13px;
  font-weight: 500;
  color: var(--slate-900);
}

/* ── Modal & Popup Fixes ───────────────────────────────────────────────── */
.modal-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(15, 23, 42, 0.6);
  backdrop-filter: blur(2px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  padding: 20px;
}

.modal {
  background: var(--white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-2xl);
  max-width: 800px;
  width: 100%;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid var(--slate-200);
}

.modal-header {
  padding: 16px 20px;
  border-bottom: 1px solid var(--slate-100);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  background: var(--slate-50);
}

.modal-header h2 {
  margin: 0;
  font-size: 18px;
  font-weight: 700;
  color: var(--slate-900);
}

.modal-close {
  background: transparent;
  border: none;
  font-size: 24px;
  color: var(--slate-400);
  cursor: pointer;
  line-height: 1;
  padding: 4px;
  border-radius: 4px;
}

.modal-close:hover {
  background: var(--slate-200);
  color: var(--slate-600);
}

.report-detail-body {
  padding: 20px;
  overflow-y: auto;
  flex: 1;
}

.url-modal-row {
  display: flex;
  align-items: center;
  padding: 12px 20px;
  border-bottom: 1px solid var(--slate-100);
  gap: 16px;
}

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

.rerun-config.compact {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 8px 14px;
  padding: 10px 12px;
  border: 1px solid var(--slate-200);
  border-radius: var(--radius-lg);
  background: var(--slate-50);
}

.rerun-config.compact .rerun-config-title {
  grid-column: 1 / -1;
  font-size: 12px;
  font-weight: 700;
  color: var(--slate-700);
}

.rerun-config.compact .rerun-cfg-row {
  display: flex;
  gap: 8px;
  min-width: 0;
  font-size: 12px;
}

.rerun-config.compact .rerun-cfg-key {
  flex-shrink: 0;
  font-weight: 700;
  color: var(--slate-500);
}

.rerun-config.compact .rerun-cfg-val {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--slate-700);
}

.cmp-rule-details-btn {
  margin-left: 8px;
  padding: 4px 9px;
  min-height: 24px;
  border-radius: 999px;
  border: 1px solid #bfdbfe;
  background: #eff6ff;
  color: #1d4ed8;
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
}

.cmp-rule-details-btn:hover {
  background: #dbeafe;
  border-color: #93c5fd;
  color: #1e40af;
}

.url-modal-num {
  font-size: 11px;
  font-weight: 700;
  color: var(--slate-400);
  width: 20px;
}

.report-reference-link {
  color: var(--blue-600);
  text-decoration: none;
  font-weight: 500;
  font-size: 13px;
}

.report-reference-link:hover {
  text-decoration: underline;
}

.report-section-divider {
  height: 1px;
  background: var(--slate-200);
  margin: 32px 0 24px 0;
}

.report-section-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--slate-900);
  margin-bottom: 16px;
}

.report-rule-id {
  display: inline-flex;
  max-width: 180px;
  padding: 2px 6px;
  border-radius: 4px;
  background: var(--gray-100);
  color: var(--slate-700);
  font-family: var(--font-mono);
  font-size: 10px;
  white-space: normal;
  word-break: break-word;
}

.report-ai-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
  flex-wrap: wrap;
  padding: 12px 14px;
  border: 1px solid var(--blue-200);
  border-radius: var(--radius);
  background: var(--blue-50);
}

.tech-ai-reason {
  margin-top: 8px;
  padding: 9px 10px;
  border: 1px solid #bbf7d0;
  border-radius: var(--radius);
  background: #f0fdf4;
  color: var(--slate-700);
  font-size: var(--text-sm);
  line-height: 1.45;
}

.report-detail-node {
  border: 1px solid var(--slate-200);
  border-radius: var(--radius-lg);
  padding: 12px 14px;
  background: var(--white);
  margin-bottom: 12px;
  box-shadow: var(--shadow-sm);
}

.report-detail-summary {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 16px;
  margin-bottom: 16px;
  border: 1px solid var(--slate-200);
  border-radius: var(--radius-lg);
  background: var(--white);
}

.report-detail-summary-copy {
  flex: 1;
  min-width: 0;
}

.clean-banner {
  padding: 16px 20px;
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  color: #15803d;
  border-radius: var(--radius-lg);
  font-weight: 600;
  text-align: center;
}

/* ── Report Filter Pills ────────────────────────────────────────────────── */
.filter-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 16px 0 24px 0;
}

.btn-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 16px;
  border-radius: 100px;
  font-size: 13px;
  font-weight: 600;
  background: var(--white);
  border: 1px solid var(--slate-300) !important;
  color: var(--slate-600);
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  cursor: pointer;
  box-shadow: var(--shadow-sm);
}

.btn-pill:hover {
  background: var(--slate-50);
  border-color: var(--slate-400) !important;
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.btn-pill.active {
  border-color: var(--blue-600) !important;
  background: var(--blue-50);
  color: var(--blue-700);
  box-shadow: 0 0 0 1px var(--blue-600);
}

.pill-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 700;
  background: var(--slate-100);
  color: var(--slate-500);
}

.btn-pill.active .pill-count {
  background: var(--blue-600);
  color: var(--white);
}

.btn-pill-critical.active { border-color: var(--severity-danger) !important; background: #fef2f2; color: #b91c1c; box-shadow: 0 0 0 1px var(--severity-danger); }
.btn-pill-critical.active .pill-count { background: var(--severity-danger); }

.btn-pill-serious.active { border-color: var(--severity-warning) !important; background: #fff7ed; color: #c2410c; box-shadow: 0 0 0 1px var(--severity-warning); }
.btn-pill-serious.active .pill-count { background: var(--severity-warning); }

.btn-pill-moderate.active { border-color: var(--severity-warning-light) !important; background: #fefce8; color: #a16207; box-shadow: 0 0 0 1px var(--severity-warning-light); }
.btn-pill-moderate.active .pill-count { background: var(--severity-warning-light); color: var(--slate-900); }

.btn-pill-manual-review.active,
.btn-pill-manual.active { border-color: var(--slate-400) !important; background: #f8fafc; color: #334155; box-shadow: 0 0 0 1px var(--slate-400); }
.btn-pill-manual-review.active .pill-count,
.btn-pill-manual.active .pill-count { background: var(--slate-600); }

.btn-pill-alert.active { border-color: var(--severity-accent) !important; background: #fdf2f8; color: #be185d; box-shadow: 0 0 0 1px var(--severity-accent); }
.btn-pill-alert.active .pill-count { background: var(--severity-accent); }

/* ── Dashboard Filter Tabs ────────────────────────────────────────────── */
.compare-filter-tabs {
  display: flex;
  gap: 8px;
  padding: 6px;
  background: var(--slate-100);
  border-radius: 12px;
  width: fit-content;
  border: 1px solid var(--slate-200);
  margin-bottom: 24px;
}

.cft-tab {
  padding: 8px 20px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 700;
  color: var(--slate-500);
  background: transparent;
  border: 1px solid transparent !important;
  cursor: pointer;
  transition: all 0.2s;
}

.cft-tab.active {
  background: var(--white);
  color: var(--blue-600);
  border-color: var(--slate-300) !important;
  box-shadow: var(--shadow-md);
}

/* ── Full Report Hierarchical UI Refinements ────────────────────────── */
.report-group-wrap {
  margin-bottom: 12px;
}

.report-group-details.is-url {
  border-left: 1px solid var(--border);
}

.report-group-details.is-url[open] {
  box-shadow: var(--shadow-md);
}

.url-header {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  cursor: pointer;
  user-select: none;
}

.url-header::-webkit-details-marker {
  display: none;
}

.header-sev-summary {
  display: flex;
  gap: 4px;
}

.sev-dot-sm {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
}

.report-table tr.row-impact-critical { border-left: 4px solid var(--severity-danger); }
.report-table tr.row-impact-serious  { border-left: 4px solid var(--severity-danger); }
.report-table tr.row-impact-moderate { border-left: 4px solid var(--severity-warning-light); }
.report-table tr.row-impact-minor    { border-left: 4px solid var(--severity-info); }
.report-table tr.row-impact-manual-review,
.report-table tr.row-impact-manual   { border-left: 4px solid var(--severity-secondary); }
.report-table tr.row-impact-alert    { border-left: 4px solid var(--severity-accent); }

.report-table tr:hover {
  background-color: var(--slate-50) !important;
}

.report-table td {
  border-bottom: 1px solid var(--slate-100);
}

.report-reference-link {
  color: var(--blue-600);
  text-decoration: none;
}

.report-reference-link:hover {
  text-decoration: underline;
}

/* --- Visual Scan Report 3-Column Layout --- */
.vr-viewport-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  padding: 16px;
  background: var(--slate-50);
  align-items: flex-start;
}

.vr-viewport-col {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 0;
}

.vr-viewport-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 700;
  color: var(--slate-500);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.vr-viewport-thumb-container {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 10;
  max-height: 320px;
  background: var(--slate-900);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
  cursor: pointer;
  transition: transform 0.2s, box-shadow 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
}

.vr-viewport-thumb-container:hover {
  transform: scale(1.02);
  border-color: var(--blue-500);
  box-shadow: 0 8px 24px rgba(0,0,0,0.12);
  z-index: 10;
}

.vr-viewport-thumb {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
  object-position: top center;
  transition: transform 0.3s ease;
  background: var(--slate-900);
}

.vr-viewport-thumb-container:hover .vr-viewport-thumb {
  transform: scale(1.05);
}

.vr-region-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}

.vr-region-thumb-container {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 10;
  max-height: 220px;
  padding: 0;
  background: var(--slate-900);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  cursor: pointer;
  transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
}

.vr-region-thumb-container:hover {
  transform: scale(1.02);
  border-color: var(--blue-600);
  box-shadow: 0 8px 24px rgba(0,0,0,0.12);
  z-index: 10;
}

.vr-region-thumb-container:hover .vr-viewport-thumb {
  transform: scale(1.05);
}

.vr-region-label {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 1;
  max-width: calc(100% - 16px);
  padding: 2px 7px;
  border-radius: 4px;
  background: rgba(15, 23, 42, 0.82);
  color: var(--white);
  font-size: 10px;
  font-weight: 800;
  line-height: 1.4;
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.vr-viewport-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  color: var(--slate-400);
  font-size: 11px;
  font-style: italic;
  background: var(--slate-100);
}

.vr-lightbox {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.vr-lb-overlay {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.82);
  cursor: pointer;
}

.vr-lb-box {
  position: relative;
  z-index: 1;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.45);
}

.vr-lb-img-wrap {
  flex: 1;
  min-height: 0;
  overflow: auto;
  display: block;
  background: #111;
  padding: 0;
}

.vr-lb-img {
  max-width: none;
  max-height: none;
  height: auto;
  width: 100%;
  display: block;
  object-fit: contain;
  border-radius: 0;
  box-shadow: none;
}

.vr-lb-chip {
  border: 1px solid rgba(148, 163, 184, 0.28);
  background: rgba(15, 23, 42, 0.8);
  color: var(--slate-300);
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  max-width: 220px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.vr-lb-chip:hover,
.vr-lb-chip.active {
  background: var(--blue-600);
  border-color: var(--blue-600);
  color: var(--white);
}

/* --- UI consistency pass: compact shared surfaces --- */
.card,
.dash-card,
.settings-card,
.viewport-preset-card,
.vp-card,
.opts-section,
.table-container,
.report-group-details,
.report-group-block,
.sev-block {
  border-color: var(--border);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-card);
}

.card {
  padding: 16px;
  background: var(--white);
  border: 1px solid var(--border);
}

.dash-grid {
  gap: 12px;
}

.dash-card {
  padding: 16px;
}

.dash-actions {
  margin-top: 14px;
  padding-top: 12px;
}

.view-header {
  margin-bottom: 12px;
}

/* ── Running scans banner ─────────────────────────────────────────────── */
.running-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--blue-50);
  border: 1px solid #bfdbfe;
  border-radius: var(--radius);
  padding: 10px 16px;
  margin-bottom: 16px;
  font-size: var(--text-sm);
  color: #1d4ed8;
  font-weight: 500;
}

.running-banner-pulse {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #2563eb;
  flex-shrink: 0;
  animation: running-pulse 1.6s ease-in-out infinite;
}

@keyframes running-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(37,99,235,0.45); }
  50%       { box-shadow: 0 0 0 6px rgba(37,99,235,0); }
}

.running-banner-sep {
  color: #93c5fd;
  font-weight: 400;
}

.running-banner-types {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.running-banner-type {
  background: #dbeafe;
  color: #1e40af;
  border-radius: 4px;
  padding: 1px 7px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .02em;
}

.compare-filter-tabs,
.filter-pills {
  margin-bottom: 14px;
}

.report-meta-grid,
.report-meta-row {
  gap: 6px;
  margin-bottom: 12px;
}

.report-stats-grid,
.summary-chart-stats {
  gap: 10px;
}

.stat,
.report-stat-card {
  padding: 12px;
  border-radius: var(--radius);
}

.stat-n {
  line-height: 1;
}

.group-accordion {
  border-radius: var(--radius);
}

.accordion-row {
  min-height: 32px;
  padding: 5px 10px;
  gap: 8px;
  border-left: 3px solid transparent;
}

.accordion-row.level-0 {
  background: var(--slate-100);
  border-left-color: var(--slate-500);
}

.accordion-row.level-1 {
  background: var(--slate-50);
  border-left-color: var(--blue-500);
}

.accordion-row.level-2 {
  background: color-mix(in srgb, var(--blue-50) 44%, var(--white));
  border-left-color: var(--blue-600);
}

.accordion-row.level-3 {
  background: var(--white);
  border-left-color: var(--slate-300);
}

.accordion-row:hover {
  background: color-mix(in srgb, var(--blue-50) 55%, var(--white));
  filter: none;
}

.accordion-row.selected {
  border-left-color: var(--blue-700);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--blue-600) 18%, transparent);
}

.accordion-url-list {
  background: var(--white);
  padding: 4px 0;
  border-top: 1px solid var(--gray-50);
}

.accordion-url-item {
  padding: 4px 16px 4px 66px; /* Extra left padding to avoid overlap with indent line */
}

.accordion-url-item::before {
  left: 48px;
}

.url-header {
  min-height: 40px;
  padding-top: 10px;
  padding-bottom: 10px;
  border-left: 3px solid transparent;
}

.depth-0 > .report-group-details > .url-header,
.depth-0 > .url-header {
  background: var(--slate-100) !important;
  border-left-color: var(--slate-500);
}

.depth-1 > .report-group-details > .url-header,
.depth-1 > .url-header {
  background: var(--slate-50) !important;
  border-left-color: var(--blue-500);
}

.depth-2 > .report-group-details > .url-header,
.depth-2 > .url-header {
  background: color-mix(in srgb, var(--blue-50) 44%, var(--white)) !important;
  border-left-color: var(--blue-600);
}

.depth-3 > .report-group-details > .url-header,
.depth-3 > .url-header {
  background: var(--white) !important;
  border-left-color: var(--slate-300);
}

.report-group-wrap,
.report-group-block {
  margin-bottom: 8px !important;
}

.report-table th,
.report-table td {
  padding: 9px 10px;
}

.modal-overlay {
  z-index: 2000;
  padding: 16px;
  background: rgba(15, 23, 42, 0.58);
  backdrop-filter: blur(3px);
}

.modal,
.report-detail-modal {
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-2xl);
  max-height: 88vh;
}

.modal-header {
  padding: 14px 18px;
  align-items: center;
  background: var(--slate-50);
  border-bottom: 1px solid var(--border);
}

.modal-header h2 {
  font-size: 16px;
  line-height: 1.25;
}

.modal-close {
  width: 30px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius);
  color: var(--slate-500);
}

.modal-close:hover {
  background: var(--slate-100);
  color: var(--slate-900);
}

.modal-body,
.report-detail-body {
  padding: 16px 18px;
}

.modal-footer {
  padding: 12px 18px;
  gap: 8px;
  background: var(--slate-50);
  border-top: 1px solid var(--border);
}

.url-modal-row {
  padding: 10px 16px;
  gap: 12px;
}

.report-detail-summary,
.report-detail-node,
.report-ai-toolbar {
  border-radius: var(--radius);
  padding: 12px;
  margin-bottom: 10px;
}

.vr-lightbox {
  padding: 16px;
}

.vr-lb-box {
  width: min(96vw, 1440px) !important;
  max-height: 94vh !important;
  border-radius: var(--radius-lg) !important;
  border: 1px solid var(--slate-700);
}

.vr-lb-header {
  padding: 12px 16px !important;
}

.vr-lb-img-wrap {
  display: block !important;
  padding: 0 !important;
}

.vr-lb-img {
  width: 100% !important;
  max-width: none !important;
  max-height: none !important;
  height: auto !important;
  display: block !important;
  object-fit: contain;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.vr-viewport-row {
  gap: 10px;
  padding: 12px;
}

.vr-viewport-col,
.vr-region-grid {
  gap: 6px;
}

.vr-viewport-thumb-container,
.vr-region-thumb-container {
  border-radius: var(--radius);
}

.spinner {
  display: inline-block;
  width: 16px;
  height: 16px;
  border: 2px solid rgba(255,255,255,.3);
  border-radius: 50%;
  border-top-color: #fff;
  animation: spin 1s ease-in-out infinite;
  margin-right: 8px;
}

.discovered-urls-preview {
  max-height: 200px;
  overflow-y: auto;
  background: var(--slate-50);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 8px 12px;
}

.discovered-url-item {
  font-size: 11px;
  font-family: var(--font-mono);
  color: var(--slate-600);
  padding: 4px 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.discovered-url-item:not(:last-child) {
  border-bottom: 1px solid var(--slate-200);
}

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



