/* ============================================================
   quiz.css — Character matching quiz page
   Inherits: shared.css → app.css
   ============================================================ */

/* --- Quiz nav --------------------------------------------- */
.nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px; border-bottom: 1px solid var(--border);
  max-width: 720px; margin: 0 auto;
}

/* --- Quiz container --------------------------------------- */
.container { max-width: 640px; margin: 0 auto; padding: 40px 24px 80px; }

/* --- Progress bar ----------------------------------------- */
.progress-bar  { height: 4px; background: var(--border); border-radius: 2px; margin-bottom: 40px; }
.progress-fill { height: 100%; background: var(--accent); border-radius: 2px; transition: width .4s ease; }

/* --- Question step ---------------------------------------- */
.q-step        { display: none; animation: qFadeIn .3s ease; }
.q-step.active { display: block; }
@keyframes qFadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }

.q-num  { font-size: 12px; color: var(--muted); letter-spacing: 1px; text-transform: uppercase; margin-bottom: 12px; }
.q-text { font-family: 'Fraunces', serif; font-size: clamp(1.4rem, 4vw, 1.9rem); line-height: 1.3; margin-bottom: 32px; }
.q-text em { color: var(--accent); font-style: italic; }

/* --- Options ---------------------------------------------- */
.options { display: flex; flex-direction: column; gap: 12px; }
.option-btn {
  background: var(--surface); border: 1.5px solid var(--border);
  border-radius: 12px; padding: 16px 20px; text-align: left;
  color: var(--text); font-family: 'DM Sans', sans-serif; font-size: 15px;
  cursor: pointer; transition: border-color .15s, background .15s;
  display: flex; align-items: center; gap: 12px;
}
.option-btn:hover    { border-color: var(--accent); background: var(--surface2); }
.option-btn.selected { border-color: var(--accent); background: rgba(232,96,28,0.08); }
.option-icon  { font-size: 22px; flex-shrink: 0; }
.option-label { font-weight: 500; }
.option-sub   { font-size: 12px; color: var(--muted); margin-top: 2px; }

/* --- Result ----------------------------------------------- */
#result { display: none; animation: qFadeIn .4s ease; text-align: center; }
.result-badge {
  display: inline-block; background: rgba(232,96,28,0.15);
  border: 1px solid rgba(232,96,28,0.4); border-radius: 20px;
  padding: 6px 16px; font-size: 12px; color: var(--accent);
  letter-spacing: 1px; text-transform: uppercase; margin-bottom: 20px;
}
.result-avatar { font-size: 64px; margin: 16px 0; }
.result-name   { font-family: 'Fraunces', serif; font-size: clamp(1.6rem, 5vw, 2.2rem); margin-bottom: 8px; }
.result-name em { color: var(--accent); font-style: italic; }
.result-desc   { color: var(--muted); font-size: 15px; line-height: 1.6; max-width: 480px; margin: 0 auto 32px; }

.result-card  { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 24px; margin: 0 auto 32px; max-width: 420px; text-align: left; }
.result-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.stat-value   { font-size: 15px; font-weight: 500; }

.retake        { margin-top: 20px; }
.retake button { background: none; border: none; color: var(--muted); font-family: 'DM Sans', sans-serif; font-size: 13px; cursor: pointer; text-decoration: underline; }
.retake button:hover { color: var(--text); }

/* --- Alt characters --------------------------------------- */
.also-consider { margin-top: 48px; }
.also-title    { font-size: 13px; color: var(--muted); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 16px; }
.also-grid     { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 10px; }
.also-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 12px; padding: 14px; text-align: center;
  text-decoration: none; color: var(--text); transition: border-color .15s;
}
.also-card:hover          { border-color: rgba(232,96,28,0.5); }
.also-card .icon          { font-size: 20px; margin-bottom: 6px; }
.also-card .name          { font-size: 13px; font-weight: 500; }
.also-card .lvl           { font-size: 11px; color: var(--muted); margin-top: 2px; }
