/* ============================================================
   Almas provträning — komponenter byggda på designsystemet "Kiho".
   Editoriell minimalism: papper & bläck, hårlinjer, mycket luft,
   grotesk + monospace, en enda vermilion-accent. Se tokens.css.
   ============================================================ */

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

/* hidden-attributet måste vinna över komponenternas display-regler */
[hidden] { display: none !important; }

body {
  font-family: var(--font-sans);
  color: var(--ink);
  background: var(--paper);
  min-height: 100vh;
  line-height: 1.6;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
a { color: inherit; }

h1, h2, h3 {
  font-family: var(--font-display);
  font-weight: 500;
  line-height: 1.04;
  letter-spacing: var(--tracking-tight);
  margin: 0;
}

/* Monospace versaletikett — designsystemets signaturdetalj */
.eyebrow,
.label,
.kbd-hint,
.quiz-count,
.quiz-source,
.stat .label,
.bar-label,
.hw-meta,
.result-chip,
.streak-chip,
.user-chip,
.brand-mark {
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: var(--tracking-label);
  font-size: 0.7rem;
  font-weight: 400;
}
.eyebrow { color: var(--accent); }

/* ---------------- Topbar ---------------- */
.topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--s4) var(--gutter);
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--paper) 88%, transparent);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
}
.brand { display: flex; align-items: center; gap: var(--s3); }
.brand-mark {
  color: var(--paper); background: var(--ink);
  padding: 5px 9px; border-radius: var(--radius);
  transition: background var(--dur) var(--ease);
}
.brand:hover .brand-mark { background: var(--accent); }
.brand-text { font-family: var(--font-display); font-weight: 500; font-size: 1rem; letter-spacing: 0; }
.topbar-right { display: flex; align-items: center; gap: var(--s3); }
.streak-chip, .user-chip {
  border: 1px solid var(--line-strong);
  padding: 7px 12px; border-radius: 999px; color: var(--ink-soft);
  display: inline-flex; align-items: center; gap: 6px;
  transition: border-color var(--dur) var(--ease), color var(--dur) var(--ease);
}
.user-chip:hover { border-color: var(--ink); color: var(--ink); }
.streak-chip b { color: var(--accent); }

/* ---------------- Layout ---------------- */
.view {
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(28px, 6vw, 72px) var(--gutter) var(--s9);
  animation: rise var(--dur-slow) var(--ease);
}
@keyframes rise { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }

.card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: clamp(22px, 4vw, 38px);
}

/* ---------------- Profil ---------------- */
.profile { display: grid; place-items: center; min-height: 76vh; text-align: left; }
.profile .card { max-width: 460px; width: 100%; }
.profile h1 {
  font-size: clamp(2rem, 6.5vw, 2.7rem); margin: var(--s3) 0 var(--s2);
  line-height: 1.08;
  /* Långa sammansatta ord ska brytas snyggt inom kortet i stället för att
     spränga ramen. Vi styr brytpunkten själva med en mjuk bindestreck (&shy;)
     i texten ("Högskoleprov­träning") och slår av automatisk avstavning så att
     webbläsarens ordlista inte väljer en egen, fulare brytpunkt. */
  hyphens: manual;
  overflow-wrap: break-word;
}
.profile p { color: var(--ink-soft); margin: 0; }
.profile-name {
  width: 100%; font-size: 1.4rem; padding: 14px 0; margin: var(--s6) 0 var(--s4);
  border: none; border-bottom: 1.5px solid var(--ink); background: transparent;
  font-family: var(--font-display); font-weight: 500; color: var(--ink);
  border-radius: 0;
}
.profile-name:focus { outline: none; border-color: var(--accent); }
.profile-chips { display: flex; flex-wrap: wrap; gap: var(--s2); margin-bottom: var(--s5); }
.profile-chips button {
  font-family: var(--font-mono); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em;
  border: 1px solid var(--line-strong); color: var(--ink-soft);
  padding: 6px 12px; border-radius: 999px;
  transition: border-color var(--dur) var(--ease), color var(--dur) var(--ease);
}
.profile-chips button:hover { border-color: var(--ink); color: var(--ink); }

/* Onboarding/inloggning */
.auth-seg { display: flex; gap: 0; border: 1px solid var(--line-strong); border-radius: var(--radius); overflow: hidden; margin: var(--s4) 0 var(--s2); }
.auth-seg button { flex: 1; font-family: var(--font-mono); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.08em; padding: var(--s3); color: var(--ink-faint); background: transparent; }
.auth-seg button.active { background: var(--ink); color: var(--paper); }
.auth-lead { color: var(--ink-soft); margin: 0 0 var(--s2); line-height: 1.5; }
.auth-legacy { margin-top: var(--s5); padding-top: var(--s4); border-top: 1px solid var(--line); }
.auth-legacy .muted { display: block; margin-bottom: var(--s3); font-size: 0.85rem; }
.err { color: var(--accent-deep); font-family: var(--font-mono); font-size: 0.8rem; }

/* ---------------- Knappar ---------------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--s2);
  font-family: var(--font-display); font-weight: 500; font-size: 1.02rem;
  padding: 15px 26px; border-radius: var(--radius);
  color: var(--paper); background: var(--ink);
  width: 100%;
  border: 1px solid var(--ink);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease),
    border-color var(--dur) var(--ease), transform 0.1s var(--ease);
}
.btn:hover { background: var(--accent); border-color: var(--accent); }
.btn:active { transform: translateY(1px); }
.btn:disabled { opacity: 0.4; cursor: default; }
.btn.secondary { background: transparent; color: var(--ink); border-color: var(--line-strong); }
.btn.secondary:hover { background: transparent; border-color: var(--ink); color: var(--accent); }
.btn.accent { background: var(--accent); border-color: var(--accent); }
.btn.accent:hover { background: var(--accent-deep); border-color: var(--accent-deep); }
.btn.ghost {
  width: auto; background: transparent; color: var(--ink-soft); border-color: transparent;
  font-family: var(--font-mono); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.12em;
  padding: 8px 4px;
}
.btn.ghost:hover { background: transparent; color: var(--accent); }

/* ---------------- Dashboard ---------------- */
.greeting { font-size: clamp(2.2rem, 6vw, 3.4rem); margin-bottom: var(--s2); }
.greeting .wave { display: inline-block; transform-origin: 70% 70%; animation: wave 2.4s var(--ease) infinite; }
@keyframes wave { 0%,55%,100%{transform:rotate(0)} 12%{transform:rotate(16deg)} 24%{transform:rotate(-6deg)} }
.subgreet { color: var(--ink-soft); margin: 0 0 var(--s7); font-size: 1.05rem; max-width: 52ch; }

.stat-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 0; margin-bottom: var(--s7);
  border-top: 1px solid var(--line);
}
.stat {
  padding: var(--s5) var(--s4) var(--s5) 0;
  border-bottom: 1px solid var(--line);
}
.stat .num { font-family: var(--font-display); font-size: 2.6rem; font-weight: 500; line-height: 1; letter-spacing: var(--tracking-tight); }
.stat .label { color: var(--ink-faint); margin-top: var(--s3); display: block; }
.stat.due .num { color: var(--accent); }
.stat.mastered .num { color: var(--good-deep); }

.progress-line { margin-bottom: var(--s7); }
.progress-track { height: 6px; background: var(--paper-2); border-radius: 999px; overflow: hidden; }
.progress-fill { height: 100%; background: var(--good); border-radius: 999px; transition: width var(--dur-slow) var(--ease); }
.progress-caption { font-family: var(--font-mono); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-soft); margin-top: var(--s3); }

/* Leitner-trappan: box 1→5 som mini-stapeldiagram */
.box-ladder { margin-bottom: var(--s7); border-top: 1px solid var(--line); padding-top: var(--s5); }
.box-ladder-head {
  font-family: var(--font-mono); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--ink-soft); margin-bottom: var(--s4); display: flex; justify-content: space-between; align-items: baseline; gap: var(--s3);
}
.box-ladder-head span { color: var(--ink-faint); }
.box-cols { display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--s3); align-items: end; }
.box-col { display: flex; flex-direction: column; align-items: center; gap: var(--s2); }
.box-count { font-family: var(--font-display); font-size: 1.5rem; font-weight: 500; line-height: 1; }
.box-bar-track { width: 100%; height: 96px; display: flex; align-items: flex-end; border-bottom: 1px solid var(--line-strong); }
.box-bar { width: 100%; min-height: 0; background: var(--ink-soft); border-radius: var(--radius) var(--radius) 0 0; transition: height var(--dur-slow) var(--ease); }
.box-col.b1 .box-bar { background: var(--accent); }
.box-col.b5 .box-bar { background: var(--good); }
.box-col.b5 .box-count { color: var(--good-deep); }
.box-name { font-family: var(--font-mono); font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.07em; color: var(--ink-faint); text-align: center; }
.box-ladder-foot { font-size: 0.82rem; color: var(--ink-faint); margin-top: var(--s4); }

.action-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s3); }
.action {
  text-align: left; padding: var(--s5); border-radius: var(--radius-lg);
  background: var(--surface); border: 1px solid var(--line);
  display: flex; flex-direction: column; gap: var(--s2); min-height: 150px;
  transition: border-color var(--dur) var(--ease), transform var(--dur) var(--ease), background var(--dur) var(--ease);
}
.action:hover { border-color: var(--ink); transform: translateY(-2px); }
.action .emoji { font-size: 1.5rem; margin-bottom: var(--s2); }
.action .title { font-family: var(--font-display); font-weight: 500; font-size: 1.25rem; }
.action .desc { color: var(--ink-soft); font-size: 0.92rem; line-height: 1.5; }
.action.primary { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.action.primary:hover { background: var(--accent); border-color: var(--accent); }
.action.primary .desc { color: color-mix(in srgb, var(--paper) 78%, transparent); }
.action .badge {
  align-self: flex-start; margin-top: auto;
  font-family: var(--font-mono); font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.12em;
  color: var(--accent); border: 1px solid var(--accent); padding: 3px 9px; border-radius: 999px;
}
.action.primary .badge { color: var(--paper); border-color: color-mix(in srgb, var(--paper) 50%, transparent); }

/* ---------------- Quiz ---------------- */
.quiz-head { display: flex; align-items: center; justify-content: space-between; gap: var(--s4); margin-bottom: var(--s5); }
.quiz-progress { flex: 1; height: 3px; background: var(--paper-2); overflow: hidden; }
.quiz-progress > div { height: 100%; background: var(--ink); transition: width var(--dur) var(--ease); }
.quiz-count { color: var(--ink-faint); white-space: nowrap; }
.quiz-source { color: var(--ink-faint); text-align: center; margin-bottom: var(--s2); }

.word-stem {
  font-family: var(--font-display); font-weight: 500;
  font-size: clamp(2.6rem, 10vw, 4.4rem); letter-spacing: var(--tracking-tight);
  text-align: center; margin: var(--s4) 0 var(--s2); word-break: break-word;
}
.word-prompt { text-align: center; color: var(--ink-faint); margin: 0 0 var(--s6); font-family: var(--font-mono); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.12em; }
.difficulty { display: inline-flex; gap: 4px; }
.difficulty span { width: 7px; height: 7px; border-radius: 50%; border: 1px solid var(--line-strong); }
.difficulty span.on { background: var(--accent); border-color: var(--accent); }

.options { display: grid; gap: var(--s2); }
.option {
  display: flex; align-items: center; gap: var(--s4); width: 100%; text-align: left;
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 16px 18px; font-size: 1.08rem; color: var(--ink);
  min-height: 60px;
  transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease), transform 0.12s var(--ease);
}
.option:hover:not(:disabled) { border-color: var(--ink); transform: translateX(3px); }
.option:disabled { cursor: default; }
.option .letter {
  flex: none; width: 32px; height: 32px; border-radius: var(--radius);
  display: grid; place-items: center; border: 1px solid var(--line-strong);
  font-family: var(--font-mono); font-size: 0.85rem; color: var(--ink-soft);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.option.correct { border-color: var(--good); background: var(--good-tint); }
.option.correct .letter { background: var(--good); color: var(--paper); border-color: var(--good); }
.option.wrong { border-color: var(--line-strong); background: var(--calm-tint); }
.option.wrong .letter { background: var(--ink); color: var(--paper); border-color: var(--ink); }
/* Rätt svar AVSLÖJAT efter ett felaktigt svar — neutralt bläck, aldrig grönt. */
.option.reveal { border-color: var(--ink); background: var(--surface); }
.option.reveal .letter { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.option.reveal::after,
.option.wrong::after {
  margin-left: auto; font-family: var(--font-mono); font-size: 0.62rem;
  text-transform: uppercase; letter-spacing: 0.12em; white-space: nowrap;
}
.option.reveal::after { content: 'Rätt svar'; color: var(--ink-soft); }
.option.wrong::after { content: 'Ditt svar'; color: var(--ink-faint); }
.option.dim { opacity: 0.45; }

.feedback { margin-top: var(--s5); padding: var(--s5); border-radius: var(--radius); animation: rise var(--dur) var(--ease); }
.feedback.correct { background: var(--good-tint); border-left: 2px solid var(--good); }
.feedback.wrong { background: var(--calm-tint); border-left: 2px solid var(--ink); }
.feedback .fb-title { font-family: var(--font-display); font-weight: 500; font-size: 1.3rem; margin-bottom: var(--s2); }
.feedback.correct .fb-title { color: var(--good-deep); }
.feedback .fb-expl { color: var(--ink-soft); line-height: 1.55; }
.feedback .fb-expl b { color: var(--ink); }
.level-up { margin-top: var(--s3); font-family: var(--font-mono); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--good-deep); }

/* Exempelmening — ordet använt i en mening (visas efter både rätt och fel svar) */
.fb-mening {
  margin-top: var(--s3); padding-left: var(--s4);
  border-left: 2px solid var(--line-strong);
  font-family: var(--font-display); font-style: italic; font-size: 1.02rem;
  color: var(--ink); line-height: 1.5;
}
.fb-mening-label {
  display: block; font-family: var(--font-mono); font-style: normal;
  font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.14em;
  color: var(--ink-faint); margin-bottom: 4px;
}

.quiz-footer { margin-top: var(--s5); }
.kbd-hint { text-align: center; color: var(--ink-faint); margin-top: var(--s5); line-height: 2; }
.kbd { font-family: var(--font-mono); border: 1px solid var(--line-strong); border-radius: var(--radius); padding: 2px 7px; font-size: 0.72rem; color: var(--ink-soft); }

/* ---------------- Sammanfattning / Resultat ---------------- */
.summary { text-align: center; }
.summary .big-score { font-family: var(--font-display); font-weight: 500; font-size: clamp(3.4rem, 16vw, 6rem); line-height: 0.95; letter-spacing: var(--tracking-tight); }
.summary .score-sub { font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.12em; color: var(--ink-faint); font-size: 0.78rem; margin-bottom: var(--s5); }
.summary .pep { font-family: var(--font-display); font-weight: 500; font-size: 1.4rem; margin: var(--s4) 0; }
.chips-row { display: flex; flex-wrap: wrap; gap: var(--s2); justify-content: center; margin: var(--s5) 0; }
.result-chip { border: 1px solid var(--line-strong); color: var(--ink-soft); padding: 7px 13px; border-radius: 999px; }
.result-chip.good { border-color: var(--good); color: var(--good-deep); }
.result-chip.accent { border-color: var(--ink); color: var(--ink); }

.review-list { display: grid; gap: var(--s2); margin: var(--s5) 0; text-align: left; }
.review-item { background: var(--surface); border: 1px solid var(--line); border-left: 2px solid var(--ink); border-radius: var(--radius); padding: var(--s4); }
.review-item .ri-word { font-family: var(--font-display); font-weight: 500; font-size: 1.15rem; }
.review-item .ri-facit { color: var(--ink); font-weight: 600; }
.review-item .ri-expl { color: var(--ink-soft); font-size: 0.9rem; margin-top: 4px; line-height: 1.5; }
.review-item.wrong { border-left-color: var(--accent); }

/* ---------------- Utveckling ---------------- */
.section-title { font-size: 1.35rem; margin: var(--s7) 0 var(--s4); padding-top: var(--s4); border-top: 1px solid var(--line); }
.chart-card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: var(--s5); margin-bottom: var(--s3); }
.chart-empty { color: var(--ink-faint); text-align: center; padding: var(--s6); font-family: var(--font-mono); font-size: 0.78rem; }
.bar-row { display: flex; align-items: center; gap: var(--s4); margin: var(--s3) 0; }
.bar-label { width: 132px; color: var(--ink-soft); flex: none; }
.bar-track { flex: 1; background: var(--paper-2); border-radius: 999px; height: 18px; overflow: hidden; }
.bar-fill { height: 100%; border-radius: 999px; display: flex; align-items: center; justify-content: flex-end; padding-right: 9px; color: var(--paper); font-family: var(--font-mono); font-size: 0.7rem; font-weight: 700; min-width: 22px; }
.hardest-word { display: flex; align-items: center; justify-content: space-between; gap: var(--s4); padding: var(--s3) 0; border-bottom: 1px solid var(--line); }
.hardest-word:last-child { border-bottom: none; }
.hardest-word b { font-family: var(--font-display); font-weight: 500; }
.hardest-word .hw-meta { color: var(--ink-faint); white-space: nowrap; }
svg.line-chart { width: 100%; height: auto; display: block; }

/* ---------------- Toast ---------------- */
.toast {
  position: fixed; left: 50%; bottom: var(--s6); transform: translateX(-50%) translateY(16px);
  background: var(--ink); color: var(--paper); padding: 12px 22px; border-radius: var(--radius);
  font-family: var(--font-mono); font-size: 0.78rem; letter-spacing: 0.04em;
  opacity: 0; transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease); z-index: 9998;
}
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ---------------- Övrigt ---------------- */
.center { text-align: center; }
.muted { color: var(--ink-faint); }
.stack > * + * { margin-top: var(--s3); }
.row { display: flex; gap: var(--s3); }
.row.wrap { flex-wrap: wrap; }
.back-link { margin-bottom: var(--s5); }
.spinner { width: 32px; height: 32px; border: 2px solid var(--line); border-top-color: var(--accent); border-radius: 50%; animation: spin 0.7s linear infinite; margin: var(--s9) auto; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ---------------- Prov-delen (kategori + tidtaget) ---------------- */
.exam-cat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--s3); }
.exam-cat {
  text-align: left; padding: var(--s5); border-radius: var(--radius-lg);
  background: var(--surface); border: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 4px;
  transition: border-color var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.exam-cat:hover { border-color: var(--ink); transform: translateY(-2px); }
.exam-cat-code { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.16em; color: var(--accent); }
.exam-cat-name { font-family: var(--font-display); font-weight: 500; font-size: 1.15rem; }
.exam-cat-meta { font-family: var(--font-mono); font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-faint); }

/* Inline-länk (t.ex. "Läs strategi & tips") */
.tip-inline-link { color: var(--ink-soft); margin: calc(-1 * var(--s5)) 0 var(--s5); font-size: 0.95rem; }
.link-btn { font: inherit; color: var(--accent); border-bottom: 1px solid currentColor; padding: 0; }
.link-btn:hover { color: var(--accent-deep); }

/* Strategi & tips — detaljvy */
.tip-head { display: flex; align-items: baseline; gap: var(--s3); margin-bottom: var(--s3); }
.tip-code { font-family: var(--font-mono); font-size: 0.78rem; letter-spacing: 0.16em; color: var(--accent); }
.tip-namn { font-family: var(--font-display); font-weight: 500; font-size: 2rem; line-height: 1.05; letter-spacing: var(--tracking-tight); margin: 0; }
.tip-ingress { color: var(--ink-soft); font-size: 1.08rem; line-height: 1.55; max-width: 60ch; margin: 0 0 var(--s5); }
.tip-note { color: var(--ink-faint); font-size: 0.92rem; line-height: 1.5; border-left: 2px solid var(--line-strong); padding-left: var(--s4); margin: var(--s5) 0 0; }

.tip-facts { display: flex; flex-wrap: wrap; gap: 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); margin-bottom: var(--s6); }
.tip-fact { padding: var(--s4) var(--s5) var(--s4) 0; margin-right: var(--s5); }
.tip-fact-val { display: block; font-family: var(--font-display); font-size: 1.5rem; font-weight: 500; line-height: 1; }
.tip-fact-label { display: block; font-family: var(--font-mono); font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.12em; color: var(--ink-faint); margin-top: var(--s2); }

.tip-trap { background: var(--accent-tint); border-radius: var(--radius-lg); padding: var(--s4) var(--s5); margin-bottom: var(--s6); }
.tip-trap-label { display: block; font-family: var(--font-mono); font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.14em; color: var(--accent-deep); margin-bottom: var(--s2); }
.tip-trap-text { color: var(--ink); line-height: 1.5; }

.tip-section { margin-bottom: var(--s6); }
.tip-rubrik { font-family: var(--font-display); font-weight: 500; font-size: 1.2rem; margin: 0 0 var(--s4); padding-bottom: var(--s2); border-bottom: 1px solid var(--line); }
.tip-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--s4); }
.tip-item { display: flex; flex-direction: column; gap: var(--s2); padding-left: var(--s4); border-left: 2px solid var(--line-strong); }
.tip-text { color: var(--ink); line-height: 1.55; }
.tip-ex { font-family: var(--font-mono); font-size: 0.82rem; color: var(--ink-soft); background: var(--paper-2); border-radius: var(--radius); padding: var(--s2) var(--s3); align-self: flex-start; max-width: 100%; }

/* Räkneträning (drillar) */
.drill-stem { font-size: 1.12rem; line-height: 1.6; color: var(--ink); margin-bottom: var(--s4); }
.drill-table { border-collapse: collapse; width: 100%; margin: var(--s3) 0 var(--s5); font-size: 0.96rem; }
.drill-table th, .drill-table td { border-bottom: 1px solid var(--line); padding: var(--s2) var(--s3); text-align: left; }
.drill-table th { font-family: var(--font-mono); font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-faint); font-weight: 500; }
.drill-table td.num, .drill-table th.num { text-align: right; font-variant-numeric: tabular-nums; }
.drill-table tbody tr:last-child td { border-bottom: none; font-weight: 500; } /* Totalt-raden */

/* LÄS — diskvalificera distraktorn */
.las-instr { color: var(--ink-soft); font-size: 0.95rem; margin: var(--s3) 0 var(--s4); }
.las-rows { display: flex; flex-direction: column; gap: var(--s3); margin-top: var(--s2); }
.las-row { display: grid; grid-template-columns: 1.6rem auto 1fr; gap: var(--s3); align-items: baseline; }
.las-row-bok { font-family: var(--font-mono); font-weight: 700; color: var(--ink-soft); }
.las-row-tag {
  font-family: var(--font-mono); font-size: 0.6rem; text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--accent-deep); background: var(--accent-tint); border-radius: 999px; padding: 3px 9px; white-space: nowrap; align-self: center;
}
.las-row-tag.good { color: var(--good-deep); background: var(--good-tint); }
.las-row-motiv { color: var(--ink); line-height: 1.5; }

.exam-source { margin-bottom: var(--s4); }
.exam-source-head { font-family: var(--font-display); font-weight: 500; font-size: 1.25rem; margin-bottom: var(--s3); }
.exam-pass-list { display: grid; gap: var(--s2); }
.exam-pass {
  display: flex; align-items: center; justify-content: space-between; gap: var(--s4);
  text-align: left; padding: 14px 16px; border-radius: var(--radius);
  background: var(--paper); border: 1px solid var(--line);
  transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.exam-pass:hover { border-color: var(--ink); }
.exam-pass.done { opacity: 0.72; }
.exam-pass-title { font-family: var(--font-display); font-weight: 500; display: block; }
.exam-pass-sub { font-family: var(--font-mono); font-size: 0.64rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-faint); }
.exam-pass-status { font-family: var(--font-mono); font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--accent); white-space: nowrap; }
.exam-pass.done .exam-pass-status { color: var(--good-deep); }

/* Provets klock-rad */
.exam-bar { display: flex; align-items: center; justify-content: space-between; gap: var(--s4); margin-bottom: var(--s4);
  position: sticky; top: 0; z-index: 30; background: color-mix(in srgb, var(--paper) 90%, transparent);
  backdrop-filter: blur(8px); padding: var(--s2) 0; }
.exam-timer { font-family: var(--font-mono); font-size: 1.3rem; font-weight: 700; letter-spacing: 0.04em;
  padding: 4px 14px; border: 1px solid var(--line-strong); border-radius: 999px; color: var(--ink); }
.exam-timer.low { color: var(--accent); border-color: var(--accent); }

.exam-nav { display: flex; gap: var(--s3); margin-top: var(--s4); }
.exam-nav .btn { width: auto; flex: 1; }

.exam-grid { margin-top: var(--s5); }
.exam-grid-label { font-family: var(--font-mono); font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.12em; color: var(--ink-faint); margin-bottom: var(--s2); }
.exam-grid-cells { display: flex; flex-wrap: wrap; gap: 6px; }
.exam-cell {
  width: 38px; height: 38px; border-radius: var(--radius); border: 1px solid var(--line-strong);
  font-family: var(--font-mono); font-size: 0.8rem; color: var(--ink-soft); background: var(--surface);
  transition: all var(--dur) var(--ease);
}
.exam-cell.answered { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.exam-cell.current { outline: 2px solid var(--accent); outline-offset: 1px; }

/* Frågeinnehåll */
.exam-stem { font-family: var(--font-display); font-weight: 500; font-size: 1.3rem; line-height: 1.4; margin: var(--s2) 0 var(--s5); }
.exam-stem-img { margin: var(--s4) 0 var(--s5); text-align: center; }
.exam-stem-img img {
  width: 100%; max-width: 780px; height: auto; margin: 0 auto;
  border: 1px solid var(--line); border-radius: var(--radius); background: #fff; padding: var(--s4);
}
.exam-stem-img.small img { width: auto; max-width: 100%; max-height: 240px; padding: var(--s2); }
.exam-passage {
  background: var(--paper); border: 1px solid var(--line); border-left: 3px solid var(--line-strong);
  border-radius: var(--radius); padding: var(--s4) var(--s5); margin-bottom: var(--s5);
  max-height: 340px; overflow-y: auto;
}
.exam-passage-rubrik { font-family: var(--font-display); font-weight: 500; font-size: 1.1rem; margin-bottom: var(--s2); }
.exam-passage-text { color: var(--ink-soft); line-height: 1.6; }
.exam-passage-text p { margin: 0 0 var(--s3); }
.exam-figure { margin-bottom: var(--s5); }
.exam-figure-rubrik { font-family: var(--font-mono); font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.12em; color: var(--ink-faint); margin-bottom: 4px; }
.exam-figure img { max-width: 100%; height: auto; border: 1px solid var(--line); border-radius: var(--radius); background: #fff; }

/* Valt alternativ under tidtaget prov (neutralt — ingen facit) */
.option.chosen { border-color: var(--ink); background: var(--paper-2); }
.option.chosen .letter { background: var(--ink); color: var(--paper); border-color: var(--ink); }

/* Resultatgenomgång */
.exam-review { display: grid; gap: var(--s2); }
.exam-review-item { background: var(--surface); border: 1px solid var(--line); border-left: 3px solid var(--line-strong); border-radius: var(--radius); padding: var(--s4); }
.exam-review-item.correct { border-left-color: var(--good); }
.exam-review-item.wrong { border-left-color: var(--accent); }
.exam-review-item.blank { border-left-color: var(--line-strong); opacity: 0.85; }
.exam-review-head { display: flex; justify-content: space-between; gap: var(--s3); flex-wrap: wrap; }
.exam-review-nr { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.08em; color: var(--ink-soft); }
.exam-review-mark { font-family: var(--font-mono); font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-faint); }
.exam-review-item.correct .exam-review-mark { color: var(--good-deep); }
.exam-review-stem { margin: var(--s2) 0; line-height: 1.45; }
.exam-review-facit { color: var(--ink); margin-top: 4px; }
.exam-review-facit b { color: var(--good-deep); }

@media (max-width: 560px) {
  .action-grid { grid-template-columns: 1fr; }
  .brand-text { display: none; }
  .bar-label { width: 104px; }
  .exam-nav { flex-direction: column; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
}
