/**
 * PDF Accessibility Checker — Namespaced Styles
 * Version: 2.1.0 - Shared color tokens + analyze-btn refactor (Phase 1.5/1.6)
 *
 * v2.1.0 Changes (2026-04-11) — Phase 1.5 + 1.6:
 * - ADDED:  --acc-red-dark, --acc-green, --acc-green-dark, --acc-green-light to :root.
 * - REFACTOR: --acc-success / --acc-success-light now alias --acc-green tokens.
 * - REFACTOR: .pdfac-analyze-btn background switched from hard-coded hsl() to
 *             var(--acc-red) / var(--acc-red-dark). Visual output IDENTICAL —
 *             rgb(220,38,38) is the same color as hsl(0,72%,51%).
 * - INTENT:   Brand red gradient KEPT (Variant B brand differentiation across tools).
 *             No visual diff expected on the live PDF Checker.
 * - SCOPE:    :root + 1 button block. All other selectors untouched.
 *
 * v2.0.0 Changes (2025-02-26):
 * - REDESIGN: Light tech background (#f0f4f8) with 80px grid lines
 * - REDESIGN: All components dark inside (dark cards, dark stat boxes, dark tabs)
 * - UPDATED: Dark issue items, dark progress bars, dark dropzone
 * - UPDATED: Font system to DM Sans + Space Mono (matching web checker)
 * - UPDATED: Success color to rgb(34, 197, 94) for consistency
 * - KEPT: All existing selectors, class names, functional behavior
 * - KEPT: Complete PDF preview section styling
 *
 * CRITICAL: All selectors scoped under .pdf-checker-tool or .pdf-report
 * to avoid conflicts with Web Checker (.accessibility-checker-tool / .accessibility-report)
 *
 * COLOR PALETTE (only these 4 + derived):
 * --acc-red: rgb(220, 38, 38)      - Errors, critical
 * --acc-blue: rgb(30, 95, 153)     - Primary, info
 * --acc-gray: rgb(51, 65, 85)      - Text, secondary
 * --acc-dark: rgb(26, 34, 52)      - Dark backgrounds
 */

/* ============================================
   CSS CUSTOM PROPERTIES
   ============================================ */

.pdf-checker-tool,
.pdf-report {
  /* Primary 4 Colors */
  --acc-red: rgb(220, 38, 38);
  --acc-red-dark: rgb(185, 28, 28);
  --acc-blue: rgb(30, 95, 153);
  --acc-gray: rgb(51, 65, 85);
  --acc-dark: rgb(26, 34, 52);

  /* v2.1.0: Brand green (Doc Checker primary) — added to shared palette
     so all 3 tools have the same token names. Used by future success states. */
  --acc-green: rgb(34, 197, 94);
  --acc-green-dark: rgb(21, 128, 61);
  --acc-green-light: rgba(34, 197, 94, 0.08);

  /* Derived Light Versions */
  --acc-red-light: rgba(220, 38, 38, 0.08);
  --acc-blue-light: rgba(30, 95, 153, 0.08);
  --acc-gray-light: rgba(51, 65, 85, 0.05);
  --acc-dark-light: rgba(26, 34, 52, 0.03);

  /* Success & Warning — v2.1.0: --acc-success now aliases --acc-green for parity */
  --acc-success: var(--acc-green);
  --acc-success-light: var(--acc-green-light);
  --acc-warning: rgb(180, 83, 9);
  --acc-warning-light: rgba(180, 83, 9, 0.08);

  /* Neutrals */
  --acc-white: #ffffff;
  --acc-bg: #f0f4f8;
  --acc-border: rgba(0, 0, 0, 0.08);
  --acc-border-dark: var(--acc-dark);
  --acc-text: var(--acc-gray);
  --acc-text-light: rgba(51, 65, 85, 0.7);

  /* v2.0.0: Dark inside card system */
  --acc-glass-border: rgba(255, 255, 255, 0.06);
  --acc-glass-border-light: rgba(255, 255, 255, 0.04);

  /* v2.0.0: Dark card backgrounds */
  --acc-card-bg: linear-gradient(135deg, rgba(26,34,52,0.97), rgba(15,23,42,0.97));
  --acc-card-flat: rgba(26, 34, 52, 0.95);
  --acc-card-border: 1px solid rgba(255, 255, 255, 0.06);
  --acc-card-radius: 8px;
  --acc-inner-radius: 6px;

  /* Typography — v2.0.0: DM Sans + Space Mono */
  --acc-font-body: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --acc-font-code: 'Space Mono', 'SF Mono', Monaco, 'Courier New', monospace;
  --acc-text-body: clamp(1.4rem, 1.2vw + 0.75rem, 1.8rem);
  --acc-text-small: clamp(1.2rem, 1vw + 0.5rem, 1.4rem);
  --acc-text-xsmall: clamp(1rem, 0.8vw + 0.4rem, 1.2rem);
  --acc-text-h1: clamp(2.5rem, 6vw + 1rem, 5rem);
  --acc-text-h2: clamp(2rem, 4.5vw + 0.5rem, 3.5rem);
  --acc-text-h3: clamp(1.75rem, 4vw + 0.25rem, 3rem);
  --acc-text-h4: clamp(1.5rem, 3.5vw + 0.1rem, 2.5rem);
  --acc-text-h5: clamp(1.4rem, 3vw, 2rem);
  --acc-text-h6: clamp(1.4rem, 2.5vw, 1.8rem);

  /* Spacing — fluid */
  --acc-space-xs: clamp(0.25rem, 0.5vw, 0.5rem);
  --acc-space-sm: clamp(0.5rem, 1vw, 1rem);
  --acc-space-md: clamp(1rem, 2vw, 2rem);
  --acc-space-lg: clamp(2rem, 3vw, 4rem);

  /* Border — v2.0.0: Updated radii */
  --acc-border-thin: 1px;
  --acc-radius: 6px;
  --acc-radius-md: 10px;
  --acc-radius-lg: 14px;
  --acc-radius-pill: 100px;
  --acc-border-radius: 6px;
  --acc-border-radius-lg: 10px;

  /* Transitions — v2.0.0: 0.2s default */
  --acc-transition-fast: 0.2s ease;
  --acc-transition-normal: 0.3s ease;

  /* Shadows — v2.0.0: Refined */
  --acc-shadow-sm: 0 1px 3px rgba(26, 34, 52, 0.04), 0 1px 2px rgba(26, 34, 52, 0.03);
  --acc-shadow-md: 0 4px 12px rgba(26, 34, 52, 0.06), 0 2px 4px rgba(26, 34, 52, 0.04);
  --acc-shadow-lg: 0 12px 32px rgba(26, 34, 52, 0.08), 0 4px 8px rgba(26, 34, 52, 0.04);
}

/* ============================================
   GLOBAL RESETS
   ============================================ */

.pdf-checker-tool,
.pdf-checker-tool *,
.pdf-report,
.pdf-report * {
  box-sizing: border-box;
}

/* Screen reader only */
.pdf-checker-tool .sr-only,
.pdf-report .sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* Focus visible */
.pdf-checker-tool button:focus-visible,
.pdf-checker-tool a:focus-visible,
.pdf-checker-tool input:focus-visible,
.pdf-checker-tool select:focus-visible {
  outline: 3px solid var(--acc-warning);
  outline-offset: 2px;
}

/* Disabled state */
.pdf-checker-tool button[disabled],
.pdf-checker-tool button[aria-busy="true"] {
  opacity: 0.6;
  cursor: not-allowed;
}

/* Skip link — visible on focus */
.pdf-checker-tool .pdfac-skip-link:focus {
  position: absolute;
  top: 10px;
  left: 50%;
  transform: translateX(-50%);
  width: auto !important;
  height: auto !important;
  padding: 12px 24px;
  margin: 0 !important;
  overflow: visible !important;
  clip: auto !important;
  white-space: nowrap !important;
  background: var(--acc-dark);
  color: var(--acc-white);
  border-radius: var(--acc-border-radius);
  font-weight: 600;
  font-size: var(--acc-text-small);
  text-decoration: none;
  z-index: 10000;
  outline: 3px solid var(--acc-warning);
  outline-offset: 2px;
}

/* ============================================
   MAIN CONTAINER
   ============================================ */

.pdf-checker-tool {
  max-width: 1400px;
  margin: 0 auto;
  padding: 24px 28px;
  font-family: var(--acc-font-body);
  font-size: var(--acc-text-small);
  line-height: 1.6;
  color: var(--acc-gray);
  background: var(--acc-bg);
  position: relative;
  border: none;
  border-radius: 0;
}

/* v2.0.0: Tech grid pattern overlay */
.pdf-checker-tool::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(30,95,153,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(30,95,153,0.04) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(ellipse 70% 50% at 50% 30%, black 20%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse 70% 50% at 50% 30%, black 20%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}

/* Ensure all direct children are above grid */
.pdf-checker-tool > * {
  position: relative;
  z-index: 1;
}

/* ============================================
   UPLOAD SECTION — Dark card wrapper
   ============================================ */

.pdf-checker-tool .pdfac-upload-section {
  background: var(--acc-card-bg);
  border: var(--acc-card-border);
  border-radius: var(--acc-card-radius);
  padding: 24px;
  margin-bottom: var(--acc-space-lg);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
  position: relative;
  overflow: hidden;
}

/* Blue orb decoration */
.pdf-checker-tool .pdfac-upload-section::before {
  content: '';
  position: absolute;
  top: -40px;
  right: -40px;
  width: 120px;
  height: 120px;
  background: radial-gradient(circle, rgba(30, 95, 153, 0.15), transparent 70%);
  pointer-events: none;
}

/* ============================================
   DROPZONE — v2.0.0: Dark inside
   ============================================ */

.pdf-checker-tool .pdfac-dropzone {
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  height: 90px;
  padding: 0 32px;
  border: 1.5px dashed rgba(220, 38, 38, 0.35);
  border-radius: var(--acc-inner-radius);
  background: rgba(220, 38, 38, 0.03);
  color: rgba(255, 255, 255, 0.5);
  font-family: var(--acc-font-body);
  font-size: var(--acc-text-small);
  cursor: pointer;
  transition: all 0.2s ease;
  margin-bottom: 10px;
  box-sizing: border-box;
}

.pdf-checker-tool .pdfac-dropzone:hover,
.pdf-checker-tool .pdfac-dropzone.dragover {
  border-color: var(--acc-red);
  border-style: solid;
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.15);
  background: rgba(220, 38, 38, 0.06);
  color: rgba(255, 255, 255, 0.7);
}

.pdf-checker-tool .pdfac-dropzone svg {
  flex-shrink: 0;
  color: rgba(220, 38, 38, 0.55);
  width: 26px;
  height: 26px;
  transition: color 0.2s;
}

.pdf-checker-tool .pdfac-dropzone:hover svg,
.pdf-checker-tool .pdfac-dropzone.dragover svg {
  color: var(--acc-red);
}

.pdf-checker-tool .pdfac-dropzone strong {
  color: #f87171;
  font-weight: 600;
}

.pdf-checker-tool .pdfac-dropzone-hint {
  margin-left: auto;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.2);
  white-space: nowrap;
  flex-shrink: 0;
}

/* ── HAS-FILE STATE ── */
.pdf-checker-tool .pdfac-dropzone.has-file {
  border: 1.5px solid rgba(220, 38, 38, 0.5);
  border-style: solid;
  background: rgba(220, 38, 38, 0.06);
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.1);
  color: #fff;
  height: auto;
  min-height: 70px;
  padding: 14px 20px;
  flex-direction: row;
  text-align: left;
  gap: 12px;
  cursor: default;
}

.pdf-checker-tool .pdfac-dropzone.has-file svg {
  color: #f87171;
  width: 28px;
  height: 28px;
  flex-shrink: 0;
  margin-bottom: 0;
}

.pdf-checker-tool .pdfac-dropzone.has-file .pdfac-dropzone-label {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
  min-width: 0;
  text-align: left;
}

.pdf-checker-tool .pdfac-dropzone.has-file strong {
  display: block;
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.pdf-checker-tool .pdfac-dropzone.has-file small {
  display: block;
  font-size: 12px;
  color: rgba(248, 113, 113, 0.8);
  font-weight: 500;
}

.pdf-checker-tool .pdfac-dropzone.has-file::after {
  content: '\2713  Ready to scan';
  font-size: 11px;
  font-weight: 600;
  color: #f87171;
  background: rgba(220, 38, 38, 0.1);
  border: 1px solid rgba(220, 38, 38, 0.25);
  border-radius: 20px;
  padding: 3px 10px;
  white-space: nowrap;
  flex-shrink: 0;
}

.pdf-checker-tool .pdfac-file-remove {
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 50%;
  font-size: 13px;
  color: rgba(255, 255, 255, 0.35);
  cursor: pointer;
  padding: 0;
  width: 26px;
  height: 26px;
  flex-shrink: 0;
  transition: all var(--acc-transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: 0;
}

.pdf-checker-tool .pdfac-file-remove:hover {
  background: rgba(248, 113, 113, 0.15);
  border-color: rgba(248, 113, 113, 0.3);
  color: #f87171;
}

/* ============================================
   BUTTON ROW — matches web checker layout
   ============================================ */

.pdf-checker-tool .pdfac-button-group {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-top: 0;
}

/* Primary button — PDF brand red gradient (Variant B brand differentiation).
   v2.1.0: Refactored from hard-coded hsl() to var(--acc-red) / var(--acc-red-dark)
   so future palette changes only need to update :root tokens. Visual output is
   identical to v2.0.0: rgb(220,38,38) → rgb(185,28,28) ≈ hsl(0,72%,51%) → hsl(0,72%,42%). */
.pdf-checker-tool .pdfac-analyze-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
  height: 50px;
  padding: 0 24px;
  border: none;
  border-radius: var(--acc-inner-radius);
  font-family: var(--acc-font-body);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  background: linear-gradient(135deg, var(--acc-red), var(--acc-red-dark));
  color: var(--acc-white);
  white-space: nowrap;
  flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(220, 38, 38, 0.35);
}

.pdf-checker-tool .pdfac-analyze-btn:hover:not(:disabled) {
  background: linear-gradient(135deg, var(--acc-red-dark), var(--acc-red));
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(220, 38, 38, 0.45);
}

.pdf-checker-tool .pdfac-analyze-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Country dropdown — ghost style like Force Fresh Check */
.pdf-checker-tool .pdfac-country-select-wrap {
  position: relative;
  flex: 1;
}

.pdf-checker-tool .pdfac-country-select {
  width: 100%;
  height: 50px;
  padding: 0 32px 0 18px;
  border-radius: var(--acc-inner-radius);
  font-family: var(--acc-font-body);
  font-size: 13px;
  font-weight: 500;
  background: transparent;
  color: rgba(255, 255, 255, 0.5);
  border: 1px solid rgba(255, 255, 255, 0.1);
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  transition: all 0.2s ease;
}

.pdf-checker-tool .pdfac-country-select:hover {
  border-color: rgba(255, 255, 255, 0.2);
  color: #fff;
  background: rgba(255, 255, 255, 0.06);
}

.pdf-checker-tool .pdfac-country-select:focus {
  outline: none;
  border-color: var(--acc-blue);
  box-shadow: 0 0 0 3px rgba(30, 95, 153, 0.2);
}

.pdf-checker-tool .pdfac-country-select option {
  background: #1a2234;
  color: #fff;
}

.pdf-checker-tool .pdfac-select-arrow {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: rgba(255, 255, 255, 0.3);
  pointer-events: none;
  font-size: 11px;
}

/* Single country — static label, no interaction */
.pdf-checker-tool .pdfac-single-country {
  height: 50px;
  flex: 1;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 18px;
  border-radius: var(--acc-inner-radius);
  font-family: var(--acc-font-body);
  font-size: 13px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.4);
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: transparent;
  user-select: none;
}

/* ============================================
   PROGRESS BAR — v2.0.0: Dark card
   ============================================ */

.pdf-checker-tool .pdfac-progress {
  margin-top: var(--acc-space-md);
  padding: var(--acc-space-md);
  background: var(--acc-card-bg);
  border: var(--acc-card-border);
  border-radius: var(--acc-card-radius);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
}

.pdf-checker-tool .pdfac-progress-header {
  font-size: var(--acc-text-h5);
  font-weight: 600;
  color: #fff;
  text-align: center;
  margin-bottom: var(--acc-space-sm);
}

.pdf-checker-tool .pdfac-progress-bar {
  width: 100%;
  height: 8px;
  background: rgba(255, 255, 255, 0.10);
  border-radius: 4px;
  overflow: hidden;
  margin-bottom: var(--acc-space-sm);
}

.pdf-checker-tool .pdfac-progress-fill {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, #2563eb, #60a5fa);
  border-radius: 4px;
  transition: width 0.4s ease;
  position: relative;
}

.pdf-checker-tool .pdfac-progress-fill::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
  animation: pdfac-shimmer 1.5s infinite;
}

@keyframes pdfac-shimmer {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}

.pdf-checker-tool .pdfac-progress-text {
  text-align: center;
  font-size: var(--acc-text-small);
  color: rgba(255, 255, 255, 0.5);
}

/* ============================================
   ERROR MESSAGE — v2.0.0: Dark context
   ============================================ */

.pdf-checker-tool .pdfac-error {
  margin-top: var(--acc-space-md);
  padding: var(--acc-space-md);
  background: rgba(220, 38, 38, 0.08);
  border: 1px solid rgba(220, 38, 38, 0.2);
  border-left: 2px solid var(--acc-red);
  border-radius: 0 var(--acc-inner-radius) var(--acc-inner-radius) 0;
  color: #f87171;
  font-size: var(--acc-text-small);
}

/* ============================================
   REPORT — STAT BOXES — v2.0.0: Dark cards
   ============================================ */

.pdf-report .stat-box-container {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--acc-space-md);
  margin-bottom: var(--acc-space-lg);
}

.pdf-report .stat-box {
  padding: var(--acc-space-md);
  background: var(--acc-card-flat);
  border: var(--acc-card-border);
  border-radius: var(--acc-card-radius);
  text-align: center;
  transition: all var(--acc-transition-fast);
  position: relative;
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.pdf-report .stat-box:hover {
  border-color: rgba(255, 255, 255, 0.1);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.2);
  transform: translateY(-1px);
}

.pdf-report .stat-box .count {
  display: block;
  font-family: var(--acc-font-body);
  font-size: var(--acc-text-h3);
  font-weight: 700;
  color: #fff;
  margin-bottom: var(--acc-space-xs);
  letter-spacing: -0.02em;
}

.pdf-report .stat-box .label {
  font-size: var(--acc-text-xsmall);
  font-weight: 600;
  color: rgba(255, 255, 255, 0.5);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Stat box states — v2.0.0: top border + colored count */
.pdf-report .stat-box.success { border-top: 2px solid #4ade80; border-left: none; }
.pdf-report .stat-box.success .count { color: #4ade80; }

.pdf-report .stat-box.critical { border-top: 2px solid #f87171; border-left: none; }
.pdf-report .stat-box.critical .count { color: #f87171; }

.pdf-report .stat-box.warning { border-top: 2px solid #fbbf24; border-left: none; }
.pdf-report .stat-box.warning .count { color: #fbbf24; }

.pdf-report .stat-box.info { border-top: 2px solid #3b82f6; border-left: none; }
.pdf-report .stat-box.info .count { color: #60a5fa; }

/* ============================================
   REPORT — TABS — v2.0.0: Dark system
   ============================================ */

.pdf-report .tabs-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: var(--acc-space-md);
  padding: 6px;
  background: rgba(15, 23, 42, 0.6);
  border-radius: var(--acc-card-radius);
  border: var(--acc-card-border);
}

.pdf-report .tab-button {
  flex: 1;
  min-width: fit-content;
  padding: 10px var(--acc-space-md);
  background: transparent;
  border: none;
  border-radius: var(--acc-inner-radius);
  font-family: var(--acc-font-body);
  font-size: var(--acc-text-small);
  font-weight: 500;
  color: rgba(255, 255, 255, 0.5);
  cursor: pointer;
  transition: all var(--acc-transition-fast);
}

.pdf-report .tab-button:hover {
  background: rgba(255, 255, 255, 0.06);
  color: rgba(255, 255, 255, 0.8);
}

.pdf-report .tab-button.active {
  background: #2563eb;
  color: #fff;
  font-weight: 600;
  box-shadow: 0 2px 8px rgba(37, 99, 235, 0.35);
}

.pdf-report .tab-content {
  display: none !important;
  padding: var(--acc-space-md);
  background: linear-gradient(135deg, rgba(26,34,52,0.97), rgba(15,23,42,0.97)) !important;
  background-color: rgba(26, 34, 52, 0.97) !important;
  border: 1px solid rgba(255, 255, 255, 0.06) !important;
  border-radius: var(--acc-card-radius);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
  color: rgba(255, 255, 255, 0.7);
}

.pdf-report .tab-content.active {
  display: block !important;
  animation: pdfac-fadeIn 0.3s ease;
}

@keyframes pdfac-fadeIn {
  from { opacity: 0; transform: translateY(5px); }
  to { opacity: 1; transform: translateY(0); }
}

/* v2.0.0: White text inside dark tab content */
.pdf-report .tab-content h3,
.pdf-report .tab-content h4 {
  color: #fff;
}

.pdf-report .tab-content p,
.pdf-report .tab-content span,
.pdf-report .tab-content strong {
  color: rgba(255, 255, 255, 0.7);
}

.pdf-report .tab-content strong {
  color: rgba(255, 255, 255, 0.9);
}

/* ============================================
   REPORT — ISSUE ITEMS — v2.0.0: Dark cards
   ============================================ */

.pdf-report .issue-item {
  margin-bottom: var(--acc-space-md);
  padding: var(--acc-space-md);
  background: rgba(26, 34, 52, 0.6);
  border: 1px solid rgba(255, 255, 255, 0.04);
  border-radius: var(--acc-inner-radius);
  border-left: 2px solid var(--acc-red);
  transition: all var(--acc-transition-fast);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.pdf-report .issue-item:last-child {
  margin-bottom: 0;
}

.pdf-report .issue-item:hover {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
  background: rgba(26, 34, 52, 0.7);
  transform: translateY(-1px);
}

.pdf-report .issue-item.critical-issue {
  border-left-color: var(--acc-red) !important;
}

.pdf-report .issue-item.warning-issue {
  border-left-color: var(--acc-warning) !important;
}

.pdf-report .issue-item.info-issue {
  border-left-color: var(--acc-blue) !important;
}

/* Issue header — v2.0.0: Dark theme */
.pdf-report .issue-header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--acc-space-sm);
  margin-bottom: var(--acc-space-sm);
  padding-bottom: var(--acc-space-sm);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.pdf-report .issue-title {
  font-size: var(--acc-text-small);
  font-weight: 600;
  color: #fff;
  margin: 0;
  flex: 1;
  min-width: 200px;
}

/* Issue description — v2.0.0: Light text on dark */
.pdf-report .issue-description {
  font-size: var(--acc-text-small);
  color: rgba(255, 255, 255, 0.7);
  line-height: 1.6;
  margin-bottom: var(--acc-space-sm);
}

/* ============================================
   BADGES — v2.0.0: Dark-compatible
   ============================================ */

.pdf-report .severity-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: var(--acc-radius-pill);
  font-family: var(--acc-font-body);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.4px;
}

.pdf-report .severity-badge.critical {
  background: var(--acc-red);
  color: var(--acc-white);
}

.pdf-report .severity-badge.warning {
  background: var(--acc-warning);
  color: var(--acc-white);
}

.pdf-report .severity-badge.info {
  background: var(--acc-blue);
  color: var(--acc-white);
}

.pdf-report .severity-badge.passed {
  background: rgba(34, 197, 94, 0.15);
  color: #4ade80;
}

.pdf-report .wcag-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 8px;
  background: var(--acc-dark);
  color: var(--acc-white);
  border-radius: 4px;
  font-size: var(--acc-text-xsmall);
  font-weight: 600;
}

/* Matterhorn Protocol badge — cyan/teal to distinguish from WCAG */
.pdf-report .pdfac-matterhorn-badge,
.pdf-report .tab-content .pdfac-matterhorn-badge {
  display: inline-flex !important;
  align-items: center;
  padding: 3px 8px;
  background: rgba(14, 116, 144, 0.2);
  color: #22d3ee !important;
  border: 1px solid rgba(14, 116, 144, 0.3);
  border-radius: 4px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  flex-shrink: 0;
}

.pdf-report .source-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: var(--acc-radius-pill);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.pdf-report .source-badge.structure { background: rgba(245, 158, 11, 0.15); color: #fbbf24; }
.pdf-report .source-badge.content { background: rgba(59, 130, 246, 0.15); color: #60a5fa; }
.pdf-report .source-badge.metadata { background: rgba(139, 92, 246, 0.15); color: #a78bfa; }

/* ============================================
   FIX SUGGESTION — v2.0.0: Dark context
   ============================================ */

.pdf-report .fix-suggestion {
  margin-top: 12px;
  padding: 14px 18px;
  background: rgba(30, 95, 153, 0.1);
  border-left: 2px solid var(--acc-blue);
  border-radius: 0 var(--acc-inner-radius) var(--acc-inner-radius) 0;
  font-size: var(--acc-text-small);
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.7);
}

.pdf-report .fix-suggestion strong {
  color: #60a5fa;
  display: block;
  margin-bottom: 6px;
}

.pdf-report .framework-specific-fix {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: flex-start;
  gap: 8px;
}

.pdf-report .framework-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  background: var(--acc-dark);
  color: var(--acc-white);
  font-family: var(--acc-font-body);
  font-size: var(--acc-text-xsmall);
  font-weight: 600;
  border-radius: var(--acc-radius-pill);
  white-space: nowrap;
  flex-shrink: 0;
}

/* ============================================
   SCORE CIRCLE — v2.0.0: Dark inner circle
   ============================================ */

.pdf-report .score-circle-wrapper {
  text-align: center;
  margin: var(--acc-space-md) auto;
}

.pdf-report .score-circle {
  position: relative;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  background: conic-gradient(
    from -90deg,
    var(--circle-color, var(--acc-success)) 0deg,
    var(--circle-color, var(--acc-success)) calc(var(--score-pct, 0) * 3.6deg),
    rgba(255, 255, 255, 0.08) calc(var(--score-pct, 0) * 3.6deg),
    rgba(255, 255, 255, 0.08) 360deg
  );
}

.pdf-report .score-circle::before {
  content: '';
  position: absolute;
  width: 85px;
  height: 85px;
  background: #1a2234;
  border-radius: 50%;
}

.pdf-report .score-circle.success { --circle-color: var(--acc-success); }
.pdf-report .score-circle.warning { --circle-color: var(--acc-warning); }
.pdf-report .score-circle.critical { --circle-color: var(--acc-red); }

.pdf-report .score-number {
  position: relative;
  z-index: 1;
  font-family: var(--acc-font-body);
  font-size: var(--acc-text-h4);
  font-weight: 700;
  color: #fff;
}

.pdf-report .score-label {
  margin-top: var(--acc-space-sm);
  font-size: var(--acc-text-small);
  font-weight: 600;
  color: var(--acc-gray);
}

.pdf-report .score-info {
  font-size: var(--acc-text-xsmall);
  color: rgba(51, 65, 85, 0.6);
  margin-top: 4px;
}

/* ============================================
   REPORT INFO — v2.0.0: Dark card
   ============================================ */

.pdf-report .report-info {
  background: var(--acc-card-flat);
  border: var(--acc-card-border);
  border-radius: var(--acc-card-radius);
  padding: var(--acc-space-md);
  margin-bottom: var(--acc-space-md);
  font-size: var(--acc-text-small);
  color: rgba(255, 255, 255, 0.7);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.pdf-report .report-info strong {
  color: rgba(255, 255, 255, 0.9);
}

/* ============================================
   COUNTRY COMPLIANCE NOTE — v2.0.0: Dark
   ============================================ */

.pdf-report .country-intro {
  padding: var(--acc-space-md);
  background: var(--acc-card-flat);
  border: var(--acc-card-border);
  border-left: 3px solid var(--acc-blue);
  border-radius: 0 var(--acc-inner-radius) var(--acc-inner-radius) 0;
  margin-bottom: var(--acc-space-md);
  font-size: var(--acc-text-small);
  color: rgba(255, 255, 255, 0.7);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.pdf-report .country-intro strong {
  color: #60a5fa;
}

/* ============================================
   SCORE SECTION
   ============================================ */

.pdf-report .score-section {
  padding: var(--acc-space-md) 0;
}

/* ============================================
   ISSUE TOGGLE — Expand/Collapse
   ============================================ */

.pdf-report .issue-toggle {
  cursor: pointer;
  user-select: none;
}

.pdf-report .issue-toggle:hover {
  background: rgba(255, 255, 255, 0.04);
  margin: calc(var(--acc-space-sm) * -1);
  padding: var(--acc-space-sm);
  border-radius: var(--acc-inner-radius);
}

.pdf-report .issue-header-left {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}

.pdf-report .issue-chevron {
  margin-left: auto;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.4);
  flex-shrink: 0;
  transition: transform var(--acc-transition-fast);
}

.pdf-report .issue-body {
  padding-top: var(--acc-space-sm);
}

/* ============================================
   ISSUE DETAILS — Found / Expected / Impact
   v2.0.0: Dark bg
   ============================================ */

.pdf-report .issue-details {
  margin: var(--acc-space-sm) 0;
  padding: var(--acc-space-sm) var(--acc-space-md);
  background: rgba(255, 255, 255, 0.04);
  border-radius: var(--acc-inner-radius);
  border: 1px solid rgba(255, 255, 255, 0.04);
  font-size: var(--acc-text-small);
}

.pdf-report .issue-detail-row {
  padding: 4px 0;
  line-height: 1.5;
}

.pdf-report .issue-detail-row + .issue-detail-row {
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.pdf-report .detail-label {
  font-weight: 600;
  color: rgba(255, 255, 255, 0.9);
  margin-right: 4px;
}

.pdf-report .detail-value {
  color: rgba(255, 255, 255, 0.7);
}

.pdf-report .detail-value.found {
  color: #f87171;
}

.pdf-report .detail-value.expected {
  color: #4ade80;
}

.pdf-report .issue-detail-row.impact {
  margin-top: 4px;
  font-style: italic;
  color: rgba(255, 255, 255, 0.5);
}

.pdf-report .issue-detail-row.impact .detail-value {
  color: rgba(255, 255, 255, 0.5);
}

/* ============================================
   FIX GUIDE — Steps & Tools
   ============================================ */

.pdf-report .fix-tools {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 8px 0;
}

.pdf-report .fix-steps {
  margin: 8px 0 0 0;
  padding-left: 20px;
  font-size: var(--acc-text-small);
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.7);
}

.pdf-report .fix-steps li {
  padding: 3px 0;
}

.pdf-report .fix-steps li::marker {
  color: #60a5fa;
  font-weight: 600;
}

/* ============================================
   FRAMEWORK BADGE — detected/highlighted variant
   Matches the detected authoring tool
   ============================================ */

.pdf-report .framework-badge.detected {
  background: var(--acc-blue);
  color: #ffffff;
  box-shadow: 0 0 0 2px rgba(30, 95, 153, 0.4);
  position: relative;
}

.pdf-report .framework-badge.detected::before {
  content: '\2713  ';
  font-size: 10px;
  opacity: 0.9;
}

/* ============================================
   AUTHORING TOOL BANNER
   Shown below report-info when tool detected
   ============================================ */

.pdf-report .authoring-tool-banner {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  margin: 8px 0 4px;
  background: var(--acc-card-flat);
  border: var(--acc-card-border);
  border-left: 3px solid var(--acc-blue);
  border-radius: var(--acc-inner-radius);
  font-size: var(--acc-text-small);
  color: rgba(255, 255, 255, 0.7);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.pdf-report .authoring-tool-icon {
  font-size: 20px;
  flex-shrink: 0;
  line-height: 1;
}

.pdf-report .authoring-tool-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.pdf-report .authoring-tool-text strong {
  color: #60a5fa;
  font-size: var(--acc-text-small);
  font-weight: 600;
}

.pdf-report .authoring-tool-note {
  font-size: var(--acc-text-xsmall);
  color: rgba(255, 255, 255, 0.45);
}

/* ============================================
   PDF/UA VALIDATION SECTION
   ISO 14289-1 Compliance Status
   ============================================ */

/* ============================================
   PDF/UA VALIDATION SECTION — VeraPDF (ISO 14289-1)
   Blue-tinted to distinguish from main WCAG detections
   ============================================ */

.pdf-report .pdfua-section {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 18px 20px;
  margin: 16px 0 10px;
  background: linear-gradient(135deg, rgba(20, 30, 50, 0.95), rgba(15, 23, 42, 0.95));
  border: 1px solid rgba(30, 95, 153, 0.15);
  border-top: 2px solid var(--acc-blue);
  border-radius: var(--acc-card-radius);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
}

.pdf-report .pdfua-section.pdfua-compliant {
  border-top-color: var(--acc-success);
  border-color: rgba(34, 197, 94, 0.12);
  border-top: 2px solid var(--acc-success);
}

.pdf-report .pdfua-section.pdfua-non-compliant {
  border-top-color: var(--acc-red);
  border-color: rgba(220, 38, 38, 0.12);
  border-top: 2px solid var(--acc-red);
}

.pdf-report .pdfua-section.pdfua-unavailable {
  border-top-color: var(--acc-gray);
  opacity: 0.6;
}

.pdf-report .pdfua-section.pdfua-error {
  border-top-color: var(--acc-orange, #f59e0b);
  background: linear-gradient(135deg, rgba(50, 40, 15, 0.95), rgba(35, 28, 10, 0.95));
}

.pdf-report .pdfua-error-msg {
  margin: 0;
  padding: 10px 14px;
  background: rgba(245, 158, 11, 0.08);
  border: 1px solid rgba(245, 158, 11, 0.15);
  border-radius: 6px;
  color: var(--acc-text-secondary, #94a3b8);
  font-size: 13px;
  line-height: 1.5;
}

.pdf-report .pdfua-icon-warn {
  color: var(--acc-orange, #f59e0b);
  background: rgba(245, 158, 11, 0.15);
}

.pdf-report .pdfua-status-badge.pdfua-warning {
  background: rgba(245, 158, 11, 0.15);
  color: #f59e0b;
  border-color: rgba(245, 158, 11, 0.3);
}

/* Header row */
.pdf-report .pdfua-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

/* Icon circle */
.pdf-report .pdfua-icon {
  font-size: 16px;
  line-height: 1;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  font-weight: 700;
}

.pdf-report .pdfua-icon-pass {
  background: rgba(34, 197, 94, 0.12);
  color: var(--acc-success);
  border: 1px solid rgba(34, 197, 94, 0.2);
}

.pdf-report .pdfua-icon-fail {
  background: rgba(220, 38, 38, 0.12);
  color: var(--acc-red);
  border: 1px solid rgba(220, 38, 38, 0.2);
}

/* Title + standard */
.pdf-report .pdfua-header-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
}

.pdf-report .pdfua-title {
  font-weight: 600;
  font-size: var(--acc-text-small);
  color: rgba(255, 255, 255, 0.9);
  letter-spacing: 0.01em;
}

.pdf-report .pdfua-standard {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.4);
  font-family: var(--acc-font-code);
}

/* Status badge pill */
.pdf-report .pdfua-status-badge {
  display: inline-flex;
  align-items: center;
  padding: 5px 14px;
  border-radius: var(--acc-radius-pill);
  font-size: var(--acc-text-xsmall);
  font-weight: 600;
  flex-shrink: 0;
  white-space: nowrap;
  letter-spacing: 0.02em;
}

.pdf-report .pdfua-status-badge.pdfua-passed {
  background: rgba(34, 197, 94, 0.1);
  color: var(--acc-success);
  border: 1px solid rgba(34, 197, 94, 0.2);
}

.pdf-report .pdfua-status-badge.pdfua-failed {
  background: rgba(220, 38, 38, 0.1);
  color: #f87171;
  border: 1px solid rgba(220, 38, 38, 0.2);
}

/* Rules stat bar */
.pdf-report .pdfua-rules {
  display: flex;
  gap: 10px;
  padding: 12px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.pdf-report .pdfua-rule-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  flex: 1;
  padding: 10px 8px;
  background: rgba(255, 255, 255, 0.025);
  border-radius: var(--acc-inner-radius);
  border: 1px solid rgba(255, 255, 255, 0.04);
}

.pdf-report .pdfua-rule-count {
  font-size: clamp(1.4rem, 2.5vw, 1.8rem);
  font-weight: 700;
  font-family: var(--acc-font-code);
  line-height: 1;
}

.pdf-report .pdfua-rule-count.pdfua-pass {
  color: var(--acc-success);
}

.pdf-report .pdfua-rule-count.pdfua-fail {
  color: #f87171;
}

.pdf-report .pdfua-rule-label {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.45);
  text-align: center;
  line-height: 1.2;
  font-weight: 500;
}

/* Issues list */
.pdf-report .pdfua-issues {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.pdf-report .pdfua-issues-header {
  font-weight: 600;
  font-size: var(--acc-text-small);
  color: rgba(255, 255, 255, 0.75);
  padding: 4px 0 6px;
}

.pdf-report .pdfua-issues-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-height: 320px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,0.1) transparent;
}

.pdf-report .pdfua-issues-list::-webkit-scrollbar {
  width: 4px;
}

.pdf-report .pdfua-issues-list::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 4px;
}

/* Individual issue item — blue-tinted to distinguish from main WCAG issues */
.pdf-report .pdfua-issue-item {
  padding: 10px 14px;
  background: rgba(15, 23, 42, 0.6);
  border-left: 3px solid rgba(30, 95, 153, 0.6);
  border-radius: var(--acc-inner-radius);
  display: flex;
  flex-direction: column;
  gap: 4px;
  transition: background var(--acc-transition-fast);
}

.pdf-report .pdfua-issue-item:hover {
  background: rgba(15, 23, 42, 0.8);
}

/* Rule ID line (clause + WCAG) */
.pdf-report .pdfua-issue-rule {
  font-family: var(--acc-font-code);
  font-size: 11px;
  color: rgba(30, 95, 153, 0.9);
  font-weight: 500;
}

/* Issue description */
.pdf-report .pdfua-issue-desc {
  font-size: var(--acc-text-xsmall);
  color: rgba(255, 255, 255, 0.7);
  line-height: 1.45;
}

/* "X more issues" footer */
.pdf-report .pdfua-issues-more {
  padding: 8px 14px;
  background: rgba(15, 23, 42, 0.4);
  border-radius: var(--acc-inner-radius);
  font-size: 11px;
  color: rgba(255, 255, 255, 0.4);
  text-align: center;
  font-style: italic;
}

/* Unavailable status text */
.pdf-report .pdfua-status {
  font-size: var(--acc-text-small);
  color: rgba(255, 255, 255, 0.5);
  padding: 4px 0;
}

/* ============================================
   ISSUE PAGE BADGE — shown in issue header
   Small pill next to WCAG badge
   ============================================ */

.pdf-report .issue-page-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: rgba(255, 255, 255, 0.55);
  font-family: var(--acc-font-mono);
  font-size: 10px;
  font-weight: 500;
  border-radius: var(--acc-radius-pill);
  white-space: nowrap;
  flex-shrink: 0;
  letter-spacing: 0.02em;
}

/* ============================================
   PASSED ITEMS — v2.0.0: Green accents on dark
   ============================================ */

.pdf-report .passed-item {
  border-left-color: var(--acc-success) !important;
}

.pdf-report .passed-item .issue-header {
  border-bottom: none;
  padding-bottom: 0;
  margin-bottom: 0;
}

.pdf-report .passed-icon {
  margin-left: auto;
  font-size: 18px;
  font-weight: 700;
  color: #4ade80;
  flex-shrink: 0;
}

/* ============================================
   MANUAL REVIEW TAB
   ============================================ */

.pdf-report .pdfac-tab-manual {
  position: relative;
}

.pdf-report .pdfac-manual-intro-box {
  background: rgba(37, 99, 235, 0.08);
  border: 1px solid rgba(37, 99, 235, 0.25);
  border-radius: var(--acc-inner-radius);
  padding: 14px 18px;
  margin-bottom: var(--acc-space-md);
}

.pdf-report .pdfac-manual-intro-text {
  margin: 0;
  font-size: var(--acc-text-small);
  color: rgba(255, 255, 255, 0.65);
  line-height: 1.6;
}

.pdf-report .pdfac-manual-item {
  background: rgba(37, 99, 235, 0.05);
  border: 1px solid rgba(37, 99, 235, 0.18);
  border-left: 3px solid #2563eb;
  border-radius: var(--acc-inner-radius);
  padding: 16px 18px;
  margin-bottom: 10px;
}

.pdf-report .pdfac-manual-item:last-child {
  margin-bottom: 0;
}

.pdf-report .pdfac-manual-item-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}

.pdf-report .pdfac-manual-icon {
  font-size: 16px;
  flex-shrink: 0;
}

.pdf-report .pdfac-manual-item-title {
  margin: 0;
  font-size: var(--acc-text-base);
  font-weight: 600;
  color: rgba(255, 255, 255, 0.92);
  flex: 1;
}

.pdf-report .pdfac-manual-detection-badge {
  font-size: 11px;
  font-weight: 500;
  color: #93c5fd;
  background: rgba(37, 99, 235, 0.2);
  border: 1px solid rgba(37, 99, 235, 0.3);
  border-radius: 4px;
  padding: 2px 8px;
  white-space: nowrap;
  flex-shrink: 0;
}

.pdf-report .pdfac-manual-item-reason {
  margin: 0 0 12px 0;
  font-size: var(--acc-text-small);
  color: rgba(255, 255, 255, 0.55);
  line-height: 1.6;
}

.pdf-report .pdfac-manual-checklist {
  margin: 0;
  padding-left: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.pdf-report .pdfac-manual-checklist-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: var(--acc-text-small);
  color: rgba(255, 255, 255, 0.7);
  line-height: 1.5;
}

.pdf-report .pdfac-manual-checklist-item::before {
  content: '\25A1';
  color: #3b82f6;
  font-size: 14px;
  flex-shrink: 0;
  margin-top: 1px;
}

/* ============================================
   NO ISSUES
   ============================================ */

.pdf-report .no-issues-message {
  padding: var(--acc-space-lg);
  background: rgba(34, 197, 94, 0.1);
  border-radius: var(--acc-inner-radius);
  text-align: center;
  color: #4ade80;
  font-size: var(--acc-text-small);
  font-weight: 600;
  border: 1px solid rgba(34, 197, 94, 0.2);
}

/* ============================================
   PDF PREVIEW SECTION — v2.0.0: Dark theme
   ============================================ */

.pdfac-preview-section {
  background: var(--acc-card-flat);
  border: var(--acc-card-border);
  border-radius: var(--acc-card-radius);
  margin-bottom: 24px;
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
}

.pdfac-preview-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  background: rgba(15, 23, 42, 0.8);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.pdfac-preview-title {
  margin: 0;
  font-size: 15px;
  font-weight: 700;
  color: #fff;
  display: flex;
  align-items: center;
  gap: 8px;
}

.pdfac-preview-title::before {
  content: ''; display: inline-block; width: 14px; height: 14px; background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2393c5fd' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M15 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V7Z'/%3E%3Cpath d='M14 2v4a2 2 0 0 0 2 2h4'/%3E%3C/svg%3E") no-repeat center/contain; vertical-align: middle;
  font-size: 16px;
}

/* Page Navigation — v2.0.0: Dark */
.pdfac-page-nav {
  display: flex;
  align-items: center;
  gap: 10px;
}

.pdfac-nav-btn {
  width: 32px;
  height: 32px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.04);
  color: rgba(255, 255, 255, 0.6);
  font-size: 12px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
}

.pdfac-nav-btn:hover:not(:disabled) {
  background: rgba(37, 99, 235, 0.15);
  border-color: rgba(37, 99, 235, 0.3);
  color: #60a5fa;
}

.pdfac-nav-btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

.pdfac-page-indicator {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.5);
  font-weight: 500;
  min-width: 100px;
  text-align: center;
}

.pdfac-page-indicator span {
  color: #fff;
  font-weight: 700;
}

/* Thumbnail Strip — v2.0.0: Dark */
.pdfac-thumbnail-strip {
  display: flex;
  gap: 8px;
  padding: 12px 16px;
  overflow-x: auto;
  background: rgba(15, 23, 42, 0.6);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
}

.pdfac-thumbnail-strip::-webkit-scrollbar {
  height: 6px;
}

.pdfac-thumbnail-strip::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.15);
  border-radius: 3px;
}

.pdfac-thumb {
  position: relative;
  flex-shrink: 0;
  cursor: pointer;
  border: 2px solid transparent;
  border-radius: 6px;
  overflow: hidden;
  transition: all 0.2s ease;
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}

.pdfac-thumb:hover {
  border-color: rgba(96, 165, 250, 0.5);
  transform: translateY(-2px);
  box-shadow: 0 4px 8px rgba(0,0,0,0.2);
}

.pdfac-thumb.active {
  border-color: #2563eb;
  box-shadow: 0 0 0 3px rgba(37,99,235,0.3);
}

.pdfac-thumb-canvas {
  display: block;
  width: auto;
  height: 80px;
  min-width: 56px;
}

.pdfac-thumb-number {
  display: block;
  text-align: center;
  font-size: 10px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.5);
  padding: 2px 0 3px;
  background: rgba(15, 23, 42, 0.8);
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.pdfac-thumb.active .pdfac-thumb-number {
  color: #60a5fa;
  background: rgba(37, 99, 235, 0.15);
}

/* Thumbnail Issue Badge */
.pdfac-thumb-badge {
  position: absolute;
  top: 3px;
  right: 3px;
  min-width: 18px;
  height: 18px;
  border-radius: 9px;
  font-size: 10px;
  font-weight: 700;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
  line-height: 1;
  z-index: 2;
  box-shadow: 0 1px 3px rgba(0,0,0,0.3);
}

.pdfac-thumb-badge.critical { background: #dc2626; }
.pdfac-thumb-badge.warning { background: #f59e0b; }

/* Doc-level badge on thumbnail — positioned bottom-left to not overlap page badge */
.pdfac-thumb-badge.doc-level {
  top: auto;
  bottom: 3px;
  right: auto;
  left: 3px;
  background: rgba(180, 83, 9, 0.92);
  font-size: 9px;
  min-width: 22px;
}
.pdfac-thumb-badge.doc-level.critical {
  background: rgba(220, 38, 38, 0.92);
}

/* Doc-level issues banner — above the thumbnail strip */
.pdfac-doc-level-banner {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  margin-bottom: 8px;
  border-radius: var(--acc-inner-radius);
  font-size: var(--acc-text-small);
  font-weight: 500;
  color: #fff;
}
.pdfac-doc-level-banner.warning {
  background: rgba(180, 83, 9, 0.25);
  border: 1px solid rgba(245, 158, 11, 0.35);
  color: #fcd34d;
}
.pdfac-doc-level-banner.critical {
  background: rgba(220, 38, 38, 0.2);
  border: 1px solid rgba(220, 38, 38, 0.35);
  color: #fca5a5;
}
.pdfac-doc-level-icon {
  font-size: 14px;
  flex-shrink: 0;
}

/* Multiple badges stacked vertically on main canvas */
.pdfac-main-badge + .pdfac-main-badge {
  margin-top: 6px;
}

/* Doc-level badge on main canvas — slightly different style */
.pdfac-main-badge.doc-level.warning {
  background: rgba(180, 83, 9, 0.88);
}
.pdfac-main-badge.doc-level.critical {
  background: rgba(185, 28, 28, 0.88);
}

/* Main Canvas — v2.0.0: Dark wrap */
.pdfac-main-canvas-wrap {
  position: relative;
  display: flex;
  justify-content: center;
  padding: 20px;
  background: rgba(15, 23, 42, 0.4);
  min-height: 200px;
  max-height: 900px;
  overflow: auto;
}

#pdfac-main-canvas {
  display: block;
  background: #fff;
  box-shadow: 0 2px 12px rgba(0,0,0,0.25);
  max-width: 100%;
  height: auto !important;
  align-self: flex-start;
}

/* Page Issue Badges (overlay on main canvas) */
.pdfac-page-badges {
  position: absolute;
  top: 28px;
  right: 28px;
  z-index: 100;
}

.pdfac-main-badge {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  color: #fff;
  backdrop-filter: blur(4px);
  box-shadow: 0 2px 8px rgba(0,0,0,0.3);
  position: relative;
  flex-wrap: wrap;
}

.pdfac-main-badge.critical { background: rgba(220, 38, 38, 0.9); }
.pdfac-main-badge.warning  { background: rgba(245, 158, 11, 0.9); }

/* Clickable variant */
.pdfac-main-badge--clickable {
  cursor: pointer;
  user-select: none;
  transition: filter 0.15s ease;
}
.pdfac-main-badge--clickable:hover { filter: brightness(1.12); }

.pdfac-main-badge-label { flex: 1; }

.pdfac-main-badge-chevron {
  font-size: 10px;
  opacity: 0.85;
  flex-shrink: 0;
  transition: transform 0.15s ease;
}

/* Dropdown panel — appended to body as portal, positioned absolute */
.pdfac-badge-dropdown {
  position: absolute;
  min-width: 260px;
  max-width: 320px;
  background: rgba(15, 23, 42, 0.98);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.5);
  z-index: 99999;
  overflow: hidden;
}

.pdfac-badge-dropdown-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 14px;
  font-size: 12px;
  font-weight: 500;
  color: #cbd5e1;
  cursor: pointer;
  transition: background 0.12s ease;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.pdfac-badge-dropdown-row:last-child { border-bottom: none; }
.pdfac-badge-dropdown-row:hover { background: rgba(255,255,255,0.08); color: #fff; }

.pdfac-badge-dropdown-icon { flex-shrink: 0; font-size: 11px; }
.pdfac-badge-dropdown-name { flex: 1; }
.pdfac-badge-dropdown-arrow {
  font-size: 11px;
  color: rgba(255,255,255,0.4);
  flex-shrink: 0;
  white-space: nowrap;
}
.pdfac-badge-dropdown-row:hover .pdfac-badge-dropdown-arrow { color: rgba(255,255,255,0.8); }

.pdfac-main-badge-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #fff;
  animation: pdfac-pulse-badge 1.5s ease infinite;
}

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

/* Show in Preview button (inside issues) */
.issue-show-preview {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.show-in-preview-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 12px;
  border: none;
  border-radius: 6px;
  background: linear-gradient(135deg, var(--acc-blue), #2563eb);
  color: #fff;
  font-family: var(--acc-font-body);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: nowrap;
}

.show-in-preview-btn:hover {
  background: linear-gradient(135deg, #184c7a, var(--acc-blue));
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(30, 95, 153, 0.25);
}

.show-in-preview-btn svg {
  flex-shrink: 0;
}

.issue-page-label {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.5);
  font-weight: 500;
}

/* ============================================
   ANALYSIS TIME — Task 1.5
   ============================================ */

.pdf-report .report-analysis-time {
  color: var(--acc-success);
  font-weight: 500;
}

/* ============================================
   FOCUS OUTLINE — Task 1.10
   ============================================ */

.pdf-report:focus {
  outline: 2px solid var(--acc-blue);
  outline-offset: 4px;
  border-radius: 4px;
}

/* ============================================
   BUTTON GROUP MOBILE — Task 1.7
   ============================================ */

.pdf-checker-tool .pdfac-button-group {
  flex-wrap: wrap;
}

/* ============================================
   COUNTRY COMPLIANCE BADGE — inline under score
   ============================================ */

.pdf-report .pdfac-compliance-inline {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 14px;
  border-radius: 20px;
  margin-top: 10px;
  font-size: 13px;
  font-weight: 600;
}

.pdf-report .pdfac-ci-icon {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 800;
  flex-shrink: 0;
}

.pdf-report .compliance-pass .pdfac-ci-icon {
  background: rgba(16, 185, 129, 0.2);
  color: #34d399;
}
.pdf-report .compliance-pass .pdfac-ci-label {
  color: #34d399;
}
.pdf-report .compliance-pass {
  background: rgba(16, 185, 129, 0.08);
  border: 1px solid rgba(16, 185, 129, 0.15);
}

.pdf-report .compliance-warning .pdfac-ci-icon {
  background: rgba(245, 158, 11, 0.2);
  color: #fbbf24;
}
.pdf-report .compliance-warning .pdfac-ci-label {
  color: #fbbf24;
}
.pdf-report .compliance-warning {
  background: rgba(245, 158, 11, 0.08);
  border: 1px solid rgba(245, 158, 11, 0.15);
}

.pdf-report .compliance-fail .pdfac-ci-icon {
  background: rgba(239, 68, 68, 0.2);
  color: #f87171;
}
.pdf-report .compliance-fail .pdfac-ci-label {
  color: #f87171;
}
.pdf-report .compliance-fail {
  background: rgba(239, 68, 68, 0.08);
  border: 1px solid rgba(239, 68, 68, 0.15);
}

.pdf-report .pdfac-ci-standard {
  margin-top: 6px;
  font-size: 12px;
  color: rgba(100, 116, 139, 0.85);
}

/* ============================================
   QUICK SUMMARY BOX — top issues to fix
   ============================================ */

.pdf-report .pdfac-quick-summary {
  padding: 16px 20px;
  background: var(--acc-card-flat);
  border: var(--acc-card-border);
  border-left: 3px solid var(--acc-warning);
  border-radius: var(--acc-inner-radius);
  margin-bottom: var(--acc-space-md);
}

.pdf-report .pdfac-quick-summary.success {
  border-left-color: var(--acc-success);
}

.pdf-report .pdfac-qs-header {
  font-size: 14px;
  color: #fff;
  margin-bottom: 10px;
}

.pdf-report .pdfac-qs-icon {
  margin-right: 6px;
}

.pdf-report .pdfac-qs-content {
  color: rgba(255, 255, 255, 0.8);
  font-size: 14px;
}

.pdf-report .pdfac-qs-list {
  margin: 0;
  padding-left: 20px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.pdf-report .pdfac-qs-list li {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.75);
  line-height: 1.4;
}

.pdf-report .pdfac-qs-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 2px 6px;
  border-radius: 3px;
  vertical-align: middle;
}

.pdf-report .pdfac-qs-badge.critical {
  background: rgba(239, 68, 68, 0.15);
  color: #f87171;
}

.pdf-report .pdfac-qs-badge.warning {
  background: rgba(245, 158, 11, 0.15);
  color: #fbbf24;
}

.pdf-report .pdfac-qs-badge.info {
  background: rgba(59, 130, 246, 0.15);
  color: #60a5fa;
}

/* Anchor link in quick summary list */
.pdf-report .pdfac-qs-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: rgba(255, 255, 255, 0.75);
  text-decoration: none;
  transition: color 0.15s;
}
.pdf-report .pdfac-qs-link:hover {
  color: #fff;
}

/* Small page indicator e.g. "p.3" */
.pdf-report .pdfac-qs-page {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.4);
  font-family: var(--acc-mono);
}

/* Highlight flash when scrolled to via anchor */
@keyframes pdfac-qs-flash {
  0%   { box-shadow: 0 0 0 3px rgba(99, 179, 237, 0.6); background: rgba(99, 179, 237, 0.08); }
  100% { box-shadow: none; background: transparent; }
}
.pdf-report .issue-item.pdfac-qs-highlight {
  animation: pdfac-qs-flash 1.8s ease-out forwards;
  border-radius: var(--acc-inner-radius);
}

/* ============================================
   FIX COST ESTIMATOR — time and cost
   ============================================ */

.pdf-report .pdfac-cost-estimator {
  padding: 16px 20px;
  background: var(--acc-card-flat);
  border: var(--acc-card-border);
  border-left: 3px solid var(--acc-blue);
  border-radius: var(--acc-inner-radius);
  margin-bottom: var(--acc-space-lg);
}

.pdf-report .pdfac-cost-row {
  display: flex;
  gap: 20px;
}

.pdf-report .pdfac-cost-item {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
}

.pdf-report .pdfac-cost-icon {
  font-size: 22px;
  flex-shrink: 0;
}

.pdf-report .pdfac-cost-item strong {
  display: block;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: rgba(255, 255, 255, 0.45);
  font-weight: 600;
  margin-bottom: 2px;
}

.pdf-report .pdfac-cost-value {
  display: block;
  font-size: 18px;
  font-weight: 700;
  color: #fff;
  font-family: var(--acc-font-mono);
}

.pdf-report .pdfac-cost-note {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  font-size: 11px;
  color: rgba(255, 255, 255, 0.35);
  line-height: 1.4;
}

/* ============================================
   CHECK ANOTHER PDF — button at bottom
   ============================================ */

.pdf-report .pdfac-check-another {
  text-align: center;
  margin-top: var(--acc-space-xl);
  padding-top: var(--acc-space-lg);
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.pdf-report .pdfac-check-another-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 12px 28px;
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: var(--acc-inner-radius);
  background: transparent;
  color: rgba(255, 255, 255, 0.6);
  font-family: var(--acc-font-body);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}

.pdf-report .pdfac-check-another-btn:hover {
  background: rgba(255, 255, 255, 0.06);
  color: #fff;
  border-color: rgba(255, 255, 255, 0.25);
  transform: translateY(-1px);
}

/* ============================================
   RESPONSIVE — 768px
   ============================================ */

@media (max-width: 768px) {
  .pdf-checker-tool,
  .pdf-report {
    max-width: 100vw !important;
    width: 100% !important;
    overflow-x: hidden !important;
    padding: 8px !important;
    box-sizing: border-box !important;
  }

  /* Manual Review header — stack title + badge vertically on mobile */
  .pdf-report .pdfac-manual-item-header {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 6px !important;
  }
  .pdf-report .pdfac-manual-detection-badge {
    align-self: flex-start !important;
  }

  .pdf-checker-tool *,
  .pdf-report * {
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  .pdf-checker-tool .pdfac-upload-section {
    padding: 16px !important;
  }

  .pdf-checker-tool .pdfac-button-group {
    flex-direction: column !important;
    gap: 8px !important;
  }

  .pdf-checker-tool .pdfac-analyze-btn {
    width: 100% !important;
  }

  .pdf-checker-tool .pdfac-country-select-wrap,
  .pdf-checker-tool .pdfac-single-country {
    width: 100% !important;
    text-align: center !important;
  }

  .pdf-checker-tool .pdfac-country-select-wrap select {
    width: 100% !important;
  }

  /* New components mobile */
  .pdf-report .pdfac-cost-row {
    flex-direction: column !important;
    gap: 12px !important;
  }

  .pdf-report .pdfac-cost-value {
    font-size: 16px !important;
  }

  .pdf-report .stat-box-container {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
  }

  .pdf-report .tabs-nav {
    flex-direction: column !important;
    gap: 5px !important;
  }

  .pdf-report .tab-button {
    width: 100% !important;
    padding: 10px !important;
  }

  .pdf-report .issue-item {
    padding: 10px !important;
  }

  .pdf-report .issue-header {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 8px !important;
  }

  .pdf-report .fix-suggestion {
    padding: 10px !important;
  }

  .pdf-report .framework-specific-fix {
    flex-direction: column !important;
    gap: 6px !important;
  }

  /* Default dropzone — column layout na mobilu (ikona nahoře, text pod ní) */
  .pdf-checker-tool .pdfac-dropzone {
    padding: 16px !important;
    min-height: 100px !important;
    height: auto !important;
    flex-direction: column !important;
    text-align: center !important;
    gap: 6px !important;
  }

  .pdf-checker-tool .pdfac-dropzone svg {
    margin-bottom: 2px !important;
    width: 28px !important;
    height: 28px !important;
  }

  .pdf-checker-tool .pdfac-dropzone-hint {
    display: block !important;
    margin-top: 4px !important;
    margin-left: 0 !important;
  }

  /* HAS-FILE — přepnout zpět na row layout, kompaktní */
  .pdf-checker-tool .pdfac-dropzone.has-file {
    flex-direction: row !important;
    text-align: left !important;
    min-height: 64px !important;
    height: auto !important;
    padding: 12px 14px !important;
    gap: 10px !important;
  }

  .pdf-checker-tool .pdfac-dropzone.has-file svg {
    width: 24px !important;
    height: 24px !important;
    margin-bottom: 0 !important;
  }

  .pdf-checker-tool .pdfac-dropzone.has-file strong {
    font-size: 13px !important;
  }

  .pdf-checker-tool .pdfac-dropzone.has-file small {
    font-size: 11px !important;
  }

  /* Schovat "Ready to scan" badge na mobilu */
  .pdf-checker-tool .pdfac-dropzone.has-file::after {
    display: none !important;
  }

  .pdf-report .score-circle {
    width: 100px !important;
    height: 100px !important;
  }

  .pdf-report .score-circle::before {
    width: 70px !important;
    height: 70px !important;
  }

  .pdf-report .issue-details {
    padding: 8px 10px !important;
  }

  .pdf-report .issue-detail-row {
    display: block !important;
  }

  .pdf-report .fix-steps {
    padding-left: 16px !important;
  }

  .pdf-checker-tool .pdfac-country-pills {
    gap: 6px !important;
  }

  .pdf-checker-tool .pdfac-country-pill {
    padding: 6px 10px !important;
    font-size: 12px !important;
  }

  .pdf-checker-tool .pdfac-pill-standard {
    display: none !important;
  }

  /* Preview responsive */
  .pdfac-preview-header {
    flex-direction: column;
    gap: 10px;
    padding: 10px 14px;
  }

  .pdfac-main-canvas-wrap {
    padding: 10px;
    max-height: 500px;
  }

  .pdfac-thumb-canvas {
    height: 60px;
  }

  .pdfac-page-badges {
    top: 16px;
    right: 16px;
  }

  .pdfac-main-badge {
    font-size: 11px;
    padding: 6px 10px;
  }
}

/* ============================================
   RESPONSIVE — 480px
   ============================================ */

@media (max-width: 480px) {
  .pdf-checker-tool {
    padding: 6px 8px !important;
  }

  .pdf-checker-tool .pdfac-upload-section {
    padding: 12px !important;
  }

  .pdf-report .stat-box-container {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  .pdf-report .issue-item {
    padding: 8px !important;
  }

  .pdf-report .fix-suggestion {
    padding: 8px !important;
  }

  .pdf-checker-tool .pdfac-country-pills {
    flex-direction: column !important;
  }

  .pdf-checker-tool .pdfac-country-pill {
    justify-content: center !important;
  }

  /* Preview 480px */
  .pdfac-thumbnail-strip {
    padding: 8px 10px;
    gap: 6px;
  }

  .pdfac-thumb-canvas {
    height: 50px;
  }

  .pdfac-main-canvas-wrap {
    padding: 6px;
    max-height: 400px;
  }

  .issue-show-preview {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* ============================================
   REDUCED MOTION
   ============================================ */

@media (prefers-reduced-motion: reduce) {
  .pdf-checker-tool *, .pdf-checker-tool *::before, .pdf-checker-tool *::after,
  .pdf-report *, .pdf-report *::before, .pdf-report *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }

  /* Exception: Progress bar must still animate */
  .pdf-checker-tool .pdfac-progress-fill {
    transition: width 0.3s linear !important;
  }
}

/* ============================================
   PRINT
   ============================================ */

@media print {
  .pdf-checker-tool .pdfac-upload-section,
  .pdf-report .tabs-nav,
  .pdfac-preview-section,
  .show-in-preview-btn {
    display: none !important;
  }

  .pdf-report .tab-content {
    display: block !important;
  }

  .pdf-report .issue-item {
    break-inside: avoid;
    page-break-inside: avoid;
  }
}

/* ============================================
   END — v2.2.0 (Phase 1 complete: animation, mobile, compliance, summary, cost, check another)
   ============================================ */
/* ============================================================
   SPECIFIC ISSUE EXAMPLES — actual problematic content
   ============================================================ */

.issue-examples-row {
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
}

.issue-examples-list {
  margin: 6px 0 0 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 4px;
  width: 100%;
}

.issue-example-item {
  display: flex;
  align-items: center;
  gap: 6px;
}

.issue-example-item::before {
  content: '→';
  color: var(--acc-text-light, #64748b);
  font-size: 11px;
  flex-shrink: 0;
}

.issue-example-item code {
  background: rgba(0, 0, 0, 0.25);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 4px;
  padding: 2px 7px;
  font-family: var(--acc-font-mono, 'Space Mono', monospace);
  font-size: 11.5px;
  color: #e2e8f0;
  word-break: break-word;
  line-height: 1.5;
}

.issue-example-item--rich {
  align-items: center;
  flex-wrap: wrap;
}

.issue-example-more {
  padding: 2px 0;
  color: var(--acc-text-light, #64748b);
  font-size: 11.5px;
  font-style: italic;
}

/* Heading text / level jump inline value */
.issue-code-value {
  font-family: var(--acc-font-mono, 'Space Mono', monospace);
  font-size: 12px;
  color: #c4b5fd;
  background: rgba(99, 102, 241, 0.1);
  border-radius: 4px;
  padding: 2px 6px;
}

/* Empty metadata value */
.issue-examples-list code.meta-empty {
  color: #f87171;
  border-color: rgba(239, 68, 68, 0.3);
}

/* "Show" button inside examples list */
.btn-show-element {
  flex-shrink: 0;
  background: rgba(249, 115, 22, 0.15);
  border: 1px solid rgba(249, 115, 22, 0.4);
  color: #fb923c;
  border-radius: 4px;
  padding: 2px 8px;
  font-size: 11px;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s;
}

.btn-show-element:hover {
  background: rgba(249, 115, 22, 0.3);
}

/* ============================================================
   ELEMENT HIGHLIGHT OVERLAY (links, form fields)
   ============================================================ */

.pdfac-element-highlight {
  position: absolute;
  border: 2px solid #f97316;
  background: rgba(249, 115, 22, 0.12);
  border-radius: 3px;
  pointer-events: none;
  z-index: 20;
  animation: pdfac-highlight-pulse-el 1.5s ease-in-out infinite;
  box-shadow: 0 0 0 3px rgba(249, 115, 22, 0.2);
}

@keyframes pdfac-highlight-pulse-el {
  0%, 100% { box-shadow: 0 0 0 3px rgba(249, 115, 22, 0.2); }
  50%       { box-shadow: 0 0 0 6px rgba(249, 115, 22, 0.05); }
}


/* ============================================================
   WHAT WE CHECK PANEL — matches Document Checker exactly
   (pdfac- prefix instead of docac-)
   ============================================================ */

.pdf-checker-tool .pdfac-checks-toggle-wrap {
    margin-top: clamp(0.5rem, 1vw, 1rem);
}

.pdf-checker-tool .pdfac-checks-toggle {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.11);
    border-radius: 100px;
    color: rgba(255, 255, 255, 0.6);
    font-family: 'DM Sans', -apple-system, sans-serif;
    font-size: 14px;
    padding: 6px 12px 6px 10px;
    cursor: pointer;
    transition: all 0.2s ease;
    line-height: 1.4;
}

.pdf-checker-tool .pdfac-checks-toggle:hover {
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.88);
    border-color: rgba(255, 255, 255, 0.2);
}

.pdf-checker-tool .pdfac-checks-toggle:focus-visible {
    outline: 2px solid #1e5f99;
    outline-offset: 2px;
}

.pdf-checker-tool .pdfac-checks-count-badge {
    background: rgba(255, 255, 255, 0.08);
    border-radius: 100px;
    padding: 1px 8px;
    font-size: 12px;
    color: rgba(255, 255, 255, 0.45);
    font-family: 'Space Mono', 'Courier New', monospace;
}

.pdf-checker-tool .pdfac-checks-arrow {
    transition: transform 0.2s ease;
    opacity: 0.45;
    flex-shrink: 0;
    font-size: 11px;
    line-height: 1;
}

.pdf-checker-tool .pdfac-checks-subtitle {
    font-size: 10px;
    color: rgba(255, 255, 255, 0.35);
    font-weight: 400;
    margin-left: 4px;
}

.pdf-checker-tool .pdfac-checks-panel {
    margin-top: 10px;
    background: rgba(8, 14, 32, 0.94);
    border: 1px solid rgba(255, 255, 255, 0.07);
    border-radius: 10px;
    padding: 18px 20px;
}

/* Grid layout — same as Doc Checker */
.pdf-checker-tool .pdfac-checks-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
    gap: 16px 24px;
}

.pdf-checker-tool .pdfac-checks-category {
    min-width: 0;
}

.pdf-checker-tool .pdfac-checks-cat-label {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.09em;
    color: rgba(255, 255, 255, 0.3);
    font-family: 'DM Sans', -apple-system, sans-serif;
    margin-bottom: 7px;
    padding-bottom: 5px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.pdf-checker-tool .pdfac-checks-cat-items {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.pdf-checker-tool .pdfac-check-item {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 5px 7px;
    border-radius: 6px;
}

.pdf-checker-tool .pdfac-check-icon {
    width: 15px;
    flex-shrink: 0;
    font-size: 1.05em;
    line-height: 1;
    text-align: center;
    font-weight: bold;
}

.pdf-checker-tool .pdfac-check-icon--on.pdfac-check-icon--critical {
    color: rgb(248, 113, 113);
}

.pdf-checker-tool .pdfac-check-icon--on.pdfac-check-icon--warning {
    color: rgb(251, 146, 60);
}

.pdf-checker-tool .pdfac-check-icon--on.pdfac-check-icon--info {
    color: rgb(96, 165, 250);
}

.pdf-checker-tool .pdfac-check-icon--off {
    color: rgba(255, 255, 255, 0.2);
    font-weight: normal;
}

.pdf-checker-tool .pdfac-check-name {
    flex: 1;
    color: rgba(255, 255, 255, 0.78);
    font-family: 'DM Sans', -apple-system, sans-serif;
    font-size: 14px;
    line-height: 1.3;
}

.pdf-checker-tool .pdfac-check-item--disabled .pdfac-check-name {
    color: rgba(255, 255, 255, 0.35);
}

/* Off items — dim name */
.pdf-checker-tool .pdfac-check-icon--off ~ .pdfac-check-name {
    color: rgba(255, 255, 255, 0.35);
}

.pdf-checker-tool .pdfac-check-wcag {
    font-size: 12px;
    font-family: 'Space Mono', 'Courier New', monospace;
    color: rgba(255, 255, 255, 0.22);
    background: rgba(255, 255, 255, 0.04);
    padding: 1px 5px;
    border-radius: 3px;
    white-space: nowrap;
    flex-shrink: 0;
}

/* Mobile — collapse to single column */
@media (max-width: 600px) {
    .pdf-checker-tool .pdfac-checks-list {
        grid-template-columns: 1fr 1fr;
        gap: 12px 16px;
    }
    .pdf-checker-tool .pdfac-checks-panel {
        padding: 14px 14px;
    }
}

@media (max-width: 400px) {
    .pdf-checker-tool .pdfac-checks-list {
        grid-template-columns: 1fr;
    }
}

/* ============================================================
   DOCUMENT STRUCTURE PANEL — identical to doc checker panel
   Positioned before #pdfac-results (below input, above report)
   ============================================================ */

.pdfac-struct-panel {
  background: linear-gradient(135deg, rgba(26,34,52,0.97), rgba(15,23,42,0.97));
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 10px;
  margin-bottom: 20px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0,0,0,0.25);
}
.pdfac-struct-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
.pdfac-struct-title {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #e2e8f0;
  font-size: 1.35rem;
  font-weight: 600;
}
.pdfac-struct-title svg { color: rgba(96,165,250,0.8); flex-shrink: 0; }
.pdfac-struct-collapse-btn {
  display: flex;
  align-items: center;
  gap: 5px;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 5px;
  color: #94a3b8;
  font-size: 1.2rem;
  padding: 4px 10px;
  cursor: pointer;
  transition: all 0.15s ease;
}
.pdfac-struct-collapse-btn:hover { background: rgba(255,255,255,0.12); color: #e2e8f0; }
.pdfac-struct-chevron { transition: transform 0.2s ease; }
.pdfac-struct-body { padding: 12px 0 4px; }
.pdfac-struct-section { margin-bottom: 8px; }
.pdfac-struct-section-header {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 18px;
  font-size: 1.1rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #64748b;
}
.pdfac-struct-section-header svg { color: #475569; flex-shrink: 0; }
.pdfac-struct-count {
  background: rgba(255,255,255,0.07);
  color: #94a3b8;
  font-size: 1.05rem;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 10px;
  margin-left: 2px;
}
.pdfac-struct-section-issues {
  margin-left: auto;
  font-size: 1.05rem;
  font-weight: 500;
  color: #f59e0b;
  letter-spacing: 0;
  text-transform: none;
}
.pdfac-struct-items { padding: 2px 0 6px; }
.pdfac-struct-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 18px;
  font-size: 1.3rem;
  color: #94a3b8;
  cursor: default;
  transition: background 0.15s ease;
  border-left: 3px solid transparent;
}
.pdfac-struct-item[data-issue-idx] { cursor: pointer; }
.pdfac-struct-item--issue { border-left-color: rgba(220,38,38,0.5); color: #cbd5e1; }
.pdfac-struct-item--issue:hover { background: rgba(255,255,255,0.07); color: #e2e8f0; border-left-color: rgba(220,38,38,0.8); }
.pdfac-struct-item-text {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pdfac-struct-dim { color: #475569; font-size: 1.1rem; }
.pdfac-struct-badge-wrap {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-left: auto;
  flex-shrink: 0;
}
.pdfac-struct-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 11px;
  font-weight: 600;
  padding: 2px 7px;
  border-radius: 100px;
  white-space: nowrap;
  flex-shrink: 0;
}
.pdfac-struct-badge--critical { background: rgba(220,38,38,0.15); border: 1px solid rgba(220,38,38,0.3); color: rgb(252,165,165); }
.pdfac-struct-badge--warning  { background: rgba(180,83,9,0.12);  border: 1px solid rgba(180,83,9,0.25);  color: #fbbf24; }
.pdfac-struct-badge--info     { background: rgba(30,95,153,0.12); border: 1px solid rgba(30,95,153,0.25); color: #93c5fd; }
.pdfac-struct-goto {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  background: rgba(30,95,153,0.0);
  color: rgba(255,255,255,0.0);
  border-radius: 50%;
  font-size: 11px;
  font-weight: 700;
  transition: all 0.15s ease;
  flex-shrink: 0;
}
.pdfac-struct-item[data-issue-idx]:hover .pdfac-struct-goto {
  background: rgba(30,95,153,0.35);
  color: rgba(255,255,255,0.9);
  transform: translateY(1px);
}
.pdfac-struct-empty-msg {
  padding: 14px 18px;
  color: #64748b;
  font-size: 1.2rem;
}

/* ═══════════════════════════════════════════════════════════
   AI SUMMARY BOX — pdfac-ai-summary-*
   Matches Dark Inside v24.0.0 — same language as AI Explain
   ═══════════════════════════════════════════════════════════ */

/* ── Wrapper ── */
.pdf-report .pdfac-ai-summary-wrap {
  margin: 0 0 16px;
}

/* ── Main button — dark card + purple left border ── */
.pdf-report .pdfac-ai-summary-btn {
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  padding: 15px 20px;
  background: var(--acc-card-flat);
  border: var(--acc-card-border);
  border-left: 3px solid #7c3aed;
  border-radius: var(--acc-card-radius);
  cursor: pointer;
  color: rgba(255, 255, 255, 0.85);
  text-align: left;
  transition: all 0.2s ease;
  font-family: var(--acc-font-body);
}
.pdf-report .pdfac-ai-summary-btn:hover:not(:disabled) {
  background: rgba(26, 34, 52, 0.98);
  border-left-color: #a78bfa;
  color: #fff;
}
.pdf-report .pdfac-ai-summary-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.pdf-report .pdfac-ai-summary-btn[aria-expanded="true"] {
  border-radius: var(--acc-card-radius) var(--acc-card-radius) 0 0;
  border-left-color: #a78bfa;
  border-bottom-color: transparent;
}

/* ── Icon circle ── */
.pdf-report .pdfac-ai-summary-btn-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: rgba(124, 58, 237, 0.15);
  border: 1px solid rgba(124, 58, 237, 0.3);
  border-radius: 50%;
  flex-shrink: 0;
  color: #a78bfa;
}

/* ── Labels ── */
.pdf-report .pdfac-ai-summary-btn-label {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.pdf-report .pdfac-ai-summary-btn-title {
  font-size: 14px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.9);
}
.pdf-report .pdfac-ai-summary-btn-sub {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.4);
  font-weight: 400;
}

/* ── CTA pill ── */
.pdf-report .pdfac-ai-summary-btn-cta {
  font-size: 12px;
  font-weight: 600;
  color: #a78bfa;
  background: rgba(124, 58, 237, 0.12);
  border: 1px solid rgba(124, 58, 237, 0.25);
  padding: 5px 12px;
  border-radius: 20px;
  white-space: nowrap;
  flex-shrink: 0;
  transition: all 0.15s ease;
}
.pdf-report .pdfac-ai-summary-btn:hover:not(:disabled) .pdfac-ai-summary-btn-cta {
  background: rgba(124, 58, 237, 0.2);
  border-color: rgba(124, 58, 237, 0.4);
  color: #c4b5fd;
}

/* ── Expandable box — same dark card as AI Explain ── */
.pdf-report .pdfac-ai-summary-box {
  background: rgba(26, 34, 52, 0.95);
  border: var(--acc-card-border);
  border-top: none;
  border-left: 3px solid #7c3aed;
  border-radius: 0 0 var(--acc-card-radius) var(--acc-card-radius);
  padding: 18px 20px;
}

/* ── Loading ── */
.pdf-report .pdfac-ai-summary-loading {
  display: flex;
  align-items: center;
  gap: 12px;
  color: rgba(255, 255, 255, 0.45);
  font-size: 13px;
  padding: 4px 0;
}

/* ── Header inside box ── */
.pdf-report .pdfac-ai-summary-header {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 11px;
  font-weight: 700;
  color: #c4b5fd;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 12px;
}
.pdf-report .pdfac-ai-summary-header svg {
  stroke: #a78bfa;
  flex-shrink: 0;
}

/* ── Summary text ── */
.pdf-report .pdfac-ai-summary-text {
  font-size: 13px;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.88);
}
.pdf-report .pdfac-ai-summary-label {
  display: block;
  color: rgba(255, 255, 255, 0.5);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-top: 12px;
  margin-bottom: 3px;
}
.pdf-report .pdfac-ai-summary-label:first-child {
  margin-top: 0;
}
.pdf-report .pdfac-ai-summary-cached {
  margin-left: 8px;
  font-size: 10px;
  color: rgba(255, 255, 255, 0.3);
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
}

/* ── Error ── */
.pdf-report .pdfac-ai-summary-error {
  font-size: 13px;
  color: rgba(248, 113, 113, 0.85);
  padding: 4px 0;
}

/* ── Mobile ── */
@media (max-width: 600px) {
  .pdf-report .pdfac-ai-summary-btn {
    padding: 13px 16px;
    gap: 12px;
  }
  .pdf-report .pdfac-ai-summary-btn-icon {
    width: 32px;
    height: 32px;
  }
  .pdf-report .pdfac-ai-summary-btn-sub,
  .pdf-report .pdfac-ai-summary-btn-cta {
    display: none;
  }
}

/* ============================================
   PHASE 9 — PDF/UA TAB + COLLAPSIBLE CATEGORIES
   ============================================ */

/* PDF/UA tab button — blue accent to distinguish from WCAG tabs */
.pdf-report .tab-button.pdfac-tab-pdfua.active {
  background: #1e40af;
  box-shadow: 0 2px 8px rgba(30, 64, 175, 0.35);
}

/* ---- Summary header inside PDF/UA tab ---- */
.pdf-report .pdfua-tab-summary {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 20px;
  margin-bottom: 16px;
  background: rgba(15, 23, 42, 0.6);
  border-radius: var(--acc-inner-radius);
  border: 1px solid rgba(255, 255, 255, 0.06);
}

.pdf-report .pdfua-tab-compliant {
  border-left: 3px solid #22c55e;
}

.pdf-report .pdfua-tab-noncompliant {
  border-left: 3px solid #ef4444;
}

.pdf-report .pdfua-tab-icon {
  font-size: 20px;
  font-weight: 700;
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
}

.pdf-report .pdfua-tab-compliant .pdfua-tab-icon {
  background: rgba(34, 197, 94, 0.12);
  color: var(--acc-success);
  border: 1px solid rgba(34, 197, 94, 0.2);
}

.pdf-report .pdfua-tab-noncompliant .pdfua-tab-icon {
  background: rgba(220, 38, 38, 0.12);
  color: #f87171;
  border: 1px solid rgba(220, 38, 38, 0.2);
}

.pdf-report .pdfua-tab-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
}

.pdf-report .pdfua-tab-status {
  font-weight: 600;
  font-size: var(--acc-text-small);
  color: rgba(255, 255, 255, 0.9);
}

.pdf-report .pdfua-tab-profile {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.4);
  font-family: var(--acc-font-code);
}

.pdf-report .pdfua-tab-counts {
  display: flex;
  gap: 12px;
  flex-shrink: 0;
}

.pdf-report .pdfua-tab-passed {
  color: var(--acc-success);
  font-size: var(--acc-text-xsmall);
  font-weight: 600;
}

.pdf-report .pdfua-tab-failed {
  color: #f87171;
  font-size: var(--acc-text-xsmall);
  font-weight: 600;
}

/* ---- Collapsible category container ---- */
.pdf-report .pdfua-category {
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: var(--acc-inner-radius);
  margin-bottom: 6px;
  overflow: hidden;
}

.pdf-report .pdfua-cat-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  cursor: pointer;
  background: rgba(15, 23, 42, 0.4);
  transition: background var(--acc-transition-fast);
  user-select: none;
}

.pdf-report .pdfua-cat-header:hover {
  background: rgba(255, 255, 255, 0.04);
}

.pdf-report .pdfua-cat-arrow {
  width: 16px;
  flex-shrink: 0;
  font-size: 10px;
  color: rgba(255, 255, 255, 0.5);
}

.pdf-report .pdfua-cat-name {
  font-weight: 600;
  font-size: var(--acc-text-small);
  color: rgba(255, 255, 255, 0.85);
}

.pdf-report .pdfua-cat-clause {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.35);
  font-family: var(--acc-font-code);
}

.pdf-report .pdfua-cat-stats {
  margin-left: auto;
  display: flex;
  gap: 10px;
  font-size: var(--acc-text-xsmall);
}

.pdf-report .pdfua-cat-fail {
  color: #f87171;
  font-weight: 600;
}

.pdf-report .pdfua-cat-pass {
  color: #86efac;
  font-weight: 500;
}

/* Rules list inside category */
.pdf-report .pdfua-cat-rules {
  border-top: 1px solid rgba(255, 255, 255, 0.04);
}

/* ---- Single rule row ---- */
.pdf-report .pdfua-rule {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 16px 10px 20px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}

.pdf-report .pdfua-rule:last-child {
  border-bottom: none;
}

.pdf-report .pdfua-rule-failed {
  border-left: 3px solid #ef4444;
  background: rgba(239, 68, 68, 0.03);
}

.pdf-report .pdfua-rule-passed {
  border-left: 3px solid rgba(34, 197, 94, 0.3);
  opacity: 0.7;
}

.pdf-report .pdfua-rule-passed:hover {
  opacity: 1;
}

.pdf-report .pdfua-rule-icon {
  font-size: 12px;
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 2px;
}

.pdf-report .pdfua-rule-failed .pdfua-rule-icon {
  color: #f87171;
}

.pdf-report .pdfua-rule-passed .pdfua-rule-icon {
  color: #86efac;
}

.pdf-report .pdfua-rule-info {
  display: flex;
  flex-direction: column;
  gap: 3px;
  flex: 1;
  min-width: 0;
}

.pdf-report .pdfua-rule-id {
  font-family: var(--acc-font-code);
  font-size: 11px;
  color: rgba(59, 130, 246, 0.8);
  font-weight: 500;
}

.pdf-report .pdfua-rule-desc {
  font-size: var(--acc-text-xsmall);
  color: rgba(255, 255, 255, 0.65);
  line-height: 1.45;
}

.pdf-report .pdfua-rule-hint {
  font-size: 12px;
  color: #fbbf24;
  line-height: 1.4;
  margin-top: 2px;
  padding: 4px 8px;
  background: rgba(251, 191, 36, 0.06);
  border-radius: 4px;
  border-left: 2px solid rgba(251, 191, 36, 0.3);
}

.pdf-report .pdfua-rule-wcag {
  font-size: 10px;
  color: rgba(255, 255, 255, 0.35);
  font-family: var(--acc-font-code);
}

.pdf-report .pdfua-rule-count {
  font-size: 11px;
  color: rgba(248, 113, 113, 0.8);
  font-family: var(--acc-font-code);
  flex-shrink: 0;
  white-space: nowrap;
  margin-top: 2px;
}

/* ---- Passed rules toggle ---- */
.pdf-report .pdfua-passed-toggle {
  padding: 8px 16px 8px 20px;
  font-size: 12px;
  color: rgba(134, 239, 172, 0.7);
  cursor: pointer;
  user-select: none;
  border-top: 1px solid rgba(255, 255, 255, 0.04);
  transition: background var(--acc-transition-fast);
}

.pdf-report .pdfua-passed-toggle:hover {
  background: rgba(255, 255, 255, 0.03);
  color: rgba(134, 239, 172, 1);
}

.pdf-report .pdfua-passed-toggle-icon {
  font-size: 9px;
  display: inline-block;
  width: 12px;
}

.pdf-report .pdfua-passed-rules {
  border-top: 1px solid rgba(255, 255, 255, 0.03);
}

/* ---- What We Check — VeraPDF separator ---- */
.pdf-checker-tool .pdfac-checks-separator {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 20px 0 14px;
  padding: 0 4px;
}

.pdf-checker-tool .pdfac-checks-separator-line {
  flex: 1;
  height: 1px;
  background: rgba(255, 255, 255, 0.08);
}

.pdf-checker-tool .pdfac-checks-separator-text {
  font-size: 10px;
  font-weight: 600;
  color: rgba(59, 130, 246, 0.6);
  white-space: nowrap;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-family: 'Space Mono', 'Courier New', monospace;
}

/* VeraPDF grid uses same pdfac-checks-list class — blue-tinted icons */
.pdf-checker-tool .pdfac-checks-list--vera .pdfac-check-icon {
  color: rgba(96, 165, 250, 0.7);
}

.pdf-checker-tool .pdfac-checks-list--vera .pdfac-check-name {
  color: rgba(255, 255, 255, 0.6);
}

.pdf-checker-tool .pdfac-checks-list--vera .pdfac-check-wcag {
  color: rgba(96, 165, 250, 0.35);
}

/* ---- Phase 9 mobile adjustments ---- */
@media (max-width: 768px) {
  .pdf-report .pdfua-tab-summary {
    flex-wrap: wrap;
    gap: 10px;
    padding: 12px 14px;
  }

  .pdf-report .pdfua-tab-counts {
    width: 100%;
    justify-content: flex-start;
  }

  .pdf-report .pdfua-cat-header {
    padding: 10px 12px;
  }

  .pdf-report .pdfua-rule {
    padding: 8px 12px 8px 14px;
  }

  .pdf-report .pdfua-rule-desc {
    font-size: 11px;
  }
}

/* ═══════════════════════════════════════════════════════════════════
   LUCIDE SVG ICONS — base styles for inline SVG icons
   Replaces all emoji with consistent Lucide icons
   ═══════════════════════════════════════════════════════════════════ */

.pdfac-icon {
  display: inline-block;
  vertical-align: middle;
  flex-shrink: 0;
}

.pdfac-qs-icon .pdfac-icon,
.pdfac-cost-icon .pdfac-icon,
.pdfac-manual-icon .pdfac-icon {
  vertical-align: -2px;
}

.pdfac-struct-ok .pdfac-icon {
  stroke: #22c55e;
}

.pdfua-rule-icon .pdfac-icon {
  vertical-align: -2px;
}

.pdfua-icon .pdfac-icon {
  vertical-align: -2px;
}

/* ============================================
   SCREEN READER PREVIEW — Phase 10.3
   ============================================ */

/* Tab button accent */
.pdf-report .tab-button.pdfac-tab-sr.active {
  background: linear-gradient(135deg, #7c3aed, #6d28d9);
  box-shadow: 0 2px 8px rgba(124, 58, 237, 0.35);
}

/* Warning banner (untagged / truncated) */
.pdfac-sr-warning {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  margin-bottom: 12px;
  background: rgba(180, 83, 9, 0.12);
  border: 1px solid rgba(180, 83, 9, 0.3);
  border-radius: var(--acc-inner-radius);
  color: #fbbf24;
  font-family: var(--acc-font-body);
  font-size: 13px;
  line-height: 1.5;
}

/* ── Player Controls ── */
.pdfac-sr-controls {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  margin-bottom: 12px;
  background: rgba(15, 23, 42, 0.5);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: var(--acc-inner-radius);
}

.pdfac-sr-buttons {
  display: flex;
  gap: 6px;
  align-items: center;
}

.pdfac-sr-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 6px;
  color: rgba(255, 255, 255, 0.7);
  cursor: pointer;
  transition: all 0.15s ease;
}

.pdfac-sr-btn:hover {
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
}

.pdfac-sr-btn.pdfac-sr-play {
  width: 44px;
  height: 44px;
  background: linear-gradient(135deg, #7c3aed, #6d28d9);
  border-color: rgba(124, 58, 237, 0.4);
  color: #fff;
  border-radius: 50%;
}

.pdfac-sr-btn.pdfac-sr-play:hover {
  background: linear-gradient(135deg, #8b5cf6, #7c3aed);
  box-shadow: 0 2px 12px rgba(124, 58, 237, 0.4);
}

.pdfac-sr-speed,
.pdfac-sr-jump {
  display: flex;
  align-items: center;
  gap: 6px;
}

.pdfac-sr-speed-label {
  font-family: var(--acc-font-body);
  font-size: 11px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.4);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.pdfac-sr-speed-select,
.pdfac-sr-jump-select {
  padding: 5px 8px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 4px;
  color: rgba(255, 255, 255, 0.8);
  font-family: var(--acc-font-body);
  font-size: 12px;
  cursor: pointer;
}

.pdfac-sr-speed-select:focus,
.pdfac-sr-jump-select:focus {
  outline: 2px solid rgba(124, 58, 237, 0.5);
  outline-offset: 1px;
}

.pdfac-sr-speed-select option,
.pdfac-sr-jump-select option {
  background: #1a2234;
  color: #fff;
}

/* Progress bar */
.pdfac-sr-progress-wrap {
  flex: 1;
  min-width: 120px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.pdfac-sr-progress-bar {
  flex: 1;
  height: 4px;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 2px;
  overflow: hidden;
}

.pdfac-sr-progress-fill {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, #7c3aed, #a78bfa);
  border-radius: 2px;
  transition: width 0.2s ease;
}

.pdfac-sr-counter {
  font-family: var(--acc-font-code);
  font-size: 11px;
  color: rgba(255, 255, 255, 0.4);
  white-space: nowrap;
}

/* ── Announcement Box ── */
.pdfac-sr-announcement {
  padding: 16px 18px;
  margin-bottom: 12px;
  background: rgba(15, 23, 42, 0.7);
  border: 1px solid rgba(124, 58, 237, 0.2);
  border-radius: var(--acc-inner-radius);
  min-height: 80px;
}

.pdfac-sr-ann-type {
  font-family: var(--acc-font-code);
  font-size: 10px;
  font-weight: 700;
  color: #a78bfa;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 6px;
}

.pdfac-sr-ann-text {
  font-family: var(--acc-font-code);
  font-size: 16px;
  line-height: 1.6;
  color: #fff;
  word-break: break-word;
}

.pdfac-sr-ann-next {
  margin-top: 10px;
  font-family: var(--acc-font-body);
  font-size: 12px;
  color: rgba(255, 255, 255, 0.35);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ── Reading Order List ── */
.pdfac-sr-list-wrap {
  margin-top: 4px;
}

.pdfac-sr-list {
  max-height: 400px;
  overflow-y: auto;
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: var(--acc-inner-radius);
  background: rgba(15, 23, 42, 0.3);
}

.pdfac-sr-list::-webkit-scrollbar {
  width: 6px;
}

.pdfac-sr-list::-webkit-scrollbar-track {
  background: transparent;
}

.pdfac-sr-list::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 3px;
}

.pdfac-sr-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.03);
  cursor: pointer;
  transition: background 0.12s ease;
}

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

.pdfac-sr-item:hover {
  background: rgba(255, 255, 255, 0.04);
}

.pdfac-sr-item.pdfac-sr-active {
  background: rgba(124, 58, 237, 0.15);
  border-left: 3px solid #7c3aed;
  padding-left: 9px;
}

.pdfac-sr-item.pdfac-sr-item-warning {
  background: rgba(180, 83, 9, 0.08);
}

.pdfac-sr-item-num {
  font-family: var(--acc-font-code);
  font-size: 10px;
  color: rgba(255, 255, 255, 0.25);
  min-width: 28px;
  text-align: right;
}

.pdfac-sr-item-text {
  flex: 1;
  font-family: var(--acc-font-body);
  font-size: 13px;
  color: rgba(255, 255, 255, 0.6);
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.pdfac-sr-item.pdfac-sr-active .pdfac-sr-item-text {
  color: #fff;
}

.pdfac-sr-item-page {
  font-family: var(--acc-font-code);
  font-size: 10px;
  color: rgba(255, 255, 255, 0.2);
  white-space: nowrap;
}

/* Type badges */
.pdfac-sr-type-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  padding: 2px 6px;
  border-radius: 3px;
  font-family: var(--acc-font-code);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.3px;
  text-align: center;
  flex-shrink: 0;
}

.pdfac-sr-type-heading {
  background: rgba(37, 99, 235, 0.2);
  color: #60a5fa;
}

.pdfac-sr-type-para {
  background: rgba(255, 255, 255, 0.06);
  color: rgba(255, 255, 255, 0.35);
}

.pdfac-sr-type-img {
  background: rgba(34, 197, 94, 0.15);
  color: #4ade80;
}

.pdfac-sr-type-table {
  background: rgba(168, 85, 247, 0.15);
  color: #c084fc;
}

.pdfac-sr-type-link {
  background: rgba(6, 182, 212, 0.15);
  color: #22d3ee;
}

.pdfac-sr-type-list {
  background: rgba(251, 191, 36, 0.12);
  color: #fbbf24;
}

.pdfac-sr-type-form {
  background: rgba(251, 146, 60, 0.15);
  color: #fb923c;
}

.pdfac-sr-type-page {
  background: rgba(255, 255, 255, 0.04);
  color: rgba(255, 255, 255, 0.2);
  font-style: italic;
}

.pdfac-sr-type-other {
  background: rgba(255, 255, 255, 0.06);
  color: rgba(255, 255, 255, 0.3);
}

/* Load more button */
.pdfac-sr-load-more {
  display: block;
  width: 100%;
  margin-top: 8px;
  padding: 10px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px dashed rgba(255, 255, 255, 0.1);
  border-radius: var(--acc-inner-radius);
  color: rgba(255, 255, 255, 0.5);
  font-family: var(--acc-font-body);
  font-size: 13px;
  cursor: pointer;
  transition: all 0.15s ease;
}

.pdfac-sr-load-more:hover {
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.8);
}

/* ── Issues in Reading Order panel ── */
.pdfac-sr-issues {
  margin-top: 14px;
  border: 1px solid rgba(220, 38, 38, 0.15);
  border-radius: var(--acc-inner-radius);
  background: rgba(220, 38, 38, 0.04);
  overflow: hidden;
}

.pdfac-sr-issues-header {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 14px;
  font-family: var(--acc-font-body);
  font-size: 12px;
  font-weight: 600;
  color: #fca5a5;
  border-bottom: 1px solid rgba(220, 38, 38, 0.1);
}

.pdfac-sr-issue-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.03);
  font-family: var(--acc-font-body);
  font-size: 12px;
  color: rgba(255, 255, 255, 0.6);
  cursor: pointer;
  transition: background 0.12s ease;
}

.pdfac-sr-issue-item:last-child {
  border-bottom: none;
}

.pdfac-sr-issue-item:hover {
  background: rgba(255, 255, 255, 0.04);
}

.pdfac-sr-issue-item[data-sr-issue-jump] {
  cursor: pointer;
}

.pdfac-sr-issue-sev {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 3px;
  font-family: var(--acc-font-code);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  flex-shrink: 0;
}

.pdfac-sr-issue-critical .pdfac-sr-issue-sev {
  background: rgba(220, 38, 38, 0.2);
  color: #fca5a5;
}

.pdfac-sr-issue-warning .pdfac-sr-issue-sev {
  background: rgba(180, 83, 9, 0.2);
  color: #fbbf24;
}

.pdfac-sr-issue-msg {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.pdfac-sr-issue-goto {
  color: #a78bfa;
  font-weight: 700;
  flex-shrink: 0;
}

/* ── SR responsive ── */
@media (max-width: 640px) {
  .pdfac-sr-controls {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }

  .pdfac-sr-buttons {
    justify-content: center;
  }

  .pdfac-sr-speed,
  .pdfac-sr-jump {
    justify-content: center;
  }

  .pdfac-sr-progress-wrap {
    min-width: 100%;
  }

  .pdfac-sr-ann-text {
    font-size: 14px;
  }

  .pdfac-sr-list {
    max-height: 300px;
  }
}

/* Focus visible for keyboard navigation */
.pdfac-sr-btn:focus-visible,
.pdfac-sr-item:focus-visible {
  outline: 2px solid #a78bfa;
  outline-offset: 2px;
}

#pdfac-tab-screenreader:focus {
  outline: none;
}

#pdfac-tab-screenreader:focus-visible {
  outline: 2px solid rgba(124, 58, 237, 0.4);
  outline-offset: -2px;
}
