/* ── Quick Scan Page ─────────────────────────────────────────────────
   One-glance case audit: manipulation flags, discrepancies, compliance
   windows, and attention items surfaced from pipeline analysis.
   ─────────────────────────────────────────────────────────────────── */

/* ── Scan Status Bar ─────────────────────────────────────────────── */

.scan-status {
  background: var(--color-surface, #f9fafb);
  border: 1px solid var(--color-border, #e5e7eb);
  border-radius: var(--radius, 0.5rem);
  padding: 0.5rem 1rem;
  margin-bottom: 1.5rem;
}

.scan-status__inner {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  flex-wrap: wrap;
}

.scan-status__item {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.8125rem;
  color: var(--color-muted-foreground, #6b7280);
}

.scan-status__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

.scan-status__dot--pending {
  background: var(--color-muted-foreground, #6b7280);
}

.scan-status__dot--running {
  background: var(--color-accent, #e07a5f);
  animation: pulse-dot 1.5s ease-in-out infinite;
}

.scan-status__dot--complete {
  background: var(--color-success, #0a6840);
}

.scan-status__dot--error {
  background: var(--color-destructive, #dc2626);
}

@keyframes pulse-dot {
  0%,
  100% {
    opacity: 1;
  }

  50% {
    opacity: 0.4;
  }
}

/* ── Scan Sections ────────────────────────────────────────────────── */

.scan-section {
  margin-bottom: 2rem;
}

.scan-section__header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 1rem;
}

.scan-section__title {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--color-foreground, #1a1a2e);
  margin: 0;
}

.scan-section__count {
  background: var(--color-destructive, #dc2626);
  color: #fff;
  font-size: 0.75rem;
  font-weight: 700;
  padding: 0.125rem 0.5rem;
  border-radius: 9999px;
  min-width: 1.5rem;
  text-align: center;
}

.scan-section__count:empty {
  display: none;
}

/* ── Attention Grid ───────────────────────────────────────────────── */

.scan-attention-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem;
}

/* ── Attention Cards ──────────────────────────────────────────────── */

.scan-attention-card {
  background: var(--color-card, #fff);
  border: 1px solid var(--color-border, #e5e7eb);
  border-radius: var(--radius, 0.5rem);
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  transition:
    border-color 0.15s ease,
    box-shadow 0.15s ease;
}

.scan-attention-card:hover {
  box-shadow: 0 2px 8px rgb(0 0 0 / 6%);
}

.scan-attention-card--critical {
  border-left: 3px solid var(--color-destructive, #dc2626);
}

.scan-attention-card--high {
  border-left: 3px solid var(--color-accent, #e07a5f);
}

.scan-attention-card--medium {
  border-left: 3px solid var(--color-primary, #0b73d2);
}

.scan-attention-card__header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.scan-attention-card__severity {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 0.125rem 0.375rem;
  border-radius: 0.25rem;
}

.scan-attention-card__severity--critical {
  background: #fef2f2;
  color: #991b1b;
}

.scan-attention-card__severity--high {
  background: #fff7ed;
  color: #9a3412;
}

.scan-attention-card__severity--medium {
  background: #eff6ff;
  color: #1e40af;
}

.scan-attention-card__title {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--color-foreground, #1a1a2e);
  margin: 0;
}

.scan-attention-card__desc {
  font-size: 0.8125rem;
  color: var(--color-muted-foreground, #6b7280);
  line-height: 1.5;
  margin: 0;
}

.scan-attention-card__stat {
  display: flex;
  align-items: baseline;
  gap: 0.375rem;
}

.scan-attention-card__value {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-foreground, #1a1a2e);
}

.scan-attention-card__stat-label {
  font-size: 0.75rem;
  color: var(--color-muted-foreground, #6b7280);
}

.scan-attention-card__action {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  background: none;
  border: none;
  color: var(--color-primary, #0b73d2);
  font-size: 0.8125rem;
  font-weight: 600;
  cursor: pointer;
  padding: 0;
  margin-top: auto;
}

.scan-attention-card__action:hover {
  text-decoration: underline;
}

.scan-attention-card__action:focus-visible {
  outline: 2px solid var(--color-primary, #0b73d2);
  outline-offset: 2px;
  border-radius: 2px;
}

/* ── Empty State ──────────────────────────────────────────────────── */

.scan-empty {
  text-align: center;
  padding: 3rem 1rem;
  color: var(--color-muted-foreground, #6b7280);
}

.scan-empty svg {
  margin-bottom: 1rem;
  opacity: 0.4;
}

.scan-empty__title {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--color-foreground, #1a1a2e);
  margin: 0 0 0.5rem;
}

.scan-empty__desc {
  font-size: 0.875rem;
  max-width: 36rem;
  margin: 0 auto 1.5rem;
  line-height: 1.6;
}

/* ── Detail Panels ────────────────────────────────────────────────── */

.scan-detail {
  margin-bottom: 2rem;
}

.scan-detail__header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1rem;
}

.scan-detail__back {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  background: none;
  border: 1px solid var(--color-border, #e5e7eb);
  border-radius: var(--radius, 0.5rem);
  color: var(--color-foreground, #1a1a2e);
  font-size: 0.8125rem;
  font-weight: 500;
  cursor: pointer;
  padding: 0.375rem 0.75rem;
}

.scan-detail__back:hover {
  background: var(--color-surface, #f9fafb);
}

.scan-detail__back:focus-visible {
  outline: 2px solid var(--color-primary, #0b73d2);
  outline-offset: 2px;
}

.scan-detail__title {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--color-foreground, #1a1a2e);
  margin: 0;
}

.scan-detail__legend {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem 1.5rem;
  margin-bottom: 1rem;
  padding: 0.75rem 1rem;
  background: var(--color-surface, #f9fafb);
  border-radius: var(--radius, 0.5rem);
  font-size: 0.75rem;
  color: var(--color-muted-foreground, #6b7280);
}

.scan-detail__legend-item {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
}

.scan-detail__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

.scan-detail__dot--critical {
  background: var(--color-destructive, #dc2626);
}

.scan-detail__dot--high {
  background: var(--color-accent, #e07a5f);
}

.scan-detail__dot--medium {
  background: var(--color-primary, #0b73d2);
}

.scan-detail__dot--low {
  background: var(--color-muted-foreground, #6b7280);
}

.scan-detail__dot--success {
  background: var(--color-success, #0a6840);
}

.scan-detail__dot--unsure {
  background: #f59e0b;
  border: 2px dashed #92400e;
}

/* ── Detail List Items ─────────────────────────────────────────────── */

.scan-detail__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.scan-detail__empty {
  font-size: 0.875rem;
  color: var(--color-muted-foreground, #6b7280);
  padding: 2rem 1rem;
  text-align: center;
  border: 1px dashed var(--color-border, #e5e7eb);
  border-radius: var(--radius, 0.5rem);
}

/* ── Flag Item (populated by JS) ───────────────────────────────────── */

.scan-flag {
  background: var(--color-card, #fff);
  border: 1px solid var(--color-border, #e5e7eb);
  border-radius: var(--radius, 0.5rem);
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.scan-flag--critical {
  border-left: 3px solid var(--color-destructive, #dc2626);
}

.scan-flag--high {
  border-left: 3px solid var(--color-accent, #e07a5f);
}

.scan-flag--medium {
  border-left: 3px solid var(--color-primary, #0b73d2);
}

.scan-flag--low {
  border-left: 3px solid var(--color-muted-foreground, #6b7280);
}

.scan-flag__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}

.scan-flag__type {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-muted-foreground, #6b7280);
}

.scan-flag__severity {
  font-size: 0.6875rem;
  font-weight: 700;
  padding: 0.125rem 0.375rem;
  border-radius: 0.25rem;
}

.scan-flag__severity--critical {
  background: #fef2f2;
  color: #991b1b;
}

.scan-flag__severity--high {
  background: #fff7ed;
  color: #9a3412;
}

.scan-flag__severity--medium {
  background: #eff6ff;
  color: #1e40af;
}

.scan-flag__severity--low {
  background: #f3f4f6;
  color: #374151;
}

.scan-flag__excerpt {
  font-size: 0.875rem;
  line-height: 1.6;
  color: var(--color-foreground, #1a1a2e);
  padding: 0.5rem 0.75rem;
  background: var(--color-surface, #f9fafb);
  border-radius: 0.25rem;
  border-left: 2px solid var(--color-border, #e5e7eb);
  font-style: italic;
}

.scan-flag__source {
  font-size: 0.75rem;
  color: var(--color-muted-foreground, #6b7280);
}

.scan-flag__source strong {
  font-weight: 600;
  color: var(--color-foreground, #1a1a2e);
}

/* ── Confidence Badge ──────────────────────────────────────────────── */

.scan-flag__confidence {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.6875rem;
  font-weight: 600;
  padding: 0.125rem 0.5rem;
  border-radius: 9999px;
  margin-left: 0.5rem;
  white-space: nowrap;
}

.scan-flag__confidence--high {
  background: #dcfce7;
  color: #166534;
}

.scan-flag__confidence--medium {
  background: #fef3c7;
  color: #92400e;
}

.scan-flag__confidence--low {
  background: #fef2f2;
  color: #991b1b;
}

.scan-flag__confidence--unsure {
  background: #fef2f2;
  color: #991b1b;
  border: 1px dashed #dc2626;
}

/* ── Unsure / Needs Review Banner ──────────────────────────────────── */

.scan-flag--unsure {
  border-left-color: #f59e0b;
  background: linear-gradient(to right, #fffbeb, transparent);
}

.scan-flag--unsure .scan-flag__header {
  background: #fef3c7;
}

.scan-flag__unsure-label {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #92400e;
  background: #fef3c7;
  padding: 0.125rem 0.5rem;
  border-radius: 0.25rem;
  border: 1px dashed #d97706;
  margin-left: 0.5rem;
}

.scan-flag__unsure-explanation {
  font-size: 0.75rem;
  color: #92400e;
  background: #fffbeb;
  border: 1px solid #fde68a;
  border-radius: 0.25rem;
  padding: 0.375rem 0.625rem;
  margin-top: 0.375rem;
  line-height: 1.5;
}

/* ── Pipeline Stage Attribution ────────────────────────────────────── */

.scan-flag__pipeline {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.6875rem;
  color: var(--color-muted-foreground, #6b7280);
  margin-left: 0.5rem;
}

.scan-flag__pipeline::before {
  content: "⚙";
  font-size: 0.625rem;
}

/* ── Responsive ───────────────────────────────────────────────────── */

@media (width <= 640px) {
  .scan-attention-grid {
    grid-template-columns: 1fr;
  }

  .scan-detail__legend {
    flex-direction: column;
    gap: 0.375rem;
  }
}

/* ── Reduced Motion ───────────────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
  .scan-status__dot--running {
    animation: none;
  }
}
