/* ============================================================
   Quizzly Prep · site styles
   Built entirely on the design-system tokens (../styles.css at the
   repo root, vendored into site/ as styles.css + tokens/ so the site
   is self-contained).
   ============================================================ */

/* ---------- Layout shell ---------- */
.qp-container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--gutter);
}
.qp-narrow { max-width: var(--container-narrow); }

/* ---------- Header ---------- */
.qp-header {
  position: sticky;
  top: 0;
  z-index: 20;
  background: color-mix(in srgb, var(--paper) 88%, transparent);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
}
.qp-header__inner {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  min-height: 64px;
}
.qp-header__brand {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
  color: var(--text-strong);
}
.qp-header__brand img { width: 36px; height: 36px; border-radius: 10px; display: block; }
.qp-header__name {
  font-family: var(--font-display);
  font-weight: var(--fw-heavy);
  font-size: var(--fs-h4);
  letter-spacing: var(--ls-tight);
}
.qp-header__tag {
  margin-left: var(--space-1);
  font-family: var(--font-sans);
  font-weight: var(--fw-heavy);
  font-size: var(--fs-xs);
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--brand);
  background: var(--brand-tint);
  border-radius: var(--radius-pill);
  padding: 3px 10px;
}
.qp-header__spacer { flex: 1; }

/* ---------- Buttons (tactile signature) ---------- */
.qp-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  min-height: var(--field-height);
  padding: 0 var(--space-6);
  border: none;
  border-radius: var(--radius-md);
  font-family: var(--font-sans);
  font-weight: var(--fw-heavy);
  font-size: var(--fs-body);
  cursor: pointer;
  text-decoration: none;
  transition: transform var(--dur-fast) var(--ease-standard),
    background var(--dur-fast) var(--ease-standard),
    box-shadow var(--dur-fast) var(--ease-standard);
  -webkit-tap-highlight-color: transparent;
}
.qp-btn:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.qp-btn--primary {
  background: var(--brand);
  color: var(--text-on-brand);
  box-shadow: var(--edge-brand);
}
.qp-btn--primary:hover { background: var(--pine-700); }
.qp-btn--primary:active { transform: translateY(2px); box-shadow: inset 0 0 0 var(--pine-700); }
.qp-btn--primary:focus-visible { box-shadow: var(--edge-brand), var(--focus-ring); }
.qp-btn--accent {
  background: var(--accent);
  color: var(--text-on-accent);
  box-shadow: var(--edge-accent);
}
.qp-btn--accent:hover { background: var(--honey-600); color: #fff; }
.qp-btn--accent:active { transform: translateY(2px); box-shadow: inset 0 0 0 var(--honey-600); }
.qp-btn--ghost {
  background: var(--surface);
  color: var(--text-strong);
  border: 2px solid var(--line-strong);
  box-shadow: var(--edge-neutral);
}
.qp-btn--ghost:hover { border-color: var(--pine-200); }
.qp-btn--ghost:active { transform: translateY(2px); box-shadow: inset 0 0 0 var(--line-strong); }
.qp-btn[disabled] {
  background: var(--surface-sunken);
  color: var(--ink-300);
  box-shadow: none;
  cursor: default;
  transform: none;
}
.qp-btn .lucide { width: 20px; height: 20px; }

/* ---------- Hero ---------- */
.qp-hero { padding: var(--space-16) 0 var(--space-12); }
.qp-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-10);
  align-items: center;
}
.qp-hero h1 {
  font-size: clamp(2.2rem, 5vw, var(--fs-display));
  font-weight: var(--fw-heavy);
  max-width: 15em;
}
.qp-hero h1 em { font-style: normal; color: var(--brand); }
.qp-hero__lede {
  font-size: var(--fs-lg);
  color: var(--text-body);
  max-width: 34em;
  margin: 0 0 var(--space-6);
  line-height: var(--lh-relaxed);
}
.qp-hero__mascot {
  width: 148px;
  height: 148px;
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-lg);
}
.qp-hero__points {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-6);
  padding: 0;
  list-style: none;
}
.qp-hero__points li {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-pill);
  padding: 8px 16px;
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  color: var(--text-body);
}
.qp-hero__points .lucide { width: 18px; height: 18px; color: var(--brand); }

/* ---------- Section headings ---------- */
.qp-section { padding: var(--space-8) 0; }
.qp-section__head { margin-bottom: var(--space-6); }
.qp-section__head h2 { font-size: var(--fs-h2); margin-bottom: var(--space-1); }
.qp-section__head p { margin: 0; color: var(--text-muted); }

/* ---------- Region blocks ---------- */
.qp-region {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  margin-bottom: var(--space-8);
}
.qp-region__head { margin-bottom: var(--space-6); }
.qp-region__head h3 { font-size: var(--fs-h3); margin-bottom: var(--space-1); }
.qp-region__head p { margin: 0; color: var(--text-muted); max-width: 46em; }

.qp-subjects {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: var(--space-4);
}

/* ---------- Subject cards ---------- */
.qp-subject {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  background: var(--color-bg);
  border: 2px solid var(--line);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  text-decoration: none;
  color: var(--text-body);
  box-shadow: inset 0 -4px 0 var(--line);
  transition: transform var(--dur-fast) var(--ease-standard),
    border-color var(--dur-fast) var(--ease-standard),
    box-shadow var(--dur-fast) var(--ease-standard);
}
.qp-subject:hover { transform: translateY(-2px); border-color: var(--subj); box-shadow: inset 0 -4px 0 var(--subj), var(--shadow-sm); }
.qp-subject:active { transform: translateY(2px); box-shadow: inset 0 0 0 var(--subj); }
.qp-subject:focus-visible { outline: none; box-shadow: inset 0 -4px 0 var(--subj), var(--focus-ring); }
.qp-subject__icon {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--subj-tint);
  color: var(--subj);
}
.qp-subject__icon .lucide { width: 24px; height: 24px; }
.qp-subject h4 { font-size: var(--fs-h4); margin: 0; }
.qp-subject p { margin: 0; font-size: var(--fs-sm); color: var(--text-muted); flex: 1; }
.qp-subject__meta {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-size: var(--fs-sm);
  color: var(--text-muted);
}
.qp-subject__meta .lucide { width: 16px; height: 16px; }
.qp-subject__progress {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.qp-subject__bar {
  flex: 1;
  height: 8px;
  background: var(--surface-sunken);
  border-radius: var(--radius-pill);
  overflow: hidden;
}
.qp-subject__fill {
  display: block;
  height: 100%;
  background: var(--subj);
  border-radius: var(--radius-pill);
}
.qp-subject__pct {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-size: var(--fs-xs, var(--fs-sm));
  color: var(--text-muted);
  white-space: nowrap;
}

/* Subject hues (from the DS subject coding) */
.qp-subject--sky   { --subj: var(--sky-500);   --subj-tint: var(--sky-100); }
.qp-subject--pine  { --subj: var(--pine-600);  --subj-tint: var(--pine-50); }
.qp-subject--honey { --subj: var(--honey-600); --subj-tint: var(--honey-50); }
.qp-subject--coral { --subj: var(--coral-600); --subj-tint: var(--coral-50); }
.qp-subject--plum  { --subj: var(--plum-500);  --subj-tint: var(--plum-100); }

/* ---------- Coming soon ---------- */
.qp-soon {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-4);
}
.qp-soon__card {
  border: 2px dashed var(--line-strong);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  color: var(--text-muted);
}
.qp-soon__card .q-eyebrow { display: block; margin-bottom: var(--space-1); }
.qp-soon__card strong {
  font-family: var(--font-display);
  font-size: var(--fs-h4);
  color: var(--text-body);
}

/* ---------- Footer ---------- */
.qp-footer {
  border-top: 1px solid var(--line);
  margin-top: var(--space-12);
  padding: var(--space-8) 0;
  color: var(--text-muted);
  font-size: var(--fs-sm);
}

/* ============================================================
   Quiz player
   ============================================================ */
.qp-quiz { padding: var(--space-8) 0 var(--space-16); }

.qp-quiz__top {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}
.qp-quiz__crumbs { flex: 1; min-width: 200px; }
.qp-quiz__crumbs .q-eyebrow { display: block; }
.qp-quiz__crumbs h1 { font-size: var(--fs-h3); margin: 2px 0 0; }
.qp-scorepill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-pill);
  padding: 8px 16px;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-weight: var(--fw-bold);
  color: var(--text-strong);
}
.qp-scorepill .lucide { width: 18px; height: 18px; color: var(--honey-600); }

/* Progress */
.qp-progress {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-6);
}
.qp-progress__track {
  flex: 1;
  height: 10px;
  background: var(--surface-sunken);
  border-radius: var(--radius-pill);
  overflow: hidden;
}
.qp-progress__fill {
  height: 100%;
  width: 0;
  background: var(--brand);
  border-radius: var(--radius-pill);
  transition: width var(--dur-slow) var(--ease-out);
}
.qp-progress__label {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-size: var(--fs-sm);
  color: var(--text-muted);
  white-space: nowrap;
}

/* Mastery progress (how many of the whole bank are cleared) */
.qp-mastery {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin: 0 0 var(--space-4);
  font-size: var(--fs-sm);
  color: var(--text-muted);
}
.qp-mastery .lucide { width: 16px; height: 16px; color: var(--honey-600); flex: none; }
.qp-mastery .q-num { color: var(--text-strong); font-weight: var(--fw-bold); }

/* Reset-progress link button */
.qp-linkbtn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-4);
  padding: 6px 8px;
  background: none;
  border: none;
  cursor: pointer;
  font: inherit;
  font-size: var(--fs-sm);
  color: var(--text-muted);
  border-radius: var(--radius-sm);
}
.qp-linkbtn:hover { color: var(--danger); }
.qp-linkbtn .lucide { width: 16px; height: 16px; }

/* Mastery panel on the results screen */
.qp-mastery-panel {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  max-width: 34em;
  margin: 0 auto var(--space-6);
  padding: var(--space-4);
  background: var(--surface-sunken);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  font-size: var(--fs-sm);
  color: var(--text-muted);
}
.qp-mastery-panel .q-num { color: var(--text-strong); font-weight: var(--fw-bold); }
.qp-mastery-panel__bar {
  height: 10px;
  background: var(--surface);
  border-radius: var(--radius-pill);
  overflow: hidden;
}
.qp-mastery-panel__fill {
  height: 100%;
  background: var(--brand);
  border-radius: var(--radius-pill);
  transition: width var(--dur-slow) var(--ease-out);
}
.qp-mastery-panel--done {
  flex-direction: row;
  align-items: center;
  gap: var(--space-3);
  text-align: left;
  background: var(--pine-50, var(--surface-sunken));
  border-color: var(--pine-200);
  color: var(--text-strong);
}
.qp-mastery-panel--done .lucide { width: 28px; height: 28px; color: var(--pine-600); flex: none; }

/* Question card */
.qp-question {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  box-shadow: var(--shadow-sm);
  animation: qp-enter var(--dur-slow) var(--ease-out);
}
@keyframes qp-enter {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: none; }
}
.qp-question__text {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: var(--fs-h3);
  line-height: var(--lh-snug);
  color: var(--text-strong);
  margin: 0 0 var(--space-6);
}

/* Answer tiles — mirrors the DS AnswerOption component */
.qp-answers { display: grid; gap: var(--space-3); }
.qp-ans {
  --_bg: var(--surface);
  --_bd: var(--line-strong);
  --_ink: var(--text-strong);
  --_edge: var(--line-strong);
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  text-align: left;
  cursor: pointer;
  font-family: var(--font-sans);
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  color: var(--_ink);
  background: var(--_bg);
  border: 2px solid var(--_bd);
  border-radius: var(--radius-xl);
  padding: 16px 18px;
  box-shadow: inset 0 -4px 0 var(--_edge);
  transition: transform var(--dur-fast) var(--ease-standard),
    border-color var(--dur-fast), background var(--dur-fast);
  -webkit-tap-highlight-color: transparent;
}
.qp-ans:not([disabled]):hover { border-color: var(--pine-200); }
.qp-ans:not([disabled]):active { transform: translateY(3px); box-shadow: inset 0 0 0 var(--_edge); }
.qp-ans:focus-visible { outline: none; box-shadow: inset 0 -4px 0 var(--_edge), var(--focus-ring); }
.qp-ans[disabled] { cursor: default; }
.qp-ans__key {
  flex: none;
  width: 38px;
  height: 38px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-weight: var(--fw-heavy);
  background: var(--surface-sunken);
  color: var(--text-muted);
}
.qp-ans__label { flex: 1; min-width: 0; }
.qp-ans__mark { flex: none; display: inline-flex; }
.qp-ans--correct { --_bd: var(--pine-600); --_edge: var(--pine-700); --_bg: var(--pine-50); --_ink: var(--pine-800); }
.qp-ans--correct .qp-ans__key { background: var(--pine-600); color: #fff; }
.qp-ans--incorrect { --_bd: var(--danger); --_edge: var(--coral-700); --_bg: var(--coral-50); --_ink: var(--coral-700); }
.qp-ans--incorrect .qp-ans__key { background: var(--danger); color: #fff; }
.qp-ans--muted { opacity: .55; }

/* Feedback banner + per-option explanations */
.qp-feedback { margin-top: var(--space-6); animation: qp-enter var(--dur-slow) var(--ease-out); }
.qp-feedback__banner {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-5);
  font-weight: var(--fw-heavy);
  font-size: var(--fs-lg);
  margin-bottom: var(--space-4);
}
.qp-feedback__banner .lucide { width: 24px; height: 24px; flex: none; }
.qp-feedback__banner--correct { background: var(--success-bg); color: var(--pine-800); animation: qp-pop var(--dur-celebrate) var(--ease-bounce); }
.qp-feedback__banner--incorrect { background: var(--danger-bg); color: var(--coral-700); }
@keyframes qp-pop {
  0% { transform: scale(.96); }
  55% { transform: scale(1.015); }
  100% { transform: none; }
}

.qp-explain { display: grid; gap: var(--space-2); }
.qp-explain__head {
  font-family: var(--font-sans);
  font-weight: var(--fw-heavy);
  font-size: var(--fs-xs);
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-muted);
  margin: var(--space-2) 0 var(--space-1);
}
.qp-explain__row {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
  background: var(--color-bg);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  font-size: var(--fs-body);
  color: var(--text-body);
}
.qp-explain__row--correct { background: var(--success-bg); border-color: var(--pine-200); }
.qp-explain__row--picked { border-color: var(--coral-500); background: var(--danger-bg); }
.qp-explain__key {
  flex: none;
  width: 26px;
  height: 26px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-weight: var(--fw-heavy);
  font-size: var(--fs-sm);
  background: var(--surface-sunken);
  color: var(--text-muted);
}
.qp-explain__row--correct .qp-explain__key { background: var(--pine-600); color: #fff; }
.qp-explain__row--picked .qp-explain__key { background: var(--danger); color: #fff; }
.qp-explain__body strong { display: block; color: var(--text-strong); margin-bottom: 2px; }

.qp-quiz__actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-3);
  margin-top: var(--space-6);
}

/* ---------- Results ---------- */
.qp-results {
  text-align: center;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  padding: var(--space-12) var(--space-8);
  box-shadow: var(--shadow-sm);
  animation: qp-enter var(--dur-slow) var(--ease-out);
}
.qp-results img { width: 96px; height: 96px; border-radius: var(--radius-lg); margin-bottom: var(--space-4); }
.qp-results h2 { font-size: var(--fs-h1); margin-bottom: var(--space-2); }
.qp-results__score {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-size: var(--fs-num-lg);
  font-weight: var(--fw-bold);
  color: var(--brand);
  display: block;
  margin: var(--space-4) 0;
}
.qp-results p { color: var(--text-muted); max-width: 30em; margin: 0 auto var(--space-6); }
.qp-results__actions { display: flex; justify-content: center; gap: var(--space-3); flex-wrap: wrap; }

.qp-review { margin-top: var(--space-8); text-align: left; }
.qp-review h3 { font-size: var(--fs-h4); margin-bottom: var(--space-3); }
.qp-review__item {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--line);
  font-size: var(--fs-sm);
}
.qp-review__item:last-child { border-bottom: none; }
.qp-review__item .lucide { width: 18px; height: 18px; flex: none; margin-top: 2px; }
.qp-review__item--correct .lucide { color: var(--pine-600); }
.qp-review__item--incorrect .lucide { color: var(--danger); }
.qp-review__q { color: var(--text-strong); font-weight: var(--fw-bold); }
.qp-review__a { color: var(--text-muted); }

/* Streak chip during quiz */
.qp-streak {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--streak);
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-weight: var(--fw-bold);
}
.qp-streak .lucide { width: 18px; height: 18px; }

/* Not-found state */
.qp-empty {
  text-align: center;
  padding: var(--space-16) 0;
}
.qp-empty img { width: 88px; height: 88px; border-radius: var(--radius-lg); margin-bottom: var(--space-4); }
.qp-empty h2 { margin-bottom: var(--space-2); }
.qp-empty p { color: var(--text-muted); margin: 0 0 var(--space-6); }

/* ---------- Responsive ---------- */
@media (max-width: 720px) {
  .qp-hero { padding: var(--space-10) 0 var(--space-8); }
  .qp-hero__grid { grid-template-columns: 1fr; }
  .qp-hero__mascot { width: 96px; height: 96px; }
  .qp-region { padding: var(--space-5); }
  .qp-question { padding: var(--space-5); }
  .qp-quiz__actions { justify-content: stretch; }
  .qp-quiz__actions .qp-btn { flex: 1; }
}

@media (prefers-reduced-motion: reduce) {
  .qp-question, .qp-feedback, .qp-results,
  .qp-feedback__banner--correct { animation: none; }
  .qp-progress__fill { transition: none; }
}
