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

        :root {
            --bg-deep: #05051a;
            --bg-card: #0a0a2e;
            --bg-elevated: #10103a;
            --bg-input: #08081f;
            --accent-lime: #39ff14;
            --accent-orange: #ff6600;
            --accent-purple: #bf00ff;
            --accent-red: #ff0040;
            --accent-cyan: #00ffff;
            --accent-magenta: #ff00ff;
            --accent-yellow: #ffff00;
            --text-primary: #e0e0ff;
            --text-secondary: #8080b0;
            --text-muted: #4040a0;
            --border: #1a1a5e;
            --pixel-border: 3px solid;
            --pixel-shadow: 4px 4px 0px #000;
            /* Accessibility: font and size tokens */
            --font-body: 'VT323', monospace;
            --font-heading: 'Press Start 2P', cursive;
            --font-size-base: 18px;
        }

        /* Simple font mode */
        html[data-font="simple"] {
            --font-body: 'Inter', system-ui, sans-serif;
            --font-heading: 'Inter', system-ui, sans-serif;
        }

        /* Font size modes */
        html[data-size="small"]  { --font-size-base: 14px; }
        html[data-size="medium"] { --font-size-base: 18px; }
        html[data-size="large"]  { --font-size-base: 20px; }

        /* ── LIGHT THEME OVERRIDES ── */
        html[data-theme="light"] {
            --bg-deep: #f5f0e8;
            --bg-card: #eee8d8;
            --bg-elevated: #faf7f0;
            --bg-input: #e8e3d8;
            --accent-lime: #1a8a0a;
            --accent-orange: #cc5500;
            --accent-purple: #7a0099;
            --accent-red: #cc0033;
            --accent-cyan: #0077aa;
            --accent-magenta: #aa0077;
            --accent-yellow: #b38f00;
            --text-primary: #1a1a2e;
            --text-secondary: #505068;
            --text-muted: #8080a0;
            --border: #c8c0b0;
        }

        /* Size overrides for light mode */
        html[data-theme="light"][data-size="small"]  { --font-size-base: 14px; }
        html[data-theme="light"][data-size="medium"] { --font-size-base: 18px; }
        html[data-theme="light"][data-size="large"]  { --font-size-base: 20px; }

        html { scroll-behavior: smooth; }

        body {
            font-family: var(--font-body);
            background: var(--bg-deep);
            color: var(--text-primary);
            overflow-x: hidden;
            line-height: 1.6;
            min-height: 100vh;
            font-size: var(--font-size-base);
            image-rendering: pixelated;
        }

        /* In simple font mode, drop pixelated rendering and override all retro font references */
        html[data-font="simple"] body { image-rendering: auto; }
        html[data-font="simple"] * { font-family: 'Inter', system-ui, sans-serif !important; letter-spacing: 0 !important; }

        h1, h2, h3, h4 { font-family: var(--font-heading); text-transform: uppercase; }

        /* Simple font: headings scale from base rather than fixed rem */
        html[data-font="simple"] h1 { font-size: clamp(1.6rem, 5vw, 2.8rem); letter-spacing: 0; }
        html[data-font="simple"] h2 { font-size: 1.6rem; letter-spacing: 0; }
        html[data-font="simple"] h3 { font-size: 1.3rem; letter-spacing: 0; }
        html[data-font="simple"] h4 { font-size: 1.1rem; letter-spacing: 0; }

        /* ── RETRO SCANLINE OVERLAY ── */
        body::after {
            content: '';
            position: fixed;
            top: 0; left: 0; width: 100%; height: 100%;
            background: repeating-linear-gradient(
                0deg,
                rgba(0, 0, 0, 0.03) 0px,
                rgba(0, 0, 0, 0.03) 1px,
                transparent 1px,
                transparent 3px
            );
            pointer-events: none;
            z-index: 99999;
        }

        /* ── STARFIELD BACKGROUND ── */
        #starfield-canvas {
            position: fixed;
            top: 0; left: 0; width: 100%; height: 100%;
            z-index: 0;
            pointer-events: none;
        }

        /* Ambient glows - replaced with retro grid */
        .bg-glow, .bg-glow-2 { display: none; }

        .container {
            max-width: 1100px;
            margin: 0 auto;
            padding: 0 24px;
            position: relative;
            z-index: 1;
        }

        /* ── NAV ─────────────────────────────── */
        nav {
            padding: 20px 0;
            display: flex;
            align-items: center;
            justify-content: space-between;
            border-bottom: 3px solid var(--accent-cyan);
            margin-bottom: 8px;
        }
        .logo {
            font-family: 'Press Start 2P', cursive;
            font-size: 0.9rem;
            font-weight: 700;
            color: var(--accent-cyan);
            letter-spacing: 1px;
            display: flex;
            align-items: center;
            gap: 10px;
            cursor: pointer;
            text-shadow: 0 0 10px rgba(0, 255, 255, 0.5), 0 0 20px rgba(0, 255, 255, 0.3);
        }
        .logo-icon {
            width: 32px;
            height: 32px;
            background: var(--accent-magenta);
            border-radius: 0px;
            border: 2px solid var(--accent-cyan);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 16px;
            transform: none;
            box-shadow: 3px 3px 0px #000;
        }
        .nav-links {
            display: flex;
            gap: 20px;
            align-items: center;
        }
        .nav-links a {
            color: var(--accent-yellow);
            text-decoration: none;
            font-size: 0.85rem;
            font-family: 'VT323', monospace;
            transition: color 0.2s;
            text-shadow: 0 0 8px rgba(255, 255, 0, 0.3);
        }
        .nav-links a:hover { color: var(--accent-lime); text-shadow: 0 0 12px rgba(57, 255, 20, 0.5); }

        .btn-nav {
            background: var(--accent-lime);
            color: #000;
            border: none;
            padding: 10px 20px;
            border-radius: 0px;
            font-weight: 700;
            font-size: 0.7rem;
            cursor: pointer;
            font-family: 'Press Start 2P', cursive;
            transition: all 0.2s;
            box-shadow: 4px 4px 0px #000;
            text-transform: uppercase;
            border: 2px solid #000;
        }
        .btn-nav:hover {
            transform: translate(-2px, -2px);
            box-shadow: 6px 6px 0px #000;
        }
        .btn-nav:active {
            transform: translate(2px, 2px);
            box-shadow: 2px 2px 0px #000;
        }

        /* ── SCREENS ─────────────────────────── */
        .screen { display: none; }
        .screen.active { display: block; }

        /* ── HERO (Landing) ──────────────────── */
        .hero {
            padding: 80px 0 60px;
            text-align: center;
        }
        .hero-badge {
            display: inline-flex;
            align-items: center;
            gap: 8px;
            background: var(--bg-elevated);
            border: 2px solid var(--accent-magenta);
            padding: 8px 18px;
            border-radius: 0px;
            font-size: 1rem;
            color: var(--accent-magenta);
            margin-bottom: 32px;
            font-family: 'VT323', monospace;
            box-shadow: 3px 3px 0px #000;
            text-transform: uppercase;
            letter-spacing: 2px;
        }
        .hero-badge .dot {
            width: 8px;
            height: 8px;
            background: var(--accent-lime);
            border-radius: 0px;
            animation: pixel-blink 1s step-end infinite;
        }
        @keyframes pulse-dot {
            0%, 100% { opacity: 1; }
            50% { opacity: 0.4; }
        }
        @keyframes pixel-blink {
            0%, 100% { opacity: 1; }
            50% { opacity: 0; }
        }
        .hero h1 {
            font-size: clamp(1.4rem, 4vw, 2.5rem);
            font-weight: 700;
            line-height: 1.5;
            letter-spacing: 2px;
            margin-bottom: 24px;
            text-shadow: 0 0 20px rgba(0, 255, 255, 0.4), 3px 3px 0px #000;
        }
        .hero h1 .accent-lime { color: var(--accent-lime); text-shadow: 0 0 20px rgba(57, 255, 20, 0.6), 3px 3px 0px #000; }
        .hero h1 .accent-orange { color: var(--accent-yellow); text-shadow: 0 0 20px rgba(255, 255, 0, 0.6), 3px 3px 0px #000; }
        .hero p {
            font-size: 1.3rem;
            color: var(--accent-cyan);
            max-width: 540px;
            margin: 0 auto 48px;
            line-height: 1.7;
            font-family: 'VT323', monospace;
            text-shadow: 0 0 10px rgba(0, 255, 255, 0.3);
        }
        .hero-cta {
            display: flex;
            gap: 16px;
            justify-content: center;
            flex-wrap: wrap;
        }
        .btn-primary {
            background: var(--accent-lime);
            color: #000;
            border: 3px solid #000;
            padding: 16px 32px;
            border-radius: 0px;
            font-weight: 700;
            font-size: 0.75rem;
            cursor: pointer;
            font-family: 'Press Start 2P', cursive;
            transition: all 0.15s;
            letter-spacing: 1px;
            box-shadow: 5px 5px 0px #000;
            text-transform: uppercase;
            animation: pixel-blink-slow 3s step-end infinite;
        }
        @keyframes pixel-blink-slow {
            0%, 90% { opacity: 1; }
            95% { opacity: 0.7; }
        }
        .btn-primary:hover {
            transform: translate(-2px, -2px);
            box-shadow: 7px 7px 0px #000;
        }
        .btn-primary:active {
            transform: translate(3px, 3px);
            box-shadow: 2px 2px 0px #000;
        }
        .btn-secondary {
            background: transparent;
            color: var(--accent-cyan);
            border: 2px solid var(--accent-cyan);
            padding: 16px 32px;
            border-radius: 0px;
            font-weight: 700;
            font-size: 0.75rem;
            cursor: pointer;
            font-family: 'Press Start 2P', cursive;
            transition: all 0.15s;
            box-shadow: 4px 4px 0px #000;
            text-transform: uppercase;
        }
        .btn-secondary:hover {
            background: var(--accent-cyan);
            color: #000;
        }

        /* ── HOW IT WORKS ────────────────────── */
        .how-it-works {
            padding: 80px 0;
        }
        .section-label {
            font-size: 0.7rem;
            text-transform: uppercase;
            letter-spacing: 4px;
            color: var(--accent-magenta);
            margin-bottom: 16px;
            font-weight: 700;
            font-family: 'Press Start 2P', cursive;
            text-shadow: 0 0 10px rgba(255, 0, 255, 0.5);
        }
        .how-it-works h2 {
            font-size: 1.4rem;
            font-weight: 700;
            letter-spacing: 2px;
            margin-bottom: 60px;
            text-shadow: 0 0 15px rgba(0, 255, 255, 0.4), 3px 3px 0px #000;
        }
        .steps-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 24px;
        }
        .step-card {
            background: var(--bg-card);
            border: 3px solid var(--accent-cyan);
            border-radius: 0px;
            padding: 36px 28px;
            transition: all 0.2s;
            position: relative;
            overflow: hidden;
            box-shadow: 5px 5px 0px #000;
        }
        .step-card::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            height: 3px;
            background: var(--accent-magenta);
            opacity: 1;
        }
        .step-card:hover::before { background: var(--accent-lime); }
        .step-card:hover { border-color: var(--accent-lime); transform: translate(-2px, -2px); box-shadow: 7px 7px 0px #000; }
        .step-number {
            font-family: 'Press Start 2P', cursive;
            font-size: 0.7rem;
            color: var(--accent-yellow);
            margin-bottom: 16px;
            font-weight: 600;
            text-shadow: 0 0 8px rgba(255, 255, 0, 0.5);
        }
        .step-card h3 {
            font-size: 0.85rem;
            margin-bottom: 12px;
            letter-spacing: 1px;
            color: var(--accent-cyan);
        }
        .step-card p {
            color: var(--text-secondary);
            font-size: 1.1rem;
            line-height: 1.6;
            font-family: 'VT323', monospace;
        }

        /* ── TIMER PREVIEW ───────────────────── */
        .timer-preview {
            padding: 80px 0;
            text-align: center;
        }
        .timer-demo {
            background: var(--bg-card);
            border: 3px solid var(--accent-magenta);
            border-radius: 0px;
            padding: 60px 40px;
            max-width: 500px;
            margin: 48px auto 0;
            box-shadow: 6px 6px 0px #000, 0 0 30px rgba(255, 0, 255, 0.15);
            position: relative;
        }
        .timer-demo::before {
            content: '[ HIDDEN TIMER ]';
            position: absolute;
            top: -14px;
            left: 50%;
            transform: translateX(-50%);
            background: var(--bg-deep);
            padding: 0 12px;
            font-family: 'Press Start 2P', cursive;
            font-size: 0.55rem;
            color: var(--accent-magenta);
            letter-spacing: 2px;
        }
        .timer-display-demo {
            font-family: 'Press Start 2P', cursive;
            font-size: 2.5rem;
            font-weight: 600;
            color: var(--accent-lime);
            margin-bottom: 16px;
            letter-spacing: 8px;
            animation: timer-flicker 3s infinite;
            text-shadow: 0 0 20px rgba(57, 255, 20, 0.6), 0 0 40px rgba(57, 255, 20, 0.3);
        }
        @keyframes timer-flicker {
            0%, 100% { opacity: 1; }
            48% { opacity: 1; }
            50% { opacity: 0.3; }
            52% { opacity: 1; }
        }
        .timer-subtext {
            color: var(--accent-cyan);
            font-size: 1.1rem;
            font-family: 'VT323', monospace;
            text-shadow: 0 0 8px rgba(0, 255, 255, 0.3);
        }

        /* ═══════════════════════════════════════
           COSMETIC SHOP (Phase 2.3)
           ═══════════════════════════════════════ */

        .shop-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            margin-bottom: 24px;
            gap: 16px;
            flex-wrap: wrap;
        }
        .shop-header h2 {
            font-size: 1.6rem;
            letter-spacing: -0.5px;
            margin: 0;
        }
        .shop-xp-badge {
            display: flex;
            align-items: center;
            gap: 8px;
            background: var(--bg-elevated);
            border: 1px solid rgba(184, 255, 87, 0.3);
            border-radius: 0px;
            padding: 8px 18px;
            font-family: 'Press Start 2P', cursive;
            font-weight: 700;
            font-size: 1rem;
            color: var(--accent-lime);
        }
        .shop-xp-badge span { font-size: 1.05rem; }

        .shop-tabs {
            display: flex;
            gap: 8px;
            margin-bottom: 20px;
            flex-wrap: wrap;
        }
        .shop-tab {
            background: var(--bg-elevated);
            border: 1px solid var(--border);
            color: var(--text-secondary);
            padding: 8px 18px;
            border-radius: 0px;
            font-size: 0.85rem;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.2s;
            font-family: 'Press Start 2P', cursive;
        }
        .shop-tab:hover { border-color: #2a2a3a; color: var(--text-primary); }
        .shop-tab.active {
            background: var(--accent-lime);
            border-color: var(--accent-lime);
            color: #0a0a0f;
        }

        .shop-grid {
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            gap: 12px;
            margin-bottom: 24px;
        }
        @media (min-width: 480px) {
            .shop-grid { grid-template-columns: repeat(3, 1fr); }
        }

        .shop-item {
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 0px;
            padding: 20px 16px;
            text-align: center;
            cursor: pointer;
            transition: all 0.25s;
            position: relative;
            overflow: hidden;
        }
        .shop-item:hover:not(.shop-item--locked) {
            border-color: #2a2a3a;
            transform: translateY(-2px);
            box-shadow: 0 8px 24px rgba(0,0,0,0.3);
        }
        .shop-item.shop-item--owned {
            border-color: rgba(16, 185, 129, 0.35);
            background: rgba(16, 185, 129, 0.04);
        }
        .shop-item.shop-item--equipped {
            border-color: var(--accent-lime);
            background: rgba(184, 255, 87, 0.06);
            box-shadow: 0 0 0 1px rgba(184, 255, 87, 0.2);
        }
        .shop-item.shop-item--locked {
            opacity: 0.45;
            cursor: default;
        }
        .shop-item-emoji {
            font-size: 2.2rem;
            display: block;
            margin-bottom: 10px;
            line-height: 1;
        }
        .shop-item-name {
            font-family: 'Press Start 2P', cursive;
            font-size: 0.82rem;
            font-weight: 600;
            color: var(--text-primary);
            margin-bottom: 6px;
            letter-spacing: -0.2px;
        }
        .shop-item-price {
            font-family: 'Press Start 2P', cursive;
            font-size: 0.78rem;
            font-weight: 600;
            color: var(--accent-lime);
        }
        .shop-item-price.owned { color: #10b981; }
        .shop-item-price.equipped { color: var(--accent-lime); font-weight: 700; }
        .shop-item-price.locked { color: var(--text-muted); }
        .shop-item-badge {
            position: absolute;
            top: 8px;
            right: 8px;
            font-size: 0.68rem;
            font-weight: 700;
            padding: 2px 7px;
            border-radius: 0px;
            font-family: 'Press Start 2P', cursive;
        }
        .shop-item-badge.equipped-badge {
            background: rgba(184, 255, 87, 0.18);
            color: var(--accent-lime);
        }
        .shop-item-badge.owned-badge {
            background: rgba(16, 185, 129, 0.18);
            color: #10b981;
        }

        /* Shop preview panel */
        .shop-preview {
            background: var(--bg-elevated);
            border: 1px solid var(--border);
            border-radius: 0px;
            padding: 24px 20px;
            margin-bottom: 20px;
            display: none;
        }
        .shop-preview.visible { display: flex; gap: 20px; align-items: center; flex-wrap: wrap; }
        .shop-preview-avatar {
            width: 80px;
            height: 105px;
            flex-shrink: 0;
        }
        .shop-preview-info { flex: 1; min-width: 160px; }
        .shop-preview-name {
            font-family: 'Press Start 2P', cursive;
            font-size: 1.1rem;
            font-weight: 700;
            margin-bottom: 4px;
        }
        .shop-preview-desc {
            font-size: 0.85rem;
            color: var(--text-secondary);
            margin-bottom: 14px;
            line-height: 1.5;
        }
        .shop-preview-actions { display: flex; gap: 10px; flex-wrap: wrap; }
        .btn-shop-buy {
            background: var(--accent-lime);
            color: #0a0a0f;
            border: none;
            padding: 10px 24px;
            border-radius: 0px;
            font-weight: 700;
            font-size: 0.9rem;
            cursor: pointer;
            font-family: 'Press Start 2P', cursive;
            transition: all 0.2s;
        }
        .btn-shop-buy:hover { transform: translateY(-1px); box-shadow: 0 4px 16px rgba(184,255,87,0.3); }
        .btn-shop-buy:disabled { opacity: 0.4; cursor: not-allowed; transform: none; box-shadow: none; }
        .btn-shop-equip {
            background: rgba(184, 255, 87, 0.12);
            color: var(--accent-lime);
            border: 1px solid rgba(184, 255, 87, 0.3);
            padding: 10px 24px;
            border-radius: 0px;
            font-weight: 700;
            font-size: 0.9rem;
            cursor: pointer;
            font-family: 'Press Start 2P', cursive;
            transition: all 0.2s;
        }
        .btn-shop-equip:hover { background: rgba(184, 255, 87, 0.2); }
        .btn-shop-unequip {
            background: transparent;
            color: var(--text-muted);
            border: 1px solid var(--border);
            padding: 10px 24px;
            border-radius: 0px;
            font-weight: 600;
            font-size: 0.9rem;
            cursor: pointer;
            font-family: 'Press Start 2P', cursive;
            transition: all 0.2s;
        }
        .btn-shop-unequip:hover { border-color: #2a2a3a; color: var(--text-secondary); }

        .shop-locked-msg {
            font-size: 0.78rem;
            color: var(--text-muted);
            margin-top: 4px;
        }

        .shop-toast {
            position: fixed;
            bottom: 80px;
            left: 50%;
            transform: translateX(-50%) translateY(20px);
            background: var(--bg-elevated);
            border: 1px solid var(--border);
            border-radius: 0px;
            padding: 12px 24px;
            font-size: 0.9rem;
            font-weight: 600;
            color: var(--text-primary);
            z-index: 1000;
            opacity: 0;
            transition: all 0.3s;
            pointer-events: none;
            white-space: nowrap;
        }
        .shop-toast.show {
            opacity: 1;
            transform: translateX(-50%) translateY(0);
        }
        .shop-toast.success { border-color: rgba(16,185,129,0.5); color: #10b981; }
        .shop-toast.warn { border-color: rgba(255,140,66,0.5); color: var(--accent-orange); }

        /* ── FOOTER ──────────────────────────── */
        footer {
            padding: 60px 0 40px;
            border-top: 3px solid var(--accent-cyan);
            text-align: center;
        }
        footer p {
            color: var(--accent-cyan);
            font-size: 1rem;
            font-family: 'VT323', monospace;
            text-shadow: 0 0 8px rgba(0, 255, 255, 0.3);
        }
        footer a {
            color: var(--accent-yellow);
            text-decoration: none;
        }
        footer a:hover { color: var(--accent-lime); }

        /* ═══════════════════════════════════════
           QUEST APP SCREENS
           ═══════════════════════════════════════ */

        .app-wrapper {
            min-height: calc(100vh - 90px);
            display: flex;
            align-items: center;
            justify-content: center;
            padding: 40px 0;
        }

        .quest-panel {
            width: 100%;
            max-width: 560px;
            margin: 0 auto;
        }

        /* ── QUEST FORM ──────────────────────── */
        .quest-form-card {
            background: var(--bg-card);
            border: 3px solid var(--accent-cyan);
            border-radius: 0px;
            padding: 48px 40px;
            box-shadow: 6px 6px 0px #000;
            position: relative;
        }
        .quest-form-card::before {
            content: '[ NEW QUEST ]';
            position: absolute;
            top: -12px;
            left: 20px;
            background: var(--bg-deep);
            padding: 0 10px;
            font-family: 'Press Start 2P', cursive;
            font-size: 0.5rem;
            color: var(--accent-cyan);
            letter-spacing: 2px;
        }
        .quest-form-card h2 {
            font-size: 1.1rem;
            margin-bottom: 8px;
            letter-spacing: 2px;
            color: var(--accent-lime);
            text-shadow: 0 0 10px rgba(57, 255, 20, 0.5);
        }
        .quest-form-card .subtitle {
            color: var(--accent-cyan);
            margin-bottom: 36px;
            font-size: 1.1rem;
            font-family: 'VT323', monospace;
        }
        .form-group {
            margin-bottom: 24px;
        }
        .form-group label {
            display: block;
            font-size: 0.6rem;
            color: var(--accent-yellow);
            margin-bottom: 8px;
            font-weight: 500;
            font-family: 'Press Start 2P', cursive;
            text-transform: uppercase;
            letter-spacing: 1px;
        }
        .form-input {
            width: 100%;
            padding: 16px 20px;
            background: var(--bg-input);
            border: 2px solid var(--accent-cyan);
            border-radius: 0px;
            color: var(--accent-lime);
            font-family: 'VT323', monospace;
            font-size: 1.3rem;
            transition: all 0.2s;
            outline: none;
            box-shadow: inset 3px 3px 0px rgba(0,0,0,0.3);
        }
        .form-input:focus {
            border-color: var(--accent-lime);
            box-shadow: 0 0 15px rgba(57, 255, 20, 0.2), inset 3px 3px 0px rgba(0,0,0,0.3);
        }
        .form-input::placeholder {
            color: var(--text-muted);
        }
        .btn-start {
            width: 100%;
            background: var(--accent-lime);
            color: #000;
            border: 3px solid #000;
            padding: 18px;
            border-radius: 0px;
            font-weight: 700;
            font-size: 0.8rem;
            cursor: pointer;
            font-family: 'Press Start 2P', cursive;
            transition: all 0.15s;
            letter-spacing: 1px;
            position: relative;
            overflow: hidden;
            box-shadow: 5px 5px 0px #000;
            text-transform: uppercase;
        }
        .btn-start:hover {
            transform: translate(-2px, -2px);
            box-shadow: 7px 7px 0px #000;
        }
        .btn-start:active { transform: translate(3px, 3px); box-shadow: 2px 2px 0px #000; }
        .btn-start:disabled {
            opacity: 0.5;
            cursor: not-allowed;
            transform: none;
            box-shadow: 4px 4px 0px #000;
        }

        /* Stats bar below form */
        .session-stats {
            display: flex;
            justify-content: center;
            gap: 40px;
            margin-top: 32px;
            padding-top: 24px;
        }
        .stat-item {
            text-align: center;
        }
        .stat-value {
            font-family: 'Press Start 2P', cursive;
            font-size: 1.6rem;
            font-weight: 700;
            color: var(--text-primary);
        }

        /* ── TIER BADGE ──────────────────────── */
        .tier-badge {
            display: inline-flex;
            align-items: center;
            gap: 8px;
            padding: 8px 16px;
            border-radius: 0px;
            background: var(--bg-elevated);
            border: 2px solid var(--tier-color, var(--text-muted));
            margin-top: 16px;
            box-shadow: 3px 3px 0px #000;
        }
        .tier-badge-icon {
            width: 20px;
            height: 20px;
            border-radius: 0px;
            background: var(--tier-color, var(--text-muted));
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 12px;
        }
        .tier-badge-name {
            font-family: 'Press Start 2P', cursive;
            font-size: 0.9rem;
            font-weight: 600;
            color: var(--tier-color, var(--text-primary));
        }
        .tier-progress-bar {
            width: 200px;
            height: 6px;
            background: var(--bg-input);
            border-radius: 3px;
            overflow: hidden;
            margin-top: 8px;
        }
        .tier-progress-fill {
            height: 100%;
            background: var(--tier-color, var(--accent-lime));
            border-radius: 3px;
            transition: width 0.5s ease;
        }
        .tier-progress-label {
            font-size: 0.75rem;
            color: var(--text-muted);
            margin-top: 4px;
        }

        /* ── TIER UNLOCK CELEBRATION ──────────── */
        .tier-celebration {
            position: fixed;
            top: 0;
            left: 0;
            width: 100vw;
            height: 100vh;
            background: rgba(10, 10, 15, 0.95);
            display: none;
            align-items: center;
            justify-content: center;
            z-index: 9999;
            animation: fadeIn 0.3s ease;
        }
        .tier-celebration.active {
            display: flex;
        }
        .tier-celebration-content {
            text-align: center;
            animation: scaleIn 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
        }
        .tier-celebration-icon {
            width: 80px;
            height: 80px;
            margin: 0 auto 24px;
            border-radius: 0px;
            background: var(--tier-color, var(--accent-lime));
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 40px;
            box-shadow: 0 0 60px var(--tier-color), 6px 6px 0px #000;
            animation: pulse 1s infinite;
            border: 3px solid #000;
        }
        .tier-celebration-title {
            font-family: 'Press Start 2P', cursive;
            font-size: 1.5rem;
            font-weight: 700;
            color: var(--tier-color);
            margin-bottom: 8px;
            text-shadow: 0 0 30px var(--tier-color), 3px 3px 0px #000;
        }
        .tier-celebration-subtitle {
            font-size: 1.2rem;
            color: var(--text-secondary);
        }

        @keyframes fadeIn {
            from { opacity: 0; }
            to { opacity: 1; }
        }
        @keyframes scaleIn {
            from { transform: scale(0.5); opacity: 0; }
            to { transform: scale(1); opacity: 1; }
        }
        @keyframes pulse {
            0%, 100% { transform: scale(1); }
            50% { transform: scale(1.05); }
        }
        .stat-value.xp { color: var(--accent-lime); }
        .stat-label {
            font-size: 0.75rem;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 1.5px;
            margin-top: 4px;
        }

        /* ── ACTIVE QUEST ────────────────────── */
        .active-quest-card {
            background: var(--bg-card);
            border: 3px solid var(--accent-lime);
            border-radius: 0px;
            padding: 48px 40px;
            text-align: center;
            position: relative;
            overflow: hidden;
            box-shadow: 6px 6px 0px #000, 0 0 30px rgba(57, 255, 20, 0.1);
        }
        .active-quest-card::after {
            content: '';
            position: absolute;
            bottom: 0;
            left: 0;
            right: 0;
            height: 4px;
            background: linear-gradient(90deg, var(--accent-cyan), var(--accent-magenta), var(--accent-yellow), var(--accent-lime));
            animation: progress-sweep 4s linear infinite;
        }
        @keyframes progress-sweep {
            0% { transform: translateX(-100%); }
            50% { transform: translateX(0); }
            100% { transform: translateX(100%); }
        }
        .quest-status-badge {
            display: inline-flex;
            align-items: center;
            gap: 8px;
            background: rgba(57, 255, 20, 0.1);
            border: 2px solid var(--accent-lime);
            padding: 6px 16px;
            border-radius: 0px;
            font-size: 0.55rem;
            color: var(--accent-lime);
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 2px;
            margin-bottom: 24px;
            font-family: 'Press Start 2P', cursive;
            box-shadow: 3px 3px 0px #000;
            animation: pixel-blink-slow 3s step-end infinite;
        }
        .quest-status-badge .pulse {
            width: 8px;
            height: 8px;
            background: var(--accent-lime);
            border-radius: 0px;
            animation: pixel-blink 1s step-end infinite;
        }
        .quest-task-name {
            font-size: 1.3rem;
            font-weight: 600;
            margin-bottom: 36px;
            color: var(--accent-cyan);
            letter-spacing: 1px;
            font-family: 'VT323', monospace;
            text-shadow: 0 0 10px rgba(0, 255, 255, 0.4);
        }

        .hidden-timer {
            margin-bottom: 12px;
        }
        .hidden-timer-display {
            font-family: 'Press Start 2P', cursive;
            font-size: 3rem;
            font-weight: 600;
            color: var(--accent-lime);
            letter-spacing: 10px;
            text-shadow: 0 0 30px rgba(57, 255, 20, 0.5), 0 0 60px rgba(57, 255, 20, 0.2);
            animation: timer-glow 2s ease-in-out infinite;
        }
        @keyframes timer-glow {
            0%, 100% { text-shadow: 0 0 30px rgba(57, 255, 20, 0.5), 0 0 60px rgba(57, 255, 20, 0.2); }
            50% { text-shadow: 0 0 50px rgba(57, 255, 20, 0.8), 0 0 100px rgba(57, 255, 20, 0.4); }
        }
        .hidden-timer-label {
            color: var(--accent-yellow);
            font-size: 0.55rem;
            text-transform: uppercase;
            letter-spacing: 3px;
            margin-top: 8px;
            font-family: 'Press Start 2P', cursive;
        }

        .elapsed-section {
            margin: 32px 0;
            padding: 20px;
            background: var(--bg-elevated);
            border-radius: 0px;
            border: 2px solid var(--accent-cyan);
            box-shadow: 4px 4px 0px #000;
        }
        .elapsed-label {
            font-size: 0.5rem;
            color: var(--accent-yellow);
            text-transform: uppercase;
            letter-spacing: 2px;
            margin-bottom: 8px;
            font-family: 'Press Start 2P', cursive;
        }
        .elapsed-time {
            font-family: 'Press Start 2P', cursive;
            font-size: 1.5rem;
            font-weight: 500;
            color: var(--accent-cyan);
            letter-spacing: 4px;
            text-shadow: 0 0 10px rgba(0, 255, 255, 0.4);
        }

        .quest-actions {
            display: flex;
            gap: 12px;
            margin-top: 32px;
        }
        .btn-complete {
            flex: 1;
            background: var(--accent-lime);
            color: #000;
            border: 3px solid #000;
            padding: 18px;
            border-radius: 0px;
            font-weight: 700;
            font-size: 0.75rem;
            cursor: pointer;
            font-family: 'Press Start 2P', cursive;
            transition: all 0.15s;
            box-shadow: 5px 5px 0px #000;
            text-transform: uppercase;
        }
        .btn-complete:hover {
            transform: translate(-2px, -2px);
            box-shadow: 7px 7px 0px #000;
        }
        .btn-abandon {
            background: transparent;
            color: var(--accent-red);
            border: 2px solid var(--accent-red);
            padding: 18px 24px;
            border-radius: 0px;
            font-weight: 600;
            font-size: 0.6rem;
            cursor: pointer;
            font-family: 'Press Start 2P', cursive;
            transition: all 0.15s;
            box-shadow: 4px 4px 0px #000;
            text-transform: uppercase;
        }
        .btn-abandon:hover {
            background: var(--accent-red);
            color: #000;
        }

        /* ── RESULT SCREEN ───────────────────── */
        .result-card {
            background: var(--bg-card);
            border: 3px solid var(--accent-cyan);
            border-radius: 0px;
            padding: 56px 40px;
            text-align: center;
            position: relative;
            overflow: hidden;
            box-shadow: 6px 6px 0px #000;
        }
        .result-card.won { border-color: var(--accent-lime); box-shadow: 6px 6px 0px #000, 0 0 30px rgba(57, 255, 20, 0.15); }
        .result-card.won::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            height: 4px;
            background: var(--accent-lime);
        }
        .result-card.lost { border-color: var(--accent-orange); }
        .result-card.lost::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            height: 4px;
            background: var(--accent-orange);
        }
        /* ── Quest Reaction (Quick Pulse Check) ── */
        .quest-reaction-prompt {
            text-align: center;
            animation: fadeInUp 0.4s ease-out;
        }
        .quest-reaction-label {
            font-size: 0.8rem;
            color: var(--text-secondary);
            margin-bottom: 10px;
            font-family: 'Press Start 2P', cursive;
        }
        .quest-reaction-options {
            display: flex;
            justify-content: center;
            gap: 16px;
        }
        .quest-reaction-btn {
            font-size: 1.8rem;
            background: rgba(255,255,255,0.05);
            border: 2px solid var(--border-color);
            border-radius: 12px;
            padding: 8px 14px;
            cursor: pointer;
            transition: all 0.15s ease;
        }
        .quest-reaction-btn:hover {
            background: rgba(255,255,255,0.12);
            border-color: var(--accent-lime);
            transform: scale(1.1);
        }
        .quest-reaction-btn.selected {
            background: rgba(184,255,87,0.15);
            border-color: var(--accent-lime);
            animation: reactionBounce 0.3s ease;
        }
        @keyframes reactionBounce {
            0% { transform: scale(1); }
            50% { transform: scale(1.25); }
            100% { transform: scale(1); }
        }
        @keyframes fadeInUp {
            from { opacity: 0; transform: translateY(10px); }
            to { opacity: 1; transform: translateY(0); }
        }
        /* ── Subscriber Prompt ── */
        .subscriber-prompt {
            margin-top: 24px;
            padding: 16px;
            background: rgba(57, 255, 20, 0.08);
            border: 2px dashed var(--accent-lime);
            border-radius: 12px;
            text-align: center;
        }
        .subscriber-prompt-title {
            font-size: 0.9rem;
            font-weight: bold;
            color: var(--text-primary);
            margin-bottom: 8px;
        }
        .subscriber-prompt-text {
            font-size: 0.8rem;
            color: var(--text-secondary);
            margin-bottom: 12px;
        }
        .subscriber-form {
            display: flex;
            gap: 8px;
            justify-content: center;
            flex-wrap: wrap;
        }
        .subscriber-input {
            flex: 1;
            min-width: 140px;
            max-width: 200px;
            padding: 8px 12px;
            font-size: 0.85rem;
            border: 2px solid var(--border-color);
            border-radius: 8px;
            background: var(--bg-card);
            color: var(--text-primary);
        }
        .subscriber-input:focus {
            outline: none;
            border-color: var(--accent-lime);
        }
        .subscriber-btn {
            padding: 8px 16px;
            font-size: 0.85rem;
            font-weight: bold;
            background: var(--accent-lime);
            color: #000;
            border: 2px solid #000;
            border-radius: 8px;
            cursor: pointer;
            box-shadow: 3px 3px 0px #000;
            transition: transform 0.1s, box-shadow 0.1s;
        }
        .subscriber-btn:hover {
            transform: translate(-1px, -1px);
            box-shadow: 4px 4px 0px #000;
        }
        .subscriber-btn:active {
            transform: translate(2px, 2px);
            box-shadow: 1px 1px 0px #000;
        }
        .subscriber-btn:disabled {
            opacity: 0.6;
            cursor: not-allowed;
        }
        .subscriber-dismiss {
            display: block;
            margin-top: 8px;
            font-size: 0.75rem;
            color: var(--text-secondary);
            background: none;
            border: none;
            cursor: pointer;
            text-decoration: underline;
        }
        .subscriber-dismiss:hover {
            color: var(--text-primary);
        }
        .subscriber-success {
            color: var(--accent-lime);
            font-weight: bold;
            font-size: 0.9rem;
        }
        .result-emoji {
            font-size: 4rem;
            margin-bottom: 16px;
            animation: result-bounce 0.6s ease-out;
        }
        @keyframes result-bounce {
            0% { transform: scale(0); }
            50% { transform: scale(1.3); }
            100% { transform: scale(1); }
        }
        .result-title {
            font-size: 1.2rem;
            font-weight: 700;
            margin-bottom: 8px;
            letter-spacing: 2px;
        }
        .result-title.won { color: var(--accent-lime); text-shadow: 0 0 20px rgba(57, 255, 20, 0.6); }
        .result-title.lost { color: var(--accent-orange); text-shadow: 0 0 20px rgba(255, 102, 0, 0.6); }
        .result-subtitle {
            color: var(--text-secondary);
            margin-bottom: 40px;
            font-size: 1rem;
        }

        .result-stats {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 16px;
            margin-bottom: 40px;
        }
        .result-stat {
            background: var(--bg-elevated);
            border-radius: 0px;
            padding: 20px 16px;
            border: 2px solid var(--accent-cyan);
            box-shadow: 3px 3px 0px #000;
        }
        .result-stat-value {
            font-family: 'Press Start 2P', cursive;
            font-size: 1.5rem;
            font-weight: 700;
            color: var(--text-primary);
            margin-bottom: 4px;
        }
        .result-stat-value.xp { color: var(--accent-lime); }
        .result-stat-label {
            font-size: 0.7rem;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 1.5px;
        }

        .result-timer-reveal {
            background: var(--bg-elevated);
            border-radius: 0px;
            padding: 24px;
            margin-bottom: 36px;
            border: 2px solid var(--accent-magenta);
            box-shadow: 4px 4px 0px #000;
        }
        .reveal-label {
            font-size: 0.75rem;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 1.5px;
            margin-bottom: 8px;
        }
        .reveal-time {
            font-family: 'Press Start 2P', cursive;
            font-size: 2.5rem;
            font-weight: 600;
            letter-spacing: 4px;
            animation: reveal-appear 0.8s ease-out;
        }
        .reveal-time.won { color: var(--accent-lime); text-shadow: 0 0 20px rgba(57, 255, 20, 0.6); }
        .reveal-time.lost { color: var(--accent-orange); text-shadow: 0 0 20px rgba(255, 102, 0, 0.6); }
        @keyframes reveal-appear {
            0% { opacity: 0; filter: blur(10px); }
            100% { opacity: 1; filter: blur(0); }
        }

        .btn-again {
            width: 100%;
            background: var(--accent-lime);
            color: #000;
            border: 3px solid #000;
            padding: 18px;
            border-radius: 0px;
            font-weight: 700;
            font-size: 0.7rem;
            cursor: pointer;
            font-family: 'Press Start 2P', cursive;
            transition: all 0.15s;
            box-shadow: 5px 5px 0px #000;
            text-transform: uppercase;
        }
        .btn-again:hover {
            transform: translate(-2px, -2px);
            box-shadow: 7px 7px 0px #000;
        }

        /* ── SHARE WIN BUTTON ────────────────── */
        .btn-share-win {
            width: 100%;
            background: transparent;
            color: var(--accent-cyan);
            border: 3px solid var(--accent-cyan);
            padding: 16px 18px;
            border-radius: 0px;
            font-family: 'Press Start 2P', cursive;
            font-size: 0.65rem;
            cursor: pointer;
            text-transform: uppercase;
            letter-spacing: 1px;
            margin-bottom: 12px;
            box-shadow: 4px 4px 0px #000, 0 0 12px rgba(0,255,255,0.1);
            text-shadow: 0 0 10px rgba(0,255,255,0.5);
            transition: all 0.12s;
        }
        .btn-share-win:hover {
            background: rgba(0,255,255,0.08);
            box-shadow: 5px 5px 0px #000, 0 0 22px rgba(0,255,255,0.25);
            transform: translate(-1px, -1px);
        }
        .btn-share-win:active {
            transform: translate(2px, 2px);
            box-shadow: 2px 2px 0px #000;
        }
        .btn-share-win:disabled {
            opacity: 0.55;
            cursor: default;
            transform: none;
        }

        /* ── QUEST HISTORY ───────────────────── */
        .history-section {
            margin-top: 32px;
        }
        .history-toggle {
            background: transparent;
            border: 1px solid var(--border);
            color: var(--text-muted);
            padding: 10px 20px;
            border-radius: 0px;
            cursor: pointer;
            font-family: 'VT323', monospace;
            font-size: 0.85rem;
            width: 100%;
            transition: all 0.2s;
        }
        .history-toggle:hover { color: var(--text-secondary); border-color: #2a2a3a; }
        .history-list {
            margin-top: 16px;
            display: none;
        }
        .history-list.open { display: block; }
        .history-item {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 14px 16px;
            background: var(--bg-card);
            border: 2px solid var(--border);
            border-radius: 0px;
            margin-bottom: 8px;
            transition: all 0.2s;
            box-shadow: 3px 3px 0px #000;
        }
        .history-item:hover { border-color: var(--accent-cyan); }
        .history-task {
            font-size: 0.9rem;
            color: var(--text-primary);
            flex: 1;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
            margin-right: 16px;
        }
        .history-meta {
            display: flex;
            align-items: center;
            gap: 12px;
            flex-shrink: 0;
        }
        .history-xp {
            font-family: 'Press Start 2P', cursive;
            font-size: 0.8rem;
            color: var(--accent-lime);
            font-weight: 600;
        }
        .history-badge {
            font-size: 0.7rem;
            padding: 3px 10px;
            border-radius: 0px;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }
        .history-badge.completed {
            background: rgba(184, 255, 87, 0.1);
            color: var(--accent-lime);
        }
        .history-badge.expired {
            background: rgba(255, 140, 66, 0.1);
            color: var(--accent-orange);
        }
        .history-badge.abandoned {
            background: rgba(85, 85, 106, 0.2);
            color: var(--text-muted);
        }
        .history-delete-btn {
            background: transparent;
            border: none;
            cursor: pointer;
            color: var(--text-muted);
            padding: 4px 6px;
            border-radius: 0px;
            font-size: 0.85rem;
            line-height: 1;
            transition: all 0.15s;
            flex-shrink: 0;
            opacity: 0;
        }
        .history-item:hover .history-delete-btn { opacity: 1; }
        .history-delete-btn:hover { color: var(--accent-red); background: rgba(255, 71, 87, 0.1); }
        .history-reset-row {
            display: flex;
            justify-content: flex-end;
            margin-top: 8px;
        }
        .history-reset-btn {
            background: transparent;
            border: none;
            cursor: pointer;
            color: var(--text-muted);
            font-size: 0.8rem;
            font-family: 'VT323', monospace;
            padding: 6px 10px;
            border-radius: 0px;
            transition: all 0.15s;
        }
        .history-reset-btn:hover { color: var(--accent-red); background: rgba(255, 71, 87, 0.08); }

        /* ── ACCESSIBILITY SETTINGS PANEL ────── */
        .a11y-btn {
            background: transparent;
            border: 2px solid var(--text-muted);
            color: var(--text-secondary);
            cursor: pointer;
            font-size: 1rem;
            padding: 6px 10px;
            border-radius: 0px;
            transition: all 0.15s;
            line-height: 1;
        }
        .a11y-btn:hover { border-color: var(--accent-cyan); color: var(--accent-cyan); }

        .a11y-panel {
            display: none;
            position: absolute;
            top: calc(100% + 8px);
            right: 0;
            background: var(--bg-card);
            border: 2px solid var(--accent-cyan);
            box-shadow: 4px 4px 0px #000;
            padding: 16px;
            z-index: 9998;
            min-width: 220px;
        }
        .a11y-panel.open { display: block; }

        .a11y-panel-title {
            font-family: var(--font-heading);
            font-size: 0.5rem;
            color: var(--accent-cyan);
            margin-bottom: 12px;
            letter-spacing: 1px;
        }

        .a11y-row {
            display: flex;
            align-items: center;
            justify-content: space-between;
            margin-bottom: 14px;
            gap: 8px;
        }
        .a11y-label {
            font-family: var(--font-body);
            font-size: 0.95rem;
            color: var(--text-secondary);
            white-space: nowrap;
        }
        /* Font toggle switch */
        .font-switch {
            position: relative;
            width: 44px;
            height: 24px;
            flex-shrink: 0;
        }
        .font-switch input { opacity: 0; width: 0; height: 0; }
        .font-switch-track {
            position: absolute;
            inset: 0;
            background: var(--bg-elevated);
            border: 2px solid var(--text-muted);
            cursor: pointer;
            transition: 0.2s;
        }
        .font-switch-track::after {
            content: '';
            position: absolute;
            top: 2px; left: 2px;
            width: 14px; height: 14px;
            background: var(--text-muted);
            transition: 0.2s;
        }
        .font-switch input:checked + .font-switch-track {
            border-color: var(--accent-lime);
        }
        .font-switch input:checked + .font-switch-track::after {
            transform: translateX(20px);
            background: var(--accent-lime);
        }

        /* Size buttons */
        .size-btns { display: flex; gap: 4px; }
        .size-btn {
            background: var(--bg-elevated);
            border: 2px solid var(--text-muted);
            color: var(--text-secondary);
            cursor: pointer;
            padding: 4px 10px;
            font-family: var(--font-body);
            font-size: 0.85rem;
            transition: all 0.15s;
            border-radius: 0px;
        }
        .size-btn:hover { border-color: var(--accent-cyan); color: var(--accent-cyan); }
        .size-btn.active {
            border-color: var(--accent-lime);
            color: var(--accent-lime);
            background: rgba(57, 255, 20, 0.1);
        }

        /* Theme toggle */
        .theme-toggle-btn {
            background: transparent;
            border: none;
            cursor: pointer;
            font-size: 1.2rem;
            padding: 4px;
            line-height: 1;
            transition: color 0.15s;
        }
        .theme-toggle-btn .icon-moon { color: var(--text-muted); }
        .theme-toggle-btn .icon-sun { color: var(--accent-yellow); }
        .theme-toggle-btn:hover { opacity: 0.8; }

        /* Nav wrapper needs relative positioning for panel */
        .nav-a11y-wrap {
            position: relative;
            display: flex;
            align-items: center;
        }

        /* ── MOBILE ──────────────────────────── */
        @media (max-width: 768px) {
            .nav-links a:not(.btn-nav) { display: none; }
            .hero h1 { font-size: 1.1rem; letter-spacing: 1px; }
            .hero p { font-size: 1rem; }
            .steps-grid { grid-template-columns: 1fr; }
            .quest-form-card, .active-quest-card, .result-card { padding: 30px 20px; }
            .hidden-timer-display { font-size: 2rem; letter-spacing: 4px; }
            .elapsed-time { font-size: 1rem; }
            .result-stats { grid-template-columns: repeat(3, 1fr); gap: 8px; }
            .result-stat { padding: 14px 8px; }
            .result-stat-value { font-size: 0.8rem; }
            .quest-actions { flex-direction: column; }
            .hero-cta { flex-direction: column; align-items: center; }
            .btn-primary, .btn-secondary { width: 100%; max-width: 320px; }
            .btn-nav { font-size: 0.55rem; padding: 8px 14px; }
            .logo { font-size: 0.7rem; }
            /* Social proof grid on mobile */
            [style*="grid-template-columns: repeat(3, 1fr)"] {
                grid-template-columns: 1fr !important;
            }
        }

        /* ── CLARIFY SCREEN ──────────────────── */
        .clarify-card {
            background: var(--bg-card);
            border: 3px solid var(--accent-magenta);
            border-radius: 0px;
            padding: 48px 40px;
            position: relative;
            overflow: hidden;
            box-shadow: 6px 6px 0px #000;
        }
        .clarify-card::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            height: 4px;
            background: linear-gradient(90deg, var(--accent-lime), var(--accent-cyan), var(--accent-magenta));
        }
        .clarify-header {
            text-align: center;
            margin-bottom: 36px;
        }
        .clarify-header h2 {
            font-size: 1.5rem;
            margin-bottom: 6px;
            letter-spacing: -0.3px;
        }
        .clarify-header p {
            color: var(--text-secondary);
            font-size: 0.9rem;
        }
        .clarify-task-badge {
            display: inline-flex;
            align-items: center;
            gap: 8px;
            background: var(--bg-elevated);
            border: 1px solid var(--border);
            padding: 8px 18px;
            border-radius: 0px;
            font-size: 0.85rem;
            color: var(--accent-lime);
            margin-bottom: 20px;
            font-weight: 500;
            max-width: 100%;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }
        .clarify-question {
            margin-bottom: 28px;
            animation: fadeIn 0.4s ease-out both;
        }
        .clarify-question:nth-child(2) { animation-delay: 0.1s; }
        .clarify-question:nth-child(3) { animation-delay: 0.2s; }
        .clarify-question-label {
            font-size: 1.05rem;
            font-weight: 600;
            color: var(--text-primary);
            margin-bottom: 12px;
            font-family: 'Press Start 2P', cursive;
        }
        .clarify-options {
            display: flex;
            gap: 10px;
            flex-wrap: wrap;
        }
        .clarify-option {
            background: var(--bg-input);
            border: 2px solid var(--accent-cyan);
            border-radius: 0px;
            padding: 12px 20px;
            color: var(--accent-cyan);
            font-family: 'VT323', monospace;
            font-size: 1.1rem;
            font-weight: 500;
            cursor: pointer;
            transition: all 0.15s;
            flex: 1;
            min-width: 100px;
            text-align: center;
            box-shadow: 3px 3px 0px #000;
        }
        .clarify-option:hover {
            border-color: var(--accent-lime);
            color: var(--accent-lime);
            background: rgba(57, 255, 20, 0.05);
            transform: translate(-1px, -1px);
            box-shadow: 4px 4px 0px #000;
        }
        .clarify-option.selected {
            border-color: var(--accent-lime);
            background: rgba(57, 255, 20, 0.15);
            color: var(--accent-lime);
            font-weight: 600;
        }
        .clarify-actions {
            display: flex;
            gap: 12px;
            margin-top: 36px;
        }
        .btn-clarify-go {
            flex: 1;
            background: var(--accent-lime);
            color: #0a0a0f;
            border: none;
            padding: 18px;
            border-radius: 0px;
            font-weight: 700;
            font-size: 1.1rem;
            cursor: pointer;
            font-family: 'Press Start 2P', cursive;
            transition: all 0.25s;
        }
        .btn-clarify-go:hover {
            transform: translateY(-2px);
            box-shadow: 0 8px 30px rgba(184, 255, 87, 0.3);
        }
        .btn-clarify-go:disabled {
            opacity: 0.5;
            cursor: not-allowed;
            transform: none;
            box-shadow: none;
        }
        .btn-skip {
            background: transparent;
            color: var(--text-muted);
            border: 1px solid var(--border);
            padding: 18px 24px;
            border-radius: 0px;
            font-weight: 600;
            font-size: 0.95rem;
            cursor: pointer;
            font-family: 'Press Start 2P', cursive;
            transition: all 0.2s;
            white-space: nowrap;
        }
        .btn-skip:hover {
            border-color: var(--text-muted);
            color: var(--text-secondary);
        }

        /* Loading dots animation */
        .clarify-loading {
            text-align: center;
            padding: 60px 20px;
        }
        .clarify-loading p {
            color: var(--text-secondary);
            font-size: 1rem;
            margin-bottom: 20px;
        }
        .loading-dots {
            display: inline-flex;
            gap: 6px;
        }
        .loading-dots span {
            width: 8px;
            height: 8px;
            background: var(--accent-lime);
            border-radius: 50%;
            animation: dotBounce 1.2s ease-in-out infinite;
        }
        .loading-dots span:nth-child(2) { animation-delay: 0.15s; }
        .loading-dots span:nth-child(3) { animation-delay: 0.3s; }
        @keyframes dotBounce {
            0%, 80%, 100% { transform: scale(0.6); opacity: 0.4; }
            40% { transform: scale(1); opacity: 1; }
        }

        @media (max-width: 768px) {
            .clarify-card { padding: 36px 24px; }
            .clarify-options { flex-direction: column; }
            .clarify-option { min-width: auto; }
            .clarify-actions { flex-direction: column; }
        }

        /* ══════════════════════════════════════
           QUEST BOARD
           ══════════════════════════════════════ */

        /* Tag Colors */
        .tag-work     { --tag-bg: rgba(59,130,246,0.22); --tag-border: rgba(59,130,246,0.6); --tag-text: #60a5fa; }
        .tag-personal { --tag-bg: rgba(167,139,250,0.22); --tag-border: rgba(167,139,250,0.6); --tag-text: #c4b5fd; }
        .tag-chores   { --tag-bg: rgba(245,158,11,0.22); --tag-border: rgba(245,158,11,0.6); --tag-text: #fbbf24; }
        .tag-study    { --tag-bg: rgba(16,185,129,0.22); --tag-border: rgba(16,185,129,0.6); --tag-text: #34d399; }
        .tag-health   { --tag-bg: rgba(244,63,94,0.22); --tag-border: rgba(244,63,94,0.6); --tag-text: #fb7185; }

        /* Board layout */
        .board-wrapper {
            min-height: calc(100vh - 90px);
            padding: 32px 0 60px;
        }
        .board-panel {
            width: 100%;
            max-width: 640px;
            margin: 0 auto;
        }
        .board-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            margin-bottom: 24px;
        }
        .board-header h2 {
            font-size: 1.8rem;
            letter-spacing: -0.5px;
        }
        .board-count-badge {
            background: var(--bg-elevated);
            border: 1px solid var(--border);
            padding: 4px 14px;
            border-radius: 0px;
            font-family: 'Press Start 2P', cursive;
            font-size: 0.85rem;
            color: var(--text-secondary);
        }

        /* Add Quest Form */
        .board-add-card {
            background: var(--bg-card);
            border: 3px solid var(--accent-cyan);
            border-radius: 0px;
            padding: 24px;
            margin-bottom: 20px;
            transition: border-color 0.2s;
            box-shadow: 5px 5px 0px #000;
        }
        .board-add-card:focus-within {
            border-color: var(--accent-lime);
        }
        .board-add-title {
            font-size: 0.75rem;
            text-transform: uppercase;
            letter-spacing: 2px;
            color: var(--accent-lime);
            font-weight: 600;
            margin-bottom: 14px;
        }
        .board-add-input {
            width: 100%;
            padding: 14px 18px;
            background: var(--bg-input);
            border: 2px solid var(--accent-cyan);
            border-radius: 0px;
            color: var(--accent-lime);
            font-family: 'VT323', monospace;
            font-size: 1.2rem;
            transition: all 0.2s;
            outline: none;
            margin-bottom: 14px;
            box-shadow: inset 3px 3px 0px rgba(0,0,0,0.3);
        }
        .board-add-input:focus {
            border-color: var(--accent-lime);
            box-shadow: 0 0 10px rgba(57, 255, 20, 0.2), inset 3px 3px 0px rgba(0,0,0,0.3);
        }
        .board-add-input::placeholder { color: var(--text-muted); }

        /* Tag picker */
        .board-tags-row {
            display: flex;
            gap: 8px;
            flex-wrap: wrap;
            margin-bottom: 14px;
            align-items: center;
        }
        .tag-row-label {
            font-size: 0.8rem;
            color: var(--text-muted);
            margin-right: 4px;
            white-space: nowrap;
            flex-shrink: 0;
        }
        .tag-btn {
            background: var(--tag-bg);
            border: 1.5px solid var(--tag-border);
            color: var(--tag-text);
            padding: 6px 14px;
            border-radius: 0px;
            font-size: 0.82rem;
            font-weight: 600;
            cursor: pointer;
            font-family: 'VT323', monospace;
            transition: all 0.15s;
            opacity: 0.85;
        }
        .tag-btn:hover { opacity: 1; transform: translateY(-1px); }
        .tag-btn.active { opacity: 1; box-shadow: 0 0 0 2px var(--tag-text); }

        /* Energy picker */
        .energy-row {
            display: flex;
            gap: 8px;
            margin-bottom: 16px;
            align-items: center;
        }
        .energy-label {
            font-size: 0.8rem;
            color: var(--text-muted);
            margin-right: 4px;
        }
        .energy-btn {
            background: var(--bg-elevated);
            border: 1.5px solid #2a2a40;
            color: var(--text-primary);
            padding: 6px 14px;
            border-radius: 0px;
            font-size: 0.82rem;
            font-weight: 600;
            cursor: pointer;
            font-family: 'VT323', monospace;
            transition: all 0.15s;
            opacity: 0.85;
        }
        .energy-btn:hover { border-color: var(--text-muted); color: var(--text-primary); opacity: 1; transform: translateY(-1px); }
        .energy-btn.active.energy-low    { border-color: #10b981; color: #10b981; background: rgba(16,185,129,0.1); }
        .energy-btn.active.energy-medium { border-color: #f59e0b; color: #f59e0b; background: rgba(245,158,11,0.1); }
        .energy-btn.active.energy-high   { border-color: #ef4444; color: #ef4444; background: rgba(239,68,68,0.1); }

        .btn-add-to-board {
            width: 100%;
            background: var(--accent-lime);
            color: #0a0a0f;
            border: none;
            padding: 14px;
            border-radius: 0px;
            font-weight: 700;
            font-size: 1rem;
            cursor: pointer;
            font-family: 'Press Start 2P', cursive;
            transition: all 0.2s;
        }
        .btn-add-to-board:hover {
            transform: translateY(-1px);
            box-shadow: 0 6px 20px rgba(184, 255, 87, 0.25);
        }
        .btn-add-to-board:disabled { opacity: 0.4; cursor: not-allowed; transform: none; box-shadow: none; }

        /* Board items list */
        .board-list {
            display: flex;
            flex-direction: column;
            gap: 10px;
        }

        /* Empty state */
        .board-empty {
            text-align: center;
            padding: 60px 20px;
            background: var(--bg-card);
            border: 1px dashed var(--border);
            border-radius: 0px;
        }
        .board-empty-icon { font-size: 3rem; margin-bottom: 16px; }
        .board-empty h3 {
            font-size: 1.2rem;
            margin-bottom: 8px;
            color: var(--text-primary);
            letter-spacing: -0.3px;
        }
        .board-empty p {
            color: var(--text-muted);
            font-size: 0.9rem;
            max-width: 300px;
            margin: 0 auto;
        }

        /* Board item card */
        .board-item {
            background: var(--bg-card);
            border: 2px solid var(--border);
            border-radius: 0px;
            padding: 18px 20px;
            display: flex;
            align-items: center;
            gap: 14px;
            transition: all 0.15s;
            animation: fadeIn 0.3s ease-out;
            box-shadow: 4px 4px 0px #000;
        }
        .board-item:hover { border-color: var(--accent-cyan); transform: translate(-1px, -1px); box-shadow: 5px 5px 0px #000; }

        .board-item-info { flex: 1; min-width: 0; }
        .board-item-name {
            font-size: 0.98rem;
            font-weight: 500;
            color: var(--text-primary);
            margin-bottom: 8px;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }
        .board-item-meta {
            display: flex;
            align-items: center;
            gap: 8px;
        }
        .board-tag-pill {
            background: var(--tag-bg);
            border: 1.5px solid var(--tag-border);
            color: var(--tag-text);
            padding: 3px 10px;
            border-radius: 0px;
            font-size: 0.78rem;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }
        .board-energy-pill {
            font-size: 0.8rem;
            color: var(--text-muted);
            display: flex;
            align-items: center;
            gap: 3px;
        }

        /* Board item actions */
        .board-item-actions {
            display: flex;
            align-items: center;
            gap: 8px;
            flex-shrink: 0;
        }
        .btn-board-start {
            background: var(--accent-lime);
            color: #000;
            border: 2px solid #000;
            padding: 9px 16px;
            border-radius: 0px;
            font-weight: 700;
            font-size: 0.6rem;
            cursor: pointer;
            font-family: 'Press Start 2P', cursive;
            transition: all 0.15s;
            white-space: nowrap;
            box-shadow: 3px 3px 0px #000;
            text-transform: uppercase;
        }
        .btn-board-start:hover {
            transform: translate(-1px, -1px);
            box-shadow: 4px 4px 0px #000;
        }
        .btn-board-delete {
            background: transparent;
            border: 2px solid var(--accent-red);
            color: var(--accent-red);
            width: 34px;
            height: 34px;
            border-radius: 0px;
            cursor: pointer;
            font-size: 1rem;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: all 0.15s;
            padding: 0;
            box-shadow: 3px 3px 0px #000;
        }
        .btn-board-delete:hover {
            background: var(--accent-red);
            color: #000;
        }

        /* Back link */
        .board-back-btn {
            background: transparent;
            border: none;
            color: var(--text-muted);
            font-size: 0.85rem;
            cursor: pointer;
            font-family: 'VT323', monospace;
            padding: 0;
            display: flex;
            align-items: center;
            gap: 6px;
            margin-bottom: 24px;
            transition: color 0.2s;
        }
        .board-back-btn:hover { color: var(--text-primary); }

        @media (max-width: 768px) {
            .board-item { flex-direction: column; align-items: flex-start; }
            .board-item-actions { width: 100%; justify-content: flex-end; }
            .btn-board-start { flex: 1; }
            .board-tags-row { gap: 6px; }
        }

        /* ── TRANSITIONS ─────────────────────── */
        .fade-in {
            animation: fadeIn 0.4s ease-out;
        }
        @keyframes fadeIn {
            from { opacity: 0; transform: translateY(12px); }
            to { opacity: 1; transform: translateY(0); }
        }

        /* ══════════════════════════════════════
           TODAY VIEW
           ══════════════════════════════════════ */

        .today-wrapper {
            min-height: calc(100vh - 90px);
            padding: 32px 0 60px;
        }
        .today-panel {
            width: 100%;
            max-width: 640px;
            margin: 0 auto;
        }
        .today-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            margin-bottom: 8px;
        }
        .today-header h2 { font-size: 1.8rem; letter-spacing: -0.5px; }

        .today-progress-row {
            display: flex;
            align-items: center;
            justify-content: space-between;
            margin-bottom: 10px;
        }
        .today-progress-badge {
            background: rgba(184,255,87,0.1);
            border: 1px solid rgba(184,255,87,0.25);
            padding: 5px 14px;
            border-radius: 0px;
            font-family: 'Press Start 2P', cursive;
            font-size: 0.82rem;
            color: var(--accent-lime);
            font-weight: 600;
        }
        .today-bar-track {
            height: 4px;
            background: var(--bg-elevated);
            border-radius: 2px;
            margin-bottom: 22px;
            overflow: hidden;
        }
        .today-bar-fill {
            height: 100%;
            background: var(--accent-lime);
            border-radius: 2px;
            transition: width 0.5s ease;
        }

        /* Empty state */
        .today-empty {
            text-align: center;
            padding: 60px 20px;
            background: var(--bg-card);
            border: 1px dashed var(--border);
            border-radius: 0px;
            margin-bottom: 20px;
        }
        .today-empty-icon { font-size: 3rem; margin-bottom: 16px; }
        .today-empty h3 { font-size: 1.2rem; margin-bottom: 8px; color: var(--text-primary); letter-spacing: -0.3px; }
        .today-empty p { color: var(--text-muted); font-size: 0.9rem; max-width: 320px; margin: 0 auto 24px; }

        /* Today item */
        .today-item {
            background: var(--bg-card);
            border: 2px solid var(--border);
            border-radius: 0px;
            padding: 18px 20px;
            display: flex;
            align-items: center;
            gap: 14px;
            transition: all 0.15s;
            animation: fadeIn 0.3s ease-out;
            margin-bottom: 10px;
            box-shadow: 4px 4px 0px #000;
        }
        .today-item:hover { border-color: var(--accent-cyan); }
        .today-item.done { opacity: 0.5; border-style: dashed; }
        .today-item.done .today-item-name { text-decoration: line-through; color: var(--text-muted); }
        .today-item-order {
            font-family: 'Press Start 2P', cursive;
            font-size: 0.82rem;
            color: var(--accent-lime);
            font-weight: 700;
            width: 22px;
            text-align: center;
            flex-shrink: 0;
        }
        .today-item-info { flex: 1; min-width: 0; }
        .today-item-name {
            font-size: 0.98rem;
            font-weight: 500;
            color: var(--text-primary);
            margin-bottom: 6px;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }
        .today-item-meta { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

        .today-item-actions {
            display: flex;
            align-items: center;
            gap: 6px;
            flex-shrink: 0;
        }
        .btn-today-reorder {
            background: transparent;
            border: 1px solid var(--border);
            color: var(--text-muted);
            width: 30px; height: 30px;
            border-radius: 0px;
            cursor: pointer;
            font-size: 0.85rem;
            display: flex; align-items: center; justify-content: center;
            transition: all 0.2s;
            padding: 0;
        }
        .btn-today-reorder:hover:not(:disabled) { border-color: var(--text-muted); color: var(--text-primary); }
        .btn-today-reorder:disabled { opacity: 0.2; cursor: not-allowed; }
        .btn-today-remove {
            background: transparent;
            border: 1px solid var(--border);
            color: var(--text-muted);
            width: 30px; height: 30px;
            border-radius: 0px;
            cursor: pointer;
            font-size: 0.85rem;
            display: flex; align-items: center; justify-content: center;
            transition: all 0.2s;
            padding: 0;
        }
        .btn-today-remove:hover { border-color: var(--accent-red); color: var(--accent-red); background: rgba(255,71,87,0.08); }

        /* Today CTAs */
        .today-cta-area { margin-top: 24px; display: flex; flex-direction: column; gap: 12px; }
        .btn-begin-raid {
            width: 100%;
            background: var(--accent-lime);
            color: #000;
            border: 3px solid #000;
            padding: 18px;
            border-radius: 0px;
            font-weight: 700;
            font-size: 0.8rem;
            cursor: pointer;
            font-family: 'Press Start 2P', cursive;
            transition: all 0.15s;
            letter-spacing: 1px;
            box-shadow: 5px 5px 0px #000;
            text-transform: uppercase;
        }
        .btn-begin-raid:hover { transform: translate(-2px, -2px); box-shadow: 7px 7px 0px #000; }
        .btn-begin-raid:disabled { opacity: 0.4; cursor: not-allowed; transform: none; box-shadow: 4px 4px 0px #000; }

        .today-secondary-actions { display: flex; gap: 10px; }
        .btn-today-secondary {
            flex: 1;
            background: transparent;
            color: var(--text-muted);
            border: 1px solid var(--border);
            padding: 12px;
            border-radius: 0px;
            font-size: 0.85rem;
            font-weight: 600;
            cursor: pointer;
            font-family: 'VT323', monospace;
            transition: all 0.2s;
        }
        .btn-today-secondary:hover { border-color: #2a2a3a; color: var(--text-secondary); }

        /* Add to today inline form */
        .today-add-row { display: flex; gap: 10px; margin-bottom: 20px; }
        .today-add-input {
            flex: 1;
            padding: 14px 18px;
            background: var(--bg-input);
            border: 1px solid var(--border);
            border-radius: 0px;
            color: var(--text-primary);
            font-family: 'VT323', monospace;
            font-size: 1rem;
            transition: all 0.2s;
            outline: none;
        }
        .today-add-input:focus { border-color: var(--accent-lime); box-shadow: 0 0 0 3px rgba(184,255,87,0.08); }
        .today-add-input::placeholder { color: var(--text-muted); }
        .btn-today-add {
            background: var(--bg-elevated);
            border: 1px solid var(--border);
            color: var(--text-secondary);
            padding: 14px 20px;
            border-radius: 0px;
            font-weight: 600;
            font-size: 0.95rem;
            cursor: pointer;
            font-family: 'Press Start 2P', cursive;
            transition: all 0.2s;
            white-space: nowrap;
        }
        .btn-today-add:hover { border-color: var(--accent-lime); color: var(--accent-lime); }
        .btn-today-add:disabled { opacity: 0.4; cursor: not-allowed; }

        /* + Today button on board items */
        .btn-board-today {
            background: rgba(184,255,87,0.1);
            color: var(--accent-lime);
            border: 1px solid rgba(184,255,87,0.25);
            padding: 9px 14px;
            border-radius: 0px;
            font-weight: 700;
            font-size: 0.8rem;
            cursor: pointer;
            font-family: 'Press Start 2P', cursive;
            transition: all 0.2s;
            white-space: nowrap;
        }
        .btn-board-today:hover { background: rgba(184,255,87,0.2); border-color: var(--accent-lime); }

        /* Next quest buttons on result screen */
        .btn-next-quest {
            width: 100%;
            background: linear-gradient(135deg, var(--accent-lime), #8eff00);
            color: #0a0a0f;
            border: none;
            padding: 18px;
            border-radius: 0px;
            font-weight: 700;
            font-size: 1.1rem;
            cursor: pointer;
            font-family: 'Press Start 2P', cursive;
            transition: all 0.25s;
            margin-bottom: 10px;
        }
        .btn-next-quest:hover { transform: translateY(-2px); box-shadow: 0 8px 30px rgba(184,255,87,0.4); }
        .btn-return-today {
            width: 100%;
            background: transparent;
            color: var(--text-muted);
            border: 1px solid var(--border);
            padding: 14px;
            border-radius: 0px;
            font-weight: 600;
            font-size: 0.9rem;
            cursor: pointer;
            font-family: 'VT323', monospace;
            transition: all 0.2s;
            margin-bottom: 12px;
        }
        .btn-return-today:hover { border-color: #2a2a3a; color: var(--text-secondary); }

        /* ══════════════════════════════════════
           END-OF-DAY SUMMARY
           ══════════════════════════════════════ */

        .summary-wrapper {
            min-height: calc(100vh - 90px);
            display: flex;
            align-items: center;
            justify-content: center;
            padding: 40px 0;
        }
        .summary-card {
            background: var(--bg-card);
            border: 3px solid var(--accent-cyan);
            border-radius: 0px;
            padding: 56px 40px;
            text-align: center;
            max-width: 540px;
            width: 100%;
            position: relative;
            overflow: hidden;
            animation: fadeIn 0.5s ease-out;
            box-shadow: 6px 6px 0px #000;
        }
        .summary-card::before {
            content: '';
            position: absolute;
            top: 0; left: 0; right: 0;
            height: 4px;
            background: linear-gradient(90deg, var(--accent-lime), var(--accent-cyan), var(--accent-magenta));
        }
        .summary-banner { font-size: 4rem; margin-bottom: 16px; animation: result-bounce 0.6s ease-out; }
        .summary-title {
            font-family: 'Press Start 2P', cursive;
            font-size: 2.2rem;
            font-weight: 700;
            letter-spacing: -0.5px;
            color: var(--accent-lime);
            margin-bottom: 8px;
        }
        .summary-date {
            font-size: 0.8rem;
            color: var(--text-muted);
            margin-bottom: 36px;
            text-transform: uppercase;
            letter-spacing: 1.5px;
        }
        .summary-stats-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 14px;
            margin-bottom: 32px;
        }
        .summary-stat { background: var(--bg-elevated); border-radius: 0px; padding: 20px 12px; border: 2px solid var(--accent-cyan); box-shadow: 3px 3px 0px #000; }
        .summary-stat-value {
            font-family: 'Press Start 2P', cursive;
            font-size: 1.8rem;
            font-weight: 700;
            color: var(--text-primary);
            margin-bottom: 4px;
        }
        .summary-stat-value.xp { color: var(--accent-lime); }
        .summary-stat-label { font-size: 0.7rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 1.5px; }
        .summary-message {
            background: var(--bg-elevated);
            border-radius: 0px;
            padding: 20px 24px;
            margin-bottom: 28px;
            font-size: 1.05rem;
            color: var(--text-secondary);
            line-height: 1.6;
            font-style: italic;
        }
        .summary-quests-done { margin-bottom: 28px; text-align: left; }
        .summary-quest-row {
            display: flex;
            align-items: center;
            gap: 10px;
            padding: 12px 16px;
            background: var(--bg-elevated);
            border-radius: 0px;
            margin-bottom: 8px;
        }
        .summary-quest-name { flex: 1; font-size: 0.9rem; color: var(--text-secondary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
        .summary-quest-result { font-size: 0.8rem; font-weight: 600; color: var(--accent-lime); white-space: nowrap; }
        .summary-quest-result.skipped { color: var(--text-muted); }

        @media (max-width: 768px) {
            .today-item { flex-wrap: wrap; }
            .today-item-actions { width: 100%; justify-content: flex-end; }
            .today-add-row { flex-direction: column; }
            .today-secondary-actions { flex-direction: column; }
            .summary-card { padding: 40px 24px; }
            .summary-stats-grid { gap: 8px; }
            .summary-stat { padding: 16px 8px; }
            .summary-stat-value { font-size: 1.4rem; }
        }

        /* ── AVATAR PANEL (Phase 2.1) ─────────────────────────── */
        .avatar-panel {
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 20px;
            padding: 20px 24px;
            margin-bottom: 16px;
            display: flex;
            align-items: center;
            gap: 20px;
            position: relative;
            overflow: hidden;
            transition: border-color 0.6s ease;
        }
        .avatar-panel::before {
            content: '';
            position: absolute;
            top: -50px;
            left: -20px;
            width: 160px;
            height: 160px;
            background: radial-gradient(ellipse, var(--avatar-color, #b8ff57) 0%, transparent 70%);
            opacity: 0.08;
            pointer-events: none;
            transition: opacity 0.6s ease;
        }
        .avatar-figure-wrap {
            flex-shrink: 0;
            width: 88px;
            display: flex;
            flex-direction: column;
            align-items: center;
        }
        .avatar-svg-container {
            width: 88px;
            height: 120px;
            display: flex;
            align-items: center;
            justify-content: center;
            animation: avatar-float 3.5s ease-in-out infinite;
            filter: drop-shadow(0 8px 20px rgba(0,0,0,0.45));
            transition: filter 0.4s ease;
        }
        .avatar-svg-container svg {
            width: 88px;
            height: 120px;
        }
        .avatar-svg-container.xp-flash {
            filter: drop-shadow(0 0 20px var(--avatar-color, #b8ff57)) brightness(1.8) saturate(1.5);
        }
        @keyframes avatar-float {
            0%, 100% { transform: translateY(0px) rotate(-0.5deg); }
            50% { transform: translateY(-8px) rotate(0.5deg); }
        }
        .avatar-info {
            flex: 1;
            min-width: 0;
        }
        .avatar-hero-label {
            font-size: 0.67rem;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 2px;
            font-weight: 600;
            margin-bottom: 3px;
        }
        .avatar-evo-name {
            font-family: 'Press Start 2P', cursive;
            font-size: 1.05rem;
            font-weight: 700;
            letter-spacing: -0.3px;
            margin-bottom: 10px;
            transition: color 0.5s ease;
        }
        .avatar-xp-bar-track {
            width: 100%;
            height: 5px;
            background: var(--bg-input);
            border-radius: 3px;
            overflow: hidden;
            margin-bottom: 5px;
        }
        .avatar-xp-bar-fill {
            height: 100%;
            border-radius: 3px;
            transition: width 1s cubic-bezier(0.34, 1.56, 0.64, 1), background 0.5s ease;
        }
        .avatar-xp-text {
            font-size: 0.67rem;
            color: var(--text-muted);
            font-family: 'Press Start 2P', cursive;
            margin-bottom: 11px;
        }
        .avatar-slots-row {
            display: flex;
            gap: 5px;
            margin-bottom: 5px;
        }
        .avatar-slot {
            width: 26px;
            height: 26px;
            background: var(--bg-elevated);
            border: 1px dashed #2a2a3a;
            border-radius: 0px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 11px;
            opacity: 0.3;
            filter: grayscale(1);
            cursor: default;
            transition: opacity 0.4s, filter 0.4s, border-color 0.4s;
        }
        .avatar-slot.unlocked {
            opacity: 0.8;
            filter: none;
            border-color: var(--avatar-color, #b8ff57);
            border-style: solid;
        }
        .avatar-slots-hint {
            font-size: 0.66rem;
            color: var(--text-muted);
            opacity: 0.65;
        }

        /* ── JOURNEY MAP (Phase 2.2) ─────────────────────────── */
        .journey-wrap { padding: 24px 0 80px; }
        .journey-header {
            display: flex; align-items: center;
            justify-content: space-between; margin-bottom: 28px;
        }
        .journey-title {
            font-family: 'Press Start 2P', cursive;
            font-size: 1.5rem; font-weight: 700; color: var(--text-primary);
        }
        .journey-subtitle { font-size: 0.82rem; color: var(--text-secondary); margin-top: 2px; }
        .journey-xp-badge {
            font-family: 'Press Start 2P', cursive; font-size: 0.85rem;
            color: var(--accent-lime); background: rgba(184,255,87,0.08);
            border: 1px solid rgba(184,255,87,0.2); padding: 6px 12px;
            border-radius: 0px; white-space: nowrap;
        }
        .journey-map { position: relative; display: flex; flex-direction: column; gap: 0; }
        .journey-path-line {
            position: absolute; left: 25px; top: 56px; bottom: 56px;
            width: 2px;
            background: linear-gradient(to bottom, transparent, rgba(255,255,255,0.07) 15%, rgba(255,255,255,0.07) 85%, transparent);
            z-index: 0;
        }
        .journey-chapter {
            position: relative; display: flex; align-items: flex-start;
            gap: 16px; padding: 14px 0; z-index: 1; transition: opacity 0.3s;
        }
        .journey-chapter.locked { opacity: 0.38; filter: grayscale(0.5); }
        .journey-chapter-node {
            flex-shrink: 0; width: 52px; height: 52px; border-radius: 50%;
            display: flex; align-items: center; justify-content: center;
            font-size: 1.3rem; border: 2px solid rgba(255,255,255,0.08);
            background: var(--bg-card); position: relative;
            transition: border-color 0.4s, box-shadow 0.4s;
        }
        .journey-chapter.current .journey-chapter-node {
            border-color: var(--ch-color, #b8ff57);
            box-shadow: 0 0 18px rgba(var(--ch-rgb, 184,255,87), 0.30);
        }
        .journey-chapter.completed .journey-chapter-node {
            border-color: var(--ch-color, #10b981);
            background: rgba(var(--ch-rgb, 16,185,129), 0.10);
        }
        .journey-done-tick {
            position: absolute; bottom: -4px; right: -4px; width: 18px; height: 18px;
            border-radius: 50%; color: #000; font-size: 0.58rem; font-weight: 900;
            display: flex; align-items: center; justify-content: center;
            border: 2px solid var(--bg-deep); background: var(--ch-color, #10b981);
        }
        .journey-avatar-marker {
            position: absolute; top: -6px; right: -6px; width: 20px; height: 20px;
            border-radius: 50%; background: var(--bg-deep);
            border: 2px solid var(--ch-color, #b8ff57);
            display: flex; align-items: center; justify-content: center;
            font-size: 0.6rem;
            box-shadow: 0 0 10px rgba(var(--ch-rgb, 184,255,87), 0.5);
            animation: marker-pulse 2s ease-in-out infinite;
        }
        @keyframes marker-pulse {
            0%, 100% { box-shadow: 0 0 8px rgba(var(--ch-rgb, 184,255,87), 0.45); }
            50%       { box-shadow: 0 0 20px rgba(var(--ch-rgb, 184,255,87), 0.85); }
        }
        .journey-chapter-body { flex: 1; padding-top: 4px; }
        .journey-chapter-name {
            font-family: 'Press Start 2P', cursive;
            font-size: 0.98rem; font-weight: 700; color: var(--text-primary); line-height: 1.2;
        }
        .journey-chapter.locked .journey-chapter-name { color: var(--text-muted); }
        .journey-chapter-threshold {
            font-family: 'Press Start 2P', cursive;
            font-size: 0.70rem; color: var(--text-muted); margin-top: 3px;
        }
        .journey-chapter.current .journey-chapter-threshold { color: var(--ch-color, #b8ff57); }
        .journey-chapter-beat {
            font-size: 0.80rem; color: var(--text-secondary);
            margin-top: 7px; line-height: 1.55; font-style: italic;
        }
        .journey-progress-track {
            margin-top: 10px; height: 4px;
            background: rgba(255,255,255,0.07); border-radius: 4px; overflow: hidden;
        }
        .journey-progress-fill {
            height: 100%; border-radius: 4px;
            background: var(--ch-color, #b8ff57); transition: width 0.6s ease;
        }
        .journey-progress-label {
            font-family: 'Press Start 2P', cursive;
            font-size: 0.66rem; color: var(--text-muted); margin-top: 4px;
        }
        /* Story beat modal */
        .journey-beat-modal {
            display: none; position: fixed; inset: 0;
            background: rgba(0,0,0,0.78); z-index: 9999;
            align-items: center; justify-content: center; padding: 24px;
        }
        .journey-beat-modal.visible { display: flex; }
        .journey-beat-card {
            background: var(--bg-card); border: 1px solid rgba(255,255,255,0.09);
            border-radius: 20px; padding: 32px 28px; max-width: 380px;
            width: 100%; text-align: center; position: relative;
            animation: beat-pop 0.35s cubic-bezier(0.34,1.56,0.64,1);
        }
        @keyframes beat-pop {
            from { opacity: 0; transform: scale(0.85) translateY(20px); }
            to   { opacity: 1; transform: scale(1) translateY(0); }
        }
        .journey-beat-emoji {
            font-size: 3rem; margin-bottom: 12px; display: block;
            filter: drop-shadow(0 0 16px var(--modal-color, #b8ff57));
        }
        .journey-beat-chapter-label {
            font-family: 'Press Start 2P', cursive; font-size: 0.7rem;
            color: var(--modal-color, #b8ff57); letter-spacing: 0.1em;
            text-transform: uppercase; margin-bottom: 8px;
        }
        .journey-beat-title {
            font-family: 'Press Start 2P', cursive;
            font-size: 1.3rem; font-weight: 700; color: var(--text-primary); margin-bottom: 14px;
        }
        .journey-beat-text {
            font-size: 0.92rem; color: var(--text-secondary);
            line-height: 1.65; margin-bottom: 24px;
        }
        .journey-beat-btn {
            width: 100%; padding: 13px; border-radius: 0px; border: none;
            background: var(--modal-color, #b8ff57); color: #0a0a0f;
            font-family: 'Press Start 2P', cursive; font-size: 0.95rem; font-weight: 700;
            cursor: pointer; transition: filter 0.2s;
        }
        .journey-beat-btn:hover { filter: brightness(1.15); }

        /* ── HIDDEN FEATURES (not yet ready for users) ──────────────
           Avatar, Journey Map, and Cosmetic Shop are hidden from UI.
           Code stays intact — just not shown until design is finalized.
        ── */
        #avatar-panel,
        #nav-shop-link,
        #nav-journey-link,
        #shop-shortcut-btn,
        #screen-shop,
        #screen-journey,
        .journey-beat-modal { display: none !important; }

        /* ── Sync Modal ─────────────────────────────────── */
        .sync-modal-overlay {
            position: fixed; inset: 0; background: rgba(0,0,0,0.75);
            display: flex; align-items: center; justify-content: center;
            z-index: 10000; padding: 20px;
        }
        .sync-modal-card {
            background: #0a0a2e; border: 3px solid var(--accent-cyan);
            border-radius: 0px; padding: 32px 28px; width: 100%; max-width: 400px;
            position: relative; text-align: center;
            box-shadow: 6px 6px 0px #000;
        }
        .sync-modal-close {
            position: absolute; top: 14px; right: 16px;
            background: none; border: none; color: #aaa; font-size: 18px;
            cursor: pointer; line-height: 1;
        }
        .sync-modal-close:hover { color: #fff; }
        .sync-modal-icon { font-size: 36px; margin-bottom: 8px; }
        .sync-modal-title {
            font-size: 0.9rem; font-weight: 700; color: var(--accent-cyan); margin: 0 0 20px;
            font-family: 'Press Start 2P', cursive; text-shadow: 0 0 10px rgba(0, 255, 255, 0.4);
        }
        .sync-modal-label {
            font-size: 0.75rem; color: #888; text-transform: uppercase;
            letter-spacing: 0.08em; margin-bottom: 8px;
        }
        .sync-code-display {
            font-family: 'Press Start 2P', cursive; font-size: 1rem; font-weight: 700;
            color: var(--accent-lime); letter-spacing: 0.12em; background: rgba(57,255,20,0.08);
            border: 2px solid var(--accent-lime); border-radius: 0px;
            padding: 12px 16px; margin-bottom: 8px; cursor: pointer;
            box-shadow: 3px 3px 0px #000;
            text-shadow: 0 0 10px rgba(57, 255, 20, 0.5);
        }
        .sync-copy-btn {
            background: rgba(163,230,53,0.15); border: 1px solid rgba(163,230,53,0.4);
            color: #a3e635; border-radius: 0px; padding: 6px 16px; cursor: pointer;
            font-size: 0.85rem; transition: background 0.2s;
        }
        .sync-copy-btn:hover { background: rgba(163,230,53,0.25); }
        .sync-modal-divider {
            color: #555; font-size: 0.8rem; margin: 20px 0 16px;
            display: flex; align-items: center; gap: 10px;
        }
        .sync-modal-divider::before, .sync-modal-divider::after {
            content: ''; flex: 1; height: 1px; background: rgba(255,255,255,0.08);
        }
        .sync-code-input {
            width: 100%; background: rgba(255,255,255,0.06); border: 2px solid var(--accent-cyan);
            border-radius: 0px; padding: 12px 14px; color: var(--accent-lime); font-size: 1rem;
            font-family: 'Press Start 2P', cursive; text-transform: uppercase;
            letter-spacing: 0.12em; text-align: center; margin-bottom: 10px;
            box-sizing: border-box; box-shadow: inset 3px 3px 0px rgba(0,0,0,0.3);
        }
        .sync-code-input:focus { outline: none; border-color: var(--accent-lime); }
        .sync-pull-btn {
            width: 100%; background: var(--accent-lime); color: #000; font-weight: 700;
            border: 2px solid #000; border-radius: 0px; padding: 12px; cursor: pointer;
            font-size: 0.7rem; transition: all 0.15s;
            font-family: 'Press Start 2P', cursive; box-shadow: 4px 4px 0px #000;
            text-transform: uppercase;
        }
        .sync-pull-btn:hover { opacity: 0.88; }
        .sync-pull-btn:disabled { opacity: 0.5; cursor: not-allowed; }
        .sync-status {
            margin-top: 14px; font-size: 0.85rem; min-height: 20px;
            color: #a3e635;
        }
        .sync-status.error { color: #f87171; }
        .sync-nav-btn {
            background: none; border: 1px solid rgba(255,255,255,0.2); color: #ccc;
            border-radius: 0px; padding: 5px 10px; font-size: 0.8rem; cursor: pointer;
            text-decoration: none; transition: border-color 0.2s, color 0.2s;
        }
        .sync-nav-btn:hover { border-color: #a3e635; color: #a3e635; }
        .feedback-nav-btn {
            color: #aaa; text-decoration: none; font-size: 0.85rem;
            font-family: 'VT323', monospace; border: 1px solid rgba(255,255,255,0.15);
            padding: 5px 10px; border-radius: 0px; transition: all 0.2s; line-height: 1;
            cursor: pointer; background: none;
        }
        .feedback-nav-btn:hover { border-color: var(--accent-magenta); color: var(--accent-magenta); }

        /* ── Feedback Modal ─────────────────────────── */
        .feedback-modal-overlay {
            position: fixed; inset: 0; background: rgba(0,0,0,0.75);
            display: flex; align-items: center; justify-content: center;
            z-index: 10000; padding: 20px;
        }
        .feedback-modal-card {
            background: #0a0a2e; border: 3px solid var(--accent-magenta);
            border-radius: 0px; padding: 32px 28px; width: 100%; max-width: 420px;
            position: relative; text-align: center;
            box-shadow: 6px 6px 0px #000;
        }
        .feedback-modal-close {
            position: absolute; top: 14px; right: 16px;
            background: none; border: none; color: #aaa; font-size: 18px;
            cursor: pointer; line-height: 1;
        }
        .feedback-modal-close:hover { color: #fff; }
        .feedback-modal-icon { font-size: 36px; margin-bottom: 8px; }
        .feedback-modal-title {
            font-size: 0.85rem; font-weight: 700; color: var(--accent-magenta); margin: 0 0 6px;
            font-family: 'Press Start 2P', cursive; text-shadow: 0 0 10px rgba(255, 0, 180, 0.4);
        }
        .feedback-modal-subtitle {
            font-size: 0.9rem; color: #888; margin-bottom: 20px;
        }
        .feedback-category-select {
            width: 100%; background: rgba(255,255,255,0.06); border: 2px solid rgba(255, 0, 180, 0.5);
            border-radius: 0px; padding: 10px 12px; color: #ccc; font-size: 0.9rem;
            font-family: 'VT323', monospace; margin-bottom: 14px; box-sizing: border-box;
            cursor: pointer; appearance: none;
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23ff00b4' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
            background-repeat: no-repeat; background-position: right 12px center;
            padding-right: 36px;
        }
        .feedback-category-select:focus { outline: none; border-color: var(--accent-magenta); }
        .feedback-textarea {
            width: 100%; min-height: 110px; background: rgba(255,255,255,0.06);
            border: 2px solid rgba(255, 0, 180, 0.5); border-radius: 0px;
            padding: 12px 14px; color: #fff; font-size: 1rem;
            font-family: 'VT323', monospace; resize: vertical; box-sizing: border-box;
            box-shadow: inset 3px 3px 0px rgba(0,0,0,0.3); margin-bottom: 14px;
        }
        .feedback-textarea:focus { outline: none; border-color: var(--accent-magenta); }
        .feedback-textarea::placeholder { color: #555; }
        .feedback-char-count {
            font-size: 0.75rem; color: #555; text-align: right; margin-bottom: 6px;
        }
        .feedback-submit-btn {
            width: 100%; background: var(--accent-magenta); color: #fff; font-weight: 700;
            border: 2px solid #000; border-radius: 0px; padding: 12px; cursor: pointer;
            font-size: 0.65rem; transition: all 0.15s;
            font-family: 'Press Start 2P', cursive; box-shadow: 4px 4px 0px #000;
            text-transform: uppercase;
        }
        .feedback-submit-btn:hover { opacity: 0.88; }
        .feedback-submit-btn:disabled { opacity: 0.5; cursor: not-allowed; }
        .feedback-status {
            margin-top: 14px; font-size: 0.85rem; min-height: 20px; color: #a3e635;
        }
        .feedback-status.error { color: #f87171; }
        .feedback-thanks {
            display: flex; flex-direction: column; align-items: center; gap: 14px; padding: 10px 0;
        }
        .feedback-thanks-icon { font-size: 44px; }
        .feedback-thanks-text {
            font-size: 0.8rem; font-family: 'Press Start 2P', cursive;
            color: var(--accent-lime); text-shadow: 0 0 10px rgba(57,255,20,0.4);
        }

        /* ── WHY TIMECRUSH (Comparison) ────────── */
        .why-section {
            padding: 80px 20px;
            max-width: 1100px;
            margin: 0 auto;
            text-align: center;
            position: relative;
            z-index: 1;
        }
        .why-section-heading {
            font-size: clamp(0.85rem, 2.5vw, 1.1rem);
            margin-bottom: 48px;
            text-shadow: 0 0 15px rgba(0,255,255,0.4), 3px 3px 0px #000;
            color: var(--text-primary);
        }
        .why-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 24px;
            margin-bottom: 48px;
            align-items: start;
        }
        .why-card {
            background: var(--bg-card);
            border: 3px solid;
            border-radius: 0px;
            padding: 28px 22px;
            position: relative;
            text-align: left;
            transition: transform 0.15s;
        }
        .why-card--competitor {
            border-color: var(--accent-red);
        }
        .why-card--winner {
            border-color: var(--accent-lime);
            box-shadow: 5px 5px 0px #000, 0 0 28px rgba(57,255,20,0.15);
            transform: translateY(-6px);
        }
        .why-card-label {
            font-family: 'Press Start 2P', cursive;
            font-size: 0.5rem;
            padding: 4px 8px;
            display: inline-block;
            margin-bottom: 14px;
            border: 2px solid;
            box-shadow: 2px 2px 0px #000;
            text-transform: uppercase;
            letter-spacing: 1px;
        }
        .why-card--competitor .why-card-label {
            color: var(--accent-red);
            border-color: var(--accent-red);
        }
        .why-card--winner .why-card-label {
            background: var(--accent-lime);
            color: #000;
            border-color: #000;
        }
        .why-card-name {
            font-family: 'Press Start 2P', cursive;
            font-size: 0.68rem;
            color: var(--text-primary);
            margin-bottom: 14px;
            letter-spacing: 1px;
        }
        .why-card-verdict {
            font-family: 'VT323', monospace;
            font-size: 1.15rem;
            line-height: 1.6;
        }
        .why-card--competitor .why-card-verdict { color: var(--text-secondary); }
        .why-card--winner .why-card-verdict { color: var(--accent-lime); }
        .why-card-icon {
            position: absolute;
            top: 12px;
            right: 14px;
            font-size: 1.1rem;
            font-family: 'Press Start 2P', cursive;
        }
        .why-card--competitor .why-card-icon { color: var(--accent-red); text-shadow: 0 0 8px rgba(255,0,64,0.6); }
        .why-card--winner .why-card-icon { color: var(--accent-lime); text-shadow: 0 0 8px rgba(57,255,20,0.6); }
        .why-free-badge {
            display: inline-block;
            background: var(--bg-elevated);
            border: 3px solid var(--accent-yellow);
            color: var(--accent-yellow);
            font-family: 'Press Start 2P', cursive;
            font-size: 0.62rem;
            padding: 14px 28px;
            box-shadow: 4px 4px 0px #000;
            margin-bottom: 24px;
            text-transform: uppercase;
            letter-spacing: 2px;
            text-shadow: 0 0 10px rgba(255,255,0,0.4);
            line-height: 2;
        }
        .why-free-sub {
            display: block;
            font-family: 'VT323', monospace;
            font-size: 1.1rem;
            color: var(--text-secondary);
            letter-spacing: 1px;
            margin-top: 6px;
            text-shadow: none;
        }
        .why-noguilt {
            font-family: 'VT323', monospace;
            font-size: 1.3rem;
            color: var(--accent-magenta);
            text-shadow: 0 0 10px rgba(255,0,255,0.4);
            letter-spacing: 1px;
        }
        .why-divider {
            border: none;
            border-top: 3px solid var(--border);
            margin: 0 0 80px;
        }
        @media (max-width: 768px) {
            .why-grid {
                grid-template-columns: 1fr;
                gap: 16px;
            }
            .why-card--winner {
                transform: none;
                border-width: 4px;
            }
        }
    