/*
 * quiz.css — enhanced answer feedback + 15 background themes
 */

/* ── Answer option base ─────────────────────────────────────────── */
.answer-option {
    border: 2px solid rgba(24,52,63,.12);
    border-radius: 12px;
    transition: background 180ms, border-color 180ms, box-shadow 180ms, transform 120ms;
    position: relative;
}

@media (hover: hover) and (pointer: fine) {
    .answer-option:hover:not(:disabled):not(.state-correct):not(.state-wrong):not(.state-reveal) {
        border-color: var(--quiz-accent-2, #2f5563);
        background: #f7fbfc;
        box-shadow: 0 8px 20px rgba(31,61,73,.12);
        transform: translateY(-1px);
    }
}

/* ── Disabled buttons inside answered state must NOT fade ───────── */
.state-correct,
.state-wrong,
.state-reveal {
    opacity: 1 !important;
}

/* ── State: correct — vivid pastel green ────────────────────────── */
.state-correct,
.answer-option.state-correct:hover,
.answer-option.state-correct:active,
.answer-option.state-correct:focus,
.answer-option.state-correct:focus-visible {
    background: linear-gradient(135deg, #4ade80 0%, #86efac 100%) !important;
    border-color: #16a34a !important;
    border-width: 2.5px !important;
    color: #14532d !important;
    font-weight: 700 !important;
    box-shadow: 0 0 0 3px rgba(74,222,128,0.4),
                0 6px 20px rgba(34,197,94,0.3) !important;
    pointer-events: none;
    animation: correctPop 0.35s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

.state-correct .answer-label {
    background: #166534 !important;
    color: #fff !important;
}

.state-correct::after {
    content: ' ✓';
    font-weight: 900;
    font-size: 1.05rem;
    color: #166534;
}

@keyframes correctPop {
    from { transform: scale(0.93); opacity: 0.7; }
    to   { transform: scale(1);    opacity: 1; }
}

/* ── State: wrong — vivid pastel coral ──────────────────────────── */
.state-wrong,
.answer-option.state-wrong:hover,
.answer-option.state-wrong:active,
.answer-option.state-wrong:focus,
.answer-option.state-wrong:focus-visible {
    background: linear-gradient(135deg, #f87171 0%, #fca5a5 100%) !important;
    border-color: #dc2626 !important;
    border-width: 2.5px !important;
    color: #7f1d1d !important;
    font-weight: 700 !important;
    box-shadow: 0 0 0 3px rgba(248,113,113,0.4),
                0 6px 20px rgba(220,38,38,0.25) !important;
    pointer-events: none;
    animation: wrongShake 0.45s ease-in-out both;
}

.state-wrong .answer-label {
    background: #991b1b !important;
    color: #fff !important;
}

.state-wrong::after {
    content: ' ✗';
    font-weight: 900;
    font-size: 1.05rem;
    color: #7f1d1d;
}

@keyframes wrongShake {
    0%,100% { transform: translateX(0); }
    12%     { transform: translateX(-7px) rotate(-0.5deg); }
    25%     { transform: translateX( 7px) rotate( 0.5deg); }
    37%     { transform: translateX(-5px); }
    50%     { transform: translateX( 5px); }
    62%     { transform: translateX(-3px); }
    75%     { transform: translateX( 3px); }
    87%     { transform: translateX(-1px); }
}

/* ── State: reveal correct — pulsing vivid green ────────────────── */
.state-reveal,
.answer-option.state-reveal:hover,
.answer-option.state-reveal:active,
.answer-option.state-reveal:focus,
.answer-option.state-reveal:focus-visible {
    background: linear-gradient(135deg, #22c55e 0%, #4ade80 100%) !important;
    border-color: #15803d !important;
    border-width: 2.5px !important;
    color: #14532d !important;
    font-weight: 700 !important;
    pointer-events: none;
    animation: revealPulse 0.7s ease-in-out infinite alternate;
}

.state-reveal .answer-label {
    background: #166534 !important;
    color: #fff !important;
}

.state-reveal::after {
    content: ' ✓';
    font-weight: 900;
    font-size: 1.05rem;
    color: #14532d;
}

@keyframes revealPulse {
    from {
        box-shadow: 0 0 0 3px rgba(74,222,128,0.45),
                    0 4px 16px rgba(34,197,94,0.3);
    }
    to {
        box-shadow: 0 0 0 8px rgba(74,222,128,0.2),
                    0 8px 28px rgba(34,197,94,0.45),
                    0 0 40px rgba(74,222,128,0.15);
    }
}

/* ── Card shake on wrong answer ──────────────────────────────────── */
@keyframes cardShake {
    0%,100% { transform: translateX(0) rotate(0deg); }
    15%     { transform: translateX(-5px) rotate(-0.3deg); }
    30%     { transform: translateX( 5px) rotate( 0.3deg); }
    45%     { transform: translateX(-4px); }
    60%     { transform: translateX( 4px); }
    75%     { transform: translateX(-2px); }
}

.card-shake {
    animation: cardShake 0.45s ease-in-out;
}

/* ── Next Question button ───────────────────────────────────────── */
#next-btn {
    display: none;
    width: 100%;
    padding: 14px;
    border-radius: 50px;
    border: none;
    background: linear-gradient(180deg, var(--quiz-accent-2, #2f5563), var(--quiz-accent, #1f3d49));
    color: #fff;
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
    font-family: 'Nunito', sans-serif;
    margin-top: 12px;
    opacity: 0;
    transition: opacity 280ms ease, transform 200ms ease;
    box-shadow: 0 12px 26px rgba(31,61,73,.24);
}

#next-btn.visible {
    opacity: 1;
    transform: translateY(0);
}

#next-btn:hover { opacity: 1; transform: translateY(-1px); box-shadow: 0 16px 30px rgba(31,61,73,.28), 0 0 0 1px var(--quiz-warm-border, rgba(240,207,132,.5)) inset; }

/* ── Question rating area ───────────────────────────────────────── */
#question-rating {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid #e5e7eb;
}

#question-rating p {
    font-size: 0.85rem;
    color: #6b7280;
    margin-bottom: 8px;
    font-weight: 600;
}

/* ── Quiz end screen ────────────────────────────────────────────── */
#quiz-end-screen {
    background: rgba(255,255,255,.92);
    border-radius: 16px;
    padding: 32px 24px;
    border: 1px solid rgba(24,52,63,.1);
    box-shadow: 0 18px 40px rgba(20,40,50,.1);
    text-align: center;
    animation: fadeInUp 350ms ease both;
}

@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(20px); }
    to   { opacity: 1; transform: translateY(0); }
}

.end-score-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin: 20px 0;
}

.end-score-box { border-radius: 10px; padding: 16px; }
.end-score-box.correct { background: #dcfce7; color: #15803d; }
.end-score-box.wrong   { background: #fee2e2; color: #dc2626; }
.end-score-box.total   { background: rgba(240,207,132,.18); color: #8a6a30; grid-column: span 2; }
.end-score-label { font-size: 0.78rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; }
.end-score-val   { font-size: 1.8rem; font-weight: 800; line-height: 1.2; margin-top: 4px; }

.perf-badge {
    display: inline-block;
    padding: 5px 18px;
    border-radius: 50px;
    font-weight: 700;
    font-size: 0.85rem;
    margin-bottom: 14px;
}
.perf-badge.badge-red   { background: #fee2e2; color: #dc2626; }
.perf-badge.badge-amber { background: rgba(240,207,132,.18); color: #8a6a30; }
.perf-badge.badge-green { background: #dcfce7; color: #15803d; }

.end-message { font-size: 0.88rem; color: #6b7280; margin-bottom: 20px; line-height: 1.6; }
.end-message a { color: #2f5563; font-weight: 700; }

.end-xp-box {
    background: rgba(240,207,132,.14);
    border-radius: 12px;
    padding: 12px 20px;
    color: #8a6a30;
    font-weight: 700;
    font-size: 0.95rem;
    margin-bottom: 16px;
}
.end-xp-box span { font-size: 0.82rem; font-weight: 500; margin-left: 6px; color: #8a6a30; }

.end-guest-cta {
    background: rgba(255,255,255,.78);
    border: 1.5px solid rgba(24,52,63,.1);
    border-radius: 12px;
    padding: 16px;
    margin-bottom: 16px;
}
.end-guest-cta p { font-weight: 700; color: #1f3d49; font-size: 0.9rem; margin-bottom: 10px; }
.end-cta-btns { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }
.end-cta-btns a { padding: 10px 22px; border-radius: 50px; font-weight: 700; font-size: 0.88rem; text-decoration: none; transition: opacity 0.15s; }
.end-cta-btns a:hover { opacity: 0.88; }
.btn-end-login  { background: #e8eef1; color: #1f3d49; }
.btn-end-signup { background: linear-gradient(180deg, #2f5563, #1f3d49); color: #fff; box-shadow: 0 10px 22px rgba(31,61,73,.22); }

.btn-play-again {
    margin-top: 16px; width: 100%; padding: 14px; border-radius: 12px;
    border: none; background: linear-gradient(180deg, #2f5563, #1f3d49);
    color: #fff; font-size: 1rem; font-weight: 700; cursor: pointer;
    font-family: 'Nunito', sans-serif; transition: opacity 0.15s, transform 0.15s, box-shadow 0.15s;
}
.btn-play-again:hover { opacity: 1; transform: translateY(-1px); box-shadow: 0 14px 28px rgba(31,61,73,.24), 0 0 0 1px rgba(240,207,132,.48) inset; }

.end-suggestions-title {
    font-size: 0.82rem; font-weight: 800; color: #9ca3af;
    text-transform: uppercase; letter-spacing: 0.07em; margin: 20px 0 10px; text-align: left;
}
.end-quiz-cards { display: flex; flex-direction: column; gap: 8px; }
.end-quiz-card {
    background: #f7fbfc; border: 1.5px solid rgba(24,52,63,.08); border-radius: 12px;
    padding: 12px 16px; display: flex; justify-content: space-between;
    align-items: center; cursor: pointer; text-align: left;
    transition: border-color 0.15s, background 0.15s; width: 100%; font-family: 'Nunito', sans-serif;
}
.end-quiz-card:hover { border-color: #2f5563; background: rgba(255,255,255,.94); }
.end-quiz-card-title { font-weight: 700; font-size: 0.88rem; color: #111827; }
.end-quiz-card-meta  { font-size: 0.78rem; color: #6b7280; margin-top: 2px; }
.btn-quiz-start {
    background: #2f5563; color: #fff; border: none; border-radius: 50px;
    padding: 7px 16px; font-size: 0.82rem; font-weight: 700; cursor: pointer;
    font-family: 'Nunito', sans-serif; white-space: nowrap; flex-shrink: 0;
    margin-left: 12px; transition: background 0.15s;
}
.btn-quiz-start:hover { background: #1f3d49; }


/* ══════════════════════════════════════════════════════════════════
   15 BACKGROUND THEMES — applied to .quiz-bg every 5 questions
   ══════════════════════════════════════════════════════════════════ */

.quiz-bg, .quiz-wrap {
    transition: background-color 0.8s ease;
}

/* 1 — Horizon Blue (default) */
.quiz-bg.theme-1, .quiz-wrap.theme-1 {
    background-color: #f0f4ff;
    background-image: none;
}

/* 2 — Green Bubbles */
.quiz-bg.theme-2, .quiz-wrap.theme-2 {
    background-color: #e8f8ed;
    background-image:
        radial-gradient(circle, rgba(34,197,94,0.22) 14px, transparent 15px),
        radial-gradient(circle, rgba(16,185,129,0.14) 8px, transparent 9px),
        radial-gradient(circle, rgba(52,211,153,0.18) 20px, transparent 21px);
    background-size: 80px 80px, 55px 55px, 110px 110px;
    background-position: 0 0, 40px 40px, 20px 60px;
}

/* 3 — Ocean Waves */
.quiz-bg.theme-3, .quiz-wrap.theme-3 {
    background-color: #dbeffe;
    background-image:
        radial-gradient(ellipse 200% 18% at 50% 0%,   rgba(59,130,246,0.22) 100%, transparent 100%),
        radial-gradient(ellipse 200% 18% at 50% 33%,  rgba(59,130,246,0.16) 100%, transparent 100%),
        radial-gradient(ellipse 200% 18% at 50% 66%,  rgba(59,130,246,0.12) 100%, transparent 100%),
        radial-gradient(ellipse 200% 18% at 50% 100%, rgba(59,130,246,0.10) 100%, transparent 100%);
    background-size: 400px 90px;
    background-position: 0 0, 200px 30px, 0 60px, 200px 90px;
}

/* 4 — Lavender Stars */
.quiz-bg.theme-4, .quiz-wrap.theme-4 {
    background-color: #f0ebff;
    background-image:
        radial-gradient(circle, rgba(139,92,246,0.28) 3px, transparent 3px),
        radial-gradient(circle, rgba(167,139,250,0.18) 2px, transparent 2px);
    background-size: 50px 50px, 30px 30px;
    background-position: 0 0, 15px 15px;
}

/* 5 — Sunset Glow */
.quiz-bg.theme-5, .quiz-wrap.theme-5 {
    background-color: #fff4ed;
    background-image:
        radial-gradient(ellipse 80% 60% at 80% 20%, rgba(251,146,60,0.18) 100%, transparent 100%),
        radial-gradient(ellipse 60% 40% at 20% 80%, rgba(244,63,94,0.14) 100%, transparent 100%);
}

/* 6 — Mint Breeze */
.quiz-bg.theme-6, .quiz-wrap.theme-6 {
    background-color: #e6fff7;
    background-image:
        repeating-linear-gradient(
            45deg,
            transparent,
            transparent 18px,
            rgba(20,184,166,0.10) 18px,
            rgba(20,184,166,0.10) 19px
        ),
        repeating-linear-gradient(
            -45deg,
            transparent,
            transparent 18px,
            rgba(20,184,166,0.07) 18px,
            rgba(20,184,166,0.07) 19px
        );
}

/* 7 — Teal Diamonds */
.quiz-bg.theme-7, .quiz-wrap.theme-7 {
    background-color: #e0fafa;
    background-image:
        repeating-linear-gradient(
            45deg,
            transparent 0px,
            transparent 20px,
            rgba(20,184,166,0.15) 20px,
            rgba(20,184,166,0.15) 21px
        ),
        repeating-linear-gradient(
            -45deg,
            transparent 0px,
            transparent 20px,
            rgba(20,184,166,0.15) 20px,
            rgba(20,184,166,0.15) 21px
        );
}

/* 8 — Rose Bloom */
.quiz-bg.theme-8, .quiz-wrap.theme-8 {
    background-color: #fff0f5;
    background-image:
        radial-gradient(circle, rgba(244,63,94,0.12) 20px, transparent 21px),
        radial-gradient(circle, rgba(251,113,133,0.08) 12px, transparent 13px),
        radial-gradient(circle, rgba(253,164,175,0.10) 30px, transparent 31px);
    background-size: 90px 90px, 60px 60px, 120px 120px;
    background-position: 0 0, 45px 45px, 25px 70px;
}

/* 9 — Forest Dots */
.quiz-bg.theme-9, .quiz-wrap.theme-9 {
    background-color: #edfae4;
    background-image:
        radial-gradient(circle, rgba(22,163,74,0.20) 5px, transparent 5px),
        radial-gradient(circle, rgba(21,128,61,0.12) 3px, transparent 3px);
    background-size: 40px 40px, 25px 25px;
    background-position: 0 0, 12px 12px;
}

/* 10 — Night Galaxy */
.quiz-bg.theme-10, .quiz-wrap.theme-10 {
    background-color: #e8eaf6;
    background-image:
        radial-gradient(circle, rgba(99,102,241,0.30) 2px, transparent 2px),
        radial-gradient(circle, rgba(129,140,248,0.20) 1px, transparent 1px),
        radial-gradient(circle, rgba(165,180,252,0.15) 3px, transparent 3px);
    background-size: 35px 35px, 20px 20px, 55px 55px;
    background-position: 0 0, 10px 10px, 28px 28px;
}

/* 11 — Golden Hour */
.quiz-bg.theme-11, .quiz-wrap.theme-11 {
    background-color: #fffaeb;
    background-image:
        repeating-linear-gradient(
            60deg,
            transparent,
            transparent 22px,
            rgba(245,158,11,0.08) 22px,
            rgba(245,158,11,0.08) 23px
        ),
        radial-gradient(ellipse 70% 50% at 90% 10%, rgba(251,191,36,0.20) 100%, transparent 100%);
}

/* 12 — Arctic Frost */
.quiz-bg.theme-12, .quiz-wrap.theme-12 {
    background-color: #edf7ff;
    background-image:
        radial-gradient(circle, rgba(147,210,255,0.30) 4px, transparent 4px),
        radial-gradient(circle, rgba(186,230,253,0.20) 2px, transparent 2px),
        radial-gradient(circle, rgba(224,242,254,0.25) 6px, transparent 6px);
    background-size: 45px 45px, 28px 28px, 70px 70px;
    background-position: 0 0, 14px 14px, 35px 35px;
}

/* 13 — Coral Reef */
.quiz-bg.theme-13, .quiz-wrap.theme-13 {
    background-color: #fff2ee;
    background-image:
        radial-gradient(ellipse 200% 20% at 30% 0%,   rgba(249,115,22,0.15) 100%, transparent 100%),
        radial-gradient(ellipse 200% 20% at 70% 50%,  rgba(234,88,12,0.12) 100%, transparent 100%),
        radial-gradient(ellipse 200% 20% at 40% 100%, rgba(249,115,22,0.10) 100%, transparent 100%);
    background-size: 500px 80px;
    background-position: 0 0, 0 40px, 0 80px;
}

/* 14 — Orchid Dreams */
.quiz-bg.theme-14, .quiz-wrap.theme-14 {
    background-color: #f7eeff;
    background-image:
        radial-gradient(circle, rgba(168,85,247,0.18) 18px, transparent 19px),
        radial-gradient(circle, rgba(192,132,252,0.12) 10px, transparent 11px),
        radial-gradient(circle, rgba(216,180,254,0.08) 26px, transparent 27px);
    background-size: 100px 100px, 65px 65px, 140px 140px;
    background-position: 0 0, 50px 50px, 30px 80px;
}

/* 15 — Jade Isle */
.quiz-bg.theme-15, .quiz-wrap.theme-15 {
    background-color: #e6f5ee;
    background-image:
        radial-gradient(ellipse 200% 15% at 50% 25%,  rgba(5,150,105,0.14) 100%, transparent 100%),
        radial-gradient(ellipse 200% 15% at 50% 75%,  rgba(16,185,129,0.10) 100%, transparent 100%),
        radial-gradient(circle, rgba(52,211,153,0.16) 4px, transparent 4px);
    background-size: 600px 100px, 600px 100px, 50px 50px;
    background-position: 0 0, 0 50px, 0 0;
}
