/* ═══════════════════════════════════════════════════════
   QUANTA — View Styles (Selector, Lobby, Exam, Results, Review)
   ═══════════════════════════════════════════════════════ */

/* ════════════════ SELECTOR VIEW ════════════════ */
.selector-view {
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
}

.selector-hero {
  padding: var(--sp-16) 0 var(--sp-12);
  text-align: center;
}

.selector-eyebrow {
  font-family: var(--ff-mono);
  font-size: var(--text-xs);
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  margin-bottom: var(--sp-4);
}

.selector-hero-title {
  font-size: clamp(var(--text-3xl), 6vw, var(--text-4xl));
  margin-bottom: var(--sp-4);
  letter-spacing: -0.04em;
}

.selector-hero-sub {
  font-size: var(--text-md);
  color: var(--text-2);
  max-width: 420px;
  margin: 0 auto;
}

.selector-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--sp-5);
  padding-bottom: var(--sp-16);
}

/* Exam Card */
.exam-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--sp-6);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  transition:
    border-color var(--dur) var(--ease),
    box-shadow var(--dur) var(--ease),
    transform var(--dur) var(--ease-spring);
  box-shadow: var(--shadow-xs);
  position: relative;
  overflow: hidden;
}

.exam-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur) var(--ease-spring);
}

.exam-card:hover {
  border-color: var(--border-hi);
  box-shadow: var(--shadow-lg);
  transform: translateY(-3px);
}

.exam-card:hover::before { transform: scaleX(1); }
.exam-card:active { transform: translateY(0); }

.exam-card-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-3);
}

.exam-card-id {
  font-family: var(--ff-mono);
  font-size: var(--text-xs);
  color: var(--text-3);
  letter-spacing: 0.06em;
}

.exam-card-title {
  font-family: var(--ff-display);
  font-size: var(--text-xl);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.2;
  color: var(--text-1);
}

.exam-card-desc {
  font-size: var(--text-sm);
  color: var(--text-2);
  line-height: 1.6;
  flex: 1;
}

.exam-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
}

.exam-card-footer {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--border);
  margin-top: auto;
}

.exam-card-stat {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  font-family: var(--ff-mono);
  font-size: var(--text-xs);
  color: var(--text-3);
}

.exam-card-arrow {
  margin-left: auto;
  color: var(--accent);
  font-size: 1rem;
  opacity: 0;
  transform: translateX(-4px);
  transition: all var(--dur) var(--ease);
}

.exam-card:hover .exam-card-arrow {
  opacity: 1;
  transform: translateX(0);
}

/* Loading skeleton */
.skeleton {
  background: linear-gradient(90deg, var(--surface-2) 25%, var(--surface-3) 50%, var(--surface-2) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: var(--r-sm);
}

@keyframes shimmer {
  from { background-position: 200% 0; }
  to   { background-position: -200% 0; }
}

/* ════════════════ LOBBY VIEW ════════════════ */
.lobby-view {
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
}

.lobby-wrap {
  flex: 1;
  padding: var(--sp-10) 0 var(--sp-16);
}

.lobby-back {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--text-sm);
  color: var(--text-2);
  cursor: pointer;
  margin-bottom: var(--sp-8);
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--r-sm);
  transition: all var(--dur-fast) var(--ease);
  background: none;
  border: none;
  font-family: var(--ff-body);
}
.lobby-back:hover { color: var(--text-1); background: var(--surface-2); }

.lobby-header {
  margin-bottom: var(--sp-10);
}

.lobby-title {
  font-size: clamp(var(--text-2xl), 4vw, var(--text-3xl));
  margin-bottom: var(--sp-3);
  letter-spacing: -0.035em;
}

.lobby-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  align-items: center;
}

.lobby-section-title {
  font-family: var(--ff-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-3);
  margin-bottom: var(--sp-4);
}

/* Mode Cards */
.mode-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-4);
  margin-bottom: var(--sp-8);
}

@media (max-width: 540px) { .mode-grid { grid-template-columns: 1fr; } }

.mode-card {
  position: relative;
  background: var(--surface);
  border: 2px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--sp-6);
  cursor: pointer;
  transition:
    border-color var(--dur) var(--ease),
    background var(--dur) var(--ease),
    box-shadow var(--dur) var(--ease);
}

.mode-card:hover { border-color: var(--border-hi); }

.mode-card.selected {
  border-color: var(--accent);
  background: var(--accent-muted);
}

.mode-card-icon {
  font-size: 1.75rem;
  margin-bottom: var(--sp-3);
  display: block;
}

.mode-card-name {
  font-family: var(--ff-display);
  font-size: var(--text-lg);
  font-weight: 700;
  margin-bottom: var(--sp-2);
}

.mode-card-desc {
  font-size: var(--text-sm);
  color: var(--text-2);
  line-height: 1.55;
}

.mode-card-check {
  position: absolute;
  top: var(--sp-4);
  right: var(--sp-4);
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--accent);
  color: white;
  font-size: 12px;
  display: none;
  align-items: center;
  justify-content: center;
}

.mode-card.selected .mode-card-check { display: flex; }

/* Config Section */
.config-section {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--sp-6);
  margin-bottom: var(--sp-8);
}

.timer-chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin-top: var(--sp-3);
}

.timer-chip {
  padding: var(--sp-2) var(--sp-4);
  border-radius: var(--r-full);
  border: 1px solid var(--border);
  background: var(--surface-2);
  color: var(--text-2);
  font-family: var(--ff-mono);
  font-size: var(--text-sm);
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease);
}

.timer-chip:hover { border-color: var(--accent); color: var(--accent); }
.timer-chip.active {
  background: var(--accent-dim);
  border-color: var(--accent);
  color: var(--accent);
  font-weight: 500;
}

/* ════════════════ EXAM VIEW ════════════════ */
.exam-view {
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
}

/* Thin progress bar at very top */
.exam-progress-strip {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--surface-3);
  z-index: 99;
}

.exam-progress-strip .progress-fill {
  height: 100%;
  background: var(--accent);
  transition: width 0.4s var(--ease);
}

/* Exam topbar */
.exam-topbar {
  position: sticky;
  top: 0;
  z-index: 90;
  background: color-mix(in srgb, var(--bg) 90%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border);
  padding: 0 var(--sp-6);
  height: 52px;
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  margin-top: 2px; /* below progress strip */
}

.exam-topbar-brand {
  font-family: var(--ff-display);
  font-size: var(--text-md);
  font-weight: 800;
  letter-spacing: -0.04em;
  color: var(--text-1);
}
.exam-topbar-brand span { color: var(--accent); }

.exam-topbar-section {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--text-xs);
  color: var(--text-2);
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-full);
  padding: 3px var(--sp-3);
  max-width: 220px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.exam-topbar-spacer { flex: 1; }

.exam-timer {
  font-family: var(--ff-mono);
  font-size: var(--text-base);
  font-weight: 500;
  color: var(--text-1);
  letter-spacing: 0.04em;
  min-width: 56px;
  text-align: right;
}
.exam-timer.warning { color: var(--err); animation: pulse 1s ease infinite; }
.exam-timer.hidden { display: none; }

.exam-map-btn {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  padding: var(--sp-1) var(--sp-3);
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text-2);
  font-size: var(--text-xs);
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease);
}
.exam-map-btn:hover { border-color: var(--border-hi); color: var(--text-1); }

/* Question Area */
.question-area {
  flex: 1;
  max-width: 720px;
  width: 100%;
  margin: 0 auto;
  padding: var(--sp-10) var(--sp-6) var(--sp-16);
}

.question-meta {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-bottom: var(--sp-6);
}

.question-num {
  font-family: var(--ff-mono);
  font-size: var(--text-sm);
  color: var(--text-3);
}

.question-text {
  font-size: clamp(var(--text-md), 2.5vw, var(--text-lg));
  line-height: 1.7;
  color: var(--text-1);
  margin-bottom: var(--sp-8);
  font-family: var(--ff-body);
  font-weight: 400;
}

/* Options */
.options-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  margin-bottom: var(--sp-8);
}

.option-btn {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-4);
  padding: var(--sp-4) var(--sp-5);
  border-radius: var(--r-lg);
  border: 1.5px solid var(--border);
  background: var(--surface);
  cursor: pointer;
  text-align: left;
  width: 100%;
  transition:
    border-color var(--dur-fast) var(--ease),
    background var(--dur-fast) var(--ease),
    transform var(--dur-fast) var(--ease-spring);
}

.option-btn:hover:not(:disabled) {
  border-color: var(--border-hi);
  background: var(--surface-2);
}

.option-btn:active:not(:disabled) { transform: scale(0.99); }
.option-btn:disabled { cursor: default; }

/* Selected state (exam mode) */
.option-btn.is-selected {
  border-color: var(--accent);
  background: var(--accent-muted);
}

/* Revealed states (practice mode) */
.option-btn.is-correct {
  border-color: var(--ok);
  background: var(--ok-dim);
  cursor: default;
}

.option-btn.is-wrong {
  border-color: var(--err);
  background: var(--err-dim);
  cursor: default;
}

.option-btn.is-neutral {
  opacity: 0.5;
  cursor: default;
}

.option-key {
  width: 28px;
  height: 28px;
  border-radius: var(--r-xs);
  border: 1px solid var(--border-hi);
  background: var(--surface-2);
  color: var(--text-2);
  font-family: var(--ff-mono);
  font-size: var(--text-xs);
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all var(--dur-fast) var(--ease);
}

.option-btn.is-selected .option-key {
  background: var(--accent);
  border-color: var(--accent);
  color: white;
}

.option-btn.is-correct .option-key {
  background: var(--ok);
  border-color: var(--ok);
  color: white;
}

.option-btn.is-wrong .option-key {
  background: var(--err);
  border-color: var(--err);
  color: white;
}

.option-text {
  flex: 1;
  font-size: var(--text-base);
  color: var(--text-1);
  line-height: 1.55;
  padding-top: 4px;
}

/* Practice feedback panel */
.feedback-panel {
  display: none;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent);
  border-radius: var(--r-md);
  padding: var(--sp-5) var(--sp-6);
  margin-bottom: var(--sp-6);
  animation: slideDown var(--dur-slow) var(--ease-out) both;
}

.feedback-panel.visible { display: block; }

.feedback-verdict {
  font-family: var(--ff-display);
  font-size: var(--text-md);
  font-weight: 700;
  margin-bottom: var(--sp-2);
}

.feedback-verdict.correct { color: var(--ok); }
.feedback-verdict.incorrect { color: var(--err); }

.feedback-panel.correct-panel { border-left-color: var(--ok); }
.feedback-panel.incorrect-panel { border-left-color: var(--err); }

.feedback-explanation {
  font-size: var(--text-sm);
  color: var(--text-2);
  line-height: 1.65;
}

/* Exam Footer Nav */
.exam-footer {
  position: sticky;
  bottom: 0;
  background: color-mix(in srgb, var(--bg) 92%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-top: 1px solid var(--border);
  padding: var(--sp-4) var(--sp-6);
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  max-width: 720px;
  width: 100%;
  margin: 0 auto;
}

/* Override: footer needs to span full width with content centered */
.exam-view .exam-footer-outer {
  position: sticky;
  bottom: 0;
  background: color-mix(in srgb, var(--bg) 92%, transparent);
  backdrop-filter: blur(12px);
  border-top: 1px solid var(--border);
}

.exam-view .exam-footer-inner {
  max-width: 720px;
  margin: 0 auto;
  padding: var(--sp-4) var(--sp-6);
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}

.exam-footer-spacer { flex: 1; }

.flag-btn {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-4);
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text-2);
  font-size: var(--text-xs);
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease);
}
.flag-btn:hover { border-color: var(--warn); color: var(--warn); }
.flag-btn.flagged { background: var(--warn-dim); border-color: rgba(217,119,6,0.3); color: var(--warn); }

/* Question Map Panel */
.qmap-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(6px);
  z-index: 200;
  display: none;
  align-items: flex-end;
  justify-content: center;
  padding: 0;
}

.qmap-overlay:not(.is-hidden) {
  display: flex;
  animation: fadeIn var(--dur) var(--ease-out);
}

@media (min-width: 640px) {
  .qmap-overlay:not(.is-hidden) { align-items: center; padding: var(--sp-6); }
}

.qmap-panel {
  background: var(--surface);
  border: 1px solid var(--border-hi);
  border-radius: var(--r-xl) var(--r-xl) 0 0;
  padding: var(--sp-6);
  width: 100%;
  max-width: 520px;
  max-height: 75dvh;
  overflow-y: auto;
  box-shadow: var(--shadow-xl);
  animation: slideUp var(--dur-slow) var(--ease-spring);
}

@media (min-width: 640px) {
  .qmap-panel {
    border-radius: var(--r-xl);
    animation: scaleIn var(--dur-slow) var(--ease-spring);
  }
}

.qmap-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-5);
}

.qmap-title {
  font-family: var(--ff-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-3);
}

.qmap-legend {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-4);
  margin-bottom: var(--sp-5);
}

.qmap-legend-item {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--text-xs);
  color: var(--text-2);
}

.qmap-dot {
  width: 10px;
  height: 10px;
  border-radius: 3px;
}

.qmap-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(40px, 1fr));
  gap: var(--sp-2);
  margin-bottom: var(--sp-6);
}

.qmap-btn {
  aspect-ratio: 1;
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
  background: var(--surface-2);
  color: var(--text-3);
  font-family: var(--ff-mono);
  font-size: var(--text-xs);
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease);
  display: flex;
  align-items: center;
  justify-content: center;
}

.qmap-btn:hover { border-color: var(--accent); color: var(--accent); }
.qmap-btn.answered { background: var(--accent-dim); border-color: var(--accent); color: var(--accent); }
.qmap-btn.flagged  { background: var(--warn-dim); border-color: rgba(217,119,6,0.4); color: var(--warn); }
.qmap-btn.current  { background: var(--accent); border-color: var(--accent); color: white; }

/* ════════════════ RESULTS VIEW ════════════════ */
.results-view {
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
}

.results-wrap {
  flex: 1;
  padding: var(--sp-10) 0 var(--sp-16);
}

.results-hero {
  text-align: center;
  padding: var(--sp-10) var(--sp-6);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  margin-bottom: var(--sp-6);
}

.verdict-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-5);
  border-radius: var(--r-full);
  font-family: var(--ff-mono);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.06em;
  margin-bottom: var(--sp-4);
}

.verdict-badge.pass { background: var(--ok-dim); color: var(--ok); border: 1px solid var(--ok-border); }
.verdict-badge.fail { background: var(--err-dim); color: var(--err); border: 1px solid var(--err-border); }

.results-tagline {
  font-size: var(--text-base);
  color: var(--text-2);
}

.results-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
  margin-bottom: var(--sp-6);
}

@media (max-width: 480px) { .results-stats { grid-template-columns: 1fr 1fr; } }

.stat-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-5) var(--sp-4);
  text-align: center;
}

.stat-val {
  font-family: var(--ff-mono);
  font-size: var(--text-2xl);
  font-weight: 500;
  color: var(--text-1);
  display: block;
  line-height: 1;
  margin-bottom: var(--sp-2);
}

.stat-label {
  font-size: var(--text-xs);
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

/* Section breakdown */
.breakdown-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--sp-6);
  margin-bottom: var(--sp-6);
}

.breakdown-title {
  font-family: var(--ff-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-3);
  margin-bottom: var(--sp-5);
}

.breakdown-row {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-bottom: var(--sp-4);
}

.breakdown-row:last-child { margin-bottom: 0; }

.breakdown-name {
  flex: 1;
  font-size: var(--text-sm);
  color: var(--text-1);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.breakdown-score {
  font-family: var(--ff-mono);
  font-size: var(--text-sm);
  color: var(--text-2);
  min-width: 40px;
  text-align: right;
  flex-shrink: 0;
}

.breakdown-track {
  width: 100px;
  height: 5px;
  background: var(--surface-3);
  border-radius: var(--r-full);
  overflow: hidden;
  flex-shrink: 0;
}

.breakdown-fill {
  height: 100%;
  border-radius: var(--r-full);
  transition: width 1.2s var(--ease);
}

.results-actions {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-3);
}

@media (max-width: 480px) { .results-actions { grid-template-columns: 1fr; } }
.results-actions .btn { justify-content: center; }

/* ════════════════ REVIEW VIEW ════════════════ */
.review-view {
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
}

.review-wrap {
  flex: 1;
  padding: var(--sp-8) 0 var(--sp-16);
}

.review-header {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  margin-bottom: var(--sp-6);
  padding-bottom: var(--sp-6);
  border-bottom: 1px solid var(--border);
}

.review-title {
  font-size: var(--text-2xl);
  letter-spacing: -0.03em;
  flex: 1;
}

.filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin-bottom: var(--sp-6);
}

.filter-btn {
  padding: var(--sp-2) var(--sp-4);
  border-radius: var(--r-full);
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text-2);
  font-size: var(--text-xs);
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease);
  font-family: var(--ff-body);
}
.filter-btn:hover { border-color: var(--accent); color: var(--accent); }
.filter-btn.active { background: var(--accent-dim); border-color: var(--accent); color: var(--accent); font-weight: 500; }

.review-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}

.review-item {
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 3px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-5) var(--sp-6);
  animation: fadeUp var(--dur-slow) var(--ease-out) both;
}

.review-item.correct   { border-left-color: var(--ok); }
.review-item.incorrect { border-left-color: var(--err); }
.review-item.skipped   { border-left-color: var(--text-3); }

.review-item-top {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  margin-bottom: var(--sp-4);
}

.review-qnum {
  font-family: var(--ff-mono);
  font-size: var(--text-xs);
  color: var(--text-3);
  flex-shrink: 0;
  margin-top: 2px;
}

.review-question-text {
  font-size: var(--text-base);
  color: var(--text-1);
  line-height: 1.55;
  flex: 1;
}

.review-options {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-2);
  margin-bottom: var(--sp-4);
}

@media (max-width: 500px) { .review-options { grid-template-columns: 1fr; } }

.review-opt {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--r-sm);
  font-size: var(--text-sm);
  border: 1px solid var(--border);
  color: var(--text-2);
  line-height: 1.45;
}

.review-opt.was-correct  { background: var(--ok-dim);  border-color: var(--ok-border);  color: var(--ok); }
.review-opt.was-selected { background: var(--err-dim); border-color: var(--err-border); color: var(--err); }

.review-opt-key {
  font-family: var(--ff-mono);
  font-weight: 500;
  flex-shrink: 0;
  font-size: var(--text-xs);
  margin-top: 1px;
}

.review-explanation {
  background: var(--surface-2);
  border-left: 3px solid var(--accent);
  border-radius: 0 var(--r-sm) var(--r-sm) 0;
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--text-sm);
  color: var(--text-2);
  line-height: 1.6;
}

.review-explanation strong { color: var(--accent); font-weight: 600; }

/* ── Mobile responsive tweaks ── */
@media (max-width: 640px) {
  .exam-topbar { padding: 0 var(--sp-4); }
  .question-area { padding: var(--sp-6) var(--sp-4) var(--sp-12); }
  .exam-view .exam-footer-inner { padding: var(--sp-3) var(--sp-4); }
  .results-stats { grid-template-columns: 1fr 1fr; }
  .breakdown-track { width: 60px; }
  .selector-hero { padding: var(--sp-10) 0 var(--sp-8); }
}