/* Quiz funnel ("Which Book Boyfriend Were You Made For?")
   Self-contained styles. Reuses site CSS variables from styles.css. */

/* ---------- Ambient background (kept dark so it never clashes with content) ---------- */
.quiz-body { position: relative; }
.quiz-bg {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(213, 167, 83, 0.10), transparent 60%),
    var(--bg-app);
}
.quiz-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: linear-gradient(to bottom, rgba(8,8,8,0.90), rgba(8,8,8,0.97)), url("/assets/quiz/quiz-hero-bg.jpg");
  background-size: cover;
  background-position: center;
  opacity: 0.28;
}
.site-header, .quiz-main, .site-footer { position: relative; z-index: 1; }

.quiz-main {
  max-width: 540px;
  margin: 0 auto;
  padding: 0.9rem 1rem 3rem;
  min-height: 70vh;
}
.quiz-loading { text-align: center; color: var(--text-muted); padding: 3rem 1rem; }

/* ---------- Progress ---------- */
.quiz-progress { display: flex; align-items: center; gap: 0.6rem; margin-bottom: 1.2rem; }
.quiz-progress-back {
  background: none; border: none; color: var(--text-secondary);
  font-size: 1.4rem; line-height: 1; cursor: pointer; padding: 0.2rem 0.5rem; border-radius: 8px;
}
.quiz-progress-back:hover { color: var(--text-primary); background: var(--bg-hover); }
.quiz-progress-back[hidden] { display: none; }
.quiz-progress-track {
  flex: 1; height: 8px; background: var(--bg-panel-2); border-radius: 999px; overflow: hidden;
}
.quiz-progress-fill {
  height: 100%; background: linear-gradient(90deg, var(--primary), var(--accent));
  border-radius: 999px; transition: width 0.35s ease;
}
.quiz-progress-label { font-size: 0.82rem; color: var(--text-muted); white-space: nowrap; }

/* ---------- Question step ---------- */
.quiz-step { animation: quizFade 0.3s ease; }
@keyframes quizFade {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
.quiz-kicker {
  text-transform: uppercase; letter-spacing: 0.12em; font-size: 0.72rem;
  color: var(--primary); margin: 0 0 0.5rem;
}
.quiz-question { font-size: 1.45rem; line-height: 1.22; margin: 0 0 1.2rem; color: var(--text-primary); }

.quiz-options { display: grid; gap: 0.6rem; }
.quiz-option {
  display: flex; align-items: center; gap: 0.7rem; width: 100%; text-align: left;
  padding: 1rem 1.05rem; background: var(--card); border: 1px solid var(--border);
  border-radius: 14px; color: var(--text-primary); font-size: 1.02rem; font-weight: 500;
  cursor: pointer; transition: border-color 0.15s ease, background 0.15s ease, transform 0.08s ease;
  -webkit-tap-highlight-color: transparent;
}
.quiz-option:hover { border-color: var(--primary); background: var(--bg-hover); }
.quiz-option:active { transform: scale(0.99); }
.quiz-option.is-selected { border-color: var(--primary); background: rgba(213, 167, 83, 0.12); }
.quiz-option-emoji { font-size: 1.25rem; line-height: 1; flex: 0 0 auto; }

/* ---------- Calculating ---------- */
.quiz-calculating { text-align: center; padding: 3.2rem 1rem; }
.quiz-calculating h2 { font-size: 1.45rem; margin: 1.4rem 0 0.4rem; color: var(--text-primary); }
.quiz-calculating p { color: var(--text-muted); margin: 0; }
.quiz-spinner {
  width: 56px; height: 56px; margin: 0 auto; border-radius: 50%;
  border: 4px solid var(--bg-panel-2); border-top-color: var(--primary);
  animation: quizSpin 0.9s linear infinite;
}
@keyframes quizSpin { to { transform: rotate(360deg); } }
.quiz-hearts { font-size: 1.6rem; letter-spacing: 0.3rem; animation: quizPulse 1.4s ease-in-out infinite; }
@keyframes quizPulse { 0%,100% { opacity: 0.55; } 50% { opacity: 1; } }

/* ---------- Result shared ---------- */
.quiz-result-eyebrow {
  text-align: center; text-transform: uppercase; letter-spacing: 0.12em; font-size: 0.72rem;
  color: var(--primary); margin: 0 0 0.35rem;
}
.quiz-result-name {
  text-align: center; font-size: 1.5rem; line-height: 1.18; margin: 0 0 0.6rem; color: var(--text-primary);
}
.quiz-cover-locked { position: relative; width: 122px; margin: 0 auto 0.8rem; }
.quiz-result-cover {
  width: 100%; aspect-ratio: 2 / 3; border-radius: 12px; object-fit: cover; display: block;
  box-shadow: 0 16px 36px rgba(0, 0, 0, 0.5);
  background: linear-gradient(160deg, var(--bg-panel-2), var(--card));
}
.quiz-cover-locked:not(.is-unlocked) .quiz-result-cover { filter: blur(8px) brightness(0.6); }
.quiz-result-cover-fallback {
  width: 100%; aspect-ratio: 2 / 3; border-radius: 12px; display: flex; align-items: center;
  justify-content: center; text-align: center; padding: 0.7rem; font-weight: 600; font-size: 0.9rem;
  color: var(--text-primary); background: linear-gradient(160deg, rgba(213,167,83,0.25), var(--card));
  border: 1px solid var(--border); box-shadow: 0 16px 36px rgba(0, 0, 0, 0.5);
}
.quiz-cover-lock {
  position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center;
  justify-content: center; gap: 0.3rem; color: #fff; font-weight: 600; font-size: 0.85rem; text-align: center;
}
.quiz-lock-ico { font-size: 1.5rem; }

/* ---------- Locked result (signup, kept above the fold) ---------- */
.quiz-teaser {
  text-align: center; color: var(--text-secondary); font-size: 0.98rem; line-height: 1.45;
  margin: 0 auto 1rem; max-width: 26rem;
}

.quiz-signup-card {
  background: var(--card); border: 1px solid var(--border); border-radius: var(--card-radius); padding: 1.1rem 1.1rem;
}
.quiz-signup-title { font-size: 1.1rem; margin: 0 0 0.25rem; color: var(--text-primary); }
.quiz-signup-sub { color: var(--text-muted); font-size: 0.92rem; margin: 0 0 0.9rem; }
.quiz-field { margin-bottom: 0.7rem; }
.quiz-field input {
  width: 100%; padding: 0.82rem 0.9rem; background: var(--bg-panel-2); color: var(--text-primary);
  border: 1px solid var(--border); border-radius: 10px; font-size: 1rem;
}
.quiz-field input:focus { outline: none; border-color: var(--primary); }
.quiz-password-wrap { position: relative; }
.quiz-password-wrap input { padding-right: 4rem; }
.quiz-password-toggle {
  position: absolute; right: 0.6rem; top: 50%; transform: translateY(-50%);
  background: none; border: none; color: var(--text-muted); cursor: pointer; font-size: 0.85rem;
}

/* Consent row: explicit single-row checkbox + text. */
.quiz-consent {
  display: flex; gap: 0.55rem; align-items: flex-start; text-align: left;
  margin: 0.3rem 0 0.9rem; font-size: 0.82rem; color: var(--text-muted); line-height: 1.45; cursor: pointer;
}
.quiz-consent input[type="checkbox"] {
  width: 18px; height: 18px; flex: 0 0 18px; margin: 0.12rem 0 0; accent-color: var(--primary); cursor: pointer;
}
.quiz-consent span { flex: 1 1 auto; }
.quiz-consent a { color: var(--text-secondary); }

.quiz-submit {
  width: 100%; font-size: 1.04rem; padding: 0.92rem 1rem;
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; text-decoration: none;
}
.quiz-reassure { text-align: center; color: var(--text-faint); font-size: 0.82rem; margin: 0.7rem 0 0; }
.quiz-provider-logo { width: 18px; height: 18px; }

.quiz-status { margin: 0.8rem 0 0; font-size: 0.9rem; min-height: 1.1rem; }
.quiz-status.error { color: #ef9a9a; }
.quiz-status.ok { color: var(--primary); }

.quiz-footnote { text-align: center; color: var(--text-faint); font-size: 0.85rem; margin: 0.9rem 0 0; }
.quiz-footnote a { color: var(--text-secondary); }

/* ---------- Reveal (after signup / logged in) ---------- */
.quiz-reveal { text-align: center; }
.quiz-reveal .quiz-cover-locked { width: 168px; margin-bottom: 1rem; }
.quiz-reveal-badge {
  display: inline-block; background: rgba(213,167,83,0.14); color: var(--primary);
  border: 1px solid rgba(213,167,83,0.4); border-radius: 999px; padding: 0.28rem 0.85rem;
  font-size: 0.78rem; font-weight: 600; margin: 0 0 0.9rem;
}
.quiz-reveal-desc {
  color: var(--text-secondary); font-size: 0.98rem; line-height: 1.55; margin: 0 auto 1.1rem; max-width: 30rem;
}
.quiz-prompt-card {
  text-align: left; background: var(--card); border: 1px solid var(--border); border-radius: 12px;
  padding: 1rem 1.1rem; margin: 0 0 1.3rem;
}
.quiz-prompt-card-head {
  font-size: 0.78rem; font-weight: 600; color: var(--primary); text-transform: uppercase;
  letter-spacing: 0.06em; margin-bottom: 0.5rem;
}
.quiz-prompt-card p { margin: 0; color: var(--text-secondary); font-size: 0.95rem; line-height: 1.55; }

/* ---------- Confirm / write step ---------- */
.quiz-write { text-align: center; }
.quiz-write-emoji { font-size: 2.4rem; }
.quiz-write h2 { font-size: 1.4rem; line-height: 1.25; margin: 0.5rem 0 0.4rem; color: var(--text-primary); }
.quiz-write-sub { color: var(--text-secondary); margin: 0 auto 1.3rem; max-width: 28rem; }
.quiz-microsteps {
  list-style: none; margin: 0 auto 1.2rem; padding: 0; max-width: 24rem; display: grid; gap: 0.6rem; text-align: left;
}
.quiz-microsteps li {
  display: flex; gap: 0.65rem; align-items: center; color: var(--text-secondary); font-size: 0.95rem; line-height: 1.35;
}
.quiz-microstep-num {
  flex: 0 0 24px; width: 24px; height: 24px; border-radius: 50%; display: inline-flex; align-items: center;
  justify-content: center; font-size: 0.8rem; font-weight: 600; color: var(--primary);
  background: rgba(213,167,83,0.14); border: 1px solid rgba(213,167,83,0.35);
}
.quiz-microsteps strong { color: var(--text-primary); font-weight: 600; }

@media (min-width: 600px) {
  .quiz-question { font-size: 1.7rem; }
  .quiz-result-name { font-size: 1.7rem; }
  .quiz-reveal .quiz-cover-locked { width: 196px; }
}
