/* ==========================================================================
   GAMIFICATION.CSS - XP System, Achievements, Enhanced Results
   ========================================================================== */

/* --- XP Bar in Stats Header --- */
.stat-item.stat-xp {
    display: flex;
    align-items: center;
    gap: 6px;
}

.xp-level-badge {
    background: linear-gradient(135deg, var(--g1, #60a5fa), var(--g2, #a78bfa));
    color: #0f172a;
    font-weight: 800;
    font-size: 0.7rem;
    padding: 2px 6px;
    border-radius: 6px;
    min-width: 28px;
    text-align: center;
}

#level-badge {
    cursor: pointer;
    user-select: none;
    transition: filter 0.2s ease;
}

#level-badge:hover {
    filter: brightness(1.08);
}

#level-badge:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--g1, #60a5fa) 68%, #ffffff 32%);
    outline-offset: 2px;
}

.xp-bar-mini {
    width: 60px;
    height: 6px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 3px;
    overflow: hidden;
}

.xp-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--g1, #60a5fa), var(--g2, #a78bfa));
    border-radius: 3px;
    transition: width 0.5s ease;
}

/* --- XP Popup Toast --- */
.xp-toast {
    position: fixed;
    top: 20px;
    right: 20px;
    background: var(--g, linear-gradient(135deg, #4ade80, #22d3ee));
    color: #fff;
    padding: 12px 20px;
    border-radius: 12px;
    font-weight: 700;
    font-size: 1rem;
    z-index: 9999;
    opacity: 0;
    transform: translateY(-20px) scale(0.9);
    transition: all 0.3s ease;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.3);
}

.xp-toast.show {
    opacity: 1;
    transform: translateY(0) scale(1);
}

.xp-toast .xp-amount {
    font-size: 1.3rem;
    margin-right: 6px;
}

/* --- Achievement Toast --- */
.achievement-toast {
    position: fixed;
    top: 80px;
    right: 20px;
    background: color-mix(in srgb, var(--card-bg, rgba(15, 23, 42, 0.92)) 90%, #0b1220 10%);
    border: 1px solid color-mix(in srgb, var(--bd, rgba(255, 255, 255, 0.15)) 78%, transparent 22%);
    color: var(--text-main, #e2e8f0);
    padding: 12px 14px;
    border-radius: 12px;
    font-weight: 600;
    z-index: 9999;
    opacity: 0;
    transform: translateX(30px);
    transition: all 0.4s ease;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.3);
    display: flex;
    align-items: center;
    gap: 10px;
}

.achievement-toast.show {
    opacity: 1;
    transform: translateX(0);
}

.achievement-toast .ach-icon {
    min-width: 42px;
    height: 24px;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--bd, rgba(255, 255, 255, 0.2)) 78%, transparent 22%);
    background: color-mix(in srgb, var(--card-bg, rgba(15, 23, 42, 0.8)) 82%, transparent 18%);
    color: var(--text-sub, #94a3b8);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.64rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    line-height: 1;
    padding: 0 8px;
}

.achievement-toast .ach-info {
    display: flex;
    flex-direction: column;
}

.achievement-toast .ach-label {
    font-size: 0.64rem;
    text-transform: uppercase;
    opacity: 0.72;
    letter-spacing: 0.08em;
}

.achievement-toast .ach-name {
    font-size: 0.9rem;
    line-height: 1.15;
}

/* --- Enhanced Results Screen --- */
#results-view {
    flex-direction: column;
    align-items: center;
    gap: 20px;
    padding: 30px;
}

/* XP Earned Banner */
.xp-earned-banner {
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.15), rgba(16, 185, 129, 0.15));
    border: 1px solid rgba(34, 197, 94, 0.3);
    border-radius: 16px;
    padding: 20px 30px;
    text-align: center;
    width: 100%;
    max-width: 400px;
}

.xp-earned-banner .xp-earned-label {
    font-size: 0.85rem;
    color: #94a3b8;
    text-transform: uppercase;
    font-weight: 600;
}

.xp-earned-banner .xp-earned-amount {
    font-size: 2.5rem;
    font-weight: 800;
    background: linear-gradient(135deg, #22c55e, #10b981);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.xp-earned-banner .xp-earned-amount.animating {
    animation: xp-pulse 0.6s ease;
}

@keyframes xp-pulse {

    0%,
    100% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.15);
    }
}

/* Level Progress Section */
.level-progress-section {
    background: rgba(255, 255, 255, 0.03);
    border-radius: 12px;
    padding: 15px 20px;
    width: 100%;
    max-width: 400px;
}

.level-progress-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.level-progress-header .current-level {
    font-weight: 700;
    color: #e2e8f0;
}

.level-progress-header .xp-text {
    font-size: 0.85rem;
    color: #94a3b8;
}

.level-bar {
    height: 10px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 5px;
    overflow: hidden;
}

.level-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--g1, #60a5fa), var(--g2, #a78bfa));
    border-radius: 5px;
    transition: width 1s ease;
}

/* Source Breakdown Table */
.source-breakdown {
    width: 100%;
    max-width: 500px;
    margin-top: 10px;
}

.source-breakdown-title {
    font-size: 0.85rem;
    color: #94a3b8;
    text-transform: uppercase;
    font-weight: 600;
    margin-bottom: 12px;
    text-align: center;
}

.source-table {
    width: 100%;
    border-collapse: collapse;
}

.source-table th {
    font-size: 0.75rem;
    color: #64748b;
    text-transform: uppercase;
    font-weight: 600;
    padding: 8px 12px;
    text-align: left;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.source-table th:nth-child(2),
.source-table th:nth-child(3),
.source-table th:nth-child(4) {
    text-align: center;
}

.source-table td {
    padding: 10px 12px;
    font-size: 0.9rem;
    color: #cbd5e1;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.source-table td:nth-child(2),
.source-table td:nth-child(3),
.source-table td:nth-child(4) {
    text-align: center;
}

.source-table .correct-count {
    color: #22c55e;
    font-weight: 600;
}

.source-table .wrong-count {
    color: #ef4444;
    font-weight: 600;
}

.source-table .pct-cell {
    font-weight: 600;
}

.source-table .pct-cell.good {
    color: #22c55e;
}

.source-table .pct-cell.mid {
    color: #fbbf24;
}

.source-table .pct-cell.bad {
    color: #ef4444;
}

/* Achievements Section */
.achievements-section {
    width: 100%;
    max-width: 500px;
    margin-top: 10px;
}

.achievements-title {
    font-size: 0.85rem;
    color: #94a3b8;
    text-transform: uppercase;
    font-weight: 600;
    margin-bottom: 12px;
    text-align: center;
}

.achievement-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
    gap: 10px;
}

.achievement-badge {
    background: color-mix(in srgb, var(--card-bg, rgba(15, 23, 42, 0.8)) 86%, #0b1220 14%);
    border: 1px solid color-mix(in srgb, var(--bd, rgba(255, 255, 255, 0.14)) 85%, transparent 15%);
    border-radius: 12px;
    padding: 12px 10px;
    text-align: center;
    transition: all 0.3s ease;
    min-height: 82px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 8px;
}

.achievement-badge.locked {
    opacity: 0.56;
}

.achievement-badge.unlocked {
    border-color: color-mix(in srgb, var(--g1, #60a5fa) 45%, var(--g2, #a78bfa) 55%);
    background: linear-gradient(135deg,
            color-mix(in srgb, var(--g1, #60a5fa) 15%, transparent 85%),
            color-mix(in srgb, var(--g2, #a78bfa) 12%, transparent 88%));
}

.achievement-badge.new-unlock {
    animation: badge-glow 1.8s ease infinite;
}

@keyframes badge-glow {

    0%,
    100% {
        box-shadow: 0 0 0 rgba(0, 0, 0, 0);
    }

    50% {
        box-shadow: 0 0 16px color-mix(in srgb, var(--g1, #60a5fa) 35%, var(--g2, #a78bfa) 65%);
    }
}

.achievement-badge .badge-icon {
    font-size: 0.64rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.09em;
    width: fit-content;
    margin: 0 auto;
    padding: 4px 10px;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--bd, rgba(255, 255, 255, 0.18)) 80%, transparent 20%);
    background: color-mix(in srgb, var(--card-bg, rgba(15, 23, 42, 0.78)) 82%, transparent 18%);
    color: var(--text-sub, #94a3b8);
    line-height: 1;
}

.achievement-badge .badge-name {
    font-size: 0.72rem;
    line-height: 1.25;
    color: var(--text-main, #cbd5e1);
    font-weight: 650;
}

/* Stats Modal Achievement Gallery */
.stats-achievements {
    margin-top: 15px;
}

.stats-achievements .achievement-grid {
    grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
}

/* ==========================================================================
   STREAK HEAT EFFECTS - XP Bar Visual States
   ========================================================================== */

/* Base transition for smooth heat changes */
.xp-bar-fill,
.level-bar-fill,
.xp-bar-mini {
    transition: all 0.5s ease;
    position: relative;
}

/* Streak 5+: Warm Glow */
.xp-bar-mini.streak-warm .xp-bar-fill,
.level-bar.streak-warm .level-bar-fill {
    background: linear-gradient(90deg, #f59e0b, #f97316);
    box-shadow: 0 0 8px rgba(249, 115, 22, 0.5);
}

.xp-bar-mini.streak-warm,
.level-bar.streak-warm {
    animation: warm-pulse 2s ease-in-out infinite;
}

@keyframes warm-pulse {

    0%,
    100% {
        box-shadow: 0 0 5px rgba(249, 115, 22, 0.3);
    }

    50% {
        box-shadow: 0 0 12px rgba(249, 115, 22, 0.6);
    }
}

/* Streak 10+: Hot */
.xp-bar-mini.streak-hot .xp-bar-fill,
.level-bar.streak-hot .level-bar-fill {
    background: linear-gradient(90deg, #f97316, #ef4444, #f97316);
    background-size: 200% 100%;
    animation: hot-flow 1.5s ease infinite;
    box-shadow: 0 0 12px rgba(239, 68, 68, 0.6);
}

.xp-bar-mini.streak-hot,
.level-bar.streak-hot {
    box-shadow: 0 0 15px rgba(239, 68, 68, 0.4);
}

@keyframes hot-flow {
    0% {
        background-position: 0% 50%;
    }

    50% {
        background-position: 100% 50%;
    }

    100% {
        background-position: 0% 50%;
    }
}

/* Streak 15+: On Fire */
.xp-bar-mini.streak-fire .xp-bar-fill,
.level-bar.streak-fire .level-bar-fill {
    background: linear-gradient(90deg, #ef4444, #f97316, #fbbf24, #f97316, #ef4444);
    background-size: 300% 100%;
    animation: fire-blaze 1s ease infinite;
    box-shadow: 0 0 20px rgba(239, 68, 68, 0.7), 0 0 40px rgba(251, 191, 36, 0.4);
}

.xp-bar-mini.streak-fire,
.level-bar.streak-fire {
    animation: fire-container 0.5s ease infinite;
}

@keyframes fire-blaze {
    0% {
        background-position: 0% 50%;
    }

    100% {
        background-position: 100% 50%;
    }
}

@keyframes fire-container {

    0%,
    100% {
        box-shadow: 0 0 15px rgba(239, 68, 68, 0.5), 0 -2px 8px rgba(251, 191, 36, 0.6);
        transform: scaleY(1);
    }

    50% {
        box-shadow: 0 0 25px rgba(239, 68, 68, 0.7), 0 -4px 12px rgba(251, 191, 36, 0.8);
        transform: scaleY(1.1);
    }
}

/* Streak 25+: Inferno */
.xp-bar-mini.streak-inferno .xp-bar-fill,
.level-bar.streak-inferno .level-bar-fill {
    background: linear-gradient(90deg, #dc2626, #f97316, #fbbf24, #fff, #fbbf24, #f97316, #dc2626);
    background-size: 400% 100%;
    animation: inferno-rage 0.8s linear infinite;
    box-shadow:
        0 0 25px rgba(220, 38, 38, 0.8),
        0 0 50px rgba(251, 191, 36, 0.5),
        inset 0 0 10px rgba(255, 255, 255, 0.3);
}

.xp-bar-mini.streak-inferno,
.level-bar.streak-inferno {
    animation: inferno-shake 0.15s ease infinite;
}

@keyframes inferno-rage {
    0% {
        background-position: 0% 50%;
    }

    100% {
        background-position: 100% 50%;
    }
}

@keyframes inferno-shake {

    0%,
    100% {
        transform: translateX(0) scaleY(1);
    }

    25% {
        transform: translateX(-1px) scaleY(1.15);
    }

    75% {
        transform: translateX(1px) scaleY(1.1);
    }
}

/* ==========================================================================
   PRESTIGE TIER BADGES - Level-Based Styling
   ========================================================================== */

/* Tier 1: Bronze (Levels 1-5) */
.xp-level-badge.tier-bronze {
    background: linear-gradient(135deg, #cd7f32, #b87333, #cd7f32);
    color: #1a1a1a;
    border: 1px solid rgba(205, 127, 50, 0.5);
    box-shadow: 0 2px 8px rgba(205, 127, 50, 0.3);
}

/* Tier 2: Silver (Levels 6-10) */
.xp-level-badge.tier-silver {
    background: linear-gradient(135deg, #c0c0c0, #e8e8e8, #a8a8a8);
    color: #1a1a1a;
    border: 1px solid rgba(192, 192, 192, 0.5);
    box-shadow: 0 2px 10px rgba(192, 192, 192, 0.4);
}

/* Tier 3: Gold (Levels 11-15) */
.xp-level-badge.tier-gold {
    background: linear-gradient(135deg, #ffd700, #ffec8b, #daa520);
    color: #1a1a1a;
    border: 1px solid rgba(255, 215, 0, 0.6);
    box-shadow: 0 2px 12px rgba(255, 215, 0, 0.5);
    animation: gold-shimmer 3s ease infinite;
}

@keyframes gold-shimmer {

    0%,
    100% {
        background-position: 0% 50%;
    }

    50% {
        background-position: 100% 50%;
    }
}

.xp-level-badge.tier-gold {
    background-size: 200% 200%;
}

/* Tier 4: Platinum (Levels 16-20) */
.xp-level-badge.tier-platinum {
    background: linear-gradient(135deg, #e5e4e2, #ffffff, #c9c9c9, #ffffff, #e5e4e2);
    background-size: 300% 300%;
    color: #1a1a1a;
    border: 1px solid rgba(255, 255, 255, 0.6);
    box-shadow:
        0 2px 15px rgba(255, 255, 255, 0.5),
        0 0 20px rgba(200, 200, 255, 0.3);
    animation: platinum-glow 4s ease infinite;
}

@keyframes platinum-glow {

    0%,
    100% {
        background-position: 0% 50%;
        box-shadow: 0 2px 15px rgba(255, 255, 255, 0.5), 0 0 20px rgba(200, 200, 255, 0.3);
    }

    50% {
        background-position: 100% 50%;
        box-shadow: 0 2px 20px rgba(255, 255, 255, 0.7), 0 0 30px rgba(200, 200, 255, 0.5);
    }
}

/* Tier 5: Diamond (Levels 21-30) */
.xp-level-badge.tier-diamond {
    background: linear-gradient(135deg,
            #b9f2ff, #e0f7fa, #ffffff,
            #a5d8ff, #c0f0ff, #ffffff,
            #b9f2ff);
    background-size: 400% 400%;
    color: #0c4a6e;
    border: 1px solid rgba(185, 242, 255, 0.8);
    box-shadow:
        0 2px 15px rgba(185, 242, 255, 0.6),
        0 0 25px rgba(96, 165, 250, 0.4),
        inset 0 0 10px rgba(255, 255, 255, 0.5);
    animation: diamond-sparkle 2s ease infinite;
}

@keyframes diamond-sparkle {
    0% {
        background-position: 0% 0%;
    }

    50% {
        background-position: 100% 100%;
    }

    100% {
        background-position: 0% 0%;
    }
}

/* Tier 6: Master (Levels 31-49) - Purple Aura */
.xp-level-badge.tier-master {
    background: linear-gradient(135deg,
            #1a1a2e, #9333ea, #a855f7,
            #9333ea, #1a1a2e);
    background-size: 400% 400%;
    color: #e9d5ff;
    border: 2px solid #a855f7;
    font-weight: 900;
    text-shadow: 0 0 10px rgba(168, 85, 247, 0.9);
    box-shadow:
        0 0 15px rgba(147, 51, 234, 0.5),
        0 0 25px rgba(168, 85, 247, 0.3),
        inset 0 0 10px rgba(168, 85, 247, 0.2);
    animation: master-pulse 6s ease infinite;
}

@keyframes master-pulse {

    0%,
    100% {
        background-position: 0% 50%;
        filter: brightness(1);
    }

    50% {
        background-position: 100% 50%;
        filter: brightness(1.2);
    }
}

/* Tier 7: Grandmaster (Levels 50-99) - Black/Gold Elite */
.xp-level-badge.tier-grandmaster {
    background: linear-gradient(135deg,
            #1a1a2e, #ffd700, #1a1a2e,
            #ffd700, #1a1a2e);
    background-size: 500% 500%;
    color: #ffd700;
    border: 2px solid #ffd700;
    font-weight: 900;
    text-shadow: 0 0 8px rgba(255, 215, 0, 0.8);
    box-shadow:
        0 0 15px rgba(255, 215, 0, 0.4),
        0 0 25px rgba(255, 215, 0, 0.25),
        inset 0 0 10px rgba(255, 215, 0, 0.15);
    animation: grandmaster-aura 7s ease infinite;
}

@keyframes grandmaster-aura {

    0%,
    100% {
        background-position: 0% 50%;
        box-shadow:
            0 0 15px rgba(255, 215, 0, 0.4),
            0 0 25px rgba(255, 215, 0, 0.25),
            inset 0 0 10px rgba(255, 215, 0, 0.15);
    }

    50% {
        background-position: 100% 50%;
        box-shadow:
            0 0 20px rgba(255, 215, 0, 0.5),
            0 0 35px rgba(255, 215, 0, 0.3),
            inset 0 0 15px rgba(255, 215, 0, 0.2);
    }
}


/* Tier 8: Legend (Levels 100-149) - Red/Orange Inferno */
.xp-level-badge.tier-legend {
    background: linear-gradient(135deg,
            #7f1d1d, #dc2626, #f97316, #fbbf24,
            #f97316, #dc2626, #7f1d1d);
    background-size: 500% 500%;
    color: #fef3c7;
    border: 2px solid #f97316;
    font-weight: 900;
    text-shadow: 0 0 12px rgba(249, 115, 22, 1);
    box-shadow:
        0 0 18px rgba(220, 38, 38, 0.5),
        0 0 30px rgba(249, 115, 22, 0.35),
        inset 0 0 12px rgba(251, 191, 36, 0.2);
    animation: legend-blaze 6s ease infinite;
}

@keyframes legend-blaze {

    0%,
    100% {
        background-position: 0% 50%;
        transform: scale(1);
    }

    50% {
        background-position: 100% 50%;
        transform: scale(1.02);
    }
}

/* Tier 9: Mythic (Levels 150-199) - Cosmic Purple/Pink */
.xp-level-badge.tier-mythic {
    background: linear-gradient(135deg,
            #0f0f23, #4c1d95, #7c3aed, #ec4899, #f472b6,
            #ec4899, #7c3aed, #4c1d95, #0f0f23);
    background-size: 600% 600%;
    color: #fdf4ff;
    border: 2px solid #ec4899;
    font-weight: 900;
    text-shadow:
        0 0 10px rgba(236, 72, 153, 0.9),
        0 0 20px rgba(124, 58, 237, 0.6);
    box-shadow:
        0 0 20px rgba(236, 72, 153, 0.45),
        0 0 35px rgba(124, 58, 237, 0.3),
        inset 0 0 12px rgba(244, 114, 182, 0.2);
    animation: mythic-cosmic 7s ease infinite;
}

@keyframes mythic-cosmic {
    0% {
        background-position: 0% 50%;
    }

    50% {
        background-position: 100% 50%;
    }

    100% {
        background-position: 0% 50%;
    }
}

/* Tier 10: Immortal (Levels 200-499) - Divine Electric Blue/Celestial */
.xp-level-badge.tier-immortal {
    background: linear-gradient(135deg,
            #0c1929, #0369a1, #0ea5e9, #38bdf8, #ffffff,
            #38bdf8, #0ea5e9, #0369a1, #0c1929);
    background-size: 600% 600%;
    color: #ffffff;
    border: 2px solid #38bdf8;
    font-weight: 900;
    letter-spacing: 0.5px;
    text-shadow:
        0 0 15px rgba(56, 189, 248, 1),
        0 0 30px rgba(14, 165, 233, 0.8),
        0 0 45px rgba(255, 255, 255, 0.5);
    box-shadow:
        0 0 20px rgba(56, 189, 248, 0.6),
        0 0 40px rgba(14, 165, 233, 0.35),
        inset 0 0 15px rgba(255, 255, 255, 0.2);
    animation: immortal-divine 8s ease infinite;
}

@keyframes immortal-divine {

    0%,
    100% {
        background-position: 0% 50%;
        box-shadow:
            0 0 20px rgba(56, 189, 248, 0.6),
            0 0 40px rgba(14, 165, 233, 0.35),
            inset 0 0 15px rgba(255, 255, 255, 0.2);
    }

    50% {
        background-position: 100% 50%;
        box-shadow:
            0 0 28px rgba(56, 189, 248, 0.7),
            0 0 50px rgba(14, 165, 233, 0.45),
            inset 0 0 20px rgba(255, 255, 255, 0.3);
    }
}

@keyframes immortal-flicker {

    0%,
    100% {
        filter: brightness(1);
    }

    50% {
        filter: brightness(1.1);
    }
}


/* Tier 11: Transcendent (Levels 500-999) - Rainbow Prismatic */
.xp-level-badge.tier-transcendent {
    background: linear-gradient(135deg,
            #ef4444, #f97316, #eab308, #22c55e,
            #06b6d4, #3b82f6, #8b5cf6, #ec4899,
            #ef4444);
    background-size: 800% 800%;
    color: #fff;
    border: 2px solid transparent;
    border-image: linear-gradient(135deg, #ef4444, #8b5cf6, #06b6d4) 1;
    font-weight: 900;
    text-shadow:
        0 0 10px rgba(255, 255, 255, 0.8),
        0 0 20px rgba(139, 92, 246, 0.6);
    box-shadow:
        0 0 22px rgba(139, 92, 246, 0.45),
        0 0 40px rgba(6, 182, 212, 0.3),
        0 0 55px rgba(236, 72, 153, 0.2);
    animation: transcendent-rainbow 10s linear infinite;
}

@keyframes transcendent-rainbow {
    0% {
        background-position: 0% 50%;
        filter: hue-rotate(0deg);
    }

    100% {
        background-position: 100% 50%;
        filter: hue-rotate(360deg);
    }
}

/* Tier 12: Eternal (Levels 1000+) - Void/Cosmic Ultimate */
.xp-level-badge.tier-eternal {
    background: linear-gradient(135deg,
            #000000, #1e1b4b, #312e81, #4338ca,
            #ffffff, #4338ca, #312e81, #1e1b4b, #000000);
    background-size: 1000% 1000%;
    color: #fff;
    border: 3px solid;
    border-image: linear-gradient(135deg, #fff, #a78bfa, #fff) 1;
    font-weight: 900;
    letter-spacing: 1px;
    text-shadow:
        0 0 10px rgba(255, 255, 255, 0.8),
        0 0 20px rgba(167, 139, 250, 0.5);
    box-shadow:
        0 0 25px rgba(255, 255, 255, 0.35),
        0 0 45px rgba(167, 139, 250, 0.25),
        inset 0 0 18px rgba(255, 255, 255, 0.15);
    animation: eternal-void 12s ease infinite, eternal-pulse 3s ease-in-out infinite;
}

@keyframes eternal-void {
    0% {
        background-position: 0% 50%;
    }

    50% {
        background-position: 100% 50%;
    }

    100% {
        background-position: 0% 50%;
    }
}

@keyframes eternal-pulse {

    0%,
    100% {
        transform: scale(1);
        filter: brightness(1);
    }

    50% {
        transform: scale(1.02);
        filter: brightness(1.1);
    }
}


/* ==========================================================================
   CONFETTI CELEBRATION
   ========================================================================== */

.level-up-effects-root {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 10010;
    overflow: hidden;
    contain: layout paint style;
    isolation: isolate;
}

.confetti-container {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 2;
    overflow: hidden;
    contain: paint;
}

.confetti {
    position: absolute;
    width: 10px;
    height: 10px;
    opacity: 0;
    animation: confetti-fall 3s ease-out forwards;
}

.confetti.square {
    border-radius: 2px;
}

.confetti.circle {
    border-radius: 50%;
}

.confetti.ribbon {
    width: 4px;
    height: 16px;
    border-radius: 2px;
}

@keyframes confetti-fall {
    0% {
        opacity: 1;
        transform: translateY(-10px) rotate(0deg) scale(1);
    }

    10% {
        opacity: 1;
    }

    100% {
        opacity: 0;
        transform: translateY(100vh) rotate(720deg) scale(0.5);
    }
}

/* Level Up Flash Effect */
.level-up-flash {
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at center, rgba(255, 215, 0, 0.3), transparent 70%);
    pointer-events: none;
    z-index: 1;
    animation: flash-fade 1s ease-out forwards;
}

@keyframes flash-fade {
    0% {
        opacity: 1;
    }

    100% {
        opacity: 0;
    }
}

/* Level Up Toast Enhancement */
.xp-toast.level-up {
    background: linear-gradient(135deg, rgba(255, 215, 0, 0.95), rgba(245, 158, 11, 0.95));
    color: #1a1a1a;
    box-shadow: 0 8px 30px rgba(255, 215, 0, 0.5);
    animation: level-toast-entrance 0.5s ease;
}

@keyframes level-toast-entrance {
    0% {
        transform: translateY(-20px) scale(0.8);
        opacity: 0;
    }

    50% {
        transform: translateY(5px) scale(1.05);
    }

    100% {
        transform: translateY(0) scale(1);
        opacity: 1;
    }
}

/* ==========================================================================
   ACHIEVEMENTS PANEL
   ========================================================================== */

#achievements-modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.8);
    z-index: 9000;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(4px);
}

#achievements-modal.show {
    display: flex;
}

.stat-achievements {
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 4px 8px;
    border-radius: 6px;
    transition: all 0.2s ease;
}

.stat-achievements:hover {
    background: rgba(255, 255, 255, 0.1);
    transform: scale(1.1);
}

.stat-achievements .gradient-text {
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.achievement-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 12px 20px;
    background: rgba(255, 255, 255, 0.05);
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

#achievements-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 12px;
    max-height: 400px;
    overflow-y: auto;
    padding-right: 8px;
}

#achievements-grid::-webkit-scrollbar {
    width: 6px;
}

#achievements-grid::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.05);
    border-radius: 3px;
}

#achievements-grid::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.2);
    border-radius: 3px;
}

.achievement-card {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px;
    background: color-mix(in srgb, var(--card-bg, rgba(15, 23, 42, 0.85)) 88%, #0b1220 12%);
    border: 1px solid color-mix(in srgb, var(--bd, rgba(255, 255, 255, 0.12)) 84%, transparent 16%);
    border-radius: 12px;
    transition: all 0.25s ease;
}

.achievement-card:hover {
    background: color-mix(in srgb, var(--card-bg, rgba(15, 23, 42, 0.85)) 80%, #111a2a 20%);
    border-color: color-mix(in srgb, var(--bd, rgba(255, 255, 255, 0.16)) 70%, var(--g1, #60a5fa) 30%);
    transform: translateY(-2px);
}

.achievement-card.locked {
    opacity: 0.64;
}

.achievement-card.locked .achievement-icon {
    color: color-mix(in srgb, var(--text-sub, #94a3b8) 85%, #6b7280 15%);
    border-color: color-mix(in srgb, var(--bd, rgba(255, 255, 255, 0.12)) 85%, transparent 15%);
}

.achievement-card.unlocked {
    border-color: color-mix(in srgb, var(--g1, #60a5fa) 42%, var(--g2, #a78bfa) 58%);
    background: linear-gradient(135deg,
            color-mix(in srgb, var(--g1, #60a5fa) 14%, transparent 86%),
            color-mix(in srgb, var(--g2, #a78bfa) 11%, transparent 89%));
}

.achievement-icon {
    min-width: 56px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: color-mix(in srgb, var(--card-bg, rgba(15, 23, 42, 0.82)) 80%, transparent 20%);
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--bd, rgba(255, 255, 255, 0.18)) 82%, transparent 18%);
    color: var(--text-sub, #94a3b8);
    font-size: 0.66rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    line-height: 1;
    padding: 0 10px;
}

.achievement-info {
    flex: 1;
    min-width: 0;
}

.achievement-name {
    font-weight: 680;
    font-size: 0.9rem;
    color: var(--text-main, #e2e8f0);
    margin-bottom: 3px;
    letter-spacing: 0.01em;
}

.achievement-desc {
    font-size: 0.78rem;
    line-height: 1.35;
    color: var(--text-sub, #94a3b8);
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
}

.achievement-progress {
    width: 100%;
    height: 5px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 999px;
    margin-top: 8px;
    overflow: hidden;
}

.achievement-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--g1, #60a5fa), var(--g2, #a78bfa));
    border-radius: 2px;
    transition: width 0.3s ease;
}

.achievement-status {
    font-size: 0.62rem;
    padding: 4px 8px;
    border-radius: 999px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    border: 1px solid transparent;
    line-height: 1;
}

.achievement-status.unlocked {
    background: color-mix(in srgb, var(--g1, #60a5fa) 18%, transparent 82%);
    color: color-mix(in srgb, var(--text-main, #e2e8f0) 75%, var(--g1, #60a5fa) 25%);
    border-color: color-mix(in srgb, var(--g1, #60a5fa) 35%, var(--bd, rgba(255, 255, 255, 0.2)) 65%);
}

.achievement-status.locked {
    background: rgba(255, 255, 255, 0.04);
    color: var(--text-sub, #64748b);
    border-color: color-mix(in srgb, var(--bd, rgba(255, 255, 255, 0.12)) 80%, transparent 20%);
}

/* ==========================================================================
   MYSTERY CARD REWARD SYSTEM - Gambling-Style XP Bonus
   ========================================================================== */

/* Mystery Card Modal Overlay */
.mystery-card-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(0, 0, 0, 0.9);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    z-index: 99999;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.4s ease;
    contain: layout paint style;
}

.mystery-card-overlay.active {
    opacity: 1;
    pointer-events: all;
}

.mystery-card-overlay.perf-lite {
    background: rgba(0, 0, 0, 0.82);
    transition-duration: 0.2s;
}

.mystery-card-overlay.perf-lite .mystery-title,
.mystery-card-overlay.perf-lite .mystery-symbol,
.mystery-card-overlay.perf-lite .mystery-card-front::before,
.mystery-card-overlay.perf-lite .rarity-legendary .rarity-badge {
    animation: none !important;
}

.mystery-card-overlay.perf-lite .mystery-card {
    transition: transform 0.16s ease, opacity 0.16s ease;
}

.mystery-card-overlay.perf-lite .mystery-card:hover:not(.flipped):not(.disabled) {
    transform: translateY(-4px) scale(1.01);
}

.mystery-card-overlay.perf-lite .mystery-front-glow {
    filter: blur(4px);
    opacity: 0.45;
}

.mystery-title {
    font-size: 2rem;
    font-weight: 800;
    background: linear-gradient(90deg, var(--g1, #4ade80), var(--g2, #22d3ee), var(--g1, #4ade80));
    background-size: 200% 100%;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    animation: title-shimmer 2s linear infinite;
    margin-bottom: 15px;
    text-align: center;
}

.mystery-subtitle {
    color: var(--text-a, #e2e8f0);
    font-size: 1rem;
    margin-bottom: 40px;
    text-align: center;
}

@keyframes title-shimmer {
    0% {
        background-position: 0% 50%;
    }

    100% {
        background-position: 200% 50%;
    }
}

/* Card Container */
.mystery-cards-container {
    display: flex;
    gap: 40px;
    perspective: 1000px;
}

/* Individual Mystery Card */
.mystery-card {
    width: 180px;
    height: 260px;
    position: relative;
    cursor: pointer;
    transition: transform 0.3s ease, opacity 0.3s ease;
}

.mystery-card:hover:not(.flipped):not(.disabled) {
    transform: translateY(-15px) scale(1.05);
}

.mystery-card.flipped {
    /* No transform - using display-based reveal */
}

.mystery-card.revealed {
    opacity: 0.6;
    filter: none;
}

.mystery-card.selected {
    transform: scale(1.05);
    opacity: 1;
    z-index: 10;
}

.mystery-card.disabled:not(.revealed):not(.selected) {
    pointer-events: none;
    opacity: 0.5;
    filter: grayscale(0.8);
}

.mystery-card-inner {
    position: absolute;
    width: 100%;
    height: 100%;
}

/* Card Front (Fire Card Back) */
.mystery-card-front {
    position: absolute;
    width: 100%;
    height: 100%;
    border-radius: 16px;
    background: linear-gradient(145deg, #1a0a00, #2a1205, #1a0a00);
    border: 3px solid transparent;
    background-clip: padding-box;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
}

/* Hide front face when card is flipped */
.mystery-card.flipped .mystery-card-front,
.mystery-card.revealed .mystery-card-front {
    display: none !important;
}

/* Animated border glow */
.mystery-card-front::before {
    content: '';
    position: absolute;
    inset: -3px;
    border-radius: 18px;
    background: linear-gradient(45deg, #ef4444, #f97316, #fbbf24, #f97316, #ef4444);
    background-size: 400% 400%;
    animation: border-fire 2s ease infinite;
    z-index: -1;
}

@keyframes border-fire {

    0%,
    100% {
        background-position: 0% 50%;
    }

    50% {
        background-position: 100% 50%;
    }
}

/* Fire particle container */
.fire-container {
    position: absolute;
    width: 100%;
    height: 100%;
    overflow: hidden;
    border-radius: 14px;
}

/* Animated fire particles */
.fire-particle {
    position: absolute;
    width: 8px;
    height: 8px;
    background: radial-gradient(circle, #fbbf24, #f97316, transparent);
    border-radius: 50%;
    animation: fire-rise 1.5s ease-out infinite;
    opacity: 0;
    filter: blur(1px);
}

.fire-particle:nth-child(1) {
    left: 10%;
    animation-delay: 0s;
}

.fire-particle:nth-child(2) {
    left: 25%;
    animation-delay: 0.2s;
}

.fire-particle:nth-child(3) {
    left: 40%;
    animation-delay: 0.4s;
}

.fire-particle:nth-child(4) {
    left: 55%;
    animation-delay: 0.1s;
}

.fire-particle:nth-child(5) {
    left: 70%;
    animation-delay: 0.3s;
}

.fire-particle:nth-child(6) {
    left: 85%;
    animation-delay: 0.5s;
}

.fire-particle:nth-child(7) {
    left: 15%;
    animation-delay: 0.6s;
}

.fire-particle:nth-child(8) {
    left: 50%;
    animation-delay: 0.7s;
}

.fire-particle:nth-child(9) {
    left: 75%;
    animation-delay: 0.15s;
}

.fire-particle:nth-child(10) {
    left: 35%;
    animation-delay: 0.35s;
}

.fire-particle:nth-child(11) {
    left: 60%;
    animation-delay: 0.55s;
}

.fire-particle:nth-child(12) {
    left: 20%;
    animation-delay: 0.25s;
}

@keyframes fire-rise {
    0% {
        transform: translateY(260px) scale(0.3);
        opacity: 0;
        background: radial-gradient(circle, #fbbf24, #f97316, transparent);
    }

    15% {
        opacity: 1;
    }

    50% {
        background: radial-gradient(circle, #f97316, #ef4444, transparent);
    }

    100% {
        transform: translateY(-30px) scale(1.5);
        opacity: 0;
        background: radial-gradient(circle, #ef4444, #dc2626, transparent);
    }
}

/* Large flame base */
.flame-base {
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 120px;
    height: 150px;
    background:
        radial-gradient(ellipse 60% 80% at 50% 100%, #fbbf24 0%, transparent 60%),
        radial-gradient(ellipse 50% 70% at 50% 90%, #f97316 0%, transparent 50%),
        radial-gradient(ellipse 40% 60% at 50% 85%, #ef4444 0%, transparent 40%);
    animation: flame-flicker 0.3s ease-in-out infinite alternate;
    filter: blur(3px);
}

@keyframes flame-flicker {
    0% {
        transform: translateX(-50%) scaleX(1) scaleY(1);
        opacity: 0.9;
    }

    100% {
        transform: translateX(-50%) scaleX(1.1) scaleY(1.05);
        opacity: 1;
    }
}

/* Light streaks */
.light-streak {
    position: absolute;
    width: 2px;
    height: 60px;
    background: linear-gradient(to top, transparent, #fbbf24, transparent);
    animation: streak-fly 1s ease-out infinite;
    opacity: 0;
}

.light-streak:nth-child(1) {
    left: 20%;
    animation-delay: 0s;
}

.light-streak:nth-child(2) {
    left: 40%;
    animation-delay: 0.3s;
}

.light-streak:nth-child(3) {
    left: 60%;
    animation-delay: 0.6s;
}

.light-streak:nth-child(4) {
    left: 80%;
    animation-delay: 0.15s;
}

.light-streak:nth-child(5) {
    left: 30%;
    animation-delay: 0.45s;
}

.light-streak:nth-child(6) {
    left: 70%;
    animation-delay: 0.75s;
}

@keyframes streak-fly {
    0% {
        transform: translateY(260px) rotate(15deg);
        opacity: 0;
    }

    20% {
        opacity: 1;
    }

    100% {
        transform: translateY(-100px) rotate(-15deg);
        opacity: 0;
    }
}

/* Theme-colored fire particles for revealed cards */
.fire-container.themed {
    --fire-color-1: var(--g1, #4ade80);
    --fire-color-2: var(--g2, #22d3ee);
}

.fire-particle.themed {
    animation: fire-rise-themed 2s ease-out infinite;
    background: radial-gradient(circle, var(--g1, #4ade80), var(--g2, #22d3ee), transparent) !important;
    box-shadow: 0 0 15px var(--g1, #4ade80);
}

@keyframes fire-rise-themed {
    0% {
        transform: translateY(260px) scale(0.3);
        opacity: 0;
    }

    15% {
        opacity: 0.8;
    }

    100% {
        transform: translateY(-30px) scale(1.5);
        opacity: 0;
    }
}

.flame-base.themed {
    background: radial-gradient(ellipse 60% 80% at 50% 100%, var(--g1, #4ade80), transparent 60%),
        radial-gradient(ellipse 50% 70% at 50% 90%, var(--g2, #22d3ee), transparent 50%);
    filter: blur(4px);
    box-shadow: 0 20px 60px var(--g1, #4ade80);
}


/* Question mark symbol on card */
.mystery-symbol {
    font-size: 4rem;
    color: #fbbf24;
    text-shadow:
        0 0 20px #f97316,
        0 0 40px #ef4444,
        0 0 60px rgba(239, 68, 68, 0.5);
    animation: symbol-pulse 1.5s ease-in-out infinite;
    z-index: 10;
}

@keyframes symbol-pulse {

    0%,
    100% {
        transform: scale(1);
        text-shadow: 0 0 20px #f97316, 0 0 40px #ef4444;
    }

    50% {
        transform: scale(1.1);
        text-shadow: 0 0 30px #fbbf24, 0 0 60px #f97316, 0 0 80px #ef4444;
    }
}

/* Card Back (Revealed XP) - hidden by default, shown when flipped */
.mystery-card-back {
    position: absolute;
    width: 100%;
    height: 100%;
    border-radius: 16px;
    display: none;
    /* Hidden by default */
    flex-direction: column;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    z-index: 3;
}

/* Show card back when card is flipped */
.mystery-card.flipped .mystery-card-back,
.mystery-card.revealed .mystery-card-back {
    display: flex !important;
    transform: none !important;
    backface-visibility: visible !important;
}

.mystery-card-back.tier-low {
    background: linear-gradient(145deg, rgba(0, 20, 20, 0.95), rgba(10, 30, 30, 0.95), rgba(0, 20, 20, 0.95));
    border: 3px solid var(--g1, #4ade80);
    box-shadow:
        0 0 30px color-mix(in srgb, var(--g1, #4ade80) 30%, transparent),
        inset 0 0 60px color-mix(in srgb, var(--g1, #4ade80) 10%, transparent);
    animation: tier-glow 2s ease-in-out infinite alternate;
}

.mystery-card-back.tier-mid {
    background: linear-gradient(145deg, rgba(10, 25, 35, 0.95), rgba(15, 35, 45, 0.95), rgba(10, 25, 35, 0.95));
    border: 3px solid var(--g2, #22d3ee);
    box-shadow:
        0 0 40px color-mix(in srgb, var(--g2, #22d3ee) 40%, transparent),
        inset 0 0 60px color-mix(in srgb, var(--g2, #22d3ee) 10%, transparent);
    animation: tier-glow 1.5s ease-in-out infinite alternate;
}

@keyframes tier-glow {
    0% {
        filter: brightness(1);
    }

    100% {
        filter: brightness(1.2);
    }
}


.mystery-card-back.tier-high {
    background: linear-gradient(145deg, #5a3a00, #2a1a00, #5a3a00);
    border: 3px solid #fbbf24;
    box-shadow:
        0 0 50px rgba(251, 191, 36, 0.6),
        0 0 100px rgba(249, 115, 22, 0.4);
    animation: jackpot-glow 0.5s ease infinite alternate;
}

@keyframes jackpot-glow {
    0% {
        box-shadow: 0 0 50px rgba(251, 191, 36, 0.6), 0 0 100px rgba(249, 115, 22, 0.4);
    }

    100% {
        box-shadow: 0 0 70px rgba(251, 191, 36, 0.8), 0 0 120px rgba(249, 115, 22, 0.6);
    }
}

.xp-reveal-icon {
    font-size: 3rem;
    margin-bottom: 8px;
    z-index: 5;
}

.xp-reveal-name {
    font-size: 1.1rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: #fff;
    margin-bottom: 5px;
    z-index: 5;
}

.xp-reveal-amount {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 5px;
    opacity: 0.9;
    z-index: 5;
}

.tier-low .xp-reveal-amount {
    color: var(--g1, #60a5fa);
    text-shadow: 0 0 20px rgba(96, 165, 250, 0.4);
}

.tier-mid .xp-reveal-amount {
    color: #4ade80;
    text-shadow: 0 0 25px rgba(74, 222, 128, 0.5);
}

.tier-high .xp-reveal-amount {
    color: #fbbf24;
    text-shadow: 0 0 30px rgba(251, 191, 36, 0.7);
    animation: amount-glow 0.3s ease infinite alternate;
}

@keyframes amount-glow {
    0% {
        transform: scale(1);
    }

    100% {
        transform: scale(1.05);
    }
}

/* Rarity Badge */
.rarity-badge {
    position: absolute;
    top: 10px;
    left: 50%;
    transform: translateX(-50%);
    padding: 3px 12px;
    border-radius: 12px;
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 1px;
    font-family: var(--font-family, inherit);
    z-index: 10;
}

/* Rarity Styles - Theme Adaptive */
.rarity-common .rarity-badge {
    background: rgba(148, 163, 184, 0.3);
    color: #94a3b8;
    border: 1px solid #64748b;
}

.rarity-rare .rarity-badge {
    background: linear-gradient(90deg, var(--g1, #4ade80), var(--g2, #22d3ee));
    color: #fff;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

.rarity-epic .rarity-badge {
    background: linear-gradient(90deg, #a855f7, #ec4899);
    color: #fff;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
    animation: epic-shimmer 2s ease infinite;
}

.rarity-legendary .rarity-badge {
    background: linear-gradient(90deg, #fbbf24, #f97316, #fbbf24);
    background-size: 200% 100%;
    color: #1a1a1a;
    font-weight: 800;
    animation: legendary-shimmer 1.5s ease infinite;
}

@keyframes epic-shimmer {

    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0.8;
    }
}

@keyframes legendary-shimmer {
    0% {
        background-position: 0% 50%;
    }

    100% {
        background-position: 200% 50%;
    }
}

/* Rarity Card Border Effects */
.rarity-common {
    border-color: #64748b !important;
}

.rarity-rare {
    border-color: var(--g1, #4ade80) !important;
}

.rarity-epic {
    border-color: #a855f7 !important;
    box-shadow: 0 0 40px rgba(168, 85, 247, 0.4), inset 0 0 30px rgba(168, 85, 247, 0.1) !important;
}

.rarity-legendary {
    border-color: #fbbf24 !important;
    box-shadow: 0 0 60px rgba(251, 191, 36, 0.6), inset 0 0 40px rgba(251, 191, 36, 0.15) !important;
    animation: legendary-glow 1s ease infinite alternate !important;
}

@keyframes legendary-glow {
    0% {
        box-shadow: 0 0 60px rgba(251, 191, 36, 0.6), inset 0 0 40px rgba(251, 191, 36, 0.15);
    }

    100% {
        box-shadow: 0 0 80px rgba(251, 191, 36, 0.8), inset 0 0 50px rgba(251, 191, 36, 0.2);
    }
}

.xp-reveal-label {
    font-size: 1rem;
    color: var(--text-a, #e2e8f0);
    text-transform: uppercase;
    letter-spacing: 2px;
}

/* Mystery Card Visual Refresh */
.mystery-card {
    width: 190px;
    height: 280px;
}

.mystery-card:hover:not(.flipped):not(.disabled) {
    transform: translateY(-10px) scale(1.02);
}

.mystery-card-front {
    border: 1px solid color-mix(in srgb, var(--g1, #60a5fa) 45%, rgba(148, 163, 184, 0.3) 55%);
    background:
        radial-gradient(120% 90% at 50% 100%, color-mix(in srgb, var(--g2, #a78bfa) 20%, transparent) 0%, transparent 62%),
        linear-gradient(165deg, rgba(8, 14, 28, 0.98), rgba(12, 20, 36, 0.95) 52%, rgba(8, 14, 28, 0.98));
    box-shadow:
        0 16px 40px rgba(2, 6, 23, 0.55),
        inset 0 1px 0 rgba(255, 255, 255, 0.06),
        0 0 0 1px rgba(255, 255, 255, 0.03);
}

.mystery-card-front::before {
    inset: -1px;
    border-radius: 16px;
    background: linear-gradient(130deg,
            color-mix(in srgb, var(--g1, #60a5fa) 72%, #ffffff 28%),
            color-mix(in srgb, var(--g2, #a78bfa) 72%, #ffffff 28%));
    opacity: 0.55;
    animation: mystery-border-flow 4.5s linear infinite;
}

@keyframes mystery-border-flow {
    0% {
        filter: hue-rotate(0deg);
    }

    100% {
        filter: hue-rotate(360deg);
    }
}

.mystery-front-grid {
    position: absolute;
    inset: 0;
    border-radius: 16px;
    background:
        linear-gradient(to right, rgba(148, 163, 184, 0.08) 1px, transparent 1px) 0 0 / 18px 18px,
        linear-gradient(to bottom, rgba(148, 163, 184, 0.06) 1px, transparent 1px) 0 0 / 18px 18px;
    mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.72), transparent 85%);
}

.mystery-front-glow {
    position: absolute;
    left: 50%;
    bottom: -14px;
    transform: translateX(-50%);
    width: 74%;
    height: 56%;
    border-radius: 50%;
    background: radial-gradient(circle at 50% 100%, color-mix(in srgb, var(--g1, #60a5fa) 60%, var(--g2, #a78bfa) 40%) 0%, transparent 70%);
    filter: blur(10px);
    opacity: 0.75;
}

.mystery-symbol {
    font-size: 3.15rem;
    font-weight: 900;
    letter-spacing: 0.02em;
    color: color-mix(in srgb, var(--g2, #a78bfa) 62%, #ffffff 38%);
    text-shadow:
        0 0 22px color-mix(in srgb, var(--g2, #a78bfa) 40%, transparent),
        0 0 36px color-mix(in srgb, var(--g1, #60a5fa) 28%, transparent);
    animation: symbol-pulse 2.1s ease-in-out infinite;
}

.mystery-card-front .fire-container,
.mystery-card-back .fire-container {
    display: none !important;
}

.mystery-card-back {
    border: 1px solid color-mix(in srgb, var(--g1, #60a5fa) 38%, rgba(148, 163, 184, 0.35) 62%);
    background:
        radial-gradient(130% 90% at 50% 100%, color-mix(in srgb, var(--g2, #a78bfa) 18%, transparent) 0%, transparent 64%),
        linear-gradient(165deg, rgba(7, 12, 26, 0.97), rgba(14, 21, 40, 0.95));
    box-shadow:
        0 18px 42px rgba(2, 6, 23, 0.62),
        inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.mystery-card-back.tier-low,
.mystery-card-back.tier-mid,
.mystery-card-back.tier-high {
    border-width: 1px;
    animation: none;
}

.mystery-card-back.tier-low {
    border-color: color-mix(in srgb, var(--g1, #60a5fa) 50%, rgba(148, 163, 184, 0.35) 50%);
}

.mystery-card-back.tier-mid {
    border-color: color-mix(in srgb, var(--g2, #a78bfa) 55%, rgba(148, 163, 184, 0.35) 45%);
}

.mystery-card-back.tier-high {
    border-color: color-mix(in srgb, #f59e0b 62%, rgba(148, 163, 184, 0.3) 38%);
    box-shadow:
        0 18px 42px rgba(2, 6, 23, 0.62),
        0 0 26px rgba(245, 158, 11, 0.26),
        inset 0 0 26px rgba(245, 158, 11, 0.12);
}

/* Rarity-first backplates (overrides tier-only styling for stronger identity) */
.mystery-card-back.rarity-common {
    background:
        radial-gradient(130% 100% at 50% 100%, rgba(148, 163, 184, 0.16) 0%, rgba(2, 6, 23, 0) 68%),
        linear-gradient(160deg, #131a28 0%, #1a2437 44%, #0f172a 100%);
    border-color: rgba(148, 163, 184, 0.62);
    box-shadow:
        0 16px 34px rgba(2, 6, 23, 0.65),
        0 0 18px rgba(148, 163, 184, 0.2),
        inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.mystery-card-back.rarity-rare {
    background:
        radial-gradient(130% 100% at 50% 100%, rgba(56, 189, 248, 0.24) 0%, rgba(2, 6, 23, 0) 68%),
        linear-gradient(160deg, #071a2f 0%, #0a2747 42%, #06172c 100%);
    border-color: rgba(96, 165, 250, 0.76);
    box-shadow:
        0 16px 34px rgba(2, 6, 23, 0.66),
        0 0 28px rgba(56, 189, 248, 0.28),
        inset 0 0 28px rgba(56, 189, 248, 0.14);
}

.mystery-card-back.rarity-epic {
    background:
        radial-gradient(130% 100% at 50% 100%, rgba(244, 114, 182, 0.24) 0%, rgba(2, 6, 23, 0) 68%),
        linear-gradient(160deg, #2a0d3e 0%, #3b1257 42%, #170a2b 100%);
    border-color: rgba(192, 132, 252, 0.78);
    box-shadow:
        0 16px 36px rgba(2, 6, 23, 0.67),
        0 0 32px rgba(216, 70, 239, 0.28),
        inset 0 0 30px rgba(192, 132, 252, 0.14);
}

.mystery-card-back.rarity-legendary {
    background:
        radial-gradient(130% 100% at 50% 100%, rgba(251, 191, 36, 0.3) 0%, rgba(2, 6, 23, 0) 68%),
        linear-gradient(160deg, #3a2402 0%, #5f3806 45%, #1f1302 100%);
    border-color: rgba(251, 191, 36, 0.9);
    box-shadow:
        0 18px 38px rgba(2, 6, 23, 0.68),
        0 0 38px rgba(251, 191, 36, 0.34),
        inset 0 0 36px rgba(251, 191, 36, 0.16);
}

.xp-reveal-icon {
    width: 66px;
    height: 66px;
    border-radius: 14px;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.05rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    color: #e2e8f0;
    border: 1px solid rgba(148, 163, 184, 0.35);
    background: linear-gradient(145deg, rgba(30, 41, 59, 0.9), rgba(15, 23, 42, 0.92));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.xp-reveal-icon.type-xp,
.xp-reveal-icon.type-xp_confetti {
    border-color: rgba(96, 165, 250, 0.5);
    color: #93c5fd;
}

.xp-reveal-icon.type-multiplier {
    border-color: rgba(167, 139, 250, 0.5);
    color: #c4b5fd;
}

.xp-reveal-icon.type-shield {
    border-color: rgba(45, 212, 191, 0.5);
    color: #5eead4;
}

.xp-reveal-icon.type-first_try_boost,
.xp-reveal-icon.type-growth_boost {
    border-color: rgba(74, 222, 128, 0.5);
    color: #86efac;
}

.xp-reveal-icon.type-streak_set,
.xp-reveal-icon.type-streak_add {
    border-color: rgba(245, 158, 11, 0.52);
    color: #fcd34d;
}

.xp-reveal-name {
    margin-bottom: 7px;
}

.mystery-card-back {
    text-align: center;
}

.mystery-card-back .xp-reveal-name,
.mystery-card-back .xp-reveal-amount {
    width: 100%;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
}

.mystery-card-back.rarity-common .xp-reveal-name { color: #f1f5f9; }
.mystery-card-back.rarity-rare .xp-reveal-name { color: #dbeafe; }
.mystery-card-back.rarity-epic .xp-reveal-name { color: #f5d0fe; }
.mystery-card-back.rarity-legendary .xp-reveal-name { color: #fde68a; }

.tier-high .xp-reveal-amount {
    animation: none;
}

.mystery-card.revealed {
    opacity: 1;
    filter: none;
}

/* Continue button */
.mystery-continue-btn {
    margin-top: 40px;
    padding: 14px 40px;
    font-size: 1.1rem;
    font-weight: 700;
    background: var(--g, linear-gradient(135deg, #60a5fa, #a78bfa));
    border: none;
    border-radius: 12px;
    color: white;
    cursor: pointer;
    opacity: 0;
    transform: translateY(20px);
    transition: all 0.3s ease;
    box-shadow: 0 4px 20px rgba(96, 165, 250, 0.4);
}

.mystery-continue-btn.visible {
    opacity: 1;
    transform: translateY(0);
}

.mystery-continue-btn:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 30px rgba(96, 165, 250, 0.6);
}

/* Confetti burst for jackpot */
.jackpot-confetti-container {
    position: absolute;
    top: 50%;
    left: 50%;
    pointer-events: none;
}

.jackpot-confetti {
    position: absolute;
    width: 10px;
    height: 10px;
    opacity: 0;
}

.jackpot-confetti.active {
    animation: jackpot-confetti-burst 1s ease-out forwards;
}

@keyframes jackpot-confetti-burst {
    0% {
        transform: translate(0, 0) rotate(0deg);
        opacity: 1;
    }

    100% {
        transform: translate(var(--tx), var(--ty)) rotate(720deg);
        opacity: 0;
    }
}

/* Streak notification that triggers mystery card */
.streak-mystery-notification {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(0.5);
    background: linear-gradient(145deg, rgba(15, 23, 42, 0.98), rgba(30, 41, 59, 0.98));
    border: 2px solid var(--g1, #60a5fa);
    border-radius: 20px;
    padding: 30px 50px;
    text-align: center;
    z-index: 99998;
    opacity: 0;
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    box-shadow: 0 0 50px rgba(96, 165, 250, 0.4);
}

.streak-mystery-notification.active {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
}

.streak-mystery-notification .streak-icon {
    font-size: 3rem;
    animation: fire-icon-bounce 0.5s ease infinite alternate;
}

@keyframes fire-icon-bounce {
    0% {
        transform: scale(1);
    }

    100% {
        transform: scale(1.1);
    }
}

.streak-mystery-notification .streak-text {
    font-size: 1.5rem;
    font-weight: 700;
    margin-top: 10px;
    background: linear-gradient(90deg, var(--g1, #60a5fa), var(--g2, #a78bfa));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* Power-up Notification */
.power-up-notification {
    position: fixed;
    top: 100px;
    left: 50%;
    transform: translateX(-50%) translateY(-20px);
    background: linear-gradient(145deg, rgba(20, 30, 40, 0.95), rgba(10, 20, 30, 0.95));
    border: 2px solid var(--g1, #4ade80);
    border-radius: 16px;
    padding: 16px 32px;
    z-index: 10000;
    text-align: center;
    opacity: 0;
    transition: all 0.3s ease;
    box-shadow:
        0 0 30px color-mix(in srgb, var(--g1, #4ade80) 40%, transparent),
        0 10px 40px rgba(0, 0, 0, 0.5);
}

.power-up-notification.visible {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

.power-up-title {
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--g1, #4ade80);
    margin-bottom: 5px;
}

.power-up-desc {
    font-size: 1rem;
    color: var(--text-a, #e2e8f0);
    opacity: 0.9;
}

/* Level Up Popup */
.level-up-popup {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate3d(-50%, -50%, 0) scale(0.8);
    background: linear-gradient(145deg, rgba(15, 23, 42, 0.98), rgba(30, 41, 59, 0.98));
    border: 3px solid var(--g1, #4ade80);
    border-radius: 24px;
    padding: 40px 60px;
    z-index: 3;
    opacity: 0;
    transition:
        opacity 0.4s cubic-bezier(0.34, 1.56, 0.64, 1),
        transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
    box-shadow:
        0 0 80px color-mix(in srgb, var(--g1, #4ade80) 50%, transparent),
        0 20px 60px rgba(0, 0, 0, 0.6);
    font-family: var(--font-family, inherit);
    will-change: transform, opacity;
    backface-visibility: hidden;
}

.level-up-popup.visible {
    opacity: 1;
    transform: translate3d(-50%, -50%, 0) scale(1);
}

.level-up-content {
    text-align: center;
}

.level-up-title {
    font-size: 2rem;
    font-weight: 800;
    background: linear-gradient(90deg, var(--g1, #4ade80), var(--g2, #22d3ee));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin-bottom: 20px;
}

.level-up-transition {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    margin-bottom: 15px;
}

.old-level,
.new-level {
    font-size: 2.5rem;
    font-weight: 800;
}

.old-level {
    opacity: 0.5;
}

.new-level {
    animation: level-pop 0.5s ease 0.3s both;
}

.level-arrow {
    font-size: 2rem;
    color: var(--g1, #4ade80);
}

.level-up-tier {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-a, #e2e8f0);
    opacity: 0.8;
    text-transform: uppercase;
    letter-spacing: 2px;
}

@keyframes level-pop {
    0% {
        transform: scale(0.5);
        opacity: 0;
    }

    60% {
        transform: scale(1.2);
    }

    100% {
        transform: scale(1);
        opacity: 1;
    }
}

/* Active Power-Up Indicator (Non-Distracting) */
.power-up-indicator {
    position: fixed;
    top: 10px;
    right: 10px;
    /* Hidden to prevent overlap with panel controls in web UI */
    display: none !important;
    pointer-events: none !important;
    flex-direction: column;
    gap: 5px;
    z-index: 1000;
    font-family: var(--font-family, inherit);
}

.power-up-badge {
    display: flex;
    align-items: center;
    gap: 6px;
    background: rgba(15, 23, 42, 0.85);
    border: 1px solid var(--g1, #4ade80);
    border-radius: 20px;
    padding: 4px 12px;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-a, #e2e8f0);
    opacity: 0.8;
    transition: opacity 0.2s ease;
}

.power-up-badge:hover {
    opacity: 1;
}

.power-up-badge .icon {
    font-size: 0.62rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    min-width: 20px;
    text-align: center;
    color: #dbeafe;
}

.power-up-badge .count {
    color: var(--g1, #4ade80);
    font-weight: 700;
}

.power-up-badge.shield {
    border-color: #60a5fa;
}

.power-up-badge.shield .count {
    color: #60a5fa;
}

.power-up-badge.multiplier {
    border-color: #fbbf24;
}

.power-up-badge.multiplier .count {
    color: #fbbf24;
}

/* ==========================================================================
   ACHIEVEMENTS RARITY REFRESH
   ========================================================================== */

/* Keep outer modal static; only the achievements list should scroll */
#achievements-modal .modal-content {
    overflow: hidden;
    max-height: min(86vh, 860px);
    display: flex;
    flex-direction: column;
}

#achievements-modal #achievements-summary {
    flex: 0 0 auto;
}

#achievements-modal #achievements-grid {
    flex: 1 1 auto;
    min-height: 0;
    max-height: none;
}

.achievement-toast .ach-icon,
.achievement-icon,
.achievement-badge .badge-icon {
    position: relative;
    overflow: hidden;
}

.achievement-toast .ach-icon {
    min-width: 52px;
}

.achievement-toast .ach-icon::after,
.achievement-icon::after,
.achievement-badge .badge-icon::after {
    content: '';
    position: absolute;
    inset: -38% auto -38% -58%;
    width: 44%;
    transform: rotate(24deg);
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.23), transparent);
    pointer-events: none;
}

.achievement-toast .ach-icon-core,
.achievement-icon .achievement-icon-core,
.achievement-badge .badge-icon-core {
    position: relative;
    z-index: 2;
    font-weight: 850;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    line-height: 1;
}

.achievement-icon {
    min-width: 84px;
    height: 34px;
}

.achievement-icon .achievement-icon-core {
    font-size: 0.62rem;
}

.achievement-badge .badge-icon {
    min-width: 84px;
    height: 30px;
    margin: 0 auto;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.achievement-badge .badge-icon-core {
    font-size: 0.58rem;
}

.achievement-badge .badge-rarity {
    margin-top: 3px;
    font-size: 0.56rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-sub, #94a3b8);
}

.achievement-card.rarity-common.unlocked {
    border-color: rgba(148, 163, 184, 0.45);
}

.achievement-card.rarity-uncommon.unlocked {
    border-color: rgba(45, 212, 191, 0.48);
}

.achievement-card.rarity-rare.unlocked {
    border-color: rgba(96, 165, 250, 0.52);
}

.achievement-card.rarity-epic.unlocked {
    border-color: rgba(168, 85, 247, 0.56);
}

.achievement-card.rarity-legendary.unlocked {
    border-color: rgba(251, 191, 36, 0.62);
    box-shadow:
        0 0 0 1px rgba(251, 191, 36, 0.18),
        0 10px 26px rgba(251, 191, 36, 0.2);
}

.achievement-card.rarity-mythic.unlocked {
    border-color: rgba(255, 255, 255, 0.82);
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.25),
        0 0 26px rgba(167, 139, 250, 0.38),
        0 0 42px rgba(59, 130, 246, 0.2);
    animation: achievement-mythic-glow 4.8s ease infinite;
}

.achievement-card.rarity-common .achievement-icon,
.achievement-badge.rarity-common .badge-icon,
.achievement-toast.rarity-common .ach-icon {
    background: linear-gradient(135deg, #1f2937, #334155, #1f2937);
    border-color: rgba(148, 163, 184, 0.42);
    color: #dbeafe;
}

.achievement-card.rarity-uncommon .achievement-icon,
.achievement-badge.rarity-uncommon .badge-icon,
.achievement-toast.rarity-uncommon .ach-icon {
    background: linear-gradient(135deg, #0f172a, #0f766e, #115e59);
    border-color: rgba(45, 212, 191, 0.52);
    color: #ccfbf1;
}

.achievement-card.rarity-rare .achievement-icon,
.achievement-badge.rarity-rare .badge-icon,
.achievement-toast.rarity-rare .ach-icon {
    background: linear-gradient(135deg, #0b1220, #1d4ed8, #1e3a8a);
    border-color: rgba(96, 165, 250, 0.56);
    color: #dbeafe;
}

.achievement-card.rarity-epic .achievement-icon,
.achievement-badge.rarity-epic .badge-icon,
.achievement-toast.rarity-epic .ach-icon {
    background: linear-gradient(135deg, #1a0f2f, #7c3aed, #c026d3);
    border-color: rgba(216, 180, 254, 0.56);
    color: #f5d0fe;
}

.achievement-card.rarity-legendary .achievement-icon,
.achievement-badge.rarity-legendary .badge-icon,
.achievement-toast.rarity-legendary .ach-icon {
    background: linear-gradient(135deg, #2b1800, #f59e0b, #fcd34d, #f59e0b, #2b1800);
    background-size: 260% 260%;
    border-color: rgba(251, 191, 36, 0.76);
    color: #1f1200;
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.38);
    animation: achievement-legend-flow 4.5s ease infinite;
}

.achievement-card.rarity-mythic .achievement-icon,
.achievement-badge.rarity-mythic .badge-icon,
.achievement-toast.rarity-mythic .ach-icon {
    background: linear-gradient(135deg,
            #05070f, #1e1b4b, #3730a3, #ffffff,
            #3730a3, #1e1b4b, #05070f);
    background-size: 520% 520%;
    border-color: rgba(255, 255, 255, 0.88);
    color: #ffffff;
    text-shadow:
        0 0 8px rgba(255, 255, 255, 0.8),
        0 0 16px rgba(167, 139, 250, 0.45);
    box-shadow:
        0 0 12px rgba(255, 255, 255, 0.32),
        0 0 24px rgba(139, 92, 246, 0.22);
    animation: achievement-mythic-flow 7s linear infinite;
}

.achievement-card.rarity-legendary .achievement-status.locked {
    color: #f8d37a;
    border-color: rgba(251, 191, 36, 0.45);
    background: rgba(251, 191, 36, 0.08);
}

.achievement-card.rarity-mythic .achievement-status.locked {
    color: #e9d5ff;
    border-color: rgba(216, 180, 254, 0.55);
    background: rgba(139, 92, 246, 0.12);
}

@keyframes achievement-legend-flow {
    0% {
        background-position: 0% 50%;
    }

    50% {
        background-position: 100% 50%;
    }

    100% {
        background-position: 0% 50%;
    }
}

@keyframes achievement-mythic-flow {
    0% {
        background-position: 0% 50%;
        filter: hue-rotate(0deg);
    }

    50% {
        background-position: 100% 50%;
    }

    100% {
        background-position: 0% 50%;
        filter: hue-rotate(360deg);
    }
}

@keyframes achievement-mythic-glow {
    0%,
    100% {
        box-shadow:
            0 0 0 1px rgba(255, 255, 255, 0.25),
            0 0 26px rgba(167, 139, 250, 0.38),
            0 0 42px rgba(59, 130, 246, 0.2);
    }

    50% {
        box-shadow:
            0 0 0 1px rgba(255, 255, 255, 0.32),
            0 0 32px rgba(167, 139, 250, 0.52),
            0 0 56px rgba(59, 130, 246, 0.28);
    }
}

/* ==========================================================================
   RESULTS V2 - Game Mode Session Summary
   ========================================================================== */

#results-view {
    align-items: stretch;
    justify-content: flex-start;
    padding: 1rem 0.75rem 1.25rem;
    overflow-y: auto;
}

#results-view .results-shell {
    width: min(980px, 100%);
    margin: 0 auto;
    display: grid;
    gap: 14px;
    padding: 18px;
    border-radius: 18px;
    border: 1px solid color-mix(in srgb, var(--bd, rgba(255, 255, 255, 0.14)) 82%, transparent 18%);
    background:
        radial-gradient(100% 70% at 50% 0%, color-mix(in srgb, var(--g1, #60a5fa) 13%, transparent 87%), transparent 70%),
        color-mix(in srgb, var(--card-bg, rgba(15, 23, 42, 0.86)) 92%, #0b1220 8%);
    box-shadow: 0 18px 48px rgba(2, 6, 23, 0.45);
}

#results-view .results-hero {
    display: grid;
    justify-items: center;
    gap: 8px;
    text-align: center;
}

#results-view .results-grade-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    border-radius: 999px;
    font-size: 0.75rem;
    border: 1px solid rgba(255, 255, 255, 0.2);
    background: rgba(255, 255, 255, 0.05);
    color: #cbd5e1;
}

#results-view .results-grade {
    font-weight: 800;
    letter-spacing: 0.05em;
}

#results-view .results-grade-label {
    opacity: 0.95;
    font-weight: 600;
}

#results-view .results-grade-chip.tier-elite {
    border-color: rgba(34, 197, 94, 0.48);
    background: rgba(34, 197, 94, 0.12);
    color: #86efac;
}

#results-view .results-grade-chip.tier-strong {
    border-color: rgba(96, 165, 250, 0.48);
    background: rgba(96, 165, 250, 0.12);
    color: #bfdbfe;
}

#results-view .results-grade-chip.tier-solid {
    border-color: rgba(250, 204, 21, 0.48);
    background: rgba(250, 204, 21, 0.12);
    color: #fde68a;
}

#results-view .results-grade-chip.tier-developing {
    border-color: rgba(251, 146, 60, 0.48);
    background: rgba(251, 146, 60, 0.12);
    color: #fdba74;
}

#results-view .results-grade-chip.tier-foundation {
    border-color: rgba(248, 113, 113, 0.48);
    background: rgba(248, 113, 113, 0.12);
    color: #fca5a5;
}

#results-view .results-grade-chip.tier-none {
    border-color: rgba(148, 163, 184, 0.44);
    background: rgba(148, 163, 184, 0.12);
    color: #cbd5e1;
}

#results-view .results-summary {
    color: #94a3b8;
    margin: 0;
}

#results-view .results-metrics-grid {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

#results-view .results-metric-card {
    border-radius: 12px;
    border: 1px solid color-mix(in srgb, var(--bd, rgba(255, 255, 255, 0.14)) 78%, transparent 22%);
    background: rgba(255, 255, 255, 0.03);
    padding: 10px 12px;
    display: grid;
    gap: 4px;
    min-width: 0;
    justify-items: center;
    align-content: start;
    text-align: center;
}

#results-view .metric-label {
    font-size: 0.72rem;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    line-height: 1.2;
    overflow-wrap: anywhere;
    word-break: break-word;
    text-wrap: balance;
}

#results-view .metric-value {
    font-size: 1.05rem;
    font-weight: 700;
    color: #e2e8f0;
    line-height: 1.08;
}

#results-view .metric-value.metric-positive {
    color: #4ade80;
}

#results-view .metric-value.metric-negative {
    color: #f87171;
}

#results-view .xp-earned-banner {
    max-width: none;
}

#results-view .xp-earned-note {
    margin-top: 4px;
    font-size: 0.8rem;
    color: #9fb0c8;
}

#results-view .level-progress-section {
    max-width: none;
}

#results-view .results-insights {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

#results-view .results-insight-item {
    border-radius: 12px;
    border: 1px solid color-mix(in srgb, var(--bd, rgba(255, 255, 255, 0.13)) 78%, transparent 22%);
    background: rgba(255, 255, 255, 0.02);
    padding: 10px 12px;
    display: grid;
    gap: 5px;
}

#results-view .insight-label {
    font-size: 0.74rem;
    text-transform: uppercase;
    color: #94a3b8;
    letter-spacing: 0.04em;
}

#results-view .insight-value {
    color: #dbeafe;
    font-size: 0.95rem;
    line-height: 1.3;
}

#results-view .session-bonus-breakdown {
    border-radius: 12px;
    border: 1px solid rgba(74, 222, 128, 0.24);
    background: rgba(16, 185, 129, 0.08);
    padding: 12px 14px;
}

#results-view .session-bonus-title {
    font-size: 0.74rem;
    color: #9fb0c8;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 8px;
}

#results-view .session-bonus-grid {
    display: grid;
    gap: 6px;
}

#results-view .session-bonus-row {
    display: flex;
    justify-content: space-between;
    color: #d1fae5;
    font-size: 0.9rem;
}

#results-view .session-bonus-row.total {
    padding-top: 6px;
    margin-top: 2px;
    border-top: 1px solid rgba(167, 243, 208, 0.25);
    font-weight: 800;
}

#results-view .source-breakdown,
#results-view .achievements-section {
    max-width: none;
    margin-top: 0;
}

#results-view .source-breakdown-title,
#results-view .achievements-title {
    text-align: left;
}

#results-view .results-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

#results-view .results-actions .welcome-btn {
    flex: 1 1 180px;
}

#results-view .results-review-tools {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

#results-view .results-review-card {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 14px 16px;
    border-radius: 16px;
    border: 1px solid rgba(148, 163, 184, 0.18);
    background:
        radial-gradient(120% 120% at 0% 0%, rgba(96, 165, 250, 0.08) 0%, transparent 56%),
        rgba(15, 23, 42, 0.44);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

#results-view .results-review-card-title {
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #dbeafe;
}

#results-view .results-review-card-note {
    color: #9fb2c9;
    font-size: 0.86rem;
    line-height: 1.5;
}

#results-view .results-review-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

#results-view .results-review-actions .welcome-btn {
    flex: 1 1 180px;
}

#results-view .results-review-mode-toggle {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 8px;
}

#results-view .results-review-mode-btn {
    appearance: none;
    border: 1px solid rgba(148, 163, 184, 0.22);
    background: rgba(15, 23, 42, 0.58);
    color: #bfd0e7;
    border-radius: 999px;
    padding: 8px 12px;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    cursor: pointer;
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

#results-view .results-review-mode-btn:hover {
    border-color: rgba(96, 165, 250, 0.44);
    color: #e2e8f0;
    transform: translateY(-1px);
}

#results-view .results-review-mode-btn.active {
    border-color: rgba(96, 165, 250, 0.52);
    background: linear-gradient(135deg, rgba(59, 130, 246, 0.22), rgba(168, 85, 247, 0.18));
    color: #f8fbff;
    box-shadow: 0 0 0 1px rgba(96, 165, 250, 0.15) inset;
}

#results-view .results-review-actions .welcome-btn:disabled,
#results-view .results-review-mode-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
}

#results-view .results-list-wrap {
    border-top: 1px solid rgba(148, 163, 184, 0.24);
    padding-top: 10px;
}

#results-view .results-list-title {
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-size: 0.74rem;
    margin-bottom: 8px;
}

#results-view .results-list {
    border-top: 0;
    padding-top: 0;
    margin-top: 0;
}

#results-view .result-item {
    border-left: 3px solid rgba(148, 163, 184, 0.45);
    align-items: center;
    gap: 10px;
}

#results-view .result-item.wrong {
    border-left-color: rgba(248, 113, 113, 0.8);
}

#results-view .result-main {
    min-width: 0;
    flex: 1;
}

#results-view .result-title {
    font-weight: 600;
    color: #cbd5e1;
    line-height: 1.35;
}

#results-view .result-meta {
    margin-top: 4px;
    color: #7f93ad;
    font-size: 0.78rem;
}

#results-view .result-cta {
    font-size: 0.78rem;
    color: #a78bfa;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 700;
    white-space: nowrap;
}

#results-view .results-empty {
    text-align: center;
    padding: 20px;
    border-radius: 10px;
    border: 1px solid rgba(148, 163, 184, 0.2);
    color: #a8b8cc;
    background: rgba(255, 255, 255, 0.02);
}

#work-area.trio-view #results-view .results-shell {
    padding: 14px 12px;
    gap: 12px;
}

#work-area.trio-view #results-view .results-metrics-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}

#work-area.trio-view #results-view .results-metric-card {
    padding: 10px 8px;
}

#work-area.trio-view #results-view .results-insights {
    grid-template-columns: 1fr;
}

#work-area.trio-view #results-view .results-grade-chip {
    justify-content: center;
    flex-wrap: wrap;
}

@media (max-width: 980px) {
    #results-view .results-metrics-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    #results-view .results-review-tools {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    #results-view {
        padding: 0.75rem 0.4rem 1rem;
    }

    #results-view .results-shell {
        padding: 12px;
        border-radius: 14px;
        gap: 12px;
    }

    #results-view .results-insights {
        grid-template-columns: 1fr;
    }

    #results-view .results-metrics-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    #results-view .results-actions {
        flex-direction: column;
    }

    #results-view .results-review-actions {
        flex-direction: column;
    }

    #results-view .results-review-actions .welcome-btn,
    #results-view .results-review-mode-btn {
        width: 100%;
    }

    #results-view .results-review-mode-toggle {
        display: flex;
        flex-direction: column;
    }

    #results-view .results-actions .welcome-btn {
        width: 100%;
    }
}

/* ==========================================================================
   ACHIEVEMENTS V3 + STREAK PROFILE POPUPS
   ========================================================================== */

.stat-achievements {
    min-width: 68px;
    justify-content: center;
    border: 1px solid color-mix(in srgb, var(--bd, rgba(255, 255, 255, 0.16)) 78%, transparent 22%);
    background: color-mix(in srgb, var(--card-bg, rgba(15, 23, 42, 0.8)) 90%, #0a1220 10%);
}

.stat-achievements .gradient-text {
    font-size: 0.62rem;
    letter-spacing: 0.08em;
}

#achievements-modal .achievements-modal-content {
    width: min(980px, 94vw);
    max-width: min(980px, 94vw);
    max-height: min(92vh, 960px);
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 18px;
    overflow: hidden;
    border: 1px solid color-mix(in srgb, var(--bd, rgba(255, 255, 255, 0.2)) 75%, var(--g1, #60a5fa) 25%);
    border-radius: 20px;
    background:
        radial-gradient(120% 120% at 0% 0%, color-mix(in srgb, var(--g1, #60a5fa) 14%, transparent 86%) 0%, transparent 58%),
        radial-gradient(100% 120% at 100% 100%, color-mix(in srgb, var(--g2, #a78bfa) 14%, transparent 86%) 0%, transparent 60%),
        color-mix(in srgb, var(--card-bg, rgba(8, 16, 32, 0.95)) 92%, #050a14 8%);
}

#achievements-modal .achievements-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    padding-bottom: 10px;
    border-bottom: 1px solid rgba(148, 163, 184, 0.22);
}

#achievements-modal .achievements-modal-header h2 {
    margin: 0;
}

#achievements-modal .achievements-summary-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin: 0;
}

#achievements-modal .achievement-stat {
    align-items: flex-start;
    padding: 12px;
    border-radius: 12px;
    border: 1px solid color-mix(in srgb, var(--bd, rgba(255, 255, 255, 0.16)) 84%, transparent 16%);
    background: color-mix(in srgb, var(--card-bg, rgba(15, 23, 42, 0.72)) 88%, #0b1220 12%);
}

#achievements-modal .ach-stat-value {
    font-size: 1.45rem;
    font-weight: 820;
    color: var(--text-main, #e2e8f0);
    line-height: 1.1;
}

#achievements-modal .ach-stat-label {
    margin-top: 3px;
    font-size: 0.74rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--text-sub, #94a3b8);
}

#achievements-modal #achievements-grid {
    flex: 0 0 clamp(180px, 30vh, 270px);
    max-height: clamp(180px, 30vh, 270px);
    min-height: 0;
}

#achievements-modal .achievement-progress-meta {
    margin-top: 4px;
    font-size: 0.7rem;
    color: #64748b;
}

#achievements-modal .achievement-unlocked-at {
    margin-top: 6px;
    font-size: 0.68rem;
    color: #8aa0bb;
    letter-spacing: 0.01em;
}

#achievements-modal .achievement-history-panel {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    padding: 12px;
    border-radius: 14px;
    border: 1px solid color-mix(in srgb, var(--bd, rgba(255, 255, 255, 0.16)) 78%, transparent 22%);
    background: color-mix(in srgb, var(--card-bg, rgba(15, 23, 42, 0.62)) 90%, #050a14 10%);
}

#achievements-modal .achievement-history-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 10px;
}

#achievements-modal .achievement-history-title {
    font-size: 0.8rem;
    font-weight: 780;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #dbeafe;
}

#achievements-modal .achievement-history-latest {
    font-size: 0.72rem;
    color: #8ea5bf;
    text-align: right;
}

#achievements-modal .achievement-history-list {
    flex: 1 1 auto;
    min-height: 0;
    max-height: none;
    overflow-y: auto;
    padding-right: 4px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

#achievements-modal .achievement-history-list::-webkit-scrollbar {
    width: 6px;
}

#achievements-modal .achievement-history-list::-webkit-scrollbar-thumb {
    background: rgba(148, 163, 184, 0.28);
    border-radius: 999px;
}

#achievements-modal .achievement-history-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    border-radius: 10px;
    border: 1px solid rgba(148, 163, 184, 0.2);
    background: rgba(10, 16, 28, 0.68);
}

#achievements-modal .achievement-history-item.locked {
    opacity: 0.78;
}

#achievements-modal .achievement-history-main {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}

#achievements-modal .achievement-history-icon {
    min-width: 54px;
    height: 28px;
    border-radius: 999px;
    border: 1px solid rgba(148, 163, 184, 0.4);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(145deg, rgba(15, 23, 42, 0.96), rgba(30, 41, 59, 0.9));
}

#achievements-modal .achievement-history-icon span {
    font-size: 0.6rem;
    font-weight: 820;
    letter-spacing: 0.08em;
    color: #dbeafe;
}

#achievements-modal .achievement-history-info {
    min-width: 0;
}

#achievements-modal .achievement-history-name {
    font-size: 0.82rem;
    font-weight: 700;
    color: #dbeafe;
}

#achievements-modal .achievement-history-desc {
    margin-top: 2px;
    font-size: 0.72rem;
    color: #8ea5bf;
    line-height: 1.25;
}

#achievements-modal .achievement-history-time {
    font-size: 0.7rem;
    color: #9fb4cd;
    text-align: right;
    white-space: nowrap;
}

#level-roadmap-modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.8);
    z-index: 9000;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(4px);
}

#level-roadmap-modal.show {
    display: flex;
}

#level-roadmap-modal.fx-boot .level-roadmap-card,
#level-roadmap-modal.fx-boot .level-roadmap-card::after,
#level-roadmap-modal.fx-boot .level-roadmap-badge,
#level-roadmap-modal.fx-boot .level-roadmap-badge::after {
    animation: none !important;
    transition: none !important;
}

#level-roadmap-modal .level-roadmap-modal-content {
    width: min(980px, 94vw);
    max-width: min(980px, 94vw);
    max-height: min(92vh, 960px);
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 18px;
    overflow: hidden;
    border: 1px solid color-mix(in srgb, var(--bd, rgba(255, 255, 255, 0.2)) 75%, var(--g2, #a78bfa) 25%);
    border-radius: 20px;
    background:
        radial-gradient(130% 140% at 0% 0%, color-mix(in srgb, var(--g1, #60a5fa) 14%, transparent 86%) 0%, transparent 58%),
        radial-gradient(120% 140% at 100% 100%, color-mix(in srgb, var(--g2, #a78bfa) 16%, transparent 84%) 0%, transparent 60%),
        color-mix(in srgb, var(--card-bg, rgba(8, 16, 32, 0.95)) 92%, #050a14 8%);
}

#level-roadmap-modal .level-roadmap-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    padding-bottom: 10px;
    border-bottom: 1px solid rgba(148, 163, 184, 0.22);
}

#level-roadmap-modal .level-roadmap-header h2 {
    margin: 0;
    min-width: 0;
    flex: 1 1 auto;
}

#level-roadmap-modal .level-roadmap-summary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}

#level-roadmap-modal .level-roadmap-stat {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    padding: 12px;
    border-radius: 12px;
    border: 1px solid color-mix(in srgb, var(--bd, rgba(255, 255, 255, 0.16)) 84%, transparent 16%);
    background: color-mix(in srgb, var(--card-bg, rgba(15, 23, 42, 0.72)) 88%, #0b1220 12%);
}

#level-roadmap-modal .level-roadmap-stat-value {
    font-size: 0.95rem;
    font-weight: 800;
    color: var(--text-main, #e2e8f0);
    line-height: 1.2;
}

#level-roadmap-modal .level-roadmap-stat-label {
    margin-top: 4px;
    font-size: 0.72rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--text-sub, #94a3b8);
}

#level-roadmap-modal .level-roadmap-grid {
    flex: 1 1 auto;
    min-height: 0;
    width: 100%;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding-right: 6px;
    overscroll-behavior: contain;
}

#level-roadmap-modal .level-roadmap-grid::-webkit-scrollbar {
    width: 6px;
}

#level-roadmap-modal .level-roadmap-grid::-webkit-scrollbar-thumb {
    background: rgba(148, 163, 184, 0.28);
    border-radius: 999px;
}

#level-roadmap-modal .level-roadmap-card {
    --road-b1: #60a5fa;
    --road-b2: #3b82f6;
    --road-b3: #1d4ed8;
    --road-edge: #bfdbfe;
    --road-aura: rgba(96, 165, 250, 0.45);
    --road-flare: rgba(191, 219, 254, 0.72);
    --road-accent: rgba(96, 165, 250, 0.75);
    --road-badge-pattern: linear-gradient(120deg, rgba(255, 255, 255, 0.22), transparent 52%);
    position: relative;
    isolation: isolate;
    overflow: hidden;
    min-height: 128px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    width: min(900px, calc(100% - 8px));
    margin-inline: auto;
    align-items: center;
    column-gap: 14px;
    padding: 12px 16px;
    border-radius: 14px;
    border: 1px solid color-mix(in srgb, var(--road-accent) 48%, rgba(148, 163, 184, 0.24) 52%);
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--road-b3) 16%, rgba(8, 12, 24, 0.9) 84%), rgba(6, 10, 18, 0.92)),
        radial-gradient(120% 160% at -14% -25%, color-mix(in srgb, var(--road-aura) 36%, transparent 64%) 0%, transparent 62%),
        rgba(10, 16, 28, 0.72);
    box-shadow: 0 12px 28px rgba(2, 6, 23, 0.42);
    transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease, opacity 0.2s ease;
    contain: layout paint style;
    content-visibility: auto;
    contain-intrinsic-size: 128px;
}

#level-roadmap-modal .level-roadmap-card::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background:
        radial-gradient(90% 140% at 16% 8%, color-mix(in srgb, var(--road-aura) 42%, transparent 58%) 0%, transparent 66%),
        linear-gradient(140deg, color-mix(in srgb, var(--road-flare) 16%, transparent 84%), transparent 52%);
    opacity: 0.34;
    z-index: -1;
    pointer-events: none;
}

#level-roadmap-modal .level-roadmap-card::after {
    content: '';
    position: absolute;
    inset: -24% -40%;
    border-radius: inherit;
    background: linear-gradient(120deg, transparent 20%, color-mix(in srgb, var(--road-flare) 54%, transparent 46%) 50%, transparent 80%);
    opacity: 0;
    pointer-events: none;
    transform: translateX(-30%);
}

#level-roadmap-modal .level-roadmap-card.locked {
    opacity: 0.74;
    filter: saturate(0.82) brightness(0.88);
}

#level-roadmap-modal .level-roadmap-card.locked::before {
    opacity: 0.22;
}

#level-roadmap-modal .level-roadmap-card.unlocked {
    border-color: color-mix(in srgb, var(--road-accent) 62%, rgba(191, 219, 254, 0.32) 38%);
}

#level-roadmap-modal .level-roadmap-card:hover,
#level-roadmap-modal .level-roadmap-card:focus-within {
    transform: translateY(-1px);
    box-shadow: 0 16px 32px rgba(2, 6, 23, 0.5);
}

#level-roadmap-modal .level-roadmap-card.unlocked:not(.current):hover::after,
#level-roadmap-modal .level-roadmap-card.current::after,
#level-roadmap-modal .level-roadmap-card:focus-within::after {
    opacity: 0.34;
    animation: level-roadmap-card-scan 6s linear infinite;
}

#level-roadmap-modal .level-roadmap-card.locked:hover,
#level-roadmap-modal .level-roadmap-card.locked:focus-within {
    opacity: 0.95;
    filter: none;
    border-color: color-mix(in srgb, var(--road-accent) 66%, rgba(191, 219, 254, 0.34) 34%);
    box-shadow:
        0 0 0 1px color-mix(in srgb, var(--road-accent) 38%, transparent 62%),
        0 16px 34px rgba(2, 6, 23, 0.56);
}

#level-roadmap-modal .level-roadmap-card.locked:hover::after,
#level-roadmap-modal .level-roadmap-card.locked:focus-within::after {
    opacity: 0.28;
    animation: level-roadmap-card-scan 6.6s linear infinite;
}

#level-roadmap-modal .level-roadmap-card.current {
    border-color: color-mix(in srgb, var(--road-edge) 84%, #ffffff 16%);
    box-shadow:
        0 0 0 1px color-mix(in srgb, var(--road-edge) 64%, transparent 36%),
        0 20px 42px rgba(2, 6, 23, 0.54);
    animation: level-roadmap-current-pulse 4s ease-in-out infinite;
}

#level-roadmap-modal .level-roadmap-card.current::before {
    opacity: 0.48;
}

#level-roadmap-modal .level-roadmap-main {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    justify-content: center;
    gap: 12px;
    min-width: 0;
    width: min(640px, 100%);
    max-width: min(640px, 100%);
    margin-inline: auto;
    justify-self: center;
}

#level-roadmap-modal .level-roadmap-badge {
    position: relative;
    min-width: 84px;
    padding: 6px 12px;
    border-radius: 999px;
    text-align: center;
    font-size: 0.74rem;
    color: #f8fafc;
    border: 1px solid color-mix(in srgb, var(--road-edge) 74%, transparent 26%);
    background: linear-gradient(135deg, var(--road-b1), var(--road-b2) 58%, var(--road-b3));
    text-shadow:
        0 1px 0 rgba(2, 6, 23, 0.75),
        0 0 12px color-mix(in srgb, var(--road-edge) 60%, transparent 40%);
    box-shadow:
        0 10px 24px color-mix(in srgb, var(--road-aura) 72%, transparent 28%),
        inset 0 0 0 1px rgba(255, 255, 255, 0.16);
    overflow: hidden;
    isolation: isolate;
    transition: transform 0.22s ease, filter 0.22s ease;
    flex-shrink: 0;
}

#level-roadmap-modal .level-roadmap-badge::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background:
        var(--road-badge-pattern),
        radial-gradient(circle at 18% 22%, color-mix(in srgb, var(--road-flare) 54%, transparent 46%) 0%, transparent 36%);
    opacity: 0.66;
    z-index: -1;
    pointer-events: none;
}

#level-roadmap-modal .level-roadmap-badge::after {
    content: '';
    position: absolute;
    top: -30%;
    left: -44%;
    width: 38%;
    height: 180%;
    transform: rotate(18deg);
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.5), transparent);
    opacity: 0;
    animation: none;
}

#level-roadmap-modal .level-roadmap-card.locked .level-roadmap-badge {
    filter: saturate(0.72) brightness(0.86);
    box-shadow: 0 6px 14px rgba(2, 6, 23, 0.36);
}

#level-roadmap-modal .level-roadmap-card.locked .level-roadmap-badge::after {
    opacity: 0.08;
}

#level-roadmap-modal .level-roadmap-card.current .level-roadmap-badge,
#level-roadmap-modal .level-roadmap-card:hover .level-roadmap-badge,
#level-roadmap-modal .level-roadmap-card:focus-within .level-roadmap-badge {
    animation: level-roadmap-badge-breathe 3.6s ease-in-out infinite;
}

#level-roadmap-modal .level-roadmap-card.current .level-roadmap-badge::after,
#level-roadmap-modal .level-roadmap-card:hover .level-roadmap-badge::after,
#level-roadmap-modal .level-roadmap-card:focus-within .level-roadmap-badge::after {
    opacity: 0.72;
    animation: level-roadmap-badge-sheen 2.8s linear infinite;
}

#level-roadmap-modal .level-roadmap-card.phase-classic .level-roadmap-badge {
    --road-badge-pattern: linear-gradient(122deg, rgba(255, 255, 255, 0.24), transparent 56%);
}

#level-roadmap-modal .level-roadmap-card.phase-ignite .level-roadmap-badge {
    --road-badge-pattern:
        repeating-linear-gradient(126deg, rgba(255, 255, 255, 0.2) 0 4px, transparent 4px 10px),
        radial-gradient(circle at 84% 24%, rgba(255, 246, 196, 0.38) 0 14%, transparent 44%);
}

#level-roadmap-modal .level-roadmap-card.phase-orbit .level-roadmap-badge {
    --road-badge-pattern:
        radial-gradient(circle at 22% 72%, rgba(255, 255, 255, 0.24) 0 10%, transparent 36%),
        repeating-radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.16) 0 1px, transparent 1px 8px);
}

#level-roadmap-modal .level-roadmap-card.phase-cosmic .level-roadmap-badge {
    --road-badge-pattern:
        conic-gradient(from 122deg at 50% 50%, rgba(255, 255, 255, 0.22), transparent 24%, rgba(255, 255, 255, 0.08) 46%, transparent 70%, rgba(255, 255, 255, 0.18) 100%),
        radial-gradient(circle at 20% 24%, rgba(255, 255, 255, 0.36) 0 10%, transparent 34%),
        radial-gradient(circle at 80% 76%, rgba(255, 255, 255, 0.28) 0 8%, transparent 30%);
}

#level-roadmap-modal .level-roadmap-card.band-ascend25 {
    background-image:
        linear-gradient(135deg, color-mix(in srgb, var(--road-b3) 16%, rgba(8, 12, 24, 0.9) 84%), rgba(6, 10, 18, 0.92)),
        radial-gradient(120% 160% at -14% -25%, color-mix(in srgb, var(--road-aura) 36%, transparent 64%) 0%, transparent 62%);
}

#level-roadmap-modal .level-roadmap-card.band-ascend50 {
    background-image:
        linear-gradient(135deg, color-mix(in srgb, var(--road-b3) 16%, rgba(8, 12, 24, 0.9) 84%), rgba(6, 10, 18, 0.92)),
        radial-gradient(120% 160% at -14% -25%, color-mix(in srgb, var(--road-aura) 36%, transparent 64%) 0%, transparent 62%);
}

#level-roadmap-modal .level-roadmap-card.band-ascend100 {
    background-image:
        linear-gradient(135deg, color-mix(in srgb, var(--road-b3) 16%, rgba(8, 12, 24, 0.9) 84%), rgba(6, 10, 18, 0.92)),
        radial-gradient(120% 160% at -14% -25%, color-mix(in srgb, var(--road-aura) 36%, transparent 64%) 0%, transparent 62%);
}

#level-roadmap-modal .level-roadmap-card.ms-50 {
    border-color: color-mix(in srgb, #ffe87a 74%, rgba(148, 163, 184, 0.26) 26%);
    box-shadow:
        0 0 0 1px rgba(255, 232, 122, 0.28),
        0 16px 32px rgba(2, 6, 23, 0.54),
        0 0 24px rgba(255, 208, 71, 0.18);
}

#level-roadmap-modal .level-roadmap-card.ms-50 .level-roadmap-badge {
    border-color: rgba(255, 245, 180, 0.95);
    background: linear-gradient(135deg, #fff07a 0%, #ffd12d 46%, #be8500 100%);
    box-shadow:
        0 0 0 1px rgba(255, 214, 85, 0.34),
        0 12px 30px rgba(255, 210, 71, 0.42),
        inset 0 0 0 1px rgba(255, 255, 255, 0.26);
}

#level-roadmap-modal .level-roadmap-card.ms-200 {
    border-color: color-mix(in srgb, #8af5ff 74%, rgba(148, 163, 184, 0.26) 26%);
    box-shadow:
        0 0 0 1px rgba(138, 245, 255, 0.3),
        0 16px 32px rgba(2, 6, 23, 0.56),
        0 0 26px rgba(64, 206, 255, 0.2);
}

#level-roadmap-modal .level-roadmap-card.ms-200 .level-roadmap-badge {
    border-color: rgba(203, 252, 255, 0.95);
    background: linear-gradient(135deg, #95fbff 0%, #34c6ff 44%, #1353b3 100%);
    box-shadow:
        0 0 0 1px rgba(120, 223, 255, 0.36),
        0 12px 30px rgba(78, 201, 255, 0.44),
        inset 0 0 0 1px rgba(255, 255, 255, 0.24);
}

#level-roadmap-modal .level-roadmap-card.ms-200 .level-roadmap-badge::before {
    background:
        linear-gradient(125deg, rgba(210, 252, 255, 0.34), transparent 56%),
        repeating-linear-gradient(145deg, rgba(180, 246, 255, 0.2) 0 3px, transparent 3px 9px),
        radial-gradient(circle at 18% 22%, rgba(210, 252, 255, 0.52) 0%, transparent 38%);
}

#level-roadmap-modal .level-roadmap-card.ms-500 .level-roadmap-badge {
    border-color: rgba(233, 231, 255, 0.94);
    background: linear-gradient(135deg, #c2cdff 0%, #9d8dff 52%, #563db7 100%);
    box-shadow:
        0 0 0 1px rgba(177, 168, 255, 0.34),
        0 12px 30px rgba(146, 129, 255, 0.42),
        inset 0 0 0 1px rgba(255, 255, 255, 0.24);
}

#level-roadmap-modal .level-roadmap-card.ms-1000 .level-roadmap-badge {
    border-color: rgba(255, 241, 227, 0.96);
    background: linear-gradient(135deg, #f7e2cb 0%, #d5b5c7 48%, #6f5b87 100%);
    box-shadow:
        0 0 0 1px rgba(236, 213, 189, 0.34),
        0 12px 30px rgba(198, 164, 208, 0.42),
        inset 0 0 0 1px rgba(255, 255, 255, 0.24);
}

/* ==========================================================================
   ROADMAP ULTRA FX (Epic / Legendary / Mythic)
   ========================================================================== */

#level-roadmap-modal .level-roadmap-card.fx-epic,
#level-roadmap-modal .level-roadmap-card.fx-legendary,
#level-roadmap-modal .level-roadmap-card.fx-mythic {
    --fx-a: #ff7d3c;
    --fx-b: #ffcc62;
    --fx-c: #7b1434;
    --fx-edge: #ffd6ad;
    --fx-overlay:
        radial-gradient(88% 132% at 8% 4%, color-mix(in srgb, var(--fx-b) 22%, transparent 78%) 0%, transparent 62%),
        linear-gradient(122deg, color-mix(in srgb, var(--fx-a) 15%, transparent 85%) 0%, transparent 54%);
    --fx-pattern:
        repeating-linear-gradient(128deg, rgba(255, 255, 255, 0.09) 0 6px, transparent 6px 14px);
    --fx-highlight:
        radial-gradient(circle at 18% 22%, rgba(255, 255, 255, 0.56) 0%, transparent 34%);
    border-color: color-mix(in srgb, var(--fx-edge) 66%, rgba(148, 163, 184, 0.34) 34%);
    background-image:
        linear-gradient(132deg, color-mix(in srgb, var(--fx-c) 30%, rgba(6, 10, 18, 0.96) 70%), rgba(6, 10, 18, 0.96)),
        var(--fx-overlay),
        radial-gradient(120% 160% at -12% -30%, color-mix(in srgb, var(--fx-a) 24%, transparent 76%) 0%, transparent 62%);
    box-shadow:
        0 0 0 1px color-mix(in srgb, var(--fx-edge) 30%, transparent 70%),
        0 16px 34px rgba(2, 6, 23, 0.58),
        0 0 28px color-mix(in srgb, var(--fx-a) 18%, transparent 82%);
}

#level-roadmap-modal .level-roadmap-card.fx-epic::before,
#level-roadmap-modal .level-roadmap-card.fx-legendary::before,
#level-roadmap-modal .level-roadmap-card.fx-mythic::before {
    background:
        var(--fx-pattern),
        radial-gradient(90% 150% at 88% -20%, color-mix(in srgb, var(--fx-b) 24%, transparent 76%) 0%, transparent 66%),
        linear-gradient(145deg, color-mix(in srgb, var(--fx-edge) 12%, transparent 88%), transparent 60%);
    opacity: 0.52;
}

#level-roadmap-modal .level-roadmap-card.fx-epic .level-roadmap-badge,
#level-roadmap-modal .level-roadmap-card.fx-legendary .level-roadmap-badge,
#level-roadmap-modal .level-roadmap-card.fx-mythic .level-roadmap-badge {
    border-color: color-mix(in srgb, var(--fx-edge) 88%, #ffffff 12%);
    background:
        linear-gradient(132deg, var(--fx-b) 0%, var(--fx-a) 46%, var(--fx-c) 100%),
        var(--fx-pattern);
    background-blend-mode: screen, normal;
    box-shadow:
        0 0 0 1px color-mix(in srgb, var(--fx-edge) 28%, transparent 72%),
        0 14px 34px color-mix(in srgb, var(--fx-a) 32%, transparent 68%),
        inset 0 0 0 1px rgba(255, 255, 255, 0.25);
    transform: translateZ(0);
    animation: none;
}

#level-roadmap-modal .level-roadmap-card.fx-epic .level-roadmap-badge::before,
#level-roadmap-modal .level-roadmap-card.fx-legendary .level-roadmap-badge::before,
#level-roadmap-modal .level-roadmap-card.fx-mythic .level-roadmap-badge::before {
    opacity: 0.92;
    background:
        var(--fx-highlight),
        var(--road-badge-pattern);
}

#level-roadmap-modal .level-roadmap-card.fx-epic .level-roadmap-badge::after,
#level-roadmap-modal .level-roadmap-card.fx-legendary .level-roadmap-badge::after,
#level-roadmap-modal .level-roadmap-card.fx-mythic .level-roadmap-badge::after {
    opacity: 0.86;
    animation: none;
}

#level-roadmap-modal .level-roadmap-card.fx-legendary {
    --fx-a: #35c7ff;
    --fx-b: #94f6ff;
    --fx-c: #1f3a9a;
    --fx-edge: #cef9ff;
    --fx-pattern:
        repeating-linear-gradient(122deg, rgba(220, 252, 255, 0.24) 0 2px, transparent 2px 9px),
        repeating-linear-gradient(36deg, rgba(141, 224, 255, 0.16) 0 1px, transparent 1px 7px);
    --fx-highlight:
        radial-gradient(circle at 20% 22%, rgba(221, 252, 255, 0.66) 0%, transparent 36%),
        repeating-linear-gradient(130deg, rgba(217, 252, 255, 0.28) 0 3px, transparent 3px 10px);
}

#level-roadmap-modal .level-roadmap-card.fx-mythic {
    --fx-a: #a98fff;
    --fx-b: #f5bbff;
    --fx-c: #3b2f8b;
    --fx-edge: #efe3ff;
    --fx-pattern:
        conic-gradient(from 28deg at 50% 50%, rgba(255, 255, 255, 0.2), transparent 24%, rgba(255, 255, 255, 0.08) 52%, transparent 74%, rgba(255, 255, 255, 0.18)),
        repeating-radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.11) 0 1px, transparent 1px 8px);
    --fx-highlight:
        radial-gradient(circle at 16% 24%, rgba(255, 255, 255, 0.66) 0 9%, transparent 34%),
        radial-gradient(circle at 82% 76%, rgba(255, 255, 255, 0.5) 0 8%, transparent 28%);
}

/* Milestone-specific aesthetic variants */
#level-roadmap-modal .level-roadmap-card.v-inferno {
    --fx-a: #ff5a2e;
    --fx-b: #ffcf71;
    --fx-c: #7a0f2f;
    --fx-edge: #ffd4a8;
}

#level-roadmap-modal .level-roadmap-card.v-blazecore {
    --fx-a: #ff7d1f;
    --fx-b: #ffe07f;
    --fx-c: #6f1a35;
    --fx-edge: #ffe2b7;
}

#level-roadmap-modal .level-roadmap-card.v-phoenix {
    --fx-a: #ff3d75;
    --fx-b: #ffba62;
    --fx-c: #6a1341;
    --fx-edge: #ffd4ca;
}

#level-roadmap-modal .level-roadmap-card.v-solarflare {
    --fx-a: #ff8b2e;
    --fx-b: #fff07a;
    --fx-c: #8f2b2b;
    --fx-edge: #ffe3a8;
}

#level-roadmap-modal .level-roadmap-card.v-thunder {
    --fx-a: #29c8ff;
    --fx-b: #a8fbff;
    --fx-c: #144fa4;
    --fx-edge: #ddfbff;
}

#level-roadmap-modal .level-roadmap-card.v-storm {
    --fx-a: #3ea8ff;
    --fx-b: #c3ecff;
    --fx-c: #3847a1;
    --fx-edge: #d9ecff;
}

#level-roadmap-modal .level-roadmap-card.v-arc {
    --fx-a: #49d2ff;
    --fx-b: #b6fdff;
    --fx-c: #1d4a9f;
    --fx-edge: #dbf6ff;
}

#level-roadmap-modal .level-roadmap-card.v-plasma {
    --fx-a: #6a7dff;
    --fx-b: #b6beff;
    --fx-c: #313593;
    --fx-edge: #dbddff;
}

#level-roadmap-modal .level-roadmap-card.v-void {
    --fx-a: #7f67ff;
    --fx-b: #d2bcff;
    --fx-c: #3a1f82;
    --fx-edge: #e4d8ff;
}

#level-roadmap-modal .level-roadmap-card.v-prism {
    --fx-a: #ae62ff;
    --fx-b: #efb8ff;
    --fx-c: #4f1f87;
    --fx-edge: #f2dcff;
}

#level-roadmap-modal .level-roadmap-card.v-nebula {
    --fx-a: #d747ff;
    --fx-b: #ffc6ff;
    --fx-c: #651f82;
    --fx-edge: #ffdcff;
}

#level-roadmap-modal .level-roadmap-card.v-celestial {
    --fx-a: #897bff;
    --fx-b: #cbd1ff;
    --fx-c: #483aa4;
    --fx-edge: #e4e8ff;
}

#level-roadmap-modal .level-roadmap-card.v-crownfire {
    --fx-a: #7f8fff;
    --fx-b: #bfd8ff;
    --fx-c: #3f4699;
    --fx-edge: #d9e7ff;
}

#level-roadmap-modal .level-roadmap-card.v-supersonic {
    --fx-a: #a56bff;
    --fx-b: #d8b6ff;
    --fx-c: #5a32a8;
    --fx-edge: #ecdeff;
}

#level-roadmap-modal .level-roadmap-card.v-astral {
    --fx-a: #d16fff;
    --fx-b: #ffc9ef;
    --fx-c: #70389f;
    --fx-edge: #ffe1f7;
}

#level-roadmap-modal .level-roadmap-card.v-rift {
    --fx-a: #ff8597;
    --fx-b: #ffd0c4;
    --fx-c: #7a487d;
    --fx-edge: #ffe5de;
}

#level-roadmap-modal .level-roadmap-card.v-omega {
    --fx-a: #caa1cb;
    --fx-b: #ffe6c8;
    --fx-c: #6f5b87;
    --fx-edge: #fff0df;
}

/* Accent special milestones to keep standout legacy vibes. */
#level-roadmap-modal .level-roadmap-card.ms-200.fx-legendary .level-roadmap-badge {
    background:
        linear-gradient(132deg, #d8fdff 0%, #45cbff 42%, #1942a2 100%),
        repeating-linear-gradient(122deg, rgba(216, 252, 255, 0.26) 0 2px, transparent 2px 8px);
    box-shadow:
        0 0 0 1px rgba(195, 247, 255, 0.42),
        0 16px 36px rgba(77, 197, 255, 0.42),
        inset 0 0 0 1px rgba(255, 255, 255, 0.24);
}

#level-roadmap-modal .level-roadmap-card.ms-500.fx-mythic .level-roadmap-badge {
    background:
        linear-gradient(132deg, #d8d4ff 0%, #9e90ff 48%, #4a35a8 100%),
        conic-gradient(from 28deg at 50% 50%, rgba(255, 255, 255, 0.2), transparent 24%, rgba(255, 255, 255, 0.08) 52%, transparent 74%, rgba(255, 255, 255, 0.18));
}

#level-roadmap-modal .level-roadmap-card.v-thunder .level-roadmap-badge::before {
    background:
        repeating-linear-gradient(120deg, rgba(221, 252, 255, 0.36) 0 2px, transparent 2px 9px),
        radial-gradient(circle at 16% 24%, rgba(255, 255, 255, 0.62) 0%, transparent 36%);
}

#level-roadmap-modal .level-roadmap-card.v-celestial .level-roadmap-badge::before,
#level-roadmap-modal .level-roadmap-card.v-omega .level-roadmap-badge::before {
    background:
        conic-gradient(from 32deg at 50% 50%, rgba(255, 255, 255, 0.22), transparent 24%, rgba(255, 255, 255, 0.08) 56%, transparent 80%, rgba(255, 255, 255, 0.2)),
        radial-gradient(circle at 18% 24%, rgba(255, 255, 255, 0.58) 0%, transparent 34%);
}

#level-roadmap-modal .level-roadmap-card.v-omega .level-roadmap-badge {
    border-width: 2px;
    box-shadow:
        0 0 0 1px rgba(255, 238, 214, 0.5),
        0 16px 36px rgba(227, 191, 209, 0.38),
        0 0 18px rgba(247, 223, 196, 0.36),
        inset 0 0 0 1px rgba(255, 255, 255, 0.3);
}

/* Animate only active/high-focus cards to keep the roadmap smooth. */
#level-roadmap-modal .level-roadmap-card.current.fx-epic .level-roadmap-badge,
#level-roadmap-modal .level-roadmap-card.is-live.fx-epic .level-roadmap-badge,
#level-roadmap-modal .level-roadmap-card.fx-epic:hover .level-roadmap-badge,
#level-roadmap-modal .level-roadmap-card.fx-epic:focus-within .level-roadmap-badge {
    animation: roadmap-fire-core 2.4s steps(6) infinite;
    will-change: transform, filter;
}

#level-roadmap-modal .level-roadmap-card.current.fx-epic .level-roadmap-badge::before,
#level-roadmap-modal .level-roadmap-card.is-live.fx-epic .level-roadmap-badge::before,
#level-roadmap-modal .level-roadmap-card.fx-epic:hover .level-roadmap-badge::before,
#level-roadmap-modal .level-roadmap-card.fx-epic:focus-within .level-roadmap-badge::before {
    animation: roadmap-ember-flicker 2.5s steps(8) infinite;
}

#level-roadmap-modal .level-roadmap-card.current.fx-legendary .level-roadmap-badge,
#level-roadmap-modal .level-roadmap-card.is-live.fx-legendary .level-roadmap-badge,
#level-roadmap-modal .level-roadmap-card.fx-legendary:hover .level-roadmap-badge,
#level-roadmap-modal .level-roadmap-card.fx-legendary:focus-within .level-roadmap-badge {
    animation: roadmap-lightning-core 2.1s steps(7) infinite;
    will-change: transform, filter;
}

#level-roadmap-modal .level-roadmap-card.current.fx-legendary .level-roadmap-badge::before,
#level-roadmap-modal .level-roadmap-card.is-live.fx-legendary .level-roadmap-badge::before,
#level-roadmap-modal .level-roadmap-card.fx-legendary:hover .level-roadmap-badge::before,
#level-roadmap-modal .level-roadmap-card.fx-legendary:focus-within .level-roadmap-badge::before {
    animation: roadmap-lightning-strobe 1.8s steps(7) infinite;
}

#level-roadmap-modal .level-roadmap-card.current.fx-mythic .level-roadmap-badge,
#level-roadmap-modal .level-roadmap-card.is-live.fx-mythic .level-roadmap-badge,
#level-roadmap-modal .level-roadmap-card.fx-mythic:hover .level-roadmap-badge,
#level-roadmap-modal .level-roadmap-card.fx-mythic:focus-within .level-roadmap-badge {
    animation: roadmap-cosmic-core 6.4s linear infinite;
    will-change: transform, filter, background-position;
}

#level-roadmap-modal .level-roadmap-card.current.fx-mythic .level-roadmap-badge::before,
#level-roadmap-modal .level-roadmap-card.is-live.fx-mythic .level-roadmap-badge::before,
#level-roadmap-modal .level-roadmap-card.fx-mythic:hover .level-roadmap-badge::before,
#level-roadmap-modal .level-roadmap-card.fx-mythic:focus-within .level-roadmap-badge::before {
    animation: roadmap-star-twinkle 3.2s steps(10) infinite;
}

#level-roadmap-modal .level-roadmap-card.current.fx-epic .level-roadmap-badge::after,
#level-roadmap-modal .level-roadmap-card.current.fx-legendary .level-roadmap-badge::after,
#level-roadmap-modal .level-roadmap-card.current.fx-mythic .level-roadmap-badge::after,
#level-roadmap-modal .level-roadmap-card.is-live.fx-epic .level-roadmap-badge::after,
#level-roadmap-modal .level-roadmap-card.is-live.fx-legendary .level-roadmap-badge::after,
#level-roadmap-modal .level-roadmap-card.is-live.fx-mythic .level-roadmap-badge::after,
#level-roadmap-modal .level-roadmap-card.fx-epic:hover .level-roadmap-badge::after,
#level-roadmap-modal .level-roadmap-card.fx-legendary:hover .level-roadmap-badge::after,
#level-roadmap-modal .level-roadmap-card.fx-mythic:hover .level-roadmap-badge::after,
#level-roadmap-modal .level-roadmap-card.fx-epic:focus-within .level-roadmap-badge::after,
#level-roadmap-modal .level-roadmap-card.fx-legendary:focus-within .level-roadmap-badge::after,
#level-roadmap-modal .level-roadmap-card.fx-mythic:focus-within .level-roadmap-badge::after {
    animation: level-roadmap-badge-sheen 2.1s linear infinite;
}

#level-roadmap-modal .level-roadmap-card.is-live.fx-epic::before,
#level-roadmap-modal .level-roadmap-card.is-live.fx-legendary::before,
#level-roadmap-modal .level-roadmap-card.is-live.fx-mythic::before {
    animation: roadmap-card-energy-drift 9s linear infinite;
}

/* Locked high-tier cards keep preview only on hover/focus */
#level-roadmap-modal .level-roadmap-card.locked.fx-epic:not(.is-live):not(:hover):not(:focus-within) .level-roadmap-badge,
#level-roadmap-modal .level-roadmap-card.locked.fx-legendary:not(.is-live):not(:hover):not(:focus-within) .level-roadmap-badge,
#level-roadmap-modal .level-roadmap-card.locked.fx-mythic:not(.is-live):not(:hover):not(:focus-within) .level-roadmap-badge {
    animation: none;
    filter: saturate(0.72) brightness(0.84);
}

#level-roadmap-modal .level-roadmap-card.locked.fx-epic:not(.is-live):not(:hover):not(:focus-within) .level-roadmap-badge::before,
#level-roadmap-modal .level-roadmap-card.locked.fx-legendary:not(.is-live):not(:hover):not(:focus-within) .level-roadmap-badge::before,
#level-roadmap-modal .level-roadmap-card.locked.fx-mythic:not(.is-live):not(:hover):not(:focus-within) .level-roadmap-badge::before {
    animation: none;
}

#level-roadmap-modal .level-roadmap-card.locked:hover.fx-epic .level-roadmap-badge,
#level-roadmap-modal .level-roadmap-card.locked:focus-within.fx-epic .level-roadmap-badge {
    animation: roadmap-fire-core 2.4s steps(6) infinite;
    filter: none;
}

#level-roadmap-modal .level-roadmap-card.locked:hover.fx-legendary .level-roadmap-badge,
#level-roadmap-modal .level-roadmap-card.locked:focus-within.fx-legendary .level-roadmap-badge {
    animation: roadmap-lightning-core 2.1s steps(7) infinite;
    filter: none;
}

#level-roadmap-modal .level-roadmap-card.locked:hover.fx-mythic .level-roadmap-badge,
#level-roadmap-modal .level-roadmap-card.locked:focus-within.fx-mythic .level-roadmap-badge {
    animation: roadmap-cosmic-core 6.5s linear infinite;
    filter: none;
}

#level-roadmap-modal .level-roadmap-card.locked:hover.fx-epic .level-roadmap-badge::before,
#level-roadmap-modal .level-roadmap-card.locked:focus-within.fx-epic .level-roadmap-badge::before {
    animation: roadmap-ember-flicker 2.5s steps(8) infinite;
}

#level-roadmap-modal .level-roadmap-card.locked:hover.fx-legendary .level-roadmap-badge::before,
#level-roadmap-modal .level-roadmap-card.locked:focus-within.fx-legendary .level-roadmap-badge::before {
    animation: roadmap-lightning-strobe 1.8s steps(7) infinite;
}

#level-roadmap-modal .level-roadmap-card.locked:hover.fx-mythic .level-roadmap-badge::before,
#level-roadmap-modal .level-roadmap-card.locked:focus-within.fx-mythic .level-roadmap-badge::before {
    animation: roadmap-star-twinkle 3.2s steps(10) infinite;
}

#level-roadmap-modal .level-roadmap-card.locked:hover .level-roadmap-requirement::after,
#level-roadmap-modal .level-roadmap-card.locked:focus-within .level-roadmap-requirement::after {
    content: '  - Preview';
    color: color-mix(in srgb, var(--road-edge) 82%, #ffffff 18%);
}

#level-roadmap-modal .level-roadmap-info {
    min-width: 0;
    max-width: 100%;
    text-align: center;
    overflow: hidden;
}

#level-roadmap-modal .level-roadmap-name {
    font-size: 0.88rem;
    font-weight: 760;
    color: #e2e8f0;
    line-height: 1.12;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    overflow-wrap: anywhere;
}

#level-roadmap-modal .level-roadmap-range {
    margin-top: 2px;
    font-size: 0.73rem;
    color: #93a7bf;
    line-height: 1.15;
    white-space: normal;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
    overflow: hidden;
    overflow-wrap: anywhere;
    text-overflow: ellipsis;
}

#level-roadmap-modal .level-roadmap-requirement {
    margin-top: 3px;
    font-size: 0.68rem;
    color: #7f95ae;
    line-height: 1.2;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    overflow-wrap: anywhere;
}

#level-roadmap-modal .level-roadmap-state {
    padding: 5px 10px;
    border-radius: 999px;
    font-size: 0.62rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border: 1px solid color-mix(in srgb, var(--road-accent) 48%, rgba(148, 163, 184, 0.32) 52%);
    color: color-mix(in srgb, var(--road-edge) 74%, #cbd5e1 26%);
    background: color-mix(in srgb, var(--road-accent) 14%, transparent 86%);
    white-space: nowrap;
    position: static;
    margin-top: 0;
    justify-self: end;
    flex-shrink: 0;
}

#level-roadmap-modal .level-roadmap-card.current .level-roadmap-state {
    color: #ffffff;
    border-color: color-mix(in srgb, var(--road-edge) 76%, transparent 24%);
    background: color-mix(in srgb, var(--road-accent) 28%, transparent 72%);
}

#level-roadmap-modal .level-roadmap-card.unlocked:not(.current) .level-roadmap-state {
    color: color-mix(in srgb, var(--road-edge) 78%, #dbeafe 22%);
}

#level-roadmap-modal .level-roadmap-card.locked .level-roadmap-state {
    color: #8a98ab;
    border-color: rgba(124, 142, 168, 0.34);
    background: rgba(15, 23, 42, 0.4);
}

#level-roadmap-modal .level-roadmap-card.locked:hover .level-roadmap-state,
#level-roadmap-modal .level-roadmap-card.locked:focus-within .level-roadmap-state {
    color: color-mix(in srgb, var(--road-edge) 76%, #dbeafe 24%);
    border-color: color-mix(in srgb, var(--road-accent) 52%, rgba(148, 163, 184, 0.32) 48%);
    background: color-mix(in srgb, var(--road-accent) 18%, transparent 82%);
}

@keyframes level-roadmap-current-pulse {
    0%,
    100% {
        box-shadow:
            0 0 0 1px color-mix(in srgb, var(--road-edge) 64%, transparent 36%),
            0 20px 42px rgba(2, 6, 23, 0.54);
    }

    50% {
        box-shadow:
            0 0 0 1px color-mix(in srgb, var(--road-edge) 84%, transparent 16%),
            0 24px 48px rgba(2, 6, 23, 0.62),
            0 0 28px color-mix(in srgb, var(--road-aura) 76%, transparent 24%);
    }
}

@keyframes level-roadmap-card-scan {
    0% {
        transform: translateX(-28%);
    }

    100% {
        transform: translateX(28%);
    }
}

@keyframes level-roadmap-badge-breathe {
    0%,
    100% {
        transform: scale(1);
        filter: brightness(1);
    }

    50% {
        transform: scale(1.035);
        filter: brightness(1.08);
    }
}

@keyframes level-roadmap-badge-sheen {
    0% {
        left: -44%;
    }

    100% {
        left: 132%;
    }
}

@keyframes roadmap-fire-core {
    0%,
    100% {
        filter: saturate(1.02) brightness(1);
        transform: translateY(0) scale(1);
    }

    35% {
        filter: saturate(1.14) brightness(1.08);
        transform: translateY(-1px) scale(1.03);
    }

    70% {
        filter: saturate(1.1) brightness(1.05);
        transform: translateY(0) scale(1.015);
    }
}

@keyframes roadmap-ember-flicker {
    0%,
    100% {
        opacity: 0.92;
        background-position: 0% 50%;
    }

    45% {
        opacity: 1;
        background-position: 38% 44%;
    }

    75% {
        opacity: 0.84;
        background-position: 58% 62%;
    }
}

@keyframes roadmap-lightning-core {
    0%,
    100% {
        filter: brightness(1) contrast(1);
        transform: scale(1);
    }

    16%,
    52% {
        filter: brightness(1.16) contrast(1.12);
        transform: scale(1.035);
    }

    24%,
    60% {
        filter: brightness(0.98) contrast(1.02);
        transform: scale(1.012);
    }
}

@keyframes roadmap-lightning-strobe {
    0%,
    100% {
        opacity: 0.9;
    }

    12%,
    44%,
    78% {
        opacity: 1;
    }

    20%,
    52%,
    86% {
        opacity: 0.62;
    }
}

@keyframes roadmap-cosmic-core {
    0% {
        filter: hue-rotate(0deg) brightness(1);
        background-position: 0% 50%;
    }

    50% {
        filter: hue-rotate(10deg) brightness(1.08);
        background-position: 40% 52%;
    }

    100% {
        filter: hue-rotate(0deg) brightness(1);
        background-position: 0% 50%;
    }
}

@keyframes roadmap-star-twinkle {
    0%,
    100% {
        opacity: 0.92;
        background-position: 0% 0%, 100% 100%;
    }

    40% {
        opacity: 1;
        background-position: 8% 6%, 94% 90%;
    }

    70% {
        opacity: 0.8;
        background-position: -6% -4%, 102% 104%;
    }
}

@keyframes roadmap-card-energy-drift {
    0% {
        background-position: 0% 0%, 100% 0%, 0% 0%;
        filter: saturate(1);
    }

    50% {
        background-position: 14% 6%, 84% 4%, -6% 0%;
        filter: saturate(1.08);
    }

    100% {
        background-position: 0% 0%, 100% 0%, 0% 0%;
        filter: saturate(1);
    }
}

@media (prefers-reduced-motion: reduce) {
    #level-roadmap-modal .level-roadmap-card,
    #level-roadmap-modal .level-roadmap-card::after,
    #level-roadmap-modal .level-roadmap-badge,
    #level-roadmap-modal .level-roadmap-badge::after {
        animation: none !important;
        transition: none !important;
    }
}

body.perf-lite #level-roadmap-modal .level-roadmap-card,
body.perf-lite #level-roadmap-modal .level-roadmap-badge {
    animation: none !important;
    transition: none !important;
}

body.perf-lite #level-roadmap-modal {
    backdrop-filter: none;
}

body.perf-lite #level-roadmap-modal .level-roadmap-card::before,
body.perf-lite #level-roadmap-modal .level-roadmap-badge::before {
    animation: none !important;
}

body.perf-lite #level-roadmap-modal .level-roadmap-card::after,
body.perf-lite #level-roadmap-modal .level-roadmap-badge::after {
    display: none;
}

.streak-mystery-notification {
    padding: 24px 30px;
    border-width: 1px;
    box-shadow: 0 18px 52px rgba(2, 6, 23, 0.7);
}

.streak-mystery-notification .streak-label {
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #dbeafe;
}

.streak-mystery-notification .streak-text {
    margin-top: 6px;
    font-size: 1.14rem;
    font-weight: 760;
}

.streak-mystery-notification .streak-note {
    margin-top: 6px;
    font-size: 0.84rem;
    color: #9fb4cd;
}

.streak-mystery-notification.lite {
    transition: opacity 0.2s ease, transform 0.2s ease;
    box-shadow: 0 12px 30px rgba(2, 6, 23, 0.58);
}

.streak-mystery-notification.lite .streak-icon {
    animation: none !important;
}

.power-up-notification.lite {
    transition: opacity 0.2s ease, transform 0.2s ease;
    box-shadow:
        0 0 18px color-mix(in srgb, var(--g1, #4ade80) 24%, transparent),
        0 8px 24px rgba(0, 0, 0, 0.42);
}

.streak-mystery-notification.streak-type-tempo {
    border-color: rgba(34, 211, 238, 0.8);
}

.streak-mystery-notification.streak-type-precision {
    border-color: rgba(168, 85, 247, 0.75);
}

.streak-mystery-notification.streak-type-cadence {
    border-color: rgba(56, 189, 248, 0.75);
}

@media (max-width: 860px) {
    #achievements-modal .achievements-summary-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    #level-roadmap-modal .level-roadmap-summary-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    #achievements-modal .achievement-history-header {
        flex-direction: column;
        align-items: flex-start;
    }

    #achievements-modal .achievement-history-latest {
        text-align: left;
    }
}

@media (max-width: 620px) {
    #achievements-modal .achievements-modal-content {
        width: min(96vw, 96vw);
        padding: 12px;
        border-radius: 14px;
    }

    #achievements-modal .achievements-summary-grid {
        grid-template-columns: 1fr;
    }

    #achievements-modal .achievement-history-item {
        flex-direction: column;
        align-items: flex-start;
    }

    #achievements-modal .achievement-history-time {
        text-align: left;
        white-space: normal;
    }

    #level-roadmap-modal .level-roadmap-modal-content {
        width: min(96vw, 96vw);
        padding: 12px;
        border-radius: 14px;
    }

    #level-roadmap-modal .level-roadmap-summary-grid {
        grid-template-columns: 1fr;
    }

    #level-roadmap-modal .level-roadmap-card {
        width: 100%;
        grid-template-columns: 1fr;
        row-gap: 10px;
        padding: 12px;
        min-height: 0;
    }

    #level-roadmap-modal .level-roadmap-state {
        position: static;
        transform: none;
        right: auto;
        top: auto;
        justify-self: start;
    }

    #level-roadmap-modal .level-roadmap-main {
        max-width: 100%;
        width: 100%;
        justify-self: start;
    }
}
