/* ═══════════════════════════════════════════════════════════════
   PEDAL REBEL VR — Player Profile Styles
   All CSS for player_profile.html
   ═══════════════════════════════════════════════════════════════ */

        /* Cyberpunk Sci-Fi CSS for Player Profile */
        
        @import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;500;700;900&family=Rajdhani:wght@300;400;500;600;700&display=swap');
        
        :root {
            /* Cyberpunk Color Palette */
            --primary-bg: #0a0a0f;
            --secondary-bg: #1a1a2e;
            --accent-purple: #9d4edd;
            --accent-magenta: #e0aaff;
            --accent-cyan: #00f5ff;
            --accent-electric: #7209b7;
            --neon-pink: #f72585;
            --neon-blue: #4361ee;
            --neon-gold: #ffd700;
            --text-primary: #ffffff;
            --text-secondary: #c77dff;
            --text-muted: #8b5cf6;
            --glass-bg: rgba(157, 78, 221, 0.1);
            --glass-border: rgba(157, 78, 221, 0.3);
            --shadow-neon: 0 0 20px rgba(157, 78, 221, 0.5);
            --shadow-cyan: 0 0 20px rgba(0, 245, 255, 0.5);
            --grid-color: rgba(157, 78, 221, 0.2);
        }
        
        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }
        
        body {
            font-family: 'Rajdhani', 'Segoe UI', sans-serif;
            background: var(--primary-bg);
            color: var(--text-primary);
            min-height: 100vh;
            overflow-x: hidden;
            position: relative;
        }
        
        /* Cyberpunk Grid Background */
        body::before {
            content: '';
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background-image: 
                linear-gradient(rgba(157, 78, 221, 0.1) 1px, transparent 1px),
                linear-gradient(90deg, rgba(157, 78, 221, 0.1) 1px, transparent 1px);
            background-size: 50px 50px;
            animation: grid-pulse 4s ease-in-out infinite alternate;
            z-index: -1;
        }
        
        @keyframes grid-pulse {
            0% { opacity: 0.3; }
            100% { opacity: 0.1; }
        }
        
        /* Floating particles effect */
        body::after {
            content: '';
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background: radial-gradient(circle at 20% 50%, rgba(157, 78, 221, 0.1) 0%, transparent 50%),
                        radial-gradient(circle at 80% 20%, rgba(0, 245, 255, 0.1) 0%, transparent 50%),
                        radial-gradient(circle at 40% 80%, rgba(247, 37, 133, 0.1) 0%, transparent 50%);
            animation: particle-float 8s ease-in-out infinite;
            z-index: -1;
        }
        
        @keyframes particle-float {
            0%, 100% { transform: translateY(0px); }
            50% { transform: translateY(-20px); }
        }
        
        /* ── PART IMAGES ── */
        .part-img-wrap {
            width: 80px; height: 80px;
            margin: 0 auto 8px;
            display: flex; align-items: center; justify-content: center;
        }
        .part-img {
            width: 80px; height: 80px;
            object-fit: contain;
            image-rendering: pixelated;
            filter: drop-shadow(0 0 6px rgba(0,245,255,0.55));
            transition: filter 0.25s, transform 0.25s;
        }
        .part-card:hover .part-img, .bike-card:hover .part-img {
            filter: drop-shadow(0 0 14px rgba(0,245,255,0.95));
            transform: scale(1.08);
        }
        .part-card.locked .part-img, .bike-card.locked .part-img {
            filter: grayscale(90%) brightness(0.5);
        }
        .part-card.equipped .part-img, .bike-card.equipped-bike .part-img {
            filter: drop-shadow(0 0 16px rgba(0,245,255,1));
        }
        .current-build-img {
            width: 48px; height: 48px; object-fit: contain;
            filter: drop-shadow(0 0 5px rgba(0,245,255,0.6));
            image-rendering: pixelated;
        }
         
        /* ── INBOX AVATAR ── */
        .inbox-avatar-img {
            width: 44px; height: 44px;
            object-fit: cover;
            border-radius: 50%;
            border: 2px solid #00f5ff;
            box-shadow: 0 0 8px rgba(0,245,255,0.4);
            flex-shrink: 0;
        }
        .inbox-msg-header {
            display: flex; align-items: center; gap: 10px; margin-bottom: 6px;
        }
         
        /* ── GANG LEADER ── */
        .gang-leader-wrap {
            display: flex; align-items: center; gap: 14px;
            padding: 12px 16px;
            background: rgba(0,245,255,0.06);
            border: 1px solid rgba(0,245,255,0.25);
            border-radius: 8px;
            margin-bottom: 16px;
        }
        .gang-leader-img {
            width: 60px; height: 60px;
            object-fit: contain;
            filter: drop-shadow(0 0 8px rgba(0,245,255,0.7));
            image-rendering: pixelated;
            flex-shrink: 0;
        }
        .gang-leader-title {
            font-family: 'Orbitron', monospace; font-size: 0.65rem; font-weight: 700;
            color: #00f5ff; letter-spacing: 0.1em; margin-bottom: 2px;
        }
        .gang-leader-name {
            font-family: 'Orbitron', monospace; font-size: 0.9rem; font-weight: 700; color: #fff;
        }
        .gang-leader-cred { font-size: 0.82rem; color: #6a7fa0; }

        /* ── ICON IMAGE SYSTEM ── */
        .icon-img-wrap img { transition: filter 0.25s, transform 0.25s; }
        .part-card2:hover .icon-img-wrap img,
        .collection-item:hover .icon-img-wrap img,
        .ach-card2:hover .icon-img-wrap img,
        .milestone-card:hover .icon-img-wrap img,
        .gang-map-card:hover .icon-img-wrap img,
        .gang-option-card:hover .icon-img-wrap img {
            filter: drop-shadow(0 0 14px rgba(0,245,255,0.95)) !important;
            transform: scale(1.1);
        }
        .part-card2.locked-part2 .icon-img-wrap img,
        .collection-item.locked .icon-img-wrap img,
        .ach-card2.ach-hidden .icon-img-wrap img,
        .milestone-card.locked-milestone .icon-img-wrap img,
        .gang-map-card.locked .icon-img-wrap img {
            filter: grayscale(85%) brightness(0.45) !important;
        }
        .part-card2.equipped-part2 .icon-img-wrap img {
            filter: drop-shadow(0 0 18px rgba(0,245,255,1)) brightness(1.15) !important;
        }
        .ach-card2.ach-earned .icon-img-wrap img {
            filter: drop-shadow(0 0 12px rgba(255,215,0,0.9)) !important;
        }
        /* Gang map card icons */
        .gmc-symbol .icon-img-wrap img { filter: drop-shadow(0 0 10px rgba(0,245,255,0.6)); }
        .gang-map-card.beaten .gmc-symbol .icon-img-wrap img { filter: grayscale(60%) brightness(0.7); }
        .gang-map-card.current .gmc-symbol .icon-img-wrap img { filter: drop-shadow(0 0 20px rgba(0,245,255,1)); }
        /* Inbox avatar */
        .inbox-avatar-img { image-rendering: auto; }
        /* Gang leader block */
        .gang-leader-block {
            display: flex; align-items: center; gap: 14px;
            padding: 12px 16px;
            background: rgba(0,245,255,0.06);
            border: 1px solid rgba(0,245,255,0.25);
            border-radius: 8px;
            margin-bottom: 16px;
        }
        
        .container {
            max-width: 1400px;
            margin: 0 auto;
            padding: 20px;
        }

        /* Loading and Status Messages */
        .loading {
            text-align: center;
            padding: 100px;
            font-size: 1.5em;
            color: var(--accent-cyan);
            font-family: 'Orbitron', monospace;
            text-transform: uppercase;
            letter-spacing: 2px;
        }

        .error {
            background: linear-gradient(135deg, rgba(247, 37, 133, 0.2), rgba(255, 107, 107, 0.2));
            border: 2px solid var(--neon-pink);
            border-radius: 20px;
            padding: 30px;
            text-align: center;
            color: var(--neon-pink);
            font-family: 'Orbitron', monospace;
            text-transform: uppercase;
            letter-spacing: 1px;
            backdrop-filter: blur(20px);
            box-shadow: 0 0 30px rgba(247, 37, 133, 0.3);
        }

        .success {
            background: linear-gradient(135deg, rgba(0, 245, 255, 0.2), rgba(76, 205, 196, 0.2));
            border: 2px solid var(--accent-cyan);
            border-radius: 20px;
            padding: 30px;
            text-align: center;
            color: var(--accent-cyan);
            font-family: 'Orbitron', monospace;
            text-transform: uppercase;
            letter-spacing: 1px;
            backdrop-filter: blur(20px);
            box-shadow: 0 0 30px rgba(0, 245, 255, 0.3);
            margin-bottom: 20px;
        }

        /* Auth Section Styles */
        .auth-section {
            background: linear-gradient(135deg, 
                rgba(157, 78, 221, 0.2) 0%, 
                rgba(114, 9, 183, 0.15) 25%, 
                rgba(247, 37, 133, 0.2) 50%, 
                rgba(67, 97, 238, 0.15) 75%, 
                rgba(0, 245, 255, 0.2) 100%);
            border-radius: 25px;
            padding: 40px;
            margin-bottom: 30px;
            position: relative;
            overflow: hidden;
            backdrop-filter: blur(20px);
            border: 2px solid var(--glass-border);
            box-shadow: 0 20px 40px rgba(157, 78, 221, 0.3);
        }

        .auth-section::before {
            content: '';
            position: absolute;
            top: -50%;
            left: -50%;
            width: 200%;
            height: 200%;
            background: conic-gradient(from 0deg, transparent, rgba(157, 78, 221, 0.1), transparent, rgba(0, 245, 255, 0.1), transparent);
            animation: rotate-gradient 15s linear infinite;
            z-index: -1;
        }

        @keyframes rotate-gradient {
            0% { transform: rotate(0deg); }
            100% { transform: rotate(360deg); }
        }

        .auth-section h3 {
            color: var(--accent-cyan);
            margin-bottom: 30px;
            font-family: 'Orbitron', monospace;
            text-transform: uppercase;
            letter-spacing: 2px;
            text-align: center;
            font-size: 1.8em;
            font-weight: 900;
            text-shadow: 0 0 20px var(--accent-cyan);
        }

        .auth-forms {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
            gap: 30px;
        }

        .auth-form {
            background: var(--glass-bg);
            border: 2px solid var(--glass-border);
            border-radius: 20px;
            padding: 30px;
            backdrop-filter: blur(20px);
            transition: all 0.3s ease;
            position: relative;
            overflow: hidden;
        }

        .auth-form::before {
            content: '';
            position: absolute;
            top: 0;
            left: -100%;
            width: 100%;
            height: 2px;
            background: linear-gradient(90deg, transparent, var(--accent-cyan), transparent);
            transition: left 0.5s ease;
        }

        .auth-form:hover::before {
            left: 100%;
        }

        .auth-form:hover {
            transform: translateY(-5px);
            box-shadow: var(--shadow-neon);
            border-color: var(--accent-purple);
            background: rgba(157, 78, 221, 0.15);
        }

        .auth-form h4 {
            color: var(--accent-magenta);
            margin-bottom: 25px;
            text-align: center;
            font-family: 'Orbitron', monospace;
            font-size: 1.3em;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 1px;
        }

        /* Profile Setup Section */
        .profile-setup-section {
            background: linear-gradient(135deg, 
                rgba(157, 78, 221, 0.2) 0%, 
                rgba(114, 9, 183, 0.15) 25%, 
                rgba(247, 37, 133, 0.2) 50%, 
                rgba(67, 97, 238, 0.15) 75%, 
                rgba(0, 245, 255, 0.2) 100%);
            border-radius: 25px;
            padding: 40px;
            margin-bottom: 30px;
            position: relative;
            overflow: hidden;
            backdrop-filter: blur(20px);
            border: 2px solid var(--glass-border);
            box-shadow: 0 20px 40px rgba(255, 215, 0, 0.3);
            display: none;
        }

        .profile-setup-section::before {
            content: '';
            position: absolute;
            top: -50%;
            left: -50%;
            width: 200%;
            height: 200%;
            background: conic-gradient(from 0deg, transparent, rgba(255, 215, 0, 0.1), transparent, rgba(0, 245, 255, 0.1), transparent);
            animation: rotate-gradient 15s linear infinite;
            z-index: -1;
        }

        .profile-setup-section h3 {
            color: var(--neon-gold);
            margin-bottom: 30px;
            font-family: 'Orbitron', monospace;
            text-transform: uppercase;
            letter-spacing: 2px;
            text-align: center;
            font-size: 1.8em;
            font-weight: 900;
            text-shadow: 0 0 20px var(--neon-gold);
        }

        .setup-progress {
            background: var(--glass-bg);
            border-radius: 15px;
            padding: 20px;
            margin-bottom: 30px;
            text-align: center;
            border: 2px solid var(--glass-border);
            backdrop-filter: blur(10px);
        }

        .progress-bar {
            background: rgba(255, 215, 0, 0.2);
            height: 10px;
            border-radius: 5px;
            margin: 15px 0;
            overflow: hidden;
            border: 1px solid var(--glass-border);
        }

        .progress-fill {
            background: linear-gradient(90deg, var(--neon-gold), var(--neon-pink));
            height: 100%;
            width: 0%;
            transition: width 0.3s ease;
            box-shadow: 0 0 10px var(--neon-gold);
        }

        .setup-form {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
            gap: 25px;
        }

        .form-section {
            background: var(--glass-bg);
            border: 2px solid var(--glass-border);
            border-radius: 20px;
            padding: 25px;
            backdrop-filter: blur(20px);
            transition: all 0.3s ease;
        }

        .form-section:hover {
            transform: translateY(-3px);
            box-shadow: var(--shadow-neon);
            border-color: var(--accent-cyan);
        }

        .form-section h4 {
            color: var(--accent-cyan);
            margin-bottom: 20px;
            font-size: 1.2em;
            font-family: 'Orbitron', monospace;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 1px;
        }

        .form-group {
            margin-bottom: 20px;
        }

        .form-group label {
            display: block;
            color: var(--text-secondary);
            margin-bottom: 8px;
            font-size: 0.95em;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 1px;
        }

        .form-group input,
        .form-group select,
        .form-group textarea {
            width: 100%;
            background: rgba(0, 0, 0, 0.7);
            border: 2px solid var(--glass-border);
            border-radius: 12px;
            padding: 15px;
            color: var(--text-primary);
            font-family: 'Rajdhani', sans-serif;
            font-size: 1em;
            font-weight: 500;
            transition: all 0.3s ease;
        }

        .form-group input:focus,
        .form-group select:focus,
        .form-group textarea:focus {
            outline: none;
            border-color: var(--accent-cyan);
            box-shadow: 0 0 15px rgba(0, 245, 255, 0.3);
            background: rgba(0, 0, 0, 0.9);
        }

        .form-group select option {
            background: var(--secondary-bg);
            color: var(--text-primary);
        }

        .checkbox-group {
            display: flex;
            align-items: center;
            gap: 12px;
            margin-bottom: 15px;
        }

        .checkbox-group input[type="checkbox"] {
            width: auto;
            margin: 0;
            transform: scale(1.2);
        }

        .checkbox-group label {
            margin: 0;
            font-size: 0.9em;
            text-transform: none;
        }

        .auth-button {
            width: 100%;
            background: linear-gradient(135deg, var(--accent-purple), var(--accent-electric));
            border: none;
            border-radius: 15px;
            padding: 18px 25px;
            color: var(--text-primary);
            font-weight: 700;
            cursor: pointer;
            font-family: 'Orbitron', monospace;
            text-transform: uppercase;
            font-size: 1em;
            letter-spacing: 1px;
            margin-top: 15px;
            transition: all 0.3s ease;
            border: 2px solid transparent;
        }

        .auth-button:hover {
            box-shadow: 0 0 25px rgba(157, 78, 221, 0.6);
            transform: translateY(-3px);
            border-color: var(--accent-cyan);
        }

        .auth-button:disabled {
            opacity: 0.5;
            cursor: not-allowed;
            transform: none;
        }

        .setup-button {
            background: linear-gradient(135deg, var(--neon-gold), var(--neon-pink));
            grid-column: 1 / -1;
            margin-top: 25px;
            color: #000;
            font-weight: 900;
        }

        .skip-button {
            background: linear-gradient(135deg, var(--text-muted), #64748b);
            margin-top: 15px;
        }

        .user-info {
            background: linear-gradient(135deg, rgba(0, 245, 255, 0.2), rgba(76, 205, 196, 0.1));
            border: 2px solid var(--accent-cyan);
            border-radius: 20px;
            padding: 25px;
            margin-bottom: 30px;
            display: none;
            backdrop-filter: blur(20px);
            box-shadow: 0 0 30px rgba(0, 245, 255, 0.3);
        }

        .user-info h3 {
            color: var(--accent-cyan);
            margin-bottom: 20px;
            font-family: 'Orbitron', monospace;
            text-transform: uppercase;
            letter-spacing: 2px;
        }

        .user-details {
            display: flex;
            justify-content: space-between;
            align-items: center;
            flex-wrap: wrap;
            gap: 20px;
        }

        .user-email {
            color: var(--text-secondary);
            font-size: 1.1em;
            font-weight: 600;
        }

        .logout-button {
            background: linear-gradient(135deg, var(--neon-pink), #ff6666);
            border: none;
            border-radius: 12px;
            padding: 12px 20px;
            color: var(--text-primary);
            font-weight: 700;
            cursor: pointer;
            font-family: 'Orbitron', monospace;
            text-transform: uppercase;
            letter-spacing: 1px;
            transition: all 0.3s ease;
        }

        .logout-button:hover {
            box-shadow: 0 0 20px rgba(247, 37, 133, 0.6);
            transform: translateY(-2px);
        }

        /* Removed duplicate Profile Header CSS - using v2 version below */

        .avatar-section {
            text-align: center;
        }
        
        .avatar-container {
            position: relative;
            width: 120px;
            height: 120px;
            margin: 0;
            flex-shrink: 0;
        }
        
        .avatar {
            width: 120px;
            height: 120px;
            border-radius: 50%;
            background: linear-gradient(45deg, var(--accent-purple), var(--accent-electric));
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 48px;
            border: 4px solid var(--glass-border);
            position: relative;
            overflow: hidden;
            box-shadow: var(--shadow-neon);
            animation: avatar-pulse 3s ease-in-out infinite;
            font-family: 'Orbitron', monospace;
            font-weight: 900;
            color: var(--accent-cyan);
            text-shadow: 0 0 20px var(--accent-cyan);
        }
        
        @keyframes avatar-pulse {
            0%, 100% { 
                box-shadow: var(--shadow-neon);
                transform: scale(1);
            }
            50% { 
                box-shadow: 0 0 30px rgba(157, 78, 221, 0.8);
                transform: scale(1.02);
            }
        }
        
        .level-badge {
            position: absolute;
            bottom: -5px;
            right: -5px;
            background: linear-gradient(45deg, var(--neon-gold), var(--accent-cyan));
            color: #000;
            width: 45px;
            height: 45px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-family: 'Orbitron', monospace;
            font-weight: 900;
            font-size: 16px;
            border: 3px solid var(--text-primary);
            animation: level-glow 2s ease-in-out infinite;
            box-shadow: 0 0 15px var(--neon-gold);
        }
        
        @keyframes level-glow {
            0%, 100% { 
                box-shadow: 0 0 15px var(--neon-gold);
                transform: scale(1);
            }
            50% { 
                box-shadow: 0 0 25px var(--neon-gold);
                transform: scale(1.1);
            }
        }
        
        .player-info {
            flex: 1;
            display: flex;
            flex-direction: column;
            justify-content: flex-start;
            gap: 6px;
            min-width: 0;
        }
        
        .player-name {
            font-family: 'Orbitron', monospace;
            font-size: 2.5em;
            font-weight: 900;
            margin-bottom: 10px;
            background: linear-gradient(45deg, var(--accent-cyan), var(--text-primary));
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
            text-transform: uppercase;
            letter-spacing: 2px;
            text-shadow: 2px 2px 4px rgba(0,0,0,0.3);
        }
        
        .player-title {
            font-family: 'Rajdhani', sans-serif;
            font-size: 1.3em;
            color: var(--accent-magenta);
            margin-bottom: 15px;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 1px;
        }
        
        .player-title::before {
            content: '◆';
            color: var(--neon-gold);
            margin-right: 8px;
            font-size: 1.2em;
        }
        
        .player-stats-quick {
            display: flex;
            gap: 25px;
            flex-wrap: wrap;
        }
        
        .quick-stat {
            text-align: center;
            background: var(--glass-bg);
            padding: 15px 20px;
            border-radius: 15px;
            border: 1px solid var(--glass-border);
            backdrop-filter: blur(10px);
            transition: all 0.3s ease;
        }
        
        .quick-stat:hover {
            background: rgba(157, 78, 221, 0.2);
            transform: translateY(-3px);
            box-shadow: var(--shadow-neon);
        }
        
        .quick-stat-value {
            font-family: 'Orbitron', monospace;
            font-size: 1.4em;
            font-weight: 700;
            background: linear-gradient(135deg, #8a2be2, #00ffff);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
            margin-bottom: 5px;
        }
        
        .quick-stat-label {
            font-size: 0.9em;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 1px;
        }
        
        .watts-currency {
            text-align: center;
            background: var(--glass-bg);
            padding: 25px;
            border-radius: 20px;
            backdrop-filter: blur(20px);
            border: 2px solid var(--glass-border);
            transition: all 0.3s ease;
            position: relative;
            overflow: hidden;
        }
        
        .watts-currency::before {
            content: '';
            position: absolute;
            top: 0;
            left: -100%;
            width: 100%;
            height: 100%;
            background: linear-gradient(90deg, transparent, rgba(255, 215, 0, 0.1), transparent);
            animation: watts-sweep 3s infinite;
        }
        
        @keyframes watts-sweep {
            0% { left: -100%; }
            100% { left: 100%; }
        }
        
        .watts-currency:hover {
            animation: watts-pulse 1s infinite;
            box-shadow: 0 0 30px var(--neon-gold);
        }
        
        @keyframes watts-pulse {
            0%, 100% { transform: scale(1); }
            50% { transform: scale(1.05); }
        }
        
        .watts-amount {
            font-family: 'Orbitron', monospace;
            font-size: 2.2em;
            font-weight: 900;
            color: var(--neon-gold);
            margin-bottom: 8px;
            text-shadow: 0 0 15px var(--neon-gold);
        }
        
        .watts-label {
            font-size: 1em;
            color: var(--text-secondary);
            text-transform: uppercase;
            letter-spacing: 1px;
        }
        
        .watts-label::before {
            content: '⚡';
            margin-right: 5px;
            color: var(--accent-cyan);
        }

        /* API Controls */
        .api-controls {
            background: var(--glass-bg);
            border: 2px solid var(--glass-border);
            border-radius: 20px;
            padding: 25px;
            margin-bottom: 30px;
            backdrop-filter: blur(20px);
        }

        .api-controls h3 {
            color: var(--accent-cyan);
            margin-bottom: 20px;
            font-family: 'Orbitron', monospace;
            text-transform: uppercase;
            letter-spacing: 2px;
        }

        .api-controls input {
            background: rgba(0, 0, 0, 0.7);
            border: 2px solid var(--glass-border);
            border-radius: 12px;
            padding: 12px 15px;
            color: var(--text-primary);
            font-family: 'Rajdhani', sans-serif;
            margin-right: 15px;
            width: 250px;
            font-weight: 500;
        }

        .api-controls input:focus {
            outline: none;
            border-color: var(--accent-cyan);
            box-shadow: 0 0 15px rgba(0, 245, 255, 0.3);
        }

        .api-controls button {
            background: linear-gradient(135deg, var(--accent-cyan), var(--accent-purple));
            border: none;
            border-radius: 12px;
            padding: 12px 20px;
            color: var(--text-primary);
            font-weight: 700;
            cursor: pointer;
            font-family: 'Orbitron', monospace;
            text-transform: uppercase;
            letter-spacing: 1px;
            margin: 5px;
            transition: all 0.3s ease;
        }

        .api-controls button:hover {
            box-shadow: 0 0 20px rgba(0, 245, 255, 0.5);
            transform: translateY(-2px);
        }
        
        /* Navigation Tabs */
        .profile-nav {
            background: var(--glass-bg);
            border-radius: 20px;
            padding: 15px;
            margin-bottom: 30px;
            backdrop-filter: blur(20px);
            border: 2px solid var(--glass-border);
        }
        
        .nav-tabs {
            display: flex;
            gap: 10px;
            flex-wrap: wrap;
        }
        
        .nav-tab {
            flex: 1;
            padding: 18px 25px;
            border: none;
            background: transparent;
            color: var(--text-muted);
            border-radius: 15px;
            cursor: pointer;
            transition: all 0.3s ease;
            font-family: 'Orbitron', monospace;
            font-size: 14px;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 1px;
            border: 2px solid transparent;
        }
        
        .nav-tab.active {
            background: linear-gradient(135deg, var(--accent-purple), var(--accent-electric));
            color: var(--text-primary);
            transform: translateY(-3px);
            box-shadow: var(--shadow-neon);
            border-color: var(--accent-cyan);
        }
        
        .nav-tab:hover:not(.active) {
            background: rgba(157, 78, 221, 0.15);
            color: var(--text-primary);
            border-color: var(--glass-border);
        }
        
        /* Content Sections */
        .profile-content {
            display: none;
            animation: fadeIn 0.5s ease-in-out;
        }
        
        .profile-content.active {
            display: block;
        }
        
        @keyframes fadeIn {
            from { opacity: 0; transform: translateY(20px); }
            to { opacity: 1; transform: translateY(0); }
        }
        
        .section-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
            gap: 25px;
            margin-bottom: 30px;
        }
        
        .card {
            background: var(--glass-bg);
            border-radius: 20px;
            padding: 30px;
            backdrop-filter: blur(20px);
            border: 2px solid var(--glass-border);
            transition: all 0.3s ease;
            position: relative;
            overflow: hidden;
        }
        
        .card::before {
            content: '';
            position: absolute;
            top: 0;
            left: -100%;
            width: 100%;
            height: 2px;
            background: linear-gradient(90deg, transparent, var(--accent-cyan), transparent);
            transition: left 0.5s ease;
        }
        
        .card:hover::before {
            left: 100%;
        }
        
        .card:hover {
            transform: translateY(-5px);
            box-shadow: var(--shadow-neon);
            border-color: var(--accent-purple);
            background: rgba(157, 78, 221, 0.15);
        }
        
        .card-header {
            display: flex;
            align-items: center;
            gap: 15px;
            margin-bottom: 25px;
        }
        
        .card-title {
            font-family: 'Orbitron', monospace;
            font-size: 1.3em;
            font-weight: 700;
            color: var(--accent-cyan);
            text-transform: uppercase;
            letter-spacing: 1px;
        }
        
        .card-icon {
            font-size: 1.5em;
            color: var(--accent-magenta);
        }

        /* Stats and Activities */
        .stats-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
            gap: 20px;
        }

        .stat-card {
            background: linear-gradient(135deg, rgba(157, 78, 221, 0.1), rgba(0, 245, 255, 0.1));
            border: 1px solid var(--glass-border);
            padding: 20px;
            border-radius: 15px;
            text-align: center;
            transition: all 0.3s ease;
        }

        .stat-card:hover {
            transform: translateY(-3px);
            box-shadow: var(--shadow-cyan);
            border-color: var(--accent-cyan);
        }

        .stat-value {
            font-size: 2em;
            font-weight: 900;
            color: var(--neon-gold);
            margin-bottom: 5px;
            font-family: 'Orbitron', monospace;
            text-shadow: 0 0 10px var(--neon-gold);
        }

        .stat-label {
            color: var(--text-muted);
            font-size: 0.9em;
            text-transform: uppercase;
            letter-spacing: 1px;
            font-weight: 600;
        }

        .activities-section {
            background: var(--glass-bg);
            border: 2px solid var(--glass-border);
            border-radius: 20px;
            padding: 30px;
            margin-bottom: 30px;
            backdrop-filter: blur(20px);
        }

        .activities-section h3 {
            color: var(--accent-cyan);
            margin-bottom: 20px;
            font-family: 'Orbitron', monospace;
            text-transform: uppercase;
            letter-spacing: 2px;
        }

        .activity-item {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 18px;
            background: rgba(0, 0, 0, 0.3);
            border-radius: 15px;
            margin-bottom: 15px;
            transition: all 0.3s ease;
            border: 1px solid var(--glass-border);
        }

        .activity-item:hover {
            background: rgba(157, 78, 221, 0.2);
            transform: translateX(8px);
            box-shadow: var(--shadow-neon);
            border-color: var(--accent-cyan);
        }

        .activity-info .type {
            color: var(--accent-cyan);
            font-weight: 700;
            margin-bottom: 5px;
            font-family: 'Orbitron', monospace;
            text-transform: uppercase;
            letter-spacing: 1px;
        }

        .activity-info .date {
            color: var(--text-muted);
            font-size: 0.9em;
        }

        .activity-stats {
            display: flex;
            gap: 20px;
            color: var(--neon-gold);
            font-family: 'Orbitron', monospace;
            font-weight: 700;
        }

        /* Debug Section */
        .debug-section {
            background: linear-gradient(135deg, rgba(247, 37, 133, 0.1), rgba(0, 0, 0, 0.8));
            border: 2px solid var(--neon-pink);
            border-radius: 20px;
            padding: 25px;
            margin-top: 30px;
            backdrop-filter: blur(20px);
        }

        .debug-section h3 {
            color: var(--neon-pink);
            margin-bottom: 20px;
            font-family: 'Orbitron', monospace;
            text-transform: uppercase;
            letter-spacing: 2px;
        }

        .debug-section pre {
            background: rgba(0, 0, 0, 0.7);
            padding: 20px;
            border-radius: 15px;
            color: var(--accent-cyan);
            font-size: 0.85em;
            overflow-x: auto;
            max-height: 300px;
            overflow-y: auto;
            border: 1px solid var(--glass-border);
            font-family: 'Courier New', monospace;
        }

        .auth-status {
            color: var(--text-muted);
            font-size: 0.9em;
            margin-top: 15px;
            text-align: center;
            font-family: 'Orbitron', monospace;
            text-transform: uppercase;
            letter-spacing: 1px;
        }

        /* Responsive Design */
        @media (max-width: 1200px) {
            /* Nothing needed — new layout handles all widths without this */
        }
        
        @media (max-width: 768px) {

            /* ── GLOBAL ── */
            * { box-sizing: border-box; }
            .container { padding: 10px; }
            .section { padding: 0; }

            /* ── PROFILE HEADER ── */
            .profile-header { padding: 14px 12px; border-radius: 16px; }
            .auth-section, .profile-setup-section { padding: 18px 14px; }

            /* Compact layout: [avatar+info row] [watts compact right] / [quick-stats full width] */
            .profile-main {
                grid-template-columns: 1fr auto !important;
                grid-template-rows: auto auto !important;
                gap: 10px 10px !important;
                align-items: start !important;
            }

            /* Avatar: shrink on mobile */
            .avatar-section { gap: 10px !important; }
            .avatar { width: 56px; height: 56px; font-size: 22px; }
            .avatar-container { width: 56px; height: 56px; flex-shrink: 0; }
            .level-badge { width: 22px; height: 22px; font-size: 9px; bottom: -2px; right: -2px; border-width: 2px; }

            /* Player info: tighter */
            .player-info { min-width: 0; overflow: hidden; }
            
            
            .player-name {
                font-size: clamp(1em, 4vw, 1.5em) !important;
                letter-spacing: 0.5px !important;
                margin-bottom: 3px !important;
                white-space: nowrap !important;
                overflow: hidden !important;
                text-overflow: ellipsis !important;
            }
            .player-title {
                font-size: 0.78em !important;
                margin-bottom: 5px !important;
                letter-spacing: 0.3px !important;
                white-space: nowrap !important;
            }
            .player-title::before { font-size: 0.9em; margin-right: 4px; }

            /* XP bar: full width, slim */
            .xp-bar-wrap {
                max-width: 100% !important;
                height: 18px !important;
                margin: 4px 0 !important;
            }
            .xp-bar-text { font-size: 8px !important; letter-spacing: 0.2px; }

            /* Badge pill: compact */
            #profileBadgeStrip {
                margin-top: 5px !important;
            }
            .badge-pill {
                font-size: 7px !important;
                padding: 2px 8px !important;
                letter-spacing: 0.3px !important;
            }

            /* Watts: fixed small pill, always top-right */
            .watts-currency {
                grid-column: 2 !important;
                grid-row: 1 !important;
                width: 80px !important;
                min-width: 0 !important;
                padding: 8px 8px !important;
                margin: 0 !important;
                border-radius: 12px !important;
                align-self: start !important;
            }
            .watts-amount { font-size: 0.95em !important; margin-bottom: 2px !important; }
            .watts-label { font-size: 0.55em !important; letter-spacing: 0 !important; }

            /* Quick stats: full-width row 2, 5 columns */
            .player-stats-quick {
                grid-column: 1 / -1 !important;
                grid-row: 2 !important;
                display: grid !important;
                grid-template-columns: repeat(5, 1fr) !important;
                gap: 6px !important;
                width: 100% !important;
                margin-top: 4px !important;
                flex-wrap: unset !important;
            }
            .quick-stat {
                padding: 10px 4px !important;
                border-radius: 10px !important;
                display: flex !important;
                flex-direction: column !important;
                justify-content: center !important;
                align-items: center !important;
                min-width: 0 !important;
            }
            .quick-stat-value {
                font-size: 0.82em !important;
                margin-bottom: 3px !important;
                white-space: nowrap !important;
                overflow: hidden !important;
                text-overflow: ellipsis !important;
                max-width: 100% !important;
            }
            .quick-stat-label {
                font-size: 0.58em !important;
                letter-spacing: 0 !important;
                line-height: 1.3;
                white-space: normal !important;
                word-break: break-word;
            }
            .player-title::before { font-size: 0.9em; margin-right: 3px; }
            .quick-stat-label {
                font-size: 0.58em !important;
                letter-spacing: 0 !important;
                line-height: 1.3;
                white-space: normal !important;
                word-break: break-word;
            }

            #claimProfileBanner {
                flex-direction: column !important;
                gap: 8px !important;
                padding: 12px !important;
                text-align: center;
                margin-top: 8px;
            }

            /* ── NAV TABS: wrap into multiple rows, always all visible ── */
            .profile-nav {
                padding: 8px 8px !important;
                margin-bottom: 12px !important;
                border-radius: 12px !important;
                overflow: visible !important;
            }
            .nav-tabs {
                display: flex !important;
                flex-wrap: wrap !important;
                overflow-x: visible !important;
                overflow-y: visible !important;
                gap: 6px !important;
                padding-bottom: 0 !important;
            }
            .nav-tabs::-webkit-scrollbar { display: none; }
            .nav-tab {
                flex: 1 1 calc(33.333% - 6px) !important;
                min-width: 0 !important;
                max-width: calc(50% - 6px) !important;
                white-space: nowrap !important;
                overflow: hidden !important;
                text-overflow: ellipsis !important;
                padding: 9px 6px !important;
                font-size: 9px !important;
                letter-spacing: 0.2px !important;
                border-radius: 10px !important;
                text-align: center !important;
                transform: none !important;
            }
            .nav-tab.active {
                padding: 9px 8px !important;
                font-size: 9px !important;
                transform: none !important;
            }
            
            
            

            /* ── SECTION GRID ── */
            .section-grid { grid-template-columns: 1fr; gap: 14px; }

            /* ── STATS GRID ── */
            .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
            .stat-card { padding: 12px 10px; }
            .stat-value { font-size: 20px; }

            /* ── AUTH FORMS ── */
            .auth-forms { grid-template-columns: 1fr; }
            .setup-form { grid-template-columns: 1fr; }
            .api-controls input { width: 100%; margin-bottom: 10px; margin-right: 0; }

            /* ── LOADOUT ── */
            .parts-layout { grid-template-columns: 1fr !important; gap: 14px; }
            .parts-sidebar { flex-direction: row !important; flex-wrap: wrap; gap: 6px; }
            .part-cat-btn { flex: 1 1 calc(50% - 6px) !important; min-width: 0 !important; max-width: calc(50% - 3px); padding: 8px 10px; gap: 7px; }
            .pcat-icon { font-size: 1.1em; }
            .pcat-name { font-size: 0.68em; }
            .pcat-sub, .pcat-eff { font-size: 8px; }
            .parts-panel { padding: 12px 10px; }
            .parts-panel-hdr { font-size: 0.75em; margin-bottom: 12px; }
            .parts-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 10px; }
            .part-card2 { padding: 12px 10px; }
            .p2-name { font-size: 0.75em; }
            .p2-desc { font-size: 10px; }
            .p2-tag { font-size: 8px; padding: 2px 6px; }
            .bss-label { font-size: 9px; width: 50px; }
            .bss-val { font-size: 10px; }

            /* ── ACHIEVEMENTS ── */
            .ach-filters { gap: 5px; }
            .ach-filter-btn { padding: 5px 10px; font-size: 10px; }
            .ach-grid { grid-template-columns: 1fr !important; gap: 10px; }
            .ach2-icon { font-size: 0; }

            /* ── COLLECTION ── */
            .collection-grid,
            #collectionAllGrid, #collectionBikeGrid, #collectionMaterialGrid,
            #collectionEnvironmentGrid, #collectionMusicGrid, #collectionAbilityGrid {
                grid-template-columns: repeat(2, 1fr) !important; gap: 10px;
            }
            .collection-item { padding: 12px 8px; }
            .item-name { font-size: 11px; }

            /* ── TABS ── */
            .tabs { flex-wrap: wrap; gap: 4px; }
            .tab { flex: 1 1 calc(33% - 4px); font-size: 11px; padding: 7px 4px; text-align: center; }

            /* ── MILESTONE / PROGRESS ── */
            .milestone-grid { grid-template-columns: 1fr !important; gap: 8px; }
            .milestone-card { padding: 12px 10px; }
            .milestone-name { font-size: 0.8em; }

            /* ── GANG / MISSIONS ── */
            .missions-layout, .missions-tabs-content { padding: 0; }
            .gang-lb-table { font-size: 11px; }
            .gang-lb-table th, .gang-lb-table td { padding: 6px 4px; }
            .gang-map-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 8px; }
            .gang-map-card { padding: 12px 8px; }
            .gmc-name { font-size: 10px; }
            .gang-leader-block { padding: 10px; gap: 10px; }
            .gang-leader-name { font-size: 0.78em; }

            /* ── INBOX ── */
            .inbox-message { padding: 12px 10px; }
            .im-subject { font-size: 12px; }
            .im-preview, .im-expanded { font-size: 12px; }

            /* ── GANG FEED / RIVALS ── */
            .gf-cards-wrap { padding: 0 4px; }
            .gf-card { min-width: 180px; padding: 12px 10px; }
            .rr-card { min-width: 200px; }
            .rivals-layout { grid-template-columns: 1fr !important; }

            /* ── SCHEDULE / FITNESS ── */
            .sched-layout { grid-template-columns: 1fr !important; }
            .cal-grid { gap: 3px; }
            .fit-stats-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 8px; }
            .fit-stat { padding: 12px 8px; }
            .fit-stat-val { font-size: 1.1em; }

            /* ── CITY MAP ── */
            #mapOuter { height: 280px !important; }
            .map-legend { flex-wrap: wrap; gap: 6px; }
            .map-legend-item { font-size: 11px; }
            .map-ticker { font-size: 10px; gap: 8px; flex-wrap: wrap; }
            .ticker-item { font-size: 10px; }

            /* ── SECTION TITLES / CARDS ── */
            .section-title, h2.section-title { font-size: 1.2em; }
            .card { padding: 16px 12px !important; border-radius: 14px; }

            /* ── OVERFLOW SAFETY ── */
            .profile-content, .profile-content > *, .section,
            .card, .parts-panel { max-width: 100%; overflow-x: hidden; }
            .gang-lb-table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; max-width: 100%; }

            /* ── PERSONAL BESTS ── */
            #personalBestsGrid { grid-template-columns: repeat(2, 1fr) !important; gap: 8px; }
            .pb-mode-header { font-size: 0.75em; }
        }

        /* ── EXTRA SMALL (iPhone SE / ≤390px) ── */
        @media (max-width: 390px) {
            .player-name { font-size: 0.95em !important; }
            .watts-currency { max-width: 72px !important; }
            .watts-amount { font-size: 0.88em !important; }
            /* Stay 5-col, just tighter */
            .player-stats-quick { gap: 4px !important; }
            .quick-stat { padding: 8px 2px !important; }
            .quick-stat-value { font-size: 0.72em !important; }
            .quick-stat-label { font-size: 0.5em !important; }
            /* 2-per-row nav tabs at very small */
            .nav-tab {
                flex: 1 1 calc(50% - 6px) !important;
                max-width: calc(50% - 6px) !important;
                font-size: 7.5px !important;
                padding: 8px 4px !important;
            }
            .parts-grid { grid-template-columns: 1fr !important; }
            .stats-grid { grid-template-columns: 1fr; }
        }

        /* Keep existing mockup sections for later implementation */
        .badges-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
            gap: 20px;
        }
        
        .badge {
            background: var(--glass-bg);
            border-radius: 15px;
            padding: 20px;
            text-align: center;
            transition: all 0.3s ease;
            cursor: pointer;
            border: 2px solid var(--glass-border);
            backdrop-filter: blur(10px);
        }
        
        .badge.unlocked {
            background: linear-gradient(135deg, rgba(255, 215, 0, 0.2), rgba(247, 37, 133, 0.15));
            border-color: var(--neon-gold);
            box-shadow: 0 4px 15px rgba(255, 215, 0, 0.3);
            animation: badge-shine 3s ease-in-out infinite;
        }
        
        .badge.locked {
            opacity: 0.4;
            filter: grayscale(100%);
        }
        
        @keyframes badge-shine {
            0%, 100% { box-shadow: 0 4px 15px rgba(255, 215, 0, 0.3); }
            50% { box-shadow: 0 8px 25px rgba(255, 215, 0, 0.6); }
        }
        
        .badge-icon {
            font-family: 'Orbitron', monospace;
            font-size: 2.5em;
            margin-bottom: 12px;
            font-weight: 900;
            color: var(--accent-cyan);
        }
        
        .badge.unlocked .badge-icon {
            color: var(--neon-gold);
        }
        
        .badge-name {
            font-family: 'Orbitron', monospace;
            font-size: 0.9em;
            font-weight: 700;
            margin-bottom: 8px;
            color: var(--text-primary);
            text-transform: uppercase;
            letter-spacing: 1px;
        }
        
        .badge-description {
            font-size: 0.8em;
            color: var(--text-muted);
            line-height: 1.3;
        }

        /* Additional mockup styles for bike, loadout, shop sections */
        .bike-preview {
            text-align: center;
            margin-bottom: 25px;
        }
        
        .bike-model {
            width: 220px;
            height: 140px;
            background: linear-gradient(45deg, var(--accent-purple), var(--accent-electric));
            border-radius: 15px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 4em;
            margin: 0 auto 20px;
            position: relative;
            overflow: hidden;
            border: 2px solid var(--glass-border);
            box-shadow: var(--shadow-neon);
            color: var(--accent-cyan);
            font-family: 'Orbitron', monospace;
        }
        
        .bike-name {
            font-family: 'Orbitron', monospace;
            font-weight: 700;
            font-size: 1.2em;
            margin-bottom: 10px;
            color: var(--text-primary);
            text-transform: uppercase;
            letter-spacing: 1px;
        }
        
        .upgrade-slots {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(80px, 1fr));
            gap: 15px;
            margin-top: 25px;
        }
        
        .upgrade-slot {
            aspect-ratio: 1;
            background: var(--glass-bg);
            border-radius: 15px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1.8em;
            cursor: pointer;
            transition: all 0.3s ease;
            border: 2px solid var(--glass-border);
            backdrop-filter: blur(10px);
            font-family: 'Orbitron', monospace;
            color: var(--accent-cyan);
        }
        
        .upgrade-slot.equipped {
            background: linear-gradient(45deg, var(--neon-gold), var(--neon-pink));
            border-color: var(--neon-gold);
            box-shadow: 0 0 20px var(--neon-gold);
            animation: equipped-pulse 2s ease-in-out infinite;
            color: #000;
        }
        
        @keyframes equipped-pulse {
            0%, 100% { transform: scale(1); }
            50% { transform: scale(1.05); }
        }
        
        .upgrade-slot:hover {
            transform: scale(1.1);
            background: rgba(157, 78, 221, 0.2);
            border-color: var(--accent-cyan);
            box-shadow: var(--shadow-cyan);
        }

        .loadout-slots {
            display: grid;
            grid-template-columns: repeat(5, 1fr);
            gap: 20px;
            margin-top: 25px;
        }
        
        .loadout-slot {
            aspect-ratio: 1;
            background: var(--glass-bg);
            border-radius: 15px;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            cursor: pointer;
            transition: all 0.3s ease;
            border: 2px solid var(--glass-border);
            padding: 15px;
            backdrop-filter: blur(10px);
        }
        
        .loadout-slot.equipped {
            border-color: var(--neon-gold);
            background: linear-gradient(45deg, rgba(255, 215, 0, 0.2), rgba(247, 37, 133, 0.15));
            box-shadow: 0 0 20px rgba(255, 215, 0, 0.4);
        }
        
        .loadout-slot:hover {
            transform: scale(1.08);
            background: rgba(157, 78, 221, 0.2);
            border-color: var(--accent-cyan);
            box-shadow: var(--shadow-cyan);
        }
        
        .loadout-icon {
            font-family: 'Orbitron', monospace;
            font-size: 2em;
            margin-bottom: 8px;
            font-weight: 900;
            color: var(--accent-cyan);
        }
        
        .loadout-slot.equipped .loadout-icon {
            color: var(--neon-gold);
        }
        
        .loadout-name {
            font-size: 0.8em;
            text-align: center;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 1px;
            font-weight: 600;
        }
        
        .loadout-slot.equipped .loadout-name {
            color: var(--text-primary);
            font-weight: 700;
        }

        .shop-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
            gap: 25px;
        }
        
        .shop-item {
            background: var(--glass-bg);
            border-radius: 20px;
            padding: 25px;
            text-align: center;
            transition: all 0.3s ease;
            cursor: pointer;
            border: 2px solid var(--glass-border);
            backdrop-filter: blur(20px);
            position: relative;
            overflow: hidden;
        }
        
        .shop-item::before {
            content: '';
            position: absolute;
            top: 0;
            left: -100%;
            width: 100%;
            height: 100%;
            background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);
            transition: left 0.5s ease;
        }
        
        .shop-item:hover::before {
            left: 100%;
        }
        
        .shop-item:hover {
            transform: translateY(-8px);
            border-color: var(--neon-gold);
            box-shadow: 0 15px 35px rgba(255, 215, 0, 0.3);
        }
        
        .shop-item.affordable {
            border-color: var(--accent-cyan);
        }
        
        .shop-item.affordable:hover {
            border-color: var(--neon-gold);
            box-shadow: 0 15px 35px rgba(0, 245, 255, 0.3);
        }
        
        .shop-item.expensive {
            opacity: 0.6;
            filter: grayscale(50%);
        }
        
        .shop-icon {
            font-family: 'Orbitron', monospace;
            font-size: 3.5em;
            margin-bottom: 20px;
            font-weight: 900;
            color: var(--accent-cyan);
        }
        
        .shop-item.affordable .shop-icon {
            color: var(--accent-cyan);
            animation: shop-glow 2s ease-in-out infinite alternate;
        }
        
        @keyframes shop-glow {
            0% { 
                text-shadow: 0 0 20px var(--accent-cyan);
                transform: scale(1);
            }
            100% { 
                text-shadow: 0 0 30px var(--accent-cyan), 0 0 40px var(--accent-magenta);
                transform: scale(1.05);
            }
        }
        
        .shop-name {
            font-family: 'Orbitron', monospace;
            font-weight: 700;
            margin-bottom: 15px;
            color: var(--text-primary);
            text-transform: uppercase;
            letter-spacing: 1px;
        }
        
        .shop-price {
            color: var(--neon-gold);
            font-family: 'Orbitron', monospace;
            font-weight: 900;
            font-size: 1.3em;
            text-shadow: 0 0 10px var(--neon-gold);
        }

        .run-history {
            max-height: 450px;
            overflow-y: auto;
            scrollbar-width: thin;
            scrollbar-color: var(--accent-purple) transparent;
        }
        
        .run-history::-webkit-scrollbar {
            width: 8px;
        }
        
        .run-history::-webkit-scrollbar-track {
            background: transparent;
        }
        
        .run-history::-webkit-scrollbar-thumb {
            background: var(--accent-purple);
            border-radius: 4px;
        }
        
        .run-item {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 18px;
            background: var(--glass-bg);
            border-radius: 15px;
            margin-bottom: 15px;
            transition: all 0.3s ease;
            border: 1px solid var(--glass-border);
            backdrop-filter: blur(10px);
        }
        
        .run-item:hover {
            background: rgba(157, 78, 221, 0.2);
            transform: translateX(8px);
            box-shadow: var(--shadow-neon);
            border-color: var(--accent-cyan);
        }
        
        .run-info {
            flex: 1;
        }
        
        .run-mode {
            font-family: 'Orbitron', monospace;
            font-weight: 700;
            margin-bottom: 8px;
            color: var(--text-primary);
            text-transform: uppercase;
            letter-spacing: 1px;
        }
        
        .run-mode::before {
            content: '▣';
            color: var(--accent-cyan);
            margin-right: 8px;
            font-size: 1.1em;
        }
        
        .run-details {
            font-size: 0.9em;
            color: var(--text-muted);
        }
        
        .run-score {
            text-align: right;
            font-family: 'Orbitron', monospace;
            font-weight: 700;
            color: var(--neon-gold);
            font-size: 1.1em;
        }
        
        /* Navigation */
        .navbar {
            background: rgba(10, 10, 15, 0.9);
            backdrop-filter: blur(20px);
            border-bottom: 1px solid var(--glass-border);
            padding: 15px 0;
            position: sticky;
            top: 0;
            z-index: 1000;
        }
        
        .nav-container {
            max-width: 1200px;
            margin: 0 auto;
            padding: 0 20px;
            display: flex;
            justify-content: space-between;
            align-items: center;
        }
        
        .logo {
            display: flex;
            align-items: center;
            gap: 12px;
            text-decoration: none;
            color: var(--text-primary);
            font-family: 'Orbitron', monospace;
            font-weight: 700;
            font-size: 1.5em;
        }
        
        .logo-icon {
            font-size: 1.5em;
            color: var(--accent-cyan);
        }
        
        .nav-links {
            display: flex;
            list-style: none;
            gap: 30px;
            align-items: center;
        }
        
        .nav-links a {
            text-decoration: none;
            color: var(--text-secondary);
            font-weight: 500;
            transition: all 0.3s ease;
            padding: 8px 16px;
            border-radius: 8px;
        }
        
        .nav-links a:hover {
            color: var(--accent-cyan);
            background: rgba(0, 245, 255, 0.1);
        }
        
        .nav-links a.active {
            color: var(--accent-cyan);
            background: rgba(0, 245, 255, 0.15);
        }

        /* ── Hamburger button ── */
        .pp-hamburger-btn {
            display: none;
            flex-direction: column;
            justify-content: center;
            gap: 5px;
            width: 40px;
            height: 40px;
            background: rgba(157, 78, 221, 0.15);
            border: 1px solid rgba(157, 78, 221, 0.4);
            border-radius: 8px;
            cursor: pointer;
            padding: 8px;
            flex-shrink: 0;
        }
        .pp-ham-line {
            display: block;
            width: 100%;
            height: 2px;
            background: var(--accent-cyan);
            border-radius: 2px;
            transition: all 0.3s ease;
        }
        .pp-hamburger-btn.open .pp-ham-line:nth-child(1) { transform: translateY(7px) rotate(45deg); }
        .pp-hamburger-btn.open .pp-ham-line:nth-child(2) { opacity: 0; }
        .pp-hamburger-btn.open .pp-ham-line:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

        /* ── Mobile overlay ── */
        .pp-mobile-overlay {
            display: none;
            position: fixed;
            inset: 0;
            background: rgba(0,0,0,0.6);
            z-index: 1998;
            backdrop-filter: blur(4px);
            -webkit-backdrop-filter: blur(4px);
        }
        .pp-mobile-overlay.active { display: block; }

        /* ── Mobile slide menu ── */
        .pp-mobile-menu {
            display: none;
            position: fixed;
            top: 0; right: 0;
            width: min(320px, 85vw);
            height: 100%;
            background: linear-gradient(160deg, #12122a 0%, #1a1a2e 100%);
            border-left: 1px solid var(--glass-border);
            z-index: 1999;
            flex-direction: column;
            box-shadow: -8px 0 40px rgba(157,78,221,0.4);
            transform: translateX(100%);
            transition: transform 0.3s ease;
        }
        .pp-mobile-menu.active {
            display: flex;
            transform: translateX(0);
        }
        .pp-menu-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 20px;
            border-bottom: 1px solid var(--glass-border);
        }
        .pp-menu-title {
            font-family: 'Orbitron', monospace;
            font-size: 1em;
            color: var(--accent-cyan);
            letter-spacing: 3px;
            text-shadow: 0 0 10px rgba(0,245,255,0.5);
        }
        .pp-menu-close {
            background: none;
            border: 1px solid rgba(157,78,221,0.4);
            color: var(--text-secondary);
            font-size: 1.1em;
            width: 34px; height: 34px;
            border-radius: 6px;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
        }
        .pp-mobile-nav-links {
            list-style: none;
            padding: 10px 0;
            flex: 1;
            overflow-y: auto;
        }
        .pp-mobile-nav-links li a {
            display: block;
            padding: 16px 24px;
            color: var(--text-secondary);
            text-decoration: none;
            font-family: 'Orbitron', monospace;
            font-size: 0.78em;
            letter-spacing: 1px;
            text-transform: uppercase;
            border-bottom: 1px solid rgba(157,78,221,0.1);
            transition: all 0.2s ease;
        }
        .pp-mobile-nav-links li a:active,
        .pp-mobile-nav-links li a.active {
            color: var(--accent-cyan);
            background: rgba(0,245,255,0.08);
        }
        .pp-menu-notif {
            padding: 20px 24px;
            border-top: 1px solid var(--glass-border);
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 12px;
        }
        .pp-menu-notif-label {
            font-family: 'Rajdhani', sans-serif;
            font-size: 0.9em;
            color: var(--text-secondary);
        }

        /* ── Hide desktop nav + notif toggle on mobile ── */
        @media (max-width: 900px) {
            #desktopNavPP,
            #desktopNotifSetting { display: none !important; }
            .pp-hamburger-btn { display: flex; }
            .nav-container { padding: 0 16px; }
            .logo { font-size: 1.05em; }
            .logo-icon { font-size: 1em; }
        }

        /* Profile Header from v2 */
        .profile-header {
            background: linear-gradient(135deg,
                rgba(157, 78, 221, 0.2) 0%,
                rgba(114, 9, 183, 0.15) 25%,
                rgba(247, 37, 133, 0.2) 50%,
                rgba(67, 97, 238, 0.15) 75%,
                rgba(0, 245, 255, 0.2) 100%);
            border-radius: 25px;
            padding: 40px;
            margin-bottom: 30px;
            position: relative;
            overflow: hidden;
            backdrop-filter: blur(20px);
            border: 2px solid rgba(157, 78, 221, 0.3);
            box-shadow: 0 20px 40px rgba(157, 78, 221, 0.3);
        }

        .profile-header::before {
            content: '';
            position: absolute;
            top: -50%;
            left: -50%;
            width: 200%;
            height: 200%;
            background: conic-gradient(from 0deg, transparent, rgba(157, 78, 221, 0.1), transparent, rgba(0, 245, 255, 0.1), transparent);
            animation: rotate-gradient 15s linear infinite;
            z-index: -1;
        }

        @keyframes rotate-gradient {
            0% { transform: rotate(0deg); }
            100% { transform: rotate(360deg); }
        }

        .profile-main {
            display: grid;
            grid-template-columns: 1fr auto;
            grid-template-rows: auto auto;
            gap: 20px 24px;
            align-items: start;
            position: relative;
            z-index: 2;
        }

        /* Avatar + info together in the left column */
        .avatar-section {
            display: flex;
            align-items: flex-start;
            gap: 20px;
            grid-column: 1;
            grid-row: 1;
            text-align: left;
        }

        /* Watts: right column, row 1 only, never full-width */
        .watts-currency {
            grid-column: 2;
            grid-row: 1;
            text-align: center;
            background: rgba(157, 78, 221, 0.1);
            padding: 20px 18px;
            border-radius: 20px;
            backdrop-filter: blur(20px);
            border: 2px solid rgba(157, 78, 221, 0.3);
            transition: all 0.3s ease;
            position: relative;
            overflow: hidden;
            width: 130px;
            flex-shrink: 0;
        }

        /* Quick-stats: full width, row 2 */
        .player-stats-quick {
            grid-column: 1 / -1;
            grid-row: 2;
            display: flex;
            gap: 12px;
            flex-wrap: nowrap;
        }

        .quick-stat {
            flex: 1;
            text-align: center;
            background: rgba(157, 78, 221, 0.1);
            padding: 14px 8px;
            border-radius: 15px;
            border: 1px solid rgba(157, 78, 221, 0.3);
            backdrop-filter: blur(10px);
            transition: all 0.3s ease;
            min-width: 0;
        }

        .avatar-container {
            position: relative;
            width: 120px;
            height: 120px;
            flex-shrink: 0;
        }

        .avatar {
            width: 120px;
            height: 120px;
            border-radius: 50%;
            background: linear-gradient(45deg, #9d4edd, #7209b7);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 48px;
            border: 4px solid rgba(157, 78, 221, 0.3);
            position: relative;
            overflow: hidden;
            box-shadow: 0 0 20px rgba(157, 78, 221, 0.5);
            animation: avatar-pulse 3s ease-in-out infinite;
            font-family: 'Orbitron', monospace;
            font-weight: 900;
            color: #00f5ff;
            text-shadow: 0 0 20px #00f5ff;
        }

        @keyframes avatar-pulse {
            0%, 100% { box-shadow: 0 0 20px rgba(157, 78, 221, 0.5); transform: scale(1); }
            50% { box-shadow: 0 0 30px rgba(157, 78, 221, 0.8); transform: scale(1.02); }
        }

        .level-badge {
            position: absolute;
            bottom: -5px;
            right: -5px;
            background: linear-gradient(45deg, #ffd700, #00f5ff);
            color: #000;
            width: 45px;
            height: 45px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-family: 'Orbitron', monospace;
            font-weight: 900;
            font-size: 16px;
            border: 3px solid #fff;
            animation: level-glow 2s ease-in-out infinite;
            box-shadow: 0 0 15px #ffd700;
        }

        @keyframes level-glow {
            0%, 100% { box-shadow: 0 0 15px #ffd700; transform: scale(1); }
            50% { box-shadow: 0 0 25px #ffd700; transform: scale(1.1); }
        }

        .player-name {
            font-family: 'Orbitron', monospace;
            font-size: clamp(1.2em, 3vw, 2.5em);
            font-weight: 900;
            margin-bottom: 0px;
            background: linear-gradient(45deg, #00f5ff, #ffffff);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
            text-transform: uppercase;
            letter-spacing: 2px;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            min-width: 0;
            max-width: 100%;
        }

        .player-title {
            font-family: 'Rajdhani', sans-serif;
            font-size: clamp(0.85em, 1.5vw, 1.3em);
            color: #e0aaff;
            margin-bottom: 12px;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 1px;
            white-space: nowrap;
        }

        .player-title::before {
            content: '◆';
            color: #ffd700;
            margin-right: 8px;
            font-size: 1.2em;
        }

        .quick-stat:hover {
            background: rgba(157, 78, 221, 0.2);
            transform: translateY(-3px);
            box-shadow: 0 0 20px rgba(157, 78, 221, 0.5);
        }

        .quick-stat-value {
            font-family: 'Orbitron', monospace;
            font-size: clamp(0.9em, 1.5vw, 1.4em);
            font-weight: 700;
            background: linear-gradient(135deg, #8a2be2, #00ffff);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
            margin-bottom: 5px;
            white-space: nowrap;
        }

        .quick-stat-label {
            font-size: clamp(0.65em, 1vw, 0.9em);
            color: #8b5cf6;
            text-transform: uppercase;
            letter-spacing: 1px;
        }

        .watts-currency::before {
            content: '';
            position: absolute;
            top: 0;
            left: -100%;
            width: 100%;
            height: 100%;
            background: linear-gradient(90deg, transparent, rgba(255, 215, 0, 0.1), transparent);
            animation: watts-sweep 3s infinite;
        }

        @keyframes watts-sweep {
            0% { left: -100%; }
            100% { left: 100%; }
        }

        .watts-currency:hover {
            animation: watts-pulse 1s infinite;
            box-shadow: 0 0 30px #ffd700;
        }

        @keyframes watts-pulse {
            0%, 100% { transform: scale(1); }
            50% { transform: scale(1.05); }
        }

        .watts-amount {
            font-family: 'Orbitron', monospace;
            font-size: clamp(1.2em, 2vw, 2.2em);
            font-weight: 900;
            color: #ffd700;
            margin-bottom: 6px;
            text-shadow: 0 0 15px #ffd700;
        }

        .watts-label {
            font-size: clamp(0.7em, 1vw, 1em);
            color: #c77dff;
            text-transform: uppercase;
            letter-spacing: 1px;
        }

        .watts-label::before {
            content: '⚡';
            margin-right: 5px;
            color: #00f5ff;
        }

        /* Content Sections from v2 */
        .profile-content {
            display: none;
            animation: fadeInUp 0.3s ease;
        }

        .profile-content.active {
            display: block;
        }

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

        /* Stats Grid from v2 */
        .stats-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
            gap: 15px;
            margin-bottom: 30px;
        }

        .stat-card {
            background: rgba(20, 20, 30, 0.8);
            backdrop-filter: blur(10px);
            border: 1px solid rgba(138, 43, 226, 0.3);
            padding: 20px;
            border-radius: 15px;
            transition: all 0.3s;
            position: relative;
            overflow: hidden;
        }

        .stat-card::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 3px;
            background: linear-gradient(90deg, #8a2be2, #00ffff, #ff0080);
        }

        .stat-card:hover {
            transform: translateY(-5px);
            box-shadow: 0 10px 40px rgba(138, 43, 226, 0.4);
            border-color: #8a2be2;
        }

        .stat-value {
            font-size: 32px;
            font-weight: 900;
            font-family: 'Orbitron', sans-serif;
            background: linear-gradient(135deg, #8a2be2, #00ffff);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            margin-bottom: 5px;
        }

        .stat-label {
            font-size: 13px;
            color: rgba(255, 255, 255, 0.6);
            text-transform: uppercase;
            letter-spacing: 1px;
        }

        /* Section */
        .section {
            background: rgba(20, 20, 30, 0.8);
            backdrop-filter: blur(10px);
            border: 1px solid rgba(138, 43, 226, 0.3);
            border-radius: 20px;
            padding: 30px;
            margin-bottom: 30px;
            box-shadow: 0 0 30px rgba(138, 43, 226, 0.15);
        }

        .section-title {
            font-family: 'Orbitron', sans-serif;
            font-size: 28px;
            font-weight: 700;
            margin-bottom: 25px;
            background: linear-gradient(135deg, #8a2be2, #00ffff);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            text-transform: uppercase;
            letter-spacing: 2px;
            position: relative;
            padding-bottom: 15px;
        }

        .section-title::after {
            content: '';
            position: absolute;
            bottom: 0;
            left: 0;
            width: 100px;
            height: 3px;
            background: linear-gradient(90deg, #8a2be2, #00ffff);
            box-shadow: 0 0 10px rgba(138, 43, 226, 0.8);
        }

        /* Period Stats Section */
        .period-stats {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
            gap: 25px;
        }

        .period-card {
            background: rgba(30, 30, 45, 0.6);
            border: 1px solid rgba(138, 43, 226, 0.3);
            border-radius: 15px;
            padding: 25px;
            position: relative;
            overflow: hidden;
        }

        .period-card::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 3px;
            background: linear-gradient(90deg, #8a2be2, #00ffff);
        }

        .period-title {
            font-family: 'Orbitron', sans-serif;
            font-size: 22px;
            font-weight: 700;
            margin-bottom: 20px;
            color: #00ffff;
            text-transform: uppercase;
            letter-spacing: 1px;
        }

        .period-stat-row {
            display: flex;
            justify-content: space-between;
            padding: 10px 0;
            border-bottom: 1px solid rgba(138, 43, 226, 0.2);
        }

        .period-stat-row:last-child {
            border-bottom: none;
        }

        .period-stat-label {
            font-size: 15px;
            color: rgba(255, 255, 255, 0.7);
        }

        .period-stat-value {
            font-size: 18px;
            font-weight: 700;
            font-family: 'Orbitron', sans-serif;
            background: linear-gradient(135deg, #8a2be2, #00ffff);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
        }

        /* Loadout Grid */
        .loadout-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
            gap: 20px;
        }

        .loadout-item {
            background: rgba(30, 30, 45, 0.6);
            border: 2px solid #8a2be2;
            padding: 20px;
            border-radius: 15px;
            position: relative;
            transition: all 0.3s;
            overflow: hidden;
        }

        .loadout-item::before {
            content: '';
            position: absolute;
            top: -50%;
            left: -50%;
            width: 200%;
            height: 200%;
            background: radial-gradient(circle, rgba(138, 43, 226, 0.1) 0%, transparent 70%);
            animation: itemPulse 4s ease-in-out infinite;
        }

        @keyframes itemPulse {
            0%, 100% { transform: translate(0, 0); opacity: 0.5; }
            50% { transform: translate(10px, 10px); opacity: 1; }
        }

        .loadout-item:hover {
            transform: scale(1.05);
            box-shadow: 0 0 40px rgba(138, 43, 226, 0.6);
        }

        .loadout-type {
            font-size: 14px;
            color: rgba(255, 255, 255, 0.6);
            text-transform: uppercase;
            letter-spacing: 1px;
            margin-bottom: 10px;
            position: relative;
            z-index: 1;
        }

        .loadout-name {
            font-size: 22px;
            font-weight: 700;
            font-family: 'Orbitron', sans-serif;
            position: relative;
            z-index: 1;
        }

        .equipped-badge {
            position: absolute;
            top: 10px;
            right: 10px;
            background: linear-gradient(135deg, #00ff88, #00ccff);
            color: #000;
            padding: 5px 12px;
            border-radius: 15px;
            font-size: 11px;
            font-weight: 700;
            text-transform: uppercase;
            box-shadow: 0 0 15px rgba(0, 255, 136, 0.6);
            z-index: 2;
        }

        /* Tabs */
        .tabs {
            display: flex;
            gap: 10px;
            margin-bottom: 25px;
            flex-wrap: wrap;
        }

        .tab {
            background: rgba(30, 30, 45, 0.6);
            border: 1px solid rgba(138, 43, 226, 0.3);
            padding: 12px 25px;
            border-radius: 10px;
            cursor: pointer;
            transition: all 0.3s;
            font-weight: 600;
            font-size: 15px;
        }

        .tab:hover {
            background: rgba(40, 40, 55, 0.8);
            border-color: #8a2be2;
        }

        .tab.active {
            background: linear-gradient(135deg, #8a2be2, #00ffff);
            border-color: transparent;
            color: #000;
            box-shadow: 0 0 20px rgba(138, 43, 226, 0.6);
            font-weight: 700;
        }

        .tab-content {
            display: none;
        }

        .tab-content.active {
            display: block;
            animation: fadeIn 0.3s ease;
        }

        /* Collection Grid */
        .collection-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
            gap: 20px;
        }

        .collection-item {
            background: rgba(30, 30, 45, 0.6);
            border: 2px solid rgba(138, 43, 226, 0.3);
            border-radius: 15px;
            padding: 20px;
            text-align: center;
            transition: all 0.3s;
            position: relative;
            cursor: pointer;
            overflow: hidden;
        }

        .collection-item::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background: radial-gradient(circle at center, rgba(138, 43, 226, 0.1) 0%, transparent 70%);
            opacity: 0;
            transition: opacity 0.3s;
        }

        .collection-item:hover::before {
            opacity: 1;
        }

        .collection-item:hover {
            border-color: #8a2be2;
            transform: translateY(-5px);
            box-shadow: 0 10px 40px rgba(138, 43, 226, 0.4);
        }

        .collection-item.equipped {
            border-color: #00ff88;
            background: rgba(0, 255, 136, 0.05);
        }

        .item-icon {
            font-size: 48px;
            margin-bottom: 15px;
            filter: drop-shadow(0 0 10px rgba(138, 43, 226, 0.6));
        }

        .item-name {
            font-size: 18px;
            font-weight: 700;
            margin-bottom: 10px;
            font-family: 'Orbitron', sans-serif;
            position: relative;
            z-index: 1;
        }

        .rarity-badge {
            display: inline-block;
            padding: 5px 15px;
            border-radius: 15px;
            font-size: 11px;
            font-weight: 700;
            text-transform: uppercase;
            position: relative;
            z-index: 1;
        }

        .rarity-starter {
            background: linear-gradient(135deg, #718096, #4a5568);
            box-shadow: 0 0 10px rgba(113, 128, 150, 0.4);
        }
        .rarity-common {
            background: linear-gradient(135deg, #48bb78, #38a169);
            box-shadow: 0 0 10px rgba(72, 187, 120, 0.4);
        }
        .rarity-rare {
            background: linear-gradient(135deg, #4299e1, #3182ce);
            box-shadow: 0 0 10px rgba(66, 153, 225, 0.4);
        }
        .rarity-epic {
            background: linear-gradient(135deg, #9f7aea, #805ad5);
            box-shadow: 0 0 10px rgba(159, 122, 234, 0.4);
        }
        .rarity-legendary {
            background: linear-gradient(135deg, #ed8936, #f093fb);
            box-shadow: 0 0 15px rgba(237, 137, 54, 0.6);
            animation: legendaryGlow 2s ease-in-out infinite;
        }

        @keyframes legendaryGlow {
            0%, 100% { box-shadow: 0 0 15px rgba(237, 137, 54, 0.6); }
            50% { box-shadow: 0 0 25px rgba(240, 147, 251, 0.8); }
        }

        /* Progress Bars */
        .progress-item {
            margin-bottom: 20px;
        }

        .progress-header {
            display: flex;
            justify-content: space-between;
            margin-bottom: 10px;
            font-size: 15px;
        }

        .progress-bar {
            width: 100%;
            height: 25px;
            background: rgba(0, 0, 0, 0.5);
            border: 1px solid rgba(138, 43, 226, 0.3);
            border-radius: 15px;
            overflow: hidden;
            position: relative;
        }

        .progress-fill {
            height: 100%;
            background: linear-gradient(90deg, #8a2be2, #00ffff);
            transition: width 1s ease;
            box-shadow: 0 0 15px rgba(138, 43, 226, 0.6);
            position: relative;
        }

        .progress-fill::after {
            content: '';
            position: absolute;
            top: 0;
            left: -100%;
            width: 100%;
            height: 100%;
            background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
            animation: shimmer 2s infinite;
        }

        @keyframes shimmer {
            0% { left: -100%; }
            100% { left: 200%; }
        }

        /* Next Unlocks */
        .unlock-preview {
            background: rgba(30, 30, 45, 0.6);
            border: 1px solid rgba(138, 43, 226, 0.3);
            border-radius: 15px;
            padding: 20px;
            margin-bottom: 15px;
            display: flex;
            align-items: center;
            gap: 20px;
            transition: all 0.3s;
            border-left: 4px solid #8a2be2;
        }

        .unlock-preview:hover {
            background: rgba(40, 40, 55, 0.8);
            border-color: #8a2be2;
            box-shadow: 0 0 20px rgba(138, 43, 226, 0.3);
        }

        .unlock-info {
            flex: 1;
        }

        .unlock-name {
            font-size: 20px;
            font-weight: 700;
            margin-bottom: 8px;
            font-family: 'Orbitron', sans-serif;
        }

        .unlock-requirement {
            color: rgba(255, 255, 255, 0.6);
            font-size: 14px;
        }

        .unlock-progress {
            min-width: 200px;
        }

        .progress-percentage {
            font-size: 28px;
            font-weight: 700;
            background: linear-gradient(135deg, #8a2be2, #00ffff);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            font-family: 'Orbitron', sans-serif;
        }

        /* Activity Feed */
        .activity-item {
            background: rgba(30, 30, 45, 0.6);
            border: 1px solid rgba(138, 43, 226, 0.2);
            padding: 15px 20px;
            border-radius: 12px;
            margin-bottom: 12px;
            display: flex;
            align-items: center;
            gap: 15px;
            border-left: 3px solid #8a2be2;
            transition: all 0.3s;
        }

        .activity-item:hover {
            background: rgba(40, 40, 55, 0.8);
            border-color: #8a2be2;
            transform: translateX(5px);
        }

        .activity-icon {
            font-size: 32px;
            filter: drop-shadow(0 0 5px rgba(138, 43, 226, 0.6));
        }

        .activity-details {
            flex: 1;
        }

        .activity-title {
            font-weight: 700;
            font-size: 16px;
            margin-bottom: 5px;
        }

        .activity-time {
            font-size: 13px;
            color: rgba(255, 255, 255, 0.5);
        }

        /* ── Locked collection item overlay ── */
        .collection-item.locked {
            opacity: 0.4;
            filter: grayscale(80%);
            cursor: not-allowed;
        }
        .collection-item.locked:hover { transform: none; box-shadow: none; border-color: rgba(138,43,226,0.3); }
        .lock-overlay { position: absolute; top: 8px; right: 8px; font-size: 18px; opacity: 0.8; }

        /* ── Bike cards (Loadout tab) ── */
        .bike-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px,1fr)); gap: 20px; margin-bottom: 30px; }
        .bike-card { background: rgba(20,20,35,0.8); border: 2px solid rgba(138,43,226,0.4); border-radius: 18px; padding: 24px; position: relative; overflow: hidden; transition: all 0.3s; }
        .bike-card.equipped-bike { border-color: #00f5ff; box-shadow: 0 0 25px rgba(0,245,255,0.3); }
        .bike-card.locked-bike { opacity: 0.4; filter: grayscale(70%); cursor: not-allowed; }
        .bike-card:not(.locked-bike):hover { transform: translateY(-5px); box-shadow: 0 12px 40px rgba(138,43,226,0.5); border-color: #9d4edd; }
        .bike-card-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 12px; }
        .bike-icon { font-size: 2.5em; }
        .bike-name { font-family: 'Orbitron', monospace; font-size: 1.1em; font-weight: 700; color: #fff; margin-bottom: 4px; }
        .bike-tag { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; padding: 3px 10px; border-radius: 10px; }
        .bike-tag.equipped  { background: linear-gradient(135deg,#00ff88,#00ccff); color: #000; }
        .bike-tag.locked    { background: rgba(100,100,100,0.4); color: #aaa; }
        .bike-tag.available { background: linear-gradient(135deg,#8a2be2,#4361ee); color: #fff; }
        .bike-desc { font-size: 13px; color: rgba(255,255,255,0.55); margin-bottom: 14px; line-height: 1.5; }
        .bike-stats { display: flex; flex-direction: column; gap: 6px; }
        .bike-stat-row { display: flex; align-items: center; gap: 8px; font-size: 12px; }
        .bike-stat-label { width: 90px; color: rgba(255,255,255,0.5); text-transform: uppercase; letter-spacing: 0.5px; font-size: 11px; }
        .bike-stat-bar { flex: 1; height: 6px; background: rgba(255,255,255,0.1); border-radius: 3px; overflow: hidden; }
        .bike-stat-fill { height: 100%; border-radius: 3px; transition: width 1s ease; }
        .fill-speed    { background: linear-gradient(90deg,#00f5ff,#4361ee); }
        .fill-accel    { background: linear-gradient(90deg,#f72585,#9d4edd); }
        .fill-battery  { background: linear-gradient(90deg,#ffd700,#ff9500); }
        .fill-recovery { background: linear-gradient(90deg,#00ff88,#00ccff); }
        .bike-lock-reason { margin-top: 12px; font-size: 12px; color: #ffd700; text-align: center; font-family: 'Orbitron',monospace; }

        /* ── Milestone / Progress cards ── */
        .milestone-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px,1fr)); gap: 16px; }
        .milestone-card { display: flex; align-items: center; gap: 16px; background: rgba(20,20,35,0.8); border: 1px solid rgba(138,43,226,0.3); border-radius: 14px; padding: 16px 20px; transition: all 0.3s; }
        .milestone-card.unlocked-milestone { border-color: rgba(0,245,255,0.4); background: rgba(0,245,255,0.04); }
        .milestone-card.unlocked-milestone:hover { transform: translateX(6px); box-shadow: 0 4px 20px rgba(0,245,255,0.2); }
        .milestone-card.locked-milestone { opacity: 0.38; filter: grayscale(60%); }
        .milestone-icon { font-size: 2em; width: 50px; text-align: center; flex-shrink: 0; filter: drop-shadow(0 0 8px rgba(0,245,255,0.4)); }
        .milestone-card.locked-milestone .milestone-icon { filter: none; }
        .milestone-info { flex: 1; }
        .milestone-name { font-family: 'Orbitron',monospace; font-size: 0.95em; font-weight: 700; color: #fff; margin-bottom: 3px; }
        .milestone-desc { font-size: 12px; color: rgba(255,255,255,0.5); line-height: 1.4; }
        .milestone-status { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; padding: 4px 10px; border-radius: 8px; flex-shrink: 0; }
        .milestone-status.done   { background: rgba(0,245,255,0.15); color: #00f5ff; }
        .milestone-status.locked { background: rgba(100,100,100,0.2); color: #666; }
        .milestone-section-title { font-family: 'Orbitron',monospace; font-size: 0.85em; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; color: #00f5ff; margin: 24px 0 12px; padding-bottom: 8px; border-bottom: 1px solid rgba(0,245,255,0.2); }

        /* ═══════════ LEVEL-UP OVERLAY ═══════════ */
        #levelUpOverlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:9999;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,0.85);backdrop-filter:blur(8px);}
        #levelUpOverlay.show{display:flex !important;}
        .levelup-box{background:linear-gradient(135deg,rgba(157,78,221,0.4),rgba(0,245,255,0.2));border:3px solid #ffd700;border-radius:30px;padding:50px 60px;text-align:center;position:relative;overflow:hidden;max-width:480px;width:90%;}
        .levelup-box::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:conic-gradient(from 0deg,transparent,rgba(255,215,0,0.3),transparent,rgba(0,245,255,0.2),transparent);animation:rotLU 3s linear infinite;z-index:-1;}
        @keyframes rotLU{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
        .lu-title{font-family:'Orbitron',monospace;font-size:1em;color:#00f5ff;text-transform:uppercase;letter-spacing:4px;margin-bottom:12px;}
        .lu-text{font-family:'Orbitron',monospace;font-size:2.8em;font-weight:900;color:#ffd700;text-shadow:0 0 30px #ffd700;margin-bottom:8px;animation:luPulse 1s ease-in-out infinite;}
        @keyframes luPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
        .lu-num{font-family:'Orbitron',monospace;font-size:5em;font-weight:900;background:linear-gradient(135deg,#ffd700,#00f5ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:10px 0;}
        .lu-sub{color:#e0aaff;font-size:1.1em;margin-bottom:28px;font-weight:600;}
        .lu-particles{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden;}
        .lu-particle{position:absolute;width:7px;height:7px;border-radius:50%;animation:luPart 2s ease-out forwards;}
        @keyframes luPart{0%{opacity:1;transform:translate(0,0) scale(1)}100%{opacity:0;transform:translate(var(--tx),var(--ty)) scale(0)}}
        .lu-btn{background:linear-gradient(135deg,#ffd700,#f72585);border:none;border-radius:14px;padding:14px 36px;color:#000;font-weight:900;cursor:pointer;font-family:'Orbitron',monospace;font-size:1em;text-transform:uppercase;letter-spacing:1px;transition:all .3s;margin-top:4px;}
        .lu-btn:hover{transform:scale(1.05);box-shadow:0 0 25px #ffd700;}

        /* ═══════════ XP BAR ═══════════ */
        .xp-bar-wrap{margin:12px 0 10px;background:rgba(0,0,0,0.5);border:1px solid rgba(157,78,221,0.4);border-radius:20px;height:24px;overflow:hidden;position:relative;}
        .xp-bar-fill{height:100%;background:linear-gradient(90deg,#7209b7,#00f5ff);border-radius:20px;transition:width 1.2s cubic-bezier(.4,0,.2,1);position:relative;min-width:2px;}
        .xp-bar-fill::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.35),transparent);animation:xpShimmer 2.5s infinite;}
        @keyframes xpShimmer{0%{left:-100%}100%{left:200%}}
        .xp-bar-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:11px;font-weight:700;color:#fff;font-family:'Orbitron',monospace;letter-spacing:1px;white-space:nowrap;z-index:2;text-shadow:0 1px 2px rgba(0,0,0,0.8);}

        /* ═══════════ BADGE STRIP ═══════════ */
        .badge-pill{display:inline-flex;align-items:center;gap:4px;background:linear-gradient(135deg,rgba(0,245,255,0.12),rgba(157,78,221,0.12));border:1px solid rgba(0,245,255,0.3);border-radius:20px;padding:3px 10px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#00f5ff;font-family:'Orbitron',monospace;white-space:nowrap;}

        /* ═══════════ NEXT GOALS WIDGET ═══════════ */
        .next-goals-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px;margin-bottom:8px;}
        .goal-card{background:rgba(30,30,45,0.7);border:2px solid rgba(255,215,0,0.35);border-radius:18px;padding:20px;position:relative;overflow:hidden;transition:all .3s;}
        .goal-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(255,215,0,0.2);border-color:rgba(255,215,0,0.7);}
        .goal-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,#ffd700,#f72585);}
        .goal-type-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#ffd700;font-family:'Orbitron',monospace;margin-bottom:7px;}
        .goal-name{font-family:'Orbitron',monospace;font-size:1em;font-weight:700;color:#fff;margin-bottom:5px;}
        .goal-desc{font-size:13px;color:rgba(255,255,255,0.52);margin-bottom:14px;line-height:1.5;}
        .goal-progress-bar{width:100%;background:rgba(255,255,255,0.08);height:8px;border-radius:4px;overflow:hidden;margin-bottom:8px;}
        .goal-progress-fill{height:100%;background:linear-gradient(90deg,#ffd700,#f72585);border-radius:4px;transition:width 1.2s ease;position:relative;}
        .goal-footer{display:flex;justify-content:space-between;align-items:center;}
        .goal-pct{font-family:'Orbitron',monospace;font-size:1.5em;font-weight:900;background:linear-gradient(135deg,#ffd700,#00f5ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
        .goal-xp{font-size:12px;color:#00f5ff;font-family:'Orbitron',monospace;font-weight:700;}

        /* ═══════════ DAILY CHALLENGES ═══════════ */
        .challenge-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;}
        .challenge-card{background:rgba(30,30,45,0.7);border:1px solid rgba(138,43,226,0.3);border-radius:16px;padding:18px;transition:all .3s;}
        .challenge-card.done-challenge{border-color:rgba(0,255,136,0.45);background:rgba(0,255,136,0.04);}
        .challenge-card:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(138,43,226,0.3);}
        .ch-diff{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;font-family:'Orbitron',monospace;margin-bottom:8px;}
        .ch-diff.easy{color:#00ff88;}.ch-diff.medium{color:#ffd700;}.ch-diff.hard{color:#f72585;}
        .ch-title{font-family:'Orbitron',monospace;font-size:.92em;font-weight:700;color:#fff;margin-bottom:5px;}
        .ch-desc{font-size:13px;color:rgba(255,255,255,0.48);margin-bottom:12px;line-height:1.4;}
        .ch-prog-bar{width:100%;background:rgba(255,255,255,0.08);height:6px;border-radius:3px;overflow:hidden;margin-bottom:7px;}
        .ch-prog-fill{height:100%;background:linear-gradient(90deg,#8a2be2,#00ffff);border-radius:3px;transition:width 1s ease;}
        .ch-footer{display:flex;justify-content:space-between;font-size:12px;}
        .ch-vals{color:rgba(255,255,255,0.38);}.ch-xp{color:#ffd700;font-family:'Orbitron',monospace;font-weight:700;}

        /* ═══════════ BIKE PARTS LOADOUT ═══════════ */
        .parts-layout{display:grid;grid-template-columns:250px 1fr;gap:22px;}
        .parts-sidebar{display:flex;flex-direction:column;gap:8px;}
        .part-cat-btn{background:rgba(20,20,35,0.85);border:2px solid rgba(138,43,226,0.3);border-radius:12px;padding:11px 14px;cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:10px;text-align:left;}
        .part-cat-btn:hover{border-color:#9d4edd;background:rgba(157,78,221,0.15);}
        .part-cat-btn.active{border-color:#00f5ff;background:linear-gradient(135deg,rgba(0,245,255,0.1),rgba(157,78,221,0.1));box-shadow:0 0 14px rgba(0,245,255,0.2);}
        .pcat-icon{font-size:1.5em;flex-shrink:0;}
        .pcat-name{font-family:'Orbitron',monospace;font-size:.78em;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px;}
        .pcat-sub{font-size:10px;color:#00f5ff;margin-top:2px;}
        .pcat-eff{font-size:9px;color:rgba(255,255,255,0.3);margin-top:1px;}
        .parts-panel{background:rgba(20,20,35,0.5);border:1px solid rgba(138,43,226,0.2);border-radius:16px;padding:20px;}
        .parts-panel-hdr{font-family:'Orbitron',monospace;font-size:.9em;font-weight:700;color:#00f5ff;text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid rgba(0,245,255,0.2);}
        .parts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px;}
        .part-card2{background:rgba(20,20,35,0.85);border:2px solid rgba(138,43,226,0.3);border-radius:14px;padding:16px;position:relative;transition:all .3s;cursor:pointer;}
        .part-card2:hover{transform:translateY(-4px);box-shadow:0 10px 30px rgba(138,43,226,0.4);border-color:#9d4edd;}
        .part-card2.equipped-part2{border-color:#00f5ff;box-shadow:0 0 20px rgba(0,245,255,0.25);}
        .part-card2.locked-part2{opacity:.38;filter:grayscale(60%);cursor:not-allowed;}
        .p2-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:9px;}
        .p2-icon{font-size:1.9em;}
        .p2-tag{font-size:10px;font-weight:700;text-transform:uppercase;padding:3px 10px;border-radius:8px;font-family:'Orbitron',monospace;}
        .p2-tag.on{background:linear-gradient(135deg,#00ff88,#00ccff);color:#000;}
        .p2-tag.off{background:rgba(100,100,100,0.3);color:#888;}
        .p2-tag.lock{background:rgba(100,100,100,0.2);color:#555;}
        .p2-name{font-family:'Orbitron',monospace;font-size:.85em;font-weight:700;color:#fff;margin-bottom:4px;}
        .p2-desc{font-size:11px;color:rgba(255,255,255,0.4);line-height:1.5;margin-bottom:10px;}
        .p2-effects{display:flex;flex-direction:column;gap:4px;}
        .p2-eff-row{display:flex;align-items:center;gap:6px;font-size:10px;}
        .p2-eff-label{color:rgba(255,255,255,0.32);width:66px;text-transform:uppercase;font-size:9px;flex-shrink:0;}
        .p2-eff-bar{flex:1;height:5px;background:rgba(255,255,255,0.08);border-radius:3px;overflow:hidden;}
        .p2-eff-fill{height:100%;border-radius:3px;}
        .pef-speed{background:linear-gradient(90deg,#00f5ff,#4361ee);}
        .pef-shield{background:linear-gradient(90deg,#00ff88,#00ccff);}
        .pef-energy{background:linear-gradient(90deg,#ffd700,#ff9500);}
        .pef-xp{background:linear-gradient(90deg,#f72585,#9d4edd);}
        .pef-boost{background:linear-gradient(90deg,#ff6b00,#ffd700);}
        .pef-visual{background:linear-gradient(90deg,#9d4edd,#e0aaff);}
        .pef-neg{background:linear-gradient(90deg,#f72585,#ff6b00);}
        .p2-lock-reason{margin-top:9px;font-size:10px;color:#ffd700;text-align:center;font-family:'Orbitron',monospace;}
        @media(max-width:900px){
            .parts-layout{grid-template-columns:1fr;}
            .parts-sidebar{flex-direction:row;flex-wrap:wrap;}
            .part-cat-btn{flex:1 1 calc(33% - 8px);min-width:110px;}
            .rivals-layout{grid-template-columns:1fr;}
        }

        /* ═══════════ ACHIEVEMENTS ═══════════ */
        .ach-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px;}
        .ach-filter-btn{background:rgba(30,30,45,0.6);border:1px solid rgba(138,43,226,0.3);padding:7px 16px;border-radius:10px;cursor:pointer;transition:all .3s;font-weight:600;font-size:12px;color:#c77dff;}
        .ach-filter-btn:hover{background:rgba(40,40,55,0.8);border-color:#8a2be2;}
        .ach-filter-btn.active{background:linear-gradient(135deg,#8a2be2,#00ffff);border-color:transparent;color:#000;font-weight:700;box-shadow:0 0 16px rgba(138,43,226,0.6);}
        .ach-section-hdr{font-family:'Orbitron',monospace;font-size:.78em;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:#ffd700;margin:20px 0 11px;padding-bottom:7px;border-bottom:1px solid rgba(255,215,0,0.2);}
        .ach-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;}
        .ach-card2{background:rgba(20,20,35,0.85);border:2px solid rgba(138,43,226,0.25);border-radius:15px;padding:16px;transition:all .3s;position:relative;overflow:hidden;}
        .ach-card2:hover{transform:translateY(-4px);box-shadow:0 10px 32px rgba(138,43,226,0.35);}
        .ach-card2.ach-earned{border-color:rgba(0,245,255,0.45);}
        .ach-card2.ach-hidden{opacity:.42;filter:grayscale(50%);}
        .ach2-top{display:flex;align-items:flex-start;gap:12px;margin-bottom:10px;}
        .ach2-icon{font-size:2em;flex-shrink:0;filter:drop-shadow(0 0 8px rgba(138,43,226,0.6));}
        .ach-card2.ach-earned .ach2-icon{filter:drop-shadow(0 0 12px rgba(0,245,255,0.8));}
        .ach2-name{font-family:'Orbitron',monospace;font-size:.85em;font-weight:700;color:#fff;margin-bottom:4px;}
        .ach2-desc{font-size:11px;color:rgba(255,255,255,0.42);line-height:1.4;}
        .ach2-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:10px;}
        .ach2-xp{font-size:11px;color:#ffd700;font-family:'Orbitron',monospace;font-weight:700;}

        /* ═══════════ MINI STAT OVERRIDE ═══════════ */
        .quick-stat-value#miniStreak, #miniStreak{background:linear-gradient(135deg,#f72585,#ffd700);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}

        /* ═══════════ NOTIFICATIONS ═══════════ */
        .pr-notif{position:fixed;top:24px;right:24px;padding:14px 20px;border-radius:14px;font-weight:bold;font-family:'Orbitron',monospace;text-transform:uppercase;letter-spacing:1px;z-index:2000;transform:translateX(130%);transition:transform .3s ease;backdrop-filter:blur(20px);border:2px solid;font-size:.82em;max-width:320px;}


        /* ═══ BIKE STAT SUMMARY ═══ */
        .bike-stat-summary {
            background: linear-gradient(135deg, rgba(0,245,255,0.06), rgba(157,78,221,0.1));
            border: 1px solid rgba(0,245,255,0.25);
            border-radius: 20px;
            padding: 24px 28px;
            margin-bottom: 28px;
            position: relative;
            overflow: hidden;
        }
        .bike-stat-summary::before {
            content: '';
            position: absolute;
            top: 0; left: 0;
            width: 100%; height: 3px;
            background: linear-gradient(90deg, #00f5ff, #9d4edd, #f72585);
        }
        .bss-title {
            font-family: 'Orbitron', monospace;
            font-size: 0.8em;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 2px;
            color: #00f5ff;
            margin-bottom: 18px;
        }
        .bss-bars {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
            gap: 12px 28px;
        }
        .bss-row {
            display: flex;
            align-items: center;
            gap: 10px;
        }
        .bss-label {
            font-size: 11px;
            font-family: 'Orbitron', monospace;
            text-transform: uppercase;
            letter-spacing: 0.5px;
            color: rgba(255,255,255,0.45);
            width: 80px;
            flex-shrink: 0;
        }
        .bss-bar-wrap {
            flex: 1;
            background: rgba(255,255,255,0.07);
            border-radius: 6px;
            height: 10px;
            overflow: hidden;
            position: relative;
        }
        .bss-bar-fill {
            height: 100%;
            border-radius: 6px;
            transition: width 0.8s cubic-bezier(0.4, 0, 0.2, 1);
            position: relative;
        }
        .bss-bar-fill::after {
            content: '';
            position: absolute;
            top: 0; left: -100%;
            width: 100%; height: 100%;
            background: linear-gradient(90deg, transparent, rgba(255,255,255,0.35), transparent);
            animation: shimmer 2.5s infinite;
        }
        .bss-val {
            font-family: 'Orbitron', monospace;
            font-size: 12px;
            font-weight: 700;
            width: 36px;
            text-align: right;
            color: rgba(255,255,255,0.7);
            flex-shrink: 0;
        }
        /* stat-specific bar colours */
        .bss-speed    { background: linear-gradient(90deg, #00f5ff, #4361ee); }
        .bss-shield   { background: linear-gradient(90deg, #00ff88, #00ccff); }
        .bss-energy   { background: linear-gradient(90deg, #ffd700, #ff9500); }
        .bss-xp       { background: linear-gradient(90deg, #f72585, #9d4edd); }
        .bss-boost    { background: linear-gradient(90deg, #ff6b00, #ffd700); }
        .bss-visual   { background: linear-gradient(90deg, #9d4edd, #e0aaff); }
        .bss-nearmiss { background: linear-gradient(90deg, #00f5ff, #00ff88); }
        
        /* ═══ BIKE SHOPS ═══ */

        .bshop-hero {
            position: relative;
            width: 100%;
            border-radius: 16px;
            overflow: hidden;
            margin-bottom: 0;
        }
        .bshop-hero-img {
            width: 100%;
            display: block;
            max-height: 340px;
            object-fit: cover;
            object-position: center 20%;
            border-radius: 16px 16px 0 0;
            filter: brightness(0.85);
        }
        .bshop-hero-overlay {
            position: absolute;
            inset: 0;
            background: linear-gradient(to bottom, transparent 30%, rgba(10,10,15,0.6) 70%, rgba(10,10,15,0.95) 100%);
            border-radius: 16px 16px 0 0;
        }
        .bshop-hero-text {
            position: absolute;
            bottom: 0; left: 0; right: 0;
            padding: 20px 24px 22px;
        }
        .bshop-hero-name {
            font-family: 'Orbitron', monospace;
            font-size: 1.4em;
            font-weight: 900;
            text-transform: uppercase;
            letter-spacing: 3px;
            color: #fff;
            text-shadow: 0 0 20px rgba(0,245,255,0.6);
            margin-bottom: 4px;
        }
        .bshop-hero-tagline {
            font-family: 'Rajdhani', sans-serif;
            font-size: 13px;
            color: rgba(255,255,255,0.55);
        }
        .bshop-hero-badge {
            position: absolute;
            top: 16px; right: 16px;
            font-family: 'Orbitron', monospace;
            font-size: 9px;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 1px;
            padding: 5px 12px;
            border-radius: 20px;
            background: rgba(0,245,255,0.15);
            border: 1px solid rgba(0,245,255,0.5);
            color: #00f5ff;
            backdrop-filter: blur(4px);
        }
        .bshop-tabs-wrap {
            background: rgba(10,10,20,0.95);
            border: 1px solid rgba(157,78,221,0.25);
            border-top: none;
            border-radius: 0 0 16px 16px;
            padding: 0 12px;
            margin-bottom: 28px;
            display: flex;
            align-items: stretch;
            overflow-x: auto;
            scrollbar-width: none;
        }
        .bshop-tabs-wrap::-webkit-scrollbar { display: none; }
        .bshop-tab {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: 3px;
            padding: 12px 16px;
            cursor: pointer;
            border-bottom: 2px solid transparent;
            transition: all 0.2s ease;
            min-width: 88px;
            position: relative;
            user-select: none;
            flex-shrink: 0;
        }
        .bshop-tab:hover:not(.locked) { background: rgba(0,245,255,0.05); }
        .bshop-tab.active { border-bottom-color: #00f5ff; }
        .bshop-tab.locked { cursor: not-allowed; opacity: 0.55; }
        .bshop-tab.locked:hover { background: rgba(247,37,133,0.04); }
        .bshop-tab-icon { font-size: 18px; line-height: 1; transition: filter 0.2s; }
        .bshop-tab.locked .bshop-tab-icon { filter: grayscale(0.7); }
        .bshop-tab-name {
            font-family: 'Orbitron', monospace;
            font-size: 8px;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.5px;
            color: rgba(255,255,255,0.4);
            text-align: center;
            line-height: 1.2;
        }
        .bshop-tab.active .bshop-tab-name { color: #00f5ff; }
        .bshop-tab-lock-label {
            font-family: 'Rajdhani', sans-serif;
            font-size: 8px;
            color: rgba(247,37,133,0.7);
            text-align: center;
            white-space: nowrap;
        }
        /* Thin coloured accent line at top of each tab, using gang colour */
        .bshop-tab::before {
            content: '';
            position: absolute;
            top: 0; left: 4px; right: 4px;
            height: 2px;
            border-radius: 0 0 2px 2px;
            background: var(--tab-gang-color, transparent);
            opacity: 0.5;
        }
        .bshop-tab.active::before { opacity: 1; }

        /* Locked shop panel */
        .bshop-locked-panel {
            background: linear-gradient(135deg, rgba(247,37,133,0.05), rgba(10,10,20,0.9));
            border: 1px solid rgba(247,37,133,0.2);
            border-radius: 16px;
            padding: 32px 24px;
            text-align: center;
            margin-bottom: 28px;
        }
        .bshop-locked-art {
            width: 100%;
            max-height: 200px;
            object-fit: cover;
            object-position: center 20%;
            border-radius: 12px;
            filter: grayscale(0.7) brightness(0.4) blur(3px);
            margin-bottom: 20px;
            display: block;
        }
        .bshop-locked-icon { font-size: 38px; margin-bottom: 10px; display: block; }
        .bshop-locked-name {
            font-family: 'Orbitron', monospace;
            font-size: 1.05em;
            font-weight: 900;
            text-transform: uppercase;
            letter-spacing: 3px;
            color: rgba(255,255,255,0.65);
            margin-bottom: 5px;
        }
        .bshop-locked-tagline {
            font-family: 'Rajdhani', sans-serif;
            font-size: 13px;
            color: rgba(255,255,255,0.3);
            margin-bottom: 18px;
            font-style: italic;
        }
        .bshop-locked-req {
            display: inline-flex;
            align-items: center;
            gap: 10px;
            background: rgba(247,37,133,0.08);
            border: 1px solid rgba(247,37,133,0.3);
            border-radius: 12px;
            padding: 12px 20px;
            margin-bottom: 14px;
        }
        .bshop-locked-req-icon { font-size: 20px; }
        .bshop-locked-req-text {
            font-family: 'Rajdhani', sans-serif;
            font-size: 13px;
            color: rgba(255,255,255,0.55);
            text-align: left;
        }
        .bshop-locked-req-text strong {
            display: block;
            font-family: 'Orbitron', monospace;
            font-size: 10px;
            color: #f72585;
            text-transform: uppercase;
            letter-spacing: 1px;
            margin-bottom: 2px;
        }
        .bshop-teaser-parts {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
            justify-content: center;
            margin-top: 16px;
        }
        .bshop-teaser-part {
            font-family: 'Rajdhani', sans-serif;
            font-size: 11px;
            padding: 4px 12px;
            border-radius: 20px;
            background: rgba(255,255,255,0.03);
            border: 1px solid rgba(255,255,255,0.08);
            color: rgba(255,255,255,0.25);
        }
        .bshop-cred-progress { margin-top: 18px; max-width: 340px; margin-left: auto; margin-right: auto; }
        .bshop-cred-labels {
            display: flex;
            justify-content: space-between;
            font-family: 'Orbitron', monospace;
            font-size: 9px;
            text-transform: uppercase;
            letter-spacing: 0.5px;
            color: rgba(255,255,255,0.3);
            margin-bottom: 5px;
        }
        .bshop-cred-bar-wrap { height: 5px; background: rgba(255,255,255,0.06); border-radius: 4px; overflow: hidden; }
        .bshop-cred-bar-fill {
            height: 100%;
            border-radius: 4px;
            background: linear-gradient(90deg, #f72585, #9d4edd);
            transition: width 0.8s cubic-bezier(0.4,0,0.2,1);
        }

        /* ═══ BIKE SCHEMATIC CALLOUT VIEWER ═══ */
        .bsv-wrap {
            position: relative;
            margin-bottom: 32px;
            background: linear-gradient(135deg, rgba(0,245,255,0.04), rgba(157,78,221,0.08));
            border: 1px solid rgba(0,245,255,0.2);
            border-radius: 20px;
            padding: 28px;
            overflow: hidden;
        }
        .bsv-wrap::before {
            content: '';
            position: absolute;
            top: 0; left: 0;
            width: 100%; height: 3px;
            background: linear-gradient(90deg, #00f5ff, #9d4edd, #f72585);
        }
        .bsv-title {
            font-family: 'Orbitron', monospace;
            font-size: 0.78em;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 2px;
            color: #00f5ff;
            margin-bottom: 4px;
        }
        .bsv-subtitle {
            font-size: 12px;
            color: rgba(255,255,255,0.35);
            margin-bottom: 20px;
            font-family: 'Rajdhani', sans-serif;
        }
        .bsv-chassis-tabs {
            display: flex;
            gap: 8px;
            flex-wrap: wrap;
            margin-bottom: 20px;
        }
        .bsv-chassis-tab {
            font-family: 'Orbitron', monospace;
            font-size: 10px;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 1px;
            padding: 6px 14px;
            border-radius: 20px;
            border: 1px solid rgba(157,78,221,0.4);
            background: rgba(157,78,221,0.08);
            color: rgba(255,255,255,0.5);
            cursor: pointer;
            transition: all 0.2s ease;
            user-select: none;
        }
        .bsv-chassis-tab:hover {
            border-color: rgba(0,245,255,0.5);
            color: #00f5ff;
            background: rgba(0,245,255,0.08);
        }
        .bsv-chassis-tab.active {
            border-color: #00f5ff;
            color: #00f5ff;
            background: rgba(0,245,255,0.12);
            box-shadow: 0 0 12px rgba(0,245,255,0.2);
        }
        .bsv-stage { position: relative; width: 100%; }
        .bsv-stage-inner {
            position: relative;
            width: 100%;
            padding-bottom: 56.25%;
        }
        .bsv-bike-img {
            position: absolute;
            inset: 0;
            width: 100%;
            height: 100%;
            object-fit: contain;
            filter: drop-shadow(0 0 24px rgba(0,245,255,0.25));
            user-select: none;
            pointer-events: none;
            border-radius: 12px;
            z-index: 1;
        }
        .bsv-stage-inner::before {
            content: '';
            position: absolute;
            inset: 0;
            background-image:
                linear-gradient(rgba(0,245,255,0.05) 1px, transparent 1px),
                linear-gradient(90deg, rgba(0,245,255,0.05) 1px, transparent 1px);
            background-size: 40px 40px;
            border-radius: 12px;
            background-color: rgba(0,0,30,0.6);
            z-index: 0;
        }
        /* Callout container — lifts entirely on hover to beat neighbouring dots */
        .bsv-callout {
            position: absolute;
            z-index: 10;
            transform: translate(-50%, -50%);
            cursor: pointer;
        }
        .bsv-callout:hover,
        .bsv-callout.active { z-index: 200; }
        /* Diamond hotspot — neon magenta */
        .bsv-dot {
            width: 18px;
            height: 18px;
            background: rgba(247,37,133,0.35);
            border: 2px solid #f72585;
            transform: rotate(45deg);
            transition: all 0.2s ease;
            box-shadow: 0 0 10px rgba(247,37,133,0.6), 0 0 20px rgba(247,37,133,0.3);
            position: relative;
            z-index: 2;
        }
        .bsv-callout:hover .bsv-dot,
        .bsv-callout.active .bsv-dot {
            background: rgba(247,37,133,0.65);
            box-shadow: 0 0 20px rgba(247,37,133,1), 0 0 40px rgba(247,37,133,0.5);
            transform: rotate(45deg) scale(1.3);
        }
        /* Connector line */
        .bsv-line {
            position: absolute;
            background: linear-gradient(90deg, rgba(247,37,133,0.7), rgba(247,37,133,0.1));
            height: 1px;
            top: 50%;
            transform-origin: left center;
            z-index: 1;
            pointer-events: none;
        }
        /* Tooltip card — always above everything */
        .bsv-tooltip {
            position: absolute;
            z-index: 100;
            min-width: 190px;
            max-width: 230px;
            background: rgba(10,10,25,0.96);
            border: 1px solid rgba(247,37,133,0.45);
            border-radius: 12px;
            padding: 14px;
            pointer-events: none;
            opacity: 0;
            transform: scale(0.92);
            transition: opacity 0.18s ease, transform 0.18s ease;
            box-shadow: 0 8px 32px rgba(0,0,0,0.7), 0 0 20px rgba(247,37,133,0.1);
        }
        .bsv-callout:hover .bsv-tooltip,
        .bsv-callout.active .bsv-tooltip {
            opacity: 1;
            transform: scale(1);
            pointer-events: auto;
        }
        .bsv-callout.flip-right .bsv-tooltip { left: calc(100% + 14px); top: 50%; transform-origin: left center; transform: translateY(-50%) scale(0.92); }
        .bsv-callout.flip-right:hover .bsv-tooltip,
        .bsv-callout.flip-right.active .bsv-tooltip { transform: translateY(-50%) scale(1); opacity: 1; }
        .bsv-callout.flip-left .bsv-tooltip { right: calc(100% + 14px); top: 50%; transform-origin: right center; transform: translateY(-50%) scale(0.92); }
        .bsv-callout.flip-left:hover .bsv-tooltip,
        .bsv-callout.flip-left.active .bsv-tooltip { transform: translateY(-50%) scale(1); opacity: 1; }
        .bsv-callout.flip-up .bsv-tooltip { bottom: calc(100% + 14px); left: 50%; transform-origin: bottom center; transform: translateX(-50%) scale(0.92); }
        .bsv-callout.flip-up:hover .bsv-tooltip,
        .bsv-callout.flip-up.active .bsv-tooltip { transform: translateX(-50%) scale(1); opacity: 1; }
        .bsv-callout.flip-down .bsv-tooltip { top: calc(100% + 14px); left: 50%; transform-origin: top center; transform: translateX(-50%) scale(0.92); }
        .bsv-callout.flip-down:hover .bsv-tooltip,
        .bsv-callout.flip-down.active .bsv-tooltip { transform: translateX(-50%) scale(1); opacity: 1; }
        .bsv-tip-header { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
        .bsv-tip-icon {
            width: 38px; height: 38px; flex-shrink: 0;
            border-radius: 6px;
            background: rgba(157,78,221,0.15);
            border: 1px solid rgba(157,78,221,0.3);
            overflow: hidden;
            display: flex; align-items: center; justify-content: center;
            font-size: 20px;
        }
        .bsv-tip-icon img { width: 100%; height: 100%; object-fit: contain; }
        .bsv-tip-meta { flex: 1; min-width: 0; }
        .bsv-tip-cat {
            font-family: 'Orbitron', monospace; font-size: 8px; font-weight: 700;
            text-transform: uppercase; letter-spacing: 1px;
            color: rgba(247,37,133,0.8); margin-bottom: 2px;
        }
        .bsv-tip-name { font-family: 'Orbitron', monospace; font-size: 11px; font-weight: 700; color: #fff; line-height: 1.2; }
        .bsv-tip-tier { display: inline-block; font-family: 'Rajdhani', sans-serif; font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; padding: 2px 7px; border-radius: 4px; margin-top: 3px; }
        .tier-1 { background: rgba(100,100,100,0.3); color: #aaa; border: 1px solid rgba(150,150,150,0.3); }
        .tier-2 { background: rgba(0,200,100,0.15); color: #00e676; border: 1px solid rgba(0,200,100,0.35); }
        .tier-3 { background: rgba(100,100,255,0.15); color: #7090ff; border: 1px solid rgba(100,100,255,0.35); }
        .tier-4 { background: rgba(157,78,221,0.2); color: #c77dff; border: 1px solid rgba(157,78,221,0.45); }
        .tier-5 { background: rgba(255,215,0,0.15); color: #ffd700; border: 1px solid rgba(255,215,0,0.45); }
        .bsv-tip-desc { font-family: 'Rajdhani', sans-serif; font-size: 11px; color: rgba(255,255,255,0.55); line-height: 1.4; margin-bottom: 8px; border-top: 1px solid rgba(255,255,255,0.07); padding-top: 7px; }
        .bsv-tip-stats { display: flex; flex-direction: column; gap: 4px; }
        .bsv-tip-stat-row { display: flex; align-items: center; gap: 6px; }
        .bsv-tip-stat-label { font-family: 'Orbitron', monospace; font-size: 8px; text-transform: uppercase; color: rgba(255,255,255,0.4); width: 52px; flex-shrink: 0; }
        .bsv-tip-stat-bar-wrap { flex: 1; height: 5px; background: rgba(255,255,255,0.07); border-radius: 3px; overflow: hidden; }
        .bsv-tip-stat-bar { height: 100%; border-radius: 3px; }
        .bsv-tip-stat-val { font-family: 'Orbitron', monospace; font-size: 8px; color: rgba(255,255,255,0.5); width: 22px; text-align: right; }
        .bsv-tip-locked { display: flex; align-items: center; gap: 6px; background: rgba(247,37,133,0.1); border: 1px solid rgba(247,37,133,0.3); border-radius: 6px; padding: 6px 10px; font-family: 'Rajdhani', sans-serif; font-size: 11px; color: #f72585; margin-top: 4px; }
        @media (max-width: 480px) {
            .bsv-line { display: none; }
            .bsv-tooltip { min-width: 160px; max-width: 180px; }
        }

        /* ═══ INTERACTIVE PART CARDS ═══ */
        .part-card2 {
            cursor: pointer;
            user-select: none;
        }
        .part-card2.equipped-part2 {
            border-color: #00f5ff;
            box-shadow: 0 0 22px rgba(0,245,255,0.3);
            background: rgba(0,245,255,0.06);
        }
        .part-card2.locked-part2 {
            cursor: not-allowed;
        }
        .part-card2:not(.locked-part2):not(.equipped-part2):hover {
            border-color: #9d4edd;
            transform: translateY(-4px);
            box-shadow: 0 10px 30px rgba(157,78,221,0.4);
        }
        .part-card2.equipping {
            animation: partEquipPulse 0.4s ease;
        }
        @keyframes partEquipPulse {
            0%  { transform: scale(1);    box-shadow: 0 0 0 rgba(0,245,255,0); }
            50% { transform: scale(1.04); box-shadow: 0 0 30px rgba(0,245,255,0.6); }
            100%{ transform: scale(1);    box-shadow: 0 0 22px rgba(0,245,255,0.3); }
        }
        .equip-hint {
            font-size: 10px;
            color: rgba(0,245,255,0.6);
            font-family: 'Orbitron', monospace;
            text-align: center;
            margin-top: 8px;
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }
        .part-saving-indicator {
            position: absolute;
            top: 8px; left: 8px;
            font-size: 10px;
            color: #ffd700;
            font-family: 'Orbitron', monospace;
            animation: fadePulse 1s ease-in-out infinite;
        }
        @keyframes fadePulse { 0%,100%{opacity:1} 50%{opacity:0.4} }


        /* ═══ ENERGY SHOP ═══ */
        .energy-balance-header {
            display: inline-flex; align-items: center; gap: 8px;
            background: linear-gradient(135deg, rgba(255,215,0,0.15), rgba(255,150,0,0.1));
            border: 1px solid rgba(255,215,0,0.4);
            border-radius: 12px; padding: 6px 16px;
            font-family: 'Orbitron', monospace; font-size: 13px; font-weight: 700;
            color: #ffd700; margin-bottom: 20px; cursor: default;
        }
        .energy-balance-header .eb-icon { font-size: 1.2em; }
        .energy-balance-header .eb-label { color: rgba(255,255,255,0.5); font-size: 10px; text-transform: uppercase; letter-spacing: 1px; margin-left: 4px; }

        /* Cost badge on part/collection cards */
        .cost-badge {
            display: inline-flex; align-items: center; gap: 4px;
            background: rgba(255,215,0,0.12); border: 1px solid rgba(255,215,0,0.35);
            border-radius: 8px; padding: 3px 9px;
            font-family: 'Orbitron', monospace; font-size: 10px; font-weight: 700; color: #ffd700;
            margin-top: 8px; white-space: nowrap;
        }
        .cost-badge.owned { background: rgba(0,255,136,0.12); border-color: rgba(0,255,136,0.35); color: #00ff88; }
        .cost-badge.cant-afford { background: rgba(247,37,133,0.12); border-color: rgba(247,37,133,0.35); color: #f72585; }

        /* Buy button on cards */
        .buy-btn {
            width: 100%; margin-top: 10px; padding: 8px 12px;
            background: linear-gradient(135deg, #ffd700, #ff9500);
            border: none; border-radius: 9px; color: #000;
            font-family: 'Orbitron', monospace; font-size: 11px; font-weight: 900;
            text-transform: uppercase; letter-spacing: 0.5px; cursor: pointer;
            transition: all 0.2s; display: block;
        }
        .buy-btn:hover { transform: scale(1.03); box-shadow: 0 0 18px rgba(255,215,0,0.5); }
        .buy-btn:disabled { opacity: 0.4; cursor: not-allowed; transform: none; box-shadow: none; }
        .buy-btn.buying { animation: buyPulse 0.6s ease; }
        @keyframes buyPulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.06)} }

        /* Purchase confirm modal */
        #purchaseModal {
            display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%;
            z-index: 9000; align-items: center; justify-content: center;
            background: rgba(0,0,0,0.75); backdrop-filter: blur(6px);
        }
        #purchaseModal.open { display: flex; }
        .purchase-box {
            background: linear-gradient(135deg, rgba(20,20,35,0.98), rgba(30,30,50,0.98));
            border: 2px solid rgba(255,215,0,0.5); border-radius: 24px;
            padding: 36px 40px; max-width: 420px; width: 90%; text-align: center;
            position: relative; overflow: hidden;
        }
        .purchase-box::before {
            content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 3px;
            background: linear-gradient(90deg, #ffd700, #ff9500, #f72585);
        }
        .pm-icon { font-size: 3em; margin-bottom: 10px; }
        .pm-name { font-family: 'Orbitron', monospace; font-size: 1.2em; font-weight: 700; color: #fff; margin-bottom: 6px; }
        .pm-desc { font-size: 13px; color: rgba(255,255,255,0.5); margin-bottom: 20px; line-height: 1.5; }
        .pm-cost-row { display: flex; justify-content: center; align-items: center; gap: 16px; margin-bottom: 8px; flex-wrap: wrap; }
        .pm-cost { font-family: 'Orbitron', monospace; font-size: 1.8em; font-weight: 900; color: #ffd700; }
        .pm-balance { font-size: 13px; color: rgba(255,255,255,0.45); }
        .pm-after { font-family: 'Orbitron', monospace; font-size: 1.1em; color: rgba(255,255,255,0.6); margin-bottom: 20px; }
        .pm-btns { display: flex; gap: 12px; }
        .pm-confirm { flex: 1; padding: 12px; background: linear-gradient(135deg,#ffd700,#ff9500); border: none; border-radius: 12px; color: #000; font-weight: 900; font-family: 'Orbitron', monospace; font-size: 13px; text-transform: uppercase; cursor: pointer; transition: all 0.2s; }
        .pm-confirm:hover { transform: scale(1.03); box-shadow: 0 0 20px rgba(255,215,0,0.5); }
        .pm-cancel { flex: 1; padding: 12px; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.15); border-radius: 12px; color: rgba(255,255,255,0.6); font-weight: 700; font-family: 'Orbitron', monospace; font-size: 13px; text-transform: uppercase; cursor: pointer; transition: all 0.2s; }
        .pm-cancel:hover { background: rgba(255,255,255,0.14); }
        .pm-warning { color: #f72585; font-size: 12px; margin-bottom: 16px; font-family: 'Orbitron', monospace; }

        /* Energy purchase success burst */
        .purchase-success-burst {
            position: fixed; top: 50%; left: 50%; transform: translate(-50%,-50%);
            font-family: 'Orbitron', monospace; font-size: 1.4em; font-weight: 900;
            color: #ffd700; text-shadow: 0 0 20px #ffd700; z-index: 9999;
            pointer-events: none; animation: burstFly 0.9s ease-out forwards;
        }
        @keyframes burstFly { 0%{opacity:1;transform:translate(-50%,-80%);} 100%{opacity:0;transform:translate(-50%,-200%);} }

        /* Unlocked glow on newly purchased items */
        .just-unlocked { animation: unlockGlow 1.2s ease; }
        @keyframes unlockGlow {
            0%  { box-shadow: 0 0 0 rgba(255,215,0,0); border-color: rgba(255,215,0,0); }
            40% { box-shadow: 0 0 40px rgba(255,215,0,0.8); border-color: rgba(255,215,0,0.9); }
            100%{ box-shadow: 0 0 20px rgba(0,245,255,0.3); border-color: rgba(0,245,255,0.4); }
        }


        /* ═══ RIVALS TAB ═══ */
        .rivals-layout { display: grid; grid-template-columns: 340px 1fr; gap: 24px; }


        /* Search box */
        .rival-search-box { display: flex; gap: 10px; margin-bottom: 20px; }
        .rival-search-box input {
            flex: 1; background: rgba(20,20,35,0.8); border: 2px solid rgba(138,43,226,0.4);
            border-radius: 12px; padding: 11px 16px; color: #fff;
            font-family: 'Orbitron', monospace; font-size: 13px; outline: none;
        }
        .rival-search-box input:focus { border-color: #00f5ff; box-shadow: 0 0 12px rgba(0,245,255,0.2); }
        .rival-search-box input::placeholder { color: rgba(255,255,255,0.25); }
        .rival-search-btn {
            background: linear-gradient(135deg, #9d4edd, #00f5ff); border: none;
            border-radius: 12px; padding: 11px 18px; color: #000; font-weight: 900;
            font-family: 'Orbitron', monospace; font-size: 12px; cursor: pointer;
            text-transform: uppercase; letter-spacing: 0.5px; white-space: nowrap;
            transition: all 0.2s;
        }
        .rival-search-btn:hover { transform: scale(1.04); box-shadow: 0 0 16px rgba(157,78,221,0.5); }

        /* Pending requests */
        .pending-card {
            background: rgba(255,215,0,0.06); border: 1px solid rgba(255,215,0,0.3);
            border-radius: 14px; padding: 14px 16px; margin-bottom: 10px;
            display: flex; align-items: center; gap: 12px;
        }
        .pending-avatar { width: 38px; height: 38px; border-radius: 50%;
            background: linear-gradient(135deg,#9d4edd,#00f5ff);
            display: flex; align-items: center; justify-content: center;
            font-family: 'Orbitron', monospace; font-weight: 900; font-size: 14px;
            color: #000; flex-shrink: 0; }
        .pending-info { flex: 1; min-width: 0; }
        .pending-name { font-family: 'Orbitron', monospace; font-size: 0.82em; font-weight: 700; color: #fff; }
        .pending-meta { font-size: 11px; color: rgba(255,255,255,0.4); margin-top: 2px; }
        .pending-btns { display: flex; gap: 6px; flex-shrink: 0; }
        .pend-accept { background: linear-gradient(135deg,#00ff88,#00ccff); border: none;
            border-radius: 8px; padding: 6px 12px; color: #000; font-weight: 900;
            font-size: 11px; cursor: pointer; font-family: 'Orbitron', monospace; }
        .pend-reject { background: rgba(247,37,133,0.2); border: 1px solid rgba(247,37,133,0.4);
            border-radius: 8px; padding: 6px 12px; color: #f72585; font-weight: 700;
            font-size: 11px; cursor: pointer; font-family: 'Orbitron', monospace; }

        /* Rival cards */
        .rival-card {
            background: rgba(20,20,35,0.85); border: 2px solid rgba(138,43,226,0.3);
            border-radius: 16px; padding: 16px; margin-bottom: 12px;
            transition: all 0.3s; position: relative; overflow: hidden;
        }
        .rival-card:hover { border-color: #9d4edd; transform: translateY(-2px); box-shadow: 0 8px 28px rgba(138,43,226,0.3); }
        .rival-card::before { content:''; position:absolute; left:0; top:0; width:3px; height:100%;
            background: linear-gradient(180deg,#9d4edd,#00f5ff); }
        .rival-card-top { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
        .rival-avatar { width: 44px; height: 44px; border-radius: 50%;
            background: linear-gradient(135deg,#f72585,#9d4edd);
            display: flex; align-items: center; justify-content: center;
            font-family: 'Orbitron', monospace; font-weight: 900; font-size: 16px;
            color: #fff; flex-shrink: 0; border: 2px solid rgba(157,78,221,0.5); }
        .rival-name { font-family: 'Orbitron', monospace; font-size: 0.9em; font-weight: 700; color: #fff; }
        .rival-level { font-size: 11px; color: #00f5ff; margin-top: 2px; font-family: 'Orbitron', monospace; }
        .rival-last-active { font-size: 10px; color: rgba(255,255,255,0.3); margin-top: 2px; }
        .rival-stats-row { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin-bottom: 10px; }
        .rival-stat { background: rgba(255,255,255,0.04); border-radius: 8px; padding: 8px; text-align: center; }
        .rival-stat-val { font-family: 'Orbitron', monospace; font-size: 0.95em; font-weight: 700;
            background: linear-gradient(135deg,#00f5ff,#9d4edd); -webkit-background-clip:text;
            -webkit-text-fill-color:transparent; background-clip:text; }
        .rival-stat-lbl { font-size: 9px; color: rgba(255,255,255,0.35); text-transform: uppercase;
            letter-spacing: 0.5px; margin-top: 2px; }
        .rival-card-footer { display: flex; justify-content: space-between; align-items: center; }
        .rival-remove-btn { background: rgba(247,37,133,0.12); border: 1px solid rgba(247,37,133,0.3);
            border-radius: 8px; padding: 5px 10px; color: #f72585; font-size: 10px;
            cursor: pointer; font-family: 'Orbitron', monospace; font-weight: 700; }
        .rival-remove-btn:hover { background: rgba(247,37,133,0.25); }

        /* Leaderboards */
        .rivals-lb-tabs { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 18px; }
        .rlb-tab { background: rgba(30,30,45,0.7); border: 1px solid rgba(138,43,226,0.3);
            padding: 7px 14px; border-radius: 10px; cursor: pointer; font-size: 12px;
            font-family: 'Orbitron', monospace; font-weight: 700; color: #c77dff;
            text-transform: uppercase; letter-spacing: 0.5px; transition: all 0.2s; }
        .rlb-tab:hover { border-color: #9d4edd; color: #fff; }
        .rlb-tab.active { background: linear-gradient(135deg,#9d4edd,#00f5ff);
            color: #000; border-color: transparent; box-shadow: 0 0 14px rgba(157,78,221,0.5); }
        .rivals-lb-table { width: 100%; border-collapse: collapse; }
        .rivals-lb-table th { font-family: 'Orbitron', monospace; font-size: 10px; font-weight: 700;
            text-transform: uppercase; letter-spacing: 1px; color: rgba(255,255,255,0.4);
            padding: 8px 12px; text-align: left; border-bottom: 1px solid rgba(255,255,255,0.08); }
        .rivals-lb-table td { padding: 12px; border-bottom: 1px solid rgba(255,255,255,0.04);
            font-size: 13px; color: rgba(255,255,255,0.75); }
        .rivals-lb-table tr:hover td { background: rgba(157,78,221,0.07); }
        .rlb-rank { font-family: 'Orbitron', monospace; font-weight: 900; font-size: 1em; width: 32px; }
        .rlb-rank.gold   { color: #ffd700; text-shadow: 0 0 12px #ffd700; }
        .rlb-rank.silver { color: #c0c0c0; }
        .rlb-rank.bronze { color: #cd7f32; }
        .rlb-name { font-family: 'Orbitron', monospace; font-weight: 700; font-size: 0.85em; }
        .rlb-name.is-you { color: #00f5ff; }
        .rlb-val { font-family: 'Orbitron', monospace; font-weight: 900;
            background: linear-gradient(135deg,#ffd700,#ff9500);
            -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
        .rlb-empty { text-align: center; padding: 40px; color: rgba(255,255,255,0.3);
            font-family: 'Orbitron', monospace; font-size: 0.85em; }

        /* Sent request chip */
        .sent-chip { display: inline-flex; align-items: center; gap: 6px;
            background: rgba(157,78,221,0.1); border: 1px solid rgba(157,78,221,0.3);
            border-radius: 20px; padding: 5px 12px; font-size: 11px;
            color: #c77dff; font-family: 'Orbitron', monospace; margin: 4px; }


        /* ═══ RIVAL REPORT WIDGET ═══ */
        .rival-report-widget {
            background: linear-gradient(135deg, rgba(247,37,133,0.06), rgba(157,78,221,0.08));
            border: 1px solid rgba(247,37,133,0.25);
            border-radius: 20px; padding: 20px 24px; margin-bottom: 28px;
            position: relative; overflow: hidden;
        }
        .rival-report-widget::before {
            content:''; position:absolute; top:0; left:0; width:100%; height:3px;
            background: linear-gradient(90deg, #f72585, #9d4edd, #00f5ff);
        }
        .rr-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
        .rr-title { font-family:'Orbitron',monospace; font-size:0.82em; font-weight:700; text-transform:uppercase; letter-spacing:2px; }
        .rr-title.has-rivals { color:#f72585; }
        .rr-title.no-rivals  { color:rgba(255,255,255,0.4); }
        .rr-rival-count { font-size:11px; font-family:'Orbitron',monospace; color:rgba(255,255,255,0.35); letter-spacing:1px; }
        .rr-rival-count span { color:#f72585; font-weight:700; }

        /* Carousel */
        .rr-carousel-outer { position:relative; overflow:hidden; }
        .rr-carousel-track { display:flex; gap:14px; transition:transform 0.45s cubic-bezier(0.4,0,0.2,1); will-change:transform; }

        /* Base card */
        .rr-card {
            flex:0 0 270px; background:rgba(20,20,35,0.9);
            border:1px solid rgba(157,78,221,0.22); border-radius:16px;
            padding:16px; position:relative; overflow:hidden; transition:all 0.25s;
            display:flex; flex-direction:column; gap:8px;
        }
        .rr-card:hover { border-color:rgba(247,37,133,0.5); transform:translateY(-3px); }

        /* Accent bar left edge by type */
        .rr-card::after { content:''; position:absolute; left:0; top:0; width:3px; height:100%; border-radius:3px 0 0 3px; }
        .rr-card.type-leaderboard::after { background:#ffd700; }
        .rr-card.type-score::after       { background:#f72585; }
        .rr-card.type-speed::after       { background:#00ff88; }
        .rr-card.type-streak::after      { background:#ff6b00; }
        .rr-card.type-combo::after       { background:#00f5ff; }
        .rr-card.type-combo_event::after { background:#00f5ff; }
        .rr-card.type-speed_event::after { background:#00ff88; }
        .rr-card.type-runs::after        { background:rgba(255,255,255,0.15); }
        .rr-card.type-global::after      { background:#9d4edd; }
        .rr-card.type-self::after        { background:rgba(255,255,255,0.1); }
        .rr-card.type-tip::after         { background:#9d4edd; }

        /* HIGHLIGHT card — the most beatable target */
        .rr-card.is-highlight {
            border-color:rgba(255,215,0,0.5) !important;
            background:linear-gradient(135deg,rgba(255,215,0,0.08),rgba(247,37,133,0.06));
            box-shadow:0 0 24px rgba(255,215,0,0.15);
        }
        .rr-card.is-highlight .rr-highlight-crown {
            display:block;
        }
        .rr-highlight-crown {
            display:none; position:absolute; top:10px; right:10px;
            background:linear-gradient(135deg,#ffd700,#ff9500);
            color:#000; font-family:'Orbitron',monospace; font-size:9px; font-weight:900;
            padding:3px 8px; border-radius:6px; text-transform:uppercase; letter-spacing:0.5px;
        }

        /* Card sections */
        .rr-card-top { display:flex; align-items:flex-start; gap:10px; }
        .rr-icon { font-size:1.6em; flex-shrink:0; line-height:1; }
        .rr-player {
            font-family:'Orbitron',monospace; font-size:0.7em; font-weight:700;
            color:#f72585; text-transform:uppercase; letter-spacing:0.5px; margin-bottom:3px;
            overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:160px;
        }
        .rr-player.is-you { color:#00f5ff; }
        .rr-text { font-size:12px; color:rgba(255,255,255,0.65); line-height:1.45; }

        /* Closeness bar */
        .rr-closeness { margin-top:4px; }
        .rr-closeness-label { display:flex; justify-content:space-between; font-size:10px; color:rgba(255,255,255,0.3); margin-bottom:4px; font-family:'Orbitron',monospace; }
        .rr-closeness-bar { width:100%; height:5px; background:rgba(255,255,255,0.07); border-radius:3px; overflow:hidden; }
        .rr-closeness-fill { height:100%; border-radius:3px; transition:width 1s ease; }
        .rr-closeness-fill.close  { background:linear-gradient(90deg,#ffd700,#f72585); }
        .rr-closeness-fill.medium { background:linear-gradient(90deg,#9d4edd,#00f5ff); }
        .rr-closeness-fill.far    { background:linear-gradient(90deg,#4361ee,#9d4edd); }

        /* XP bounty badge */
        .rr-xp-row { display:flex; align-items:center; justify-content:space-between; margin-top:4px; }
        .rr-xp-badge {
            display:inline-flex; align-items:center; gap:4px;
            background:linear-gradient(135deg,rgba(255,215,0,0.18),rgba(255,150,0,0.12));
            border:1px solid rgba(255,215,0,0.4); border-radius:8px;
            padding:3px 9px; font-family:'Orbitron',monospace; font-size:10px;
            font-weight:900; color:#ffd700;
        }
        .rr-cta { font-size:10px; color:rgba(255,255,255,0.3); font-style:italic; }
        .rr-cta.has-cta { color:#00f5ff; font-style:normal; font-family:'Orbitron',monospace; font-size:9px; font-weight:700; letter-spacing:0.3px; }

        /* Already beaten */
        .rr-beaten-badge {
            display:inline-flex; align-items:center; gap:4px;
            background:rgba(0,255,136,0.1); border:1px solid rgba(0,255,136,0.3);
            border-radius:8px; padding:3px 9px; font-size:10px; color:#00ff88;
            font-family:'Orbitron',monospace; font-weight:700;
        }

        .rr-ago { font-size:9px; color:rgba(255,255,255,0.2); font-family:'Orbitron',monospace; margin-top:2px; }

        /* Nav */
        .rr-nav { display:flex; gap:8px; align-items:center; margin-top:14px; justify-content:flex-end; }
        .rr-arrow { width:30px; height:30px; border-radius:50%; background:rgba(157,78,221,0.15);
            border:1px solid rgba(157,78,221,0.3); display:flex; align-items:center; justify-content:center;
            cursor:pointer; font-size:14px; color:#c77dff; transition:all 0.2s; user-select:none; }
        .rr-arrow:hover { background:rgba(157,78,221,0.3); border-color:#9d4edd; }
        .rr-arrow.disabled { opacity:0.25; cursor:default; }
        .rr-dots { display:flex; gap:5px; align-items:center; }
        .rr-dot { width:6px; height:6px; border-radius:50%; background:rgba(255,255,255,0.15); transition:all 0.2s; cursor:pointer; }
        .rr-dot.active { background:#f72585; width:18px; border-radius:3px; }

        /* CTA button on tip card */
        .rr-goto-rivals {
            background:linear-gradient(135deg,rgba(247,37,133,0.2),rgba(157,78,221,0.2));
            border:1px solid rgba(247,37,133,0.4); border-radius:10px; padding:6px 16px;
            color:#f72585; font-family:'Orbitron',monospace; font-size:10px; font-weight:700;
            cursor:pointer; text-transform:uppercase; letter-spacing:0.5px; transition:all 0.2s; margin-top:6px;
        }
        .rr-goto-rivals:hover { background:rgba(247,37,133,0.3); transform:scale(1.03); }

        /* ═══ RIVALS TAB ═══ */
        .rivals-layout { display: grid; grid-template-columns: 340px 1fr; gap: 24px; }


        /* Search box */
        .rival-search-box { display: flex; gap: 10px; margin-bottom: 20px; }
        .rival-search-box input {
            flex: 1; background: rgba(20,20,35,0.8); border: 2px solid rgba(138,43,226,0.4);
            border-radius: 12px; padding: 11px 16px; color: #fff;
            font-family: 'Orbitron', monospace; font-size: 13px; outline: none;
        }
        .rival-search-box input:focus { border-color: #00f5ff; box-shadow: 0 0 12px rgba(0,245,255,0.2); }
        .rival-search-box input::placeholder { color: rgba(255,255,255,0.25); }
        .rival-search-btn {
            background: linear-gradient(135deg, #9d4edd, #00f5ff); border: none;
            border-radius: 12px; padding: 11px 18px; color: #000; font-weight: 900;
            font-family: 'Orbitron', monospace; font-size: 12px; cursor: pointer;
            text-transform: uppercase; letter-spacing: 0.5px; white-space: nowrap;
            transition: all 0.2s;
        }
        .rival-search-btn:hover { transform: scale(1.04); box-shadow: 0 0 16px rgba(157,78,221,0.5); }

        /* Pending requests */
        .pending-card {
            background: rgba(255,215,0,0.06); border: 1px solid rgba(255,215,0,0.3);
            border-radius: 14px; padding: 14px 16px; margin-bottom: 10px;
            display: flex; align-items: center; gap: 12px;
        }
        .pending-avatar { width: 38px; height: 38px; border-radius: 50%;
            background: linear-gradient(135deg,#9d4edd,#00f5ff);
            display: flex; align-items: center; justify-content: center;
            font-family: 'Orbitron', monospace; font-weight: 900; font-size: 14px;
            color: #000; flex-shrink: 0; }
        .pending-info { flex: 1; min-width: 0; }
        .pending-name { font-family: 'Orbitron', monospace; font-size: 0.82em; font-weight: 700; color: #fff; }
        .pending-meta { font-size: 11px; color: rgba(255,255,255,0.4); margin-top: 2px; }
        .pending-btns { display: flex; gap: 6px; flex-shrink: 0; }
        .pend-accept { background: linear-gradient(135deg,#00ff88,#00ccff); border: none;
            border-radius: 8px; padding: 6px 12px; color: #000; font-weight: 900;
            font-size: 11px; cursor: pointer; font-family: 'Orbitron', monospace; }
        .pend-reject { background: rgba(247,37,133,0.2); border: 1px solid rgba(247,37,133,0.4);
            border-radius: 8px; padding: 6px 12px; color: #f72585; font-weight: 700;
            font-size: 11px; cursor: pointer; font-family: 'Orbitron', monospace; }

        /* Rival cards */
        .rival-card {
            background: rgba(20,20,35,0.85); border: 2px solid rgba(138,43,226,0.3);
            border-radius: 16px; padding: 16px; margin-bottom: 12px;
            transition: all 0.3s; position: relative; overflow: hidden;
        }
        .rival-card:hover { border-color: #9d4edd; transform: translateY(-2px); box-shadow: 0 8px 28px rgba(138,43,226,0.3); }
        .rival-card::before { content:''; position:absolute; left:0; top:0; width:3px; height:100%;
            background: linear-gradient(180deg,#9d4edd,#00f5ff); }
        .rival-card-top { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
        .rival-avatar { width: 44px; height: 44px; border-radius: 50%;
            background: linear-gradient(135deg,#f72585,#9d4edd);
            display: flex; align-items: center; justify-content: center;
            font-family: 'Orbitron', monospace; font-weight: 900; font-size: 16px;
            color: #fff; flex-shrink: 0; border: 2px solid rgba(157,78,221,0.5); }
        .rival-name { font-family: 'Orbitron', monospace; font-size: 0.9em; font-weight: 700; color: #fff; }
        .rival-level { font-size: 11px; color: #00f5ff; margin-top: 2px; font-family: 'Orbitron', monospace; }
        .rival-last-active { font-size: 10px; color: rgba(255,255,255,0.3); margin-top: 2px; }
        .rival-stats-row { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin-bottom: 10px; }
        .rival-stat { background: rgba(255,255,255,0.04); border-radius: 8px; padding: 8px; text-align: center; }
        .rival-stat-val { font-family: 'Orbitron', monospace; font-size: 0.95em; font-weight: 700;
            background: linear-gradient(135deg,#00f5ff,#9d4edd); -webkit-background-clip:text;
            -webkit-text-fill-color:transparent; background-clip:text; }
        .rival-stat-lbl { font-size: 9px; color: rgba(255,255,255,0.35); text-transform: uppercase;
            letter-spacing: 0.5px; margin-top: 2px; }
        .rival-card-footer { display: flex; justify-content: space-between; align-items: center; }
        .rival-remove-btn { background: rgba(247,37,133,0.12); border: 1px solid rgba(247,37,133,0.3);
            border-radius: 8px; padding: 5px 10px; color: #f72585; font-size: 10px;
            cursor: pointer; font-family: 'Orbitron', monospace; font-weight: 700; }
        .rival-remove-btn:hover { background: rgba(247,37,133,0.25); }

        /* Leaderboards */
        .rivals-lb-tabs { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 18px; }
        .rlb-tab { background: rgba(30,30,45,0.7); border: 1px solid rgba(138,43,226,0.3);
            padding: 7px 14px; border-radius: 10px; cursor: pointer; font-size: 12px;
            font-family: 'Orbitron', monospace; font-weight: 700; color: #c77dff;
            text-transform: uppercase; letter-spacing: 0.5px; transition: all 0.2s; }
        .rlb-tab:hover { border-color: #9d4edd; color: #fff; }
        .rlb-tab.active { background: linear-gradient(135deg,#9d4edd,#00f5ff);
            color: #000; border-color: transparent; box-shadow: 0 0 14px rgba(157,78,221,0.5); }
        .rivals-lb-table { width: 100%; border-collapse: collapse; }
        .rivals-lb-table th { font-family: 'Orbitron', monospace; font-size: 10px; font-weight: 700;
            text-transform: uppercase; letter-spacing: 1px; color: rgba(255,255,255,0.4);
            padding: 8px 12px; text-align: left; border-bottom: 1px solid rgba(255,255,255,0.08); }
        .rivals-lb-table td { padding: 12px; border-bottom: 1px solid rgba(255,255,255,0.04);
            font-size: 13px; color: rgba(255,255,255,0.75); }
        .rivals-lb-table tr:hover td { background: rgba(157,78,221,0.07); }
        .rlb-rank { font-family: 'Orbitron', monospace; font-weight: 900; font-size: 1em; width: 32px; }
        .rlb-rank.gold   { color: #ffd700; text-shadow: 0 0 12px #ffd700; }
        .rlb-rank.silver { color: #c0c0c0; }
        .rlb-rank.bronze { color: #cd7f32; }
        .rlb-name { font-family: 'Orbitron', monospace; font-weight: 700; font-size: 0.85em; }
        .rlb-name.is-you { color: #00f5ff; }
        .rlb-val { font-family: 'Orbitron', monospace; font-weight: 900;
            background: linear-gradient(135deg,#ffd700,#ff9500);
            -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
        .rlb-empty { text-align: center; padding: 40px; color: rgba(255,255,255,0.3);
            font-family: 'Orbitron', monospace; font-size: 0.85em; }

        /* Sent request chip */
        .sent-chip { display: inline-flex; align-items: center; gap: 6px;
            background: rgba(157,78,221,0.1); border: 1px solid rgba(157,78,221,0.3);
            border-radius: 20px; padding: 5px 12px; font-size: 11px;
            color: #c77dff; font-family: 'Orbitron', monospace; margin: 4px; }


        /* ═══ RIVAL REPORT WIDGET ═══ */
        .rival-report-widget {
            background: linear-gradient(135deg, rgba(247,37,133,0.06), rgba(157,78,221,0.08));
            border: 1px solid rgba(247,37,133,0.25);
            border-radius: 20px;
            padding: 20px 24px;
            margin-bottom: 28px;
            position: relative;
            overflow: hidden;
        }
        .rival-report-widget::before {
            content: '';
            position: absolute; top: 0; left: 0;
            width: 100%; height: 3px;
            background: linear-gradient(90deg, #f72585, #9d4edd, #00f5ff);
        }
        .rr-header {
            display: flex; align-items: center; justify-content: space-between;
            margin-bottom: 16px;
        }
        .rr-title {
            font-family: 'Orbitron', monospace; font-size: 0.82em; font-weight: 700;
            text-transform: uppercase; letter-spacing: 2px;
        }
        .rr-title.has-rivals  { color: #f72585; }
        .rr-title.no-rivals   { color: rgba(255,255,255,0.4); }
        .rr-rival-count {
            font-size: 11px; font-family: 'Orbitron', monospace;
            color: rgba(255,255,255,0.35); letter-spacing: 1px;
        }
        .rr-rival-count span { color: #f72585; font-weight: 700; }

        /* Carousel track */
        .rr-carousel-outer {
            position: relative; overflow: hidden;
        }
        .rr-carousel-track {
            display: flex; gap: 12px;
            transition: transform 0.45s cubic-bezier(0.4, 0, 0.2, 1);
            will-change: transform;
        }

        /* Feed cards */
        .rr-card {
            flex: 0 0 260px; background: rgba(20,20,35,0.85);
            border: 1px solid rgba(157,78,221,0.25); border-radius: 14px;
            padding: 14px 16px; position: relative; overflow: hidden;
            transition: all 0.25s;
        }
        .rr-card:hover { border-color: rgba(247,37,133,0.5); transform: translateY(-3px); }
        .rr-card.type-pb         { border-left: 3px solid #ffd700; }
        .rr-card.type-combo      { border-left: 3px solid #00f5ff; }
        .rr-card.type-streak     { border-left: 3px solid #f72585; }
        .rr-card.type-speed      { border-left: 3px solid #00ff88; }
        .rr-card.type-leaderboard{ border-left: 3px solid #ffd700; }
        .rr-card.type-unlock     { border-left: 3px solid #9d4edd; }
        .rr-card.type-global     { border-left: 3px solid rgba(255,255,255,0.2); }
        .rr-card.type-tip        { border-left: 3px solid rgba(255,255,255,0.1); }

        .rr-card-top { display: flex; align-items: flex-start; gap: 10px; margin-bottom: 8px; }
        .rr-icon { font-size: 1.5em; flex-shrink: 0; line-height: 1; }
        .rr-player {
            font-family: 'Orbitron', monospace; font-size: 0.72em; font-weight: 700;
            color: #f72585; text-transform: uppercase; letter-spacing: 0.5px;
            margin-bottom: 4px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
        }
        .rr-player.is-you { color: #00f5ff; }
        .rr-text {
            font-size: 12px; color: rgba(255,255,255,0.65); line-height: 1.45;
        }
        .rr-ago {
            font-size: 10px; color: rgba(255,255,255,0.25);
            margin-top: 8px; font-family: 'Orbitron', monospace;
        }

        /* Nav arrows */
        .rr-nav {
            display: flex; gap: 8px; align-items: center; margin-top: 14px;
            justify-content: flex-end;
        }
        .rr-arrow {
            width: 30px; height: 30px; border-radius: 50%;
            background: rgba(157,78,221,0.15); border: 1px solid rgba(157,78,221,0.3);
            display: flex; align-items: center; justify-content: center;
            cursor: pointer; font-size: 14px; color: #c77dff;
            transition: all 0.2s; user-select: none;
        }
        .rr-arrow:hover { background: rgba(157,78,221,0.3); border-color: #9d4edd; }
        .rr-arrow.disabled { opacity: 0.25; cursor: default; }
        .rr-dots { display: flex; gap: 5px; align-items: center; }
        .rr-dot {
            width: 6px; height: 6px; border-radius: 50%;
            background: rgba(255,255,255,0.15); transition: all 0.2s; cursor: pointer;
        }
        .rr-dot.active { background: #f72585; width: 18px; border-radius: 3px; }

        /* Rivals wanted state */
        .rr-wanted-cta {
            text-align: center; padding: 6px 0 4px;
        }
        .rr-wanted-cta p {
            font-size: 12px; color: rgba(255,255,255,0.35); margin-bottom: 10px; line-height: 1.5;
        }
        .rr-goto-rivals {
            background: linear-gradient(135deg, rgba(247,37,133,0.2), rgba(157,78,221,0.2));
            border: 1px solid rgba(247,37,133,0.4); border-radius: 10px;
            padding: 7px 18px; color: #f72585; font-family: 'Orbitron', monospace;
            font-size: 11px; font-weight: 700; cursor: pointer; text-transform: uppercase;
            letter-spacing: 0.5px; transition: all 0.2s;
        }
        .rr-goto-rivals:hover { background: rgba(247,37,133,0.25); transform: scale(1.03); }


        /* ═══ SCHEDULE / HABIT SYSTEM ═══ */

        /* Overview snippet card */
        .schedule-snippet {
            background: linear-gradient(135deg, rgba(0,245,255,0.05), rgba(157,78,221,0.08));
            border: 1px solid rgba(0,245,255,0.2); border-radius: 20px;
            padding: 20px 24px; margin-bottom: 28px; position: relative; overflow: hidden;
            cursor: pointer; transition: all 0.3s;
        }
        .schedule-snippet:hover { border-color: rgba(0,245,255,0.4); transform: translateY(-2px); }
        .schedule-snippet::before {
            content:''; position:absolute; top:0; left:0; width:100%; height:3px;
            background: linear-gradient(90deg, #00f5ff, #9d4edd, #f72585);
        }
        .ss-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
        .ss-title { font-family:'Orbitron',monospace; font-size:0.8em; font-weight:700;
            text-transform:uppercase; letter-spacing:2px; color:#00f5ff; }
        .ss-streak { font-family:'Orbitron',monospace; font-size:1.4em; font-weight:900;
            background:linear-gradient(135deg,#f72585,#ffd700);
            -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
        .ss-streak-label { font-size:10px; color:rgba(255,255,255,0.35); text-transform:uppercase; letter-spacing:1px; font-family:'Orbitron',monospace; }

        /* Mini week dots */
        .ss-week { display:flex; gap:6px; margin-bottom:14px; }
        .ss-day-dot {
            flex:1; height:28px; border-radius:6px; display:flex; align-items:center;
            justify-content:center; font-size:9px; font-family:'Orbitron',monospace;
            font-weight:700; text-transform:uppercase; letter-spacing:0.3px;
            transition: all 0.3s;
        }
        .ss-day-dot.played  { background:linear-gradient(135deg,#00f5ff,#9d4edd); color:#000; }
        .ss-day-dot.skipped { background:rgba(255,215,0,0.2); border:1px solid rgba(255,215,0,0.4); color:#ffd700; }
        .ss-day-dot.today   { background:rgba(247,37,133,0.2); border:2px solid #f72585; color:#f72585; }
        .ss-day-dot.missed  { background:rgba(255,255,255,0.05); color:rgba(255,255,255,0.2); }
        .ss-day-dot.future  { background:rgba(255,255,255,0.03); color:rgba(255,255,255,0.1); border:1px dashed rgba(255,255,255,0.1); }

        /* Next reward row */
        .ss-reward-row { display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; }
        .ss-reward-info { flex:1; min-width:0; }
        .ss-reward-label { font-family:'Orbitron',monospace; font-size:0.78em; font-weight:700; color:#ffd700; margin-bottom:3px; }
        .ss-reward-timeout { font-size:11px; color:rgba(255,255,255,0.4); }
        .ss-reward-xp { font-family:'Orbitron',monospace; font-size:1.3em; font-weight:900;
            color:#ffd700; text-shadow:0 0 10px rgba(255,215,0,0.5); white-space:nowrap; }
        .ss-view-btn { font-family:'Orbitron',monospace; font-size:10px; font-weight:700;
            color:rgba(0,245,255,0.7); text-transform:uppercase; letter-spacing:0.5px;
            background:none; border:1px solid rgba(0,245,255,0.25); border-radius:8px;
            padding:5px 12px; cursor:pointer; transition:all 0.2s; white-space:nowrap; }
        .ss-view-btn:hover { background:rgba(0,245,255,0.1); border-color:rgba(0,245,255,0.5); }

        /* Timeout countdown */
        .ss-countdown { font-family:'Orbitron',monospace; font-size:0.75em; font-weight:700;
            color:#f72585; margin-left:6px; }

        /* ── SCHEDULE TAB ── */
        .sched-layout { display:grid; grid-template-columns:1fr 340px; gap:24px; }
        @media(max-width:960px){ .sched-layout { grid-template-columns:1fr; } }

        /* Phase banner */
        .phase-banner {
            border-radius:16px; padding:16px 20px; margin-bottom:24px;
            display:flex; align-items:center; gap:16px; position:relative; overflow:hidden;
        }
        .phase-banner.new       { background:linear-gradient(135deg,rgba(0,245,255,0.12),rgba(157,78,221,0.08)); border:1px solid rgba(0,245,255,0.3); }
        .phase-banner.returning { background:linear-gradient(135deg,rgba(255,215,0,0.12),rgba(247,37,133,0.08)); border:1px solid rgba(255,215,0,0.35); }
        .phase-banner.building  { background:linear-gradient(135deg,rgba(157,78,221,0.12),rgba(0,245,255,0.08)); border:1px solid rgba(157,78,221,0.35); }
        .phase-banner.regular   { background:linear-gradient(135deg,rgba(247,37,133,0.12),rgba(157,78,221,0.1)); border:1px solid rgba(247,37,133,0.35); }
        .phase-banner.elite     { background:linear-gradient(135deg,rgba(255,215,0,0.15),rgba(247,37,133,0.1)); border:1px solid rgba(255,215,0,0.45); }
        .phase-icon { font-size:2.2em; flex-shrink:0; }
        .phase-title { font-family:'Orbitron',monospace; font-size:0.95em; font-weight:700; color:#fff; margin-bottom:4px; }
        .phase-desc { font-size:13px; color:rgba(255,255,255,0.5); line-height:1.4; }

        /* Weekly progress bar */
        .weekly-progress-wrap { margin-bottom:24px; }
        .wp-header { display:flex; justify-content:space-between; align-items:baseline; margin-bottom:8px; }
        .wp-label { font-family:'Orbitron',monospace; font-size:0.78em; font-weight:700; color:rgba(255,255,255,0.6); text-transform:uppercase; letter-spacing:1px; }
        .wp-count { font-family:'Orbitron',monospace; font-size:1.1em; font-weight:900; color:#00f5ff; }
        .wp-bar { height:12px; background:rgba(255,255,255,0.07); border-radius:6px; overflow:hidden; }
        .wp-fill { height:100%; background:linear-gradient(90deg,#9d4edd,#00f5ff); border-radius:6px; transition:width 1s ease; position:relative; }
        .wp-fill::after { content:''; position:absolute; top:0; left:-100%; width:100%; height:100%;
            background:linear-gradient(90deg,transparent,rgba(255,255,255,0.3),transparent);
            animation: shimmer 2.5s infinite; }

        /* 28-day calendar grid */
        .cal-grid-header { display:grid; grid-template-columns:repeat(7,1fr); gap:4px; margin-bottom:4px; }
        .cal-dow-label { text-align:center; font-family:'Orbitron',monospace; font-size:9px;
            color:rgba(255,255,255,0.25); text-transform:uppercase; letter-spacing:0.5px; }
        .cal-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:4px; }
        .cal-day {
            aspect-ratio:1; border-radius:8px; display:flex; flex-direction:column;
            align-items:center; justify-content:center; position:relative;
            transition:all 0.2s; font-size:11px;
        }
        .cal-day.played {
            background:linear-gradient(135deg,#9d4edd,#00f5ff);
            box-shadow:0 2px 8px rgba(157,78,221,0.4);
        }
        .cal-day.played-multi {
            background:linear-gradient(135deg,#f72585,#9d4edd);
            box-shadow:0 2px 10px rgba(247,37,133,0.5);
        }
        .cal-day.skipped {
            background:rgba(255,215,0,0.15); border:1px solid rgba(255,215,0,0.35);
        }
        .cal-day.missed  { background:rgba(255,255,255,0.04); }
        .cal-day.today   { border:2px solid #f72585; background:rgba(247,37,133,0.12); }
        .cal-day.future  { background:rgba(255,255,255,0.02); opacity:0.4; }
        .cal-num { font-family:'Orbitron',monospace; font-weight:700; font-size:11px;
            color:rgba(255,255,255,0.8); line-height:1; }
        .cal-day.played .cal-num, .cal-day.played-multi .cal-num { color:#fff; }
        .cal-day.missed .cal-num  { color:rgba(255,255,255,0.2); }
        .cal-sessions-dot { width:4px; height:4px; border-radius:50%; background:rgba(255,255,255,0.6); margin-top:2px; }
        .cal-skip-icon { font-size:8px; margin-top:1px; }
        .cal-month-label { font-size:8px; color:rgba(255,255,255,0.25); margin-top:1px; font-family:'Orbitron',monospace; }

        /* Reward tiers */
        .reward-tier {
            background:rgba(20,20,35,0.8); border:1px solid rgba(138,43,226,0.2);
            border-radius:14px; padding:14px 16px; margin-bottom:10px;
            display:flex; align-items:center; gap:14px; transition:all 0.3s;
            position:relative; overflow:hidden;
        }
        .reward-tier.achieved { border-color:rgba(0,255,136,0.35); background:rgba(0,255,136,0.05); }
        .reward-tier.is-next  { border-color:rgba(255,215,0,0.5); background:rgba(255,215,0,0.07);
            box-shadow:0 0 16px rgba(255,215,0,0.1); }
        .reward-tier.is-next::before { content:'→ NEXT'; position:absolute; right:10px; top:8px;
            font-family:'Orbitron',monospace; font-size:8px; font-weight:900;
            color:#ffd700; letter-spacing:1px; }
        .rt-icon { font-size:1.6em; flex-shrink:0; }
        .rt-label { font-family:'Orbitron',monospace; font-size:0.82em; font-weight:700; color:#fff; margin-bottom:3px; }
        .rt-xp { font-size:12px; color:#ffd700; font-family:'Orbitron',monospace; font-weight:700; }
        .rt-check { margin-left:auto; font-size:1.2em; color:#00ff88; flex-shrink:0; }

        /* Skip token widget */
        .skip-widget {
            background:rgba(255,215,0,0.06); border:1px solid rgba(255,215,0,0.25);
            border-radius:16px; padding:16px 18px;
        }
        .skip-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
        .skip-title { font-family:'Orbitron',monospace; font-size:0.78em; font-weight:700;
            text-transform:uppercase; letter-spacing:1px; color:#ffd700; }
        .skip-tokens-display { display:flex; gap:5px; }
        .skip-token-pip { width:12px; height:12px; border-radius:50%; border:1px solid rgba(255,215,0,0.5); }
        .skip-token-pip.filled { background:#ffd700; box-shadow:0 0 6px rgba(255,215,0,0.6); }
        .skip-desc { font-size:12px; color:rgba(255,255,255,0.4); line-height:1.5; margin-bottom:14px; }
        .skip-date-select { display:flex; gap:8px; align-items:center; margin-bottom:10px; flex-wrap:wrap; }
        .skip-date-input { background:rgba(20,20,35,0.8); border:1px solid rgba(255,215,0,0.3);
            border-radius:10px; padding:7px 12px; color:#ffd700; font-family:'Orbitron',monospace;
            font-size:11px; outline:none; }
        .skip-date-input:focus { border-color:#ffd700; }
        .skip-btn { background:linear-gradient(135deg,#ffd700,#ff9500); border:none;
            border-radius:10px; padding:8px 16px; color:#000; font-family:'Orbitron',monospace;
            font-size:11px; font-weight:900; cursor:pointer; transition:all 0.2s; text-transform:uppercase; }
        .skip-btn:hover { transform:scale(1.04); box-shadow:0 0 14px rgba(255,215,0,0.4); }
        .skip-btn:disabled { opacity:0.4; cursor:not-allowed; transform:none; }
        .skip-earn-hint { font-size:11px; color:rgba(255,255,255,0.3); font-style:italic; margin-top:8px; }


        /* ═══ FITNESS TRACKING TAB ═══ */

        /* Overview snippet */
        .fitness-snippet {
            background: linear-gradient(135deg, rgba(0,255,136,0.06), rgba(0,245,255,0.06));
            border: 1px solid rgba(0,255,136,0.2); border-radius: 20px;
            padding: 18px 24px; margin-bottom: 28px; position: relative; overflow: hidden;
            cursor: pointer; transition: all 0.3s;
        }
        .fitness-snippet:hover { border-color: rgba(0,255,136,0.4); transform: translateY(-2px); }
        .fitness-snippet::before {
            content:''; position:absolute; top:0; left:0; width:100%; height:3px;
            background: linear-gradient(90deg, #00ff88, #00f5ff, #9d4edd);
        }
        .fs-row { display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; }
        .fs-block { text-align:center; }
        .fs-val { font-family:'Orbitron',monospace; font-size:1.5em; font-weight:900;
            background:linear-gradient(135deg,#00ff88,#00f5ff);
            -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
        .fs-label { font-size:10px; color:rgba(255,255,255,0.35); text-transform:uppercase;
            letter-spacing:1px; font-family:'Orbitron',monospace; margin-top:2px; }
        .fs-title { font-family:'Orbitron',monospace; font-size:0.8em; font-weight:700;
            text-transform:uppercase; letter-spacing:2px; color:#00ff88; margin-bottom:10px; }
        .fs-level-pill { display:inline-flex; align-items:center; gap:6px;
            background:rgba(0,255,136,0.12); border:1px solid rgba(0,255,136,0.3);
            border-radius:20px; padding:4px 12px; font-family:'Orbitron',monospace;
            font-size:11px; font-weight:700; color:#00ff88; }

        /* Fitness level badge */
        .fitness-level-display {
            background: linear-gradient(135deg, rgba(0,255,136,0.1), rgba(0,245,255,0.08));
            border: 1px solid rgba(0,255,136,0.25); border-radius: 20px;
            padding: 24px; margin-bottom: 24px; text-align: center; position: relative; overflow: hidden;
        }
        .fld-icon { font-size: 3.5em; margin-bottom: 8px; line-height: 1; }
        .fld-level { font-family:'Orbitron',monospace; font-size:0.75em; color:rgba(255,255,255,0.4);
            text-transform:uppercase; letter-spacing:2px; margin-bottom:4px; }
        .fld-label { font-family:'Orbitron',monospace; font-size:1.5em; font-weight:900;
            background:linear-gradient(135deg,#00ff88,#00f5ff);
            -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
            margin-bottom:12px; }
        .fld-bar-wrap { max-width:300px; margin:0 auto 8px; }
        .fld-bar { height:10px; background:rgba(255,255,255,0.07); border-radius:5px; overflow:hidden; }
        .fld-fill { height:100%; background:linear-gradient(90deg,#00ff88,#00f5ff); border-radius:5px;
            transition:width 1.2s cubic-bezier(0.4,0,0.2,1); position:relative; }
        .fld-fill::after { content:''; position:absolute; top:0; left:-100%; width:100%; height:100%;
            background:linear-gradient(90deg,transparent,rgba(255,255,255,0.35),transparent);
            animation:shimmer 2.5s infinite; }
        .fld-next { font-size:12px; color:rgba(255,255,255,0.4); margin-top:6px; }

        /* Stat grid */
        .fit-stat-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:12px; margin-bottom:24px; }
        .fit-stat { background:rgba(20,20,35,0.8); border:1px solid rgba(0,255,136,0.15);
            border-radius:14px; padding:16px; text-align:center; transition:all 0.3s; }
        .fit-stat:hover { border-color:rgba(0,255,136,0.4); transform:translateY(-3px); }
        .fit-stat-icon { font-size:1.6em; margin-bottom:6px; }
        .fit-stat-val { font-family:'Orbitron',monospace; font-size:1.3em; font-weight:900;
            background:linear-gradient(135deg,#00ff88,#00f5ff);
            -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
        .fit-stat-label { font-size:10px; color:rgba(255,255,255,0.35); text-transform:uppercase;
            letter-spacing:0.5px; margin-top:4px; font-family:'Orbitron',monospace; }
        .fit-stat-sub { font-size:10px; color:rgba(255,255,255,0.2); margin-top:2px; }

        /* Period toggle */
        .fit-period-tabs { display:flex; gap:8px; margin-bottom:18px; }
        .fit-period-tab { background:rgba(30,30,45,0.7); border:1px solid rgba(0,255,136,0.2);
            padding:7px 16px; border-radius:10px; cursor:pointer; font-size:12px;
            font-family:'Orbitron',monospace; font-weight:700; color:rgba(0,255,136,0.5);
            text-transform:uppercase; letter-spacing:0.5px; transition:all 0.2s; }
        .fit-period-tab.active { background:linear-gradient(135deg,rgba(0,255,136,0.2),rgba(0,245,255,0.15));
            border-color:#00ff88; color:#00ff88; box-shadow:0 0 12px rgba(0,255,136,0.2); }

        /* WHO exercise goal */
        .who-card { background:rgba(20,20,35,0.8); border:1px solid rgba(0,245,255,0.2);
            border-radius:16px; padding:20px; margin-bottom:24px; }
        .who-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:12px; }
        .who-title { font-family:'Orbitron',monospace; font-size:0.8em; font-weight:700; color:#00f5ff; text-transform:uppercase; letter-spacing:1px; }
        .who-status { font-size:12px; color:#00ff88; font-family:'Orbitron',monospace; font-weight:700; }
        .who-bar { height:14px; background:rgba(255,255,255,0.07); border-radius:7px; overflow:hidden; margin-bottom:8px; }
        .who-fill { height:100%; background:linear-gradient(90deg,#00ff88,#00f5ff); border-radius:7px; transition:width 1.2s ease; }
        .who-labels { display:flex; justify-content:space-between; font-size:10px; color:rgba(255,255,255,0.3); font-family:'Orbitron',monospace; }

        /* Calorie bar chart (30 days) */
        .cal-chart { display:flex; align-items:flex-end; gap:3px; height:80px; margin-bottom:8px; }
        .cal-bar-wrap { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:flex-end; height:100%; }
        .cal-bar-fill { width:100%; border-radius:3px 3px 0 0; transition:height 1s ease; min-height:2px;
            background:linear-gradient(180deg,#00f5ff,#9d4edd); }
        .cal-bar-fill.today-bar { background:linear-gradient(180deg,#ffd700,#f72585); }
        .cal-chart-label { display:flex; justify-content:space-between; font-size:9px;
            color:rgba(255,255,255,0.2); font-family:'Orbitron',monospace; margin-top:4px; }

        /* Fun equivalents carousel */
        .equiv-carousel-outer { overflow:hidden; margin-bottom:8px; }
        .equiv-carousel-track { display:flex; gap:12px; transition:transform 0.4s ease; }
        .equiv-card { flex:0 0 200px; background:rgba(20,20,35,0.85);
            border:1px solid rgba(0,255,136,0.2); border-radius:14px; padding:16px;
            text-align:center; transition:all 0.25s; }
        .equiv-card:hover { border-color:rgba(0,255,136,0.5); transform:translateY(-3px); }
        .equiv-icon { font-size:2.2em; margin-bottom:8px; }
        .equiv-val { font-family:'Orbitron',monospace; font-size:1.4em; font-weight:900;
            background:linear-gradient(135deg,#00ff88,#ffd700);
            -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
            margin-bottom:4px; }
        .equiv-label { font-size:11px; color:rgba(255,255,255,0.45); line-height:1.4; }
        .equiv-unit { font-size:10px; color:rgba(0,255,136,0.6); font-family:'Orbitron',monospace;
            margin-top:3px; font-weight:700; }

        /* Health facts carousel */
        .health-card { flex:0 0 260px; background:rgba(20,20,35,0.85);
            border:1px solid rgba(157,78,221,0.2); border-radius:14px; padding:18px;
            transition:all 0.25s; }
        .health-card:hover { border-color:rgba(157,78,221,0.5); transform:translateY(-3px); }
        .health-card-top { display:flex; align-items:center; gap:10px; margin-bottom:10px; }
        .health-icon { font-size:1.8em; flex-shrink:0; }
        .health-tag { background:rgba(157,78,221,0.2); border:1px solid rgba(157,78,221,0.3);
            border-radius:6px; padding:2px 8px; font-family:'Orbitron',monospace;
            font-size:9px; font-weight:700; color:#c77dff; text-transform:uppercase; letter-spacing:0.5px; }
        .health-text { font-size:12px; color:rgba(255,255,255,0.6); line-height:1.55; }

        /* Carousel controls shared */
        .carousel-nav { display:flex; justify-content:flex-end; gap:8px; margin-top:10px; }
        .c-arrow { width:28px; height:28px; border-radius:50%; background:rgba(157,78,221,0.15);
            border:1px solid rgba(157,78,221,0.3); display:flex; align-items:center;
            justify-content:center; cursor:pointer; font-size:13px; color:#c77dff;
            transition:all 0.2s; user-select:none; }
        .c-arrow:hover { background:rgba(157,78,221,0.3); }
        .c-arrow.disabled { opacity:0.25; cursor:default; }


        /* ═══ MISSIONS / GANG SYSTEM ═══ */

        /* Gang colour themes applied via CSS vars on containers */
        .gang-theme { --gc: var(--gang-colour, #9d4edd); }

        /* Overview snippet */
        .missions-snippet {
            background: linear-gradient(135deg, rgba(247,37,133,0.07), rgba(157,78,221,0.07));
            border: 1px solid rgba(247,37,133,0.22); border-radius: 20px;
            padding: 18px 24px; margin-bottom: 28px; position: relative; overflow: hidden;
            cursor: pointer; transition: all 0.3s;
        }
        .missions-snippet:hover { border-color: rgba(247,37,133,0.45); transform: translateY(-2px); }
        .missions-snippet::before { content:''; position:absolute; top:0; left:0; width:100%; height:3px;
            background: linear-gradient(90deg, #f72585, #9d4edd, #ffd700); }
        .ms-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
        .ms-gang-badge { display:flex; align-items:center; gap:8px; }
        .ms-gang-icon { font-size:1.8em; }
        .ms-gang-name { font-family:'Orbitron',monospace; font-size:1em; font-weight:900; color:#fff; }
        .ms-gang-status { font-size:10px; font-family:'Orbitron',monospace; font-weight:700;
            text-transform:uppercase; letter-spacing:1px; margin-top:2px; }
        .ms-cred { font-family:'Orbitron',monospace; font-size:1.4em; font-weight:900;
            background:linear-gradient(135deg,#f72585,#ffd700);
            -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
        .ms-cred-label { font-size:10px; color:rgba(255,255,255,0.35); text-transform:uppercase;
            letter-spacing:1px; font-family:'Orbitron',monospace; }
        .ms-progress-row { display:flex; align-items:center; gap:12px; }
        .ms-prog-bar { flex:1; height:8px; background:rgba(255,255,255,0.07); border-radius:4px; overflow:hidden; }
        .ms-prog-fill { height:100%; background:linear-gradient(90deg,#f72585,#ffd700); border-radius:4px; transition:width 1s ease; }
        .ms-prog-label { font-size:11px; color:rgba(255,255,255,0.4); white-space:nowrap; }
        .ms-inbox-badge { background:#f72585; color:#fff; border-radius:50%; width:20px; height:20px;
            display:flex; align-items:center; justify-content:center; font-size:11px;
            font-weight:900; font-family:'Orbitron',monospace; flex-shrink:0; }

        /* Gang map (all 10 gangs overview) */
        .gang-map { display:grid; grid-template-columns:repeat(auto-fill,minmax(120px,1fr)); gap:10px; margin-bottom:24px; }
        .gang-map-card { border-radius:12px; padding:14px; text-align:center; border:2px solid transparent; transition:all 0.3s; position:relative; }
        .gang-map-card.beaten  { border-color:rgba(0,255,136,0.4); background:rgba(0,255,136,0.05); }
        .gang-map-card.current { border-color:rgba(255,215,0,0.6); background:rgba(255,215,0,0.08);
            box-shadow:0 0 18px rgba(255,215,0,0.15); }
        .gang-map-card.locked  { opacity:0.35; filter:grayscale(60%); }
        .gmc-symbol { font-size:1.8em; margin-bottom:5px; }
        .gmc-name { font-family:'Orbitron',monospace; font-size:0.65em; font-weight:700; color:#fff; text-transform:uppercase; letter-spacing:0.3px; }
        .gmc-tier { font-size:9px; color:rgba(255,255,255,0.3); font-family:'Orbitron',monospace; margin-top:2px; }
        .gmc-check { position:absolute; top:6px; right:6px; font-size:12px; color:#00ff88; }
        .gmc-current-arrow { position:absolute; top:6px; right:6px; font-size:10px; color:#ffd700; font-family:'Orbitron',monospace; font-weight:900; }

        /* Gang leaderboard */
        .gang-lb-table { width:100%; border-collapse:collapse; table-layout:fixed; }
        .gang-lb-table th { font-family:'Orbitron',monospace; font-size:9px; font-weight:700;
            text-transform:uppercase; letter-spacing:1px; color:rgba(255,255,255,0.35);
            padding:8px 10px; text-align:left; border-bottom:1px solid rgba(255,255,255,0.06); }
        .gang-lb-table td { padding:8px 6px; border-bottom:1px solid rgba(255,255,255,0.04); font-size:12px; vertical-align:middle; overflow:hidden; }
        .gang-lb-table tr:hover td { background:rgba(255,255,255,0.03); }
        .lb-player-row td { background:rgba(255,215,0,0.06); border-left:3px solid #ffd700; }
        .npc-avatar { width:32px; height:32px; border-radius:50%; display:inline-flex; align-items:center;
            justify-content:center; font-family:'Orbitron',monospace; font-size:10px; font-weight:900;
            color:#fff; flex-shrink:0; overflow:hidden; }
        .npc-name { font-family:'Orbitron',monospace; font-size:0.82em; font-weight:700; color:#fff;
            white-space:nowrap; overflow:hidden; text-overflow:ellipsis; min-width:0; display:inline-block; max-width:120px; }
        .npc-name.you { color:#ffd700; }
        .npc-cred { font-family:'Orbitron',monospace; font-size:0.9em; font-weight:700;
            background:linear-gradient(135deg,#f72585,#ffd700);
            -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; white-space:nowrap; }
        .lb-rank { font-family:'Orbitron',monospace; font-weight:900; font-size:0.9em; color:rgba(255,255,255,0.4); width:28px; }
        .lb-rank.r1 { color:#ffd700; } .lb-rank.r2 { color:#c0c0c0; } .lb-rank.r3 { color:#cd7f32; }

        /* Challenge cards */
        .challenge-mission { background:rgba(20,20,35,0.85); border:1px solid rgba(138,43,226,0.25);
            border-radius:14px; padding:16px; margin-bottom:10px; transition:all 0.3s; }
        .challenge-mission.done { border-color:rgba(0,255,136,0.35); background:rgba(0,255,136,0.04); }
        .challenge-mission:hover { border-color:rgba(247,37,133,0.4); }
        .cm-top { display:flex; align-items:flex-start; gap:12px; margin-bottom:10px; }
        .cm-icon { font-size:1.6em; flex-shrink:0; }
        .cm-label { font-family:'Orbitron',monospace; font-size:0.85em; font-weight:700; color:#fff; margin-bottom:3px; }
        .cm-desc { font-size:12px; color:rgba(255,255,255,0.4); }
        .cm-footer { display:flex; align-items:center; justify-content:space-between; }
        .cm-cred { font-family:'Orbitron',monospace; font-size:11px; color:#f72585; font-weight:700; }
        .cm-prog-bar { flex:1; height:5px; background:rgba(255,255,255,0.07); border-radius:3px; overflow:hidden; margin:0 12px; }
        .cm-prog-fill { height:100%; background:linear-gradient(90deg,#f72585,#ffd700); border-radius:3px; transition:width 1s ease; }
        .cm-pct { font-family:'Orbitron',monospace; font-size:10px; color:rgba(255,255,255,0.35); }

        /* Inbox */
        .inbox-message { background:rgba(20,20,35,0.85); border:1px solid rgba(138,43,226,0.2);
            border-radius:14px; padding:16px; margin-bottom:10px; cursor:pointer; transition:all 0.3s; }
        .inbox-message:hover { border-color:rgba(247,37,133,0.4); transform:translateX(3px); }
        .inbox-message.unread { border-color:rgba(247,37,133,0.4); background:rgba(247,37,133,0.04); }
        .inbox-message.unread::before { content:''; width:6px; height:6px; background:#f72585;
            border-radius:50%; display:inline-block; margin-right:8px; box-shadow:0 0 6px #f72585; }
        .im-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:8px; }
        .im-sender { font-family:'Orbitron',monospace; font-size:0.82em; font-weight:700; color:#f72585; }
        .im-subject { font-family:'Orbitron',monospace; font-size:0.88em; font-weight:700; color:#fff; margin-bottom:6px; }
        .im-preview { font-size:12px; color:rgba(255,255,255,0.45); line-height:1.5; }
        .im-time { font-size:10px; color:rgba(255,255,255,0.25); font-family:'Orbitron',monospace; }
        .im-expanded { margin-top:10px; font-size:13px; color:rgba(255,255,255,0.65); line-height:1.7;
            border-top:1px solid rgba(255,255,255,0.08); padding-top:10px; display:none; }

        /* Status / join bar */
        .join-status-card { border-radius:16px; padding:20px; margin-bottom:20px; text-align:center; }
        .join-status-card.prospect { background:linear-gradient(135deg,rgba(157,78,221,0.12),rgba(0,245,255,0.08)); border:1px solid rgba(157,78,221,0.35); }
        .join-status-card.member   { background:linear-gradient(135deg,rgba(0,255,136,0.08),rgba(0,245,255,0.05)); border:1px solid rgba(0,255,136,0.3); }
        .join-status-card.rival    { background:linear-gradient(135deg,rgba(255,107,0,0.1),rgba(255,215,0,0.07)); border:1px solid rgba(255,107,0,0.4); }
        .join-status-card.champion { background:linear-gradient(135deg,rgba(255,215,0,0.12),rgba(247,37,133,0.08)); border:1px solid rgba(255,215,0,0.5); }
        .jsc-title { font-family:'Orbitron',monospace; font-size:1em; font-weight:700; color:#fff; margin-bottom:6px; }
        .jsc-desc { font-size:13px; color:rgba(255,255,255,0.5); margin-bottom:16px; line-height:1.5; }
        .jsc-bar-wrap { max-width:360px; margin:0 auto 8px; }
        .jsc-bar { height:12px; background:rgba(255,255,255,0.07); border-radius:6px; overflow:hidden; }
        .jsc-fill { height:100%; background:linear-gradient(90deg,#f72585,#ffd700); border-radius:6px; transition:width 1.2s ease; }
        .jsc-label { font-size:11px; color:rgba(255,255,255,0.35); margin-top:5px; font-family:'Orbitron',monospace; }
        .chop-discount-badge { display:inline-flex; align-items:center; gap:6px;
            background:rgba(0,255,136,0.12); border:1px solid rgba(0,255,136,0.3);
            border-radius:12px; padding:5px 14px; font-family:'Orbitron',monospace;
            font-size:12px; font-weight:700; color:#00ff88; margin-top:10px; }


        /* ═══ GANG ACTIVITY FEED ═══ */
        .gang-feed-widget {
            background: linear-gradient(135deg, rgba(0,255,136,0.04), rgba(157,78,221,0.07));
            border: 1px solid rgba(157,78,221,0.22);
            border-radius: 20px; padding: 20px 24px; margin-bottom: 28px;
            position: relative; overflow: hidden;
        }
        .gang-feed-widget::before {
            content:''; position:absolute; top:0; left:0; width:100%; height:3px;
            background: linear-gradient(90deg, #00ff88, #9d4edd, #f72585);
        }
        .gf-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
        .gf-title { font-family:'Orbitron',monospace; font-size:0.82em; font-weight:700;
            text-transform:uppercase; letter-spacing:2px; color:#9d4edd; }
        .gf-gang-label { font-size:11px; font-family:'Orbitron',monospace;
            color:rgba(255,255,255,0.35); letter-spacing:1px; }
        .gf-gang-label span { font-weight:700; }

        /* Position spotlight — above/below */
        .gf-position-row {
            display:grid; grid-template-columns:1fr auto 1fr;
            gap:10px; align-items:center; margin-bottom:16px;
        }
        .gf-rider-block {
            background:rgba(20,20,35,0.8); border:1px solid rgba(138,43,226,0.2);
            border-radius:12px; padding:12px; text-align:center;
        }
        .gf-rider-block.above { border-color:rgba(255,215,0,0.3); }
        .gf-rider-block.below { border-color:rgba(247,37,133,0.3); }
        .gf-rider-block.you   {
            border-color:rgba(157,78,221,0.5);
            background:linear-gradient(135deg,rgba(157,78,221,0.12),rgba(0,245,255,0.06));
        }
        .gf-rider-block.above.close { border-color:rgba(255,215,0,0.7);
            box-shadow:0 0 16px rgba(255,215,0,0.15); }
        .gf-rider-block.below.threat { border-color:rgba(247,37,133,0.7);
            box-shadow:0 0 16px rgba(247,37,133,0.15); animation:threatPulse 2s ease-in-out infinite; }
        @keyframes threatPulse { 0%,100%{box-shadow:0 0 16px rgba(247,37,133,0.15);}
                                  50%{box-shadow:0 0 26px rgba(247,37,133,0.35);} }
        .gf-avatar { width:34px; height:34px; border-radius:50%; display:flex; align-items:center;
            justify-content:center; font-family:'Orbitron',monospace; font-size:11px;
            font-weight:900; color:#000; margin:0 auto 6px; }
        .gf-rider-name { font-family:'Orbitron',monospace; font-size:0.68em; font-weight:700;
            color:#fff; margin-bottom:3px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
        .gf-rider-cred { font-size:11px; color:rgba(255,255,255,0.4); font-family:'Orbitron',monospace; }
        .gf-pos-label { font-size:9px; text-transform:uppercase; letter-spacing:0.5px;
            font-family:'Orbitron',monospace; margin-top:3px; }
        .gf-pos-label.above { color:#ffd700; }
        .gf-pos-label.below { color:#f72585; }
        .gf-pos-label.you   { color:#9d4edd; }
        .gf-rank-badge { font-family:'Orbitron',monospace; font-size:0.65em; font-weight:900;
            background:linear-gradient(135deg,#9d4edd,#f72585);
            -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }

        /* Progress bars between riders */
        .gf-vs-col { display:flex; flex-direction:column; align-items:center; gap:6px; }
        .gf-vs-bar-wrap { width:8px; flex:1; background:rgba(255,255,255,0.07);
            border-radius:4px; overflow:hidden; min-height:40px; }
        .gf-vs-bar-fill { width:100%; border-radius:4px; transition:height 1s ease; }
        .gf-vs-bar-fill.above-fill { background:linear-gradient(180deg,#ffd700,#ff9500); }
        .gf-vs-bar-fill.below-fill { background:linear-gradient(180deg,#f72585,#9d4edd); }
        .gf-vs-pct { font-family:'Orbitron',monospace; font-size:9px; font-weight:700;
            color:rgba(255,255,255,0.4); writing-mode:vertical-rl; }

        /* Feed cards */
        .gf-carousel-outer { overflow:hidden; }
        .gf-carousel-track { display:flex; gap:12px; transition:transform 0.4s ease; }
        .gf-card {
            flex:0 0 240px; background:rgba(20,20,35,0.88);
            border:1px solid rgba(138,43,226,0.2); border-radius:14px;
            padding:14px; transition:all 0.25s;
        }
        .gf-card:hover { border-color:rgba(157,78,221,0.5); transform:translateY(-3px); }
        .gf-card.type-warning {
            border-color:rgba(247,37,133,0.5);
            background:linear-gradient(135deg,rgba(247,37,133,0.07),rgba(20,20,35,0.9));
        }
        .gf-card.type-target {
            border-color:rgba(255,215,0,0.5);
            background:linear-gradient(135deg,rgba(255,215,0,0.07),rgba(20,20,35,0.9));
        }
        .gf-card-top { display:flex; align-items:center; gap:10px; margin-bottom:8px; }
        .gf-card-avatar { width:30px; height:30px; border-radius:50%; display:flex;
            align-items:center; justify-content:center; font-family:'Orbitron',monospace;
            font-size:10px; font-weight:900; color:#000; flex-shrink:0; }
        .gf-card-rider { font-family:'Orbitron',monospace; font-size:0.72em;
            font-weight:700; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
        .gf-card-type-icon { font-size:1.1em; flex-shrink:0; }
        .gf-card-text { font-size:12px; color:rgba(255,255,255,0.58); line-height:1.5; }
        .gf-card-time { font-size:9px; color:rgba(255,255,255,0.22);
            font-family:'Orbitron',monospace; margin-top:6px; }

        /* Feed nav arrows */
        .gf-nav { display:flex; justify-content:flex-end; gap:7px; margin-top:12px; }


        /* ═══ CITY MAP TAB ═══ */
        .map-section { position:relative; }
        .map-outer {
            background: #050510;
            border: 1px solid rgba(0,245,255,0.15);
            border-radius: 16px;
            overflow: hidden;
            position: relative;
            cursor: crosshair;
        }
        .map-outer svg { display:block; width:100%; height:auto; }

        /* Scanline overlay */
        .map-outer::after {
            content:'';
            position:absolute; top:0; left:0; width:100%; height:100%;
            background: repeating-linear-gradient(
                0deg,
                transparent,
                transparent 2px,
                rgba(0,245,255,0.015) 2px,
                rgba(0,245,255,0.015) 4px
            );
            pointer-events:none; z-index:5;
        }

        /* Map controls */
        .map-controls {
            display:flex; align-items:center; justify-content:space-between;
            margin-bottom:14px; flex-wrap:wrap; gap:10px;
        }
        .map-title-row { font-family:'Orbitron',monospace; font-size:0.8em; font-weight:700;
            text-transform:uppercase; letter-spacing:2px; color:#00f5ff; }
        .map-legend { display:flex; gap:14px; flex-wrap:wrap; }
        .map-legend-item { display:flex; align-items:center; gap:6px;
            font-size:11px; font-family:'Orbitron',monospace; color:rgba(255,255,255,0.5); }
        .map-legend-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; }

        /* Tooltip */
        #mapTooltip {
            position:absolute; z-index:20;
            background:rgba(5,5,20,0.97);
            border:1px solid rgba(0,245,255,0.4);
            border-radius:14px; padding:14px 18px;
            min-width:220px; max-width:280px;
            pointer-events:none;
            display:none;
            box-shadow:0 0 30px rgba(0,245,255,0.2);
        }
        #mapTooltip::before {
            content:''; position:absolute; top:0; left:0; width:100%; height:2px;
            background: var(--gang-col, linear-gradient(90deg,#00f5ff,#9d4edd));
            border-radius:14px 14px 0 0;
        }
        .mt-gang { font-family:'Orbitron',monospace; font-size:0.9em; font-weight:900;
            margin-bottom:4px; }
        .mt-territory { font-size:11px; color:rgba(255,255,255,0.5); margin-bottom:10px; }
        .mt-stat { display:flex; justify-content:space-between; font-size:11px;
            margin-bottom:4px; }
        .mt-stat-label { color:rgba(255,255,255,0.4); }
        .mt-stat-val { font-family:'Orbitron',monospace; font-weight:700; color:#00f5ff; }
        .mt-bar { height:5px; background:rgba(255,255,255,0.08); border-radius:3px;
            overflow:hidden; margin:8px 0; }
        .mt-bar-fill { height:100%; border-radius:3px; }
        .mt-player-here { margin-top:10px; padding:6px 10px;
            background:rgba(255,215,0,0.1); border:1px solid rgba(255,215,0,0.3);
            border-radius:8px; font-family:'Orbitron',monospace; font-size:10px;
            color:#ffd700; text-align:center; }
        .mt-npc-list { margin-top:8px; }
        .mt-npc { display:flex; align-items:center; gap:6px; font-size:11px;
            padding:3px 0; border-bottom:1px solid rgba(255,255,255,0.04); }
        .mt-npc-av { width:18px; height:18px; border-radius:50%; display:flex;
            align-items:center; justify-content:center; font-size:8px;
            font-family:'Orbitron',monospace; font-weight:900; color:#000; flex-shrink:0; }
        .mt-npc-name { color:rgba(255,255,255,0.6); flex:1; }
        .mt-npc-cred { font-family:'Orbitron',monospace; font-size:10px; color:#9d4edd; }

        /* Layer toggle buttons */
        .map-layer-btns { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:12px; }
        .map-layer-btn { background:rgba(0,245,255,0.05); border:1px solid rgba(0,245,255,0.2);
            border-radius:8px; padding:5px 12px; cursor:pointer; font-size:11px;
            font-family:'Orbitron',monospace; font-weight:700; color:rgba(0,245,255,0.5);
            text-transform:uppercase; letter-spacing:0.5px; transition:all 0.2s; }
        .map-layer-btn.active { background:rgba(0,245,255,0.15); border-color:#00f5ff; color:#00f5ff; }

        /* Energy ticker at the bottom */
        .map-ticker {
            background:rgba(0,0,0,0.7); border:1px solid rgba(0,245,255,0.1);
            border-radius:0 0 16px 16px; padding:8px 16px;
            font-family:'Orbitron',monospace; font-size:10px; color:rgba(0,245,255,0.6);
            display:flex; gap:20px; overflow:hidden; letter-spacing:0.5px;
        }
        .ticker-item { white-space:nowrap; }
        .ticker-item span { color:#00f5ff; font-weight:700; }
        
        /* Cyberpunk Toggle Style */
        .switch { position: relative; display: inline-block; width: 50px; height: 24px; }
        .switch input { opacity: 0; width: 0; height: 0; }
        .slider { position: absolute; cursor: pointer; top: 0; left: 0; right: 0; bottom: 0; background-color: #333; transition: .4s; border-radius: 34px; border: 1px solid #ff00ff; }
        input:checked + .slider { background-color: #ff00ff; box-shadow: 0 0 10px #ff00ff; }
            .slider:before { position: absolute; content: ""; height: 16px; width: 16px; left: 4px; bottom: 3px; background-color: white; transition: .4s; border-radius: 50%; }
        input:checked + .slider:before { transform: translateX(26px); }
        
        
        /* ══════════════════════════════════════════════
           BADGE SYSTEM — 4a Featured Strip + 4b Tab
           ══════════════════════════════════════════════ */

        /* ── Featured strip (replaces the old badge-pill strip) ── */
        #profileBadgeStrip {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
            margin-top: 10px;
            margin-bottom: 4px;
            align-items: center;
            min-height: 44px;
        }
        .featured-badge-wrap {
            position: relative;
            cursor: pointer;
            transition: transform .2s;
            flex-shrink: 0;
        }
        .featured-badge-wrap:hover {
            transform: scale(1.1) translateY(-2px);
        }
        .featured-badge-wrap canvas {
            display: block;
            filter: drop-shadow(0 0 6px rgba(0,245,255,0.35));
            transition: filter .2s;
        }
        .featured-badge-wrap:hover canvas {
            filter: drop-shadow(0 0 14px rgba(0,245,255,0.75));
        }
        .featured-badge-tooltip {
            position: absolute;
            bottom: calc(100% + 8px);
            left: 50%;
            transform: translateX(-50%);
            background: rgba(10,10,20,0.97);
            border: 1px solid rgba(0,245,255,0.3);
            border-radius: 8px;
            padding: 7px 11px;
            white-space: nowrap;
            pointer-events: none;
            opacity: 0;
            transition: opacity .15s;
            z-index: 200;
        }
        .featured-badge-wrap:hover .featured-badge-tooltip {
            opacity: 1;
        }
        .fbt-name {
            font-family: 'Orbitron', monospace;
            font-size: .68rem;
            color: #fff;
            letter-spacing: .06em;
        }
        .fbt-level {
            font-size: .7rem;
            color: #00f5ff;
            margin-top: 2px;
        }
        .badge-strip-empty {
            font-size: .78rem;
            color: rgba(255,255,255,0.2);
            font-family: 'Orbitron', monospace;
            letter-spacing: .06em;
            padding: 4px 0;
        }
        .badge-strip-loading {
            font-size: .75rem;
            color: rgba(0,245,255,0.3);
            font-family: 'Orbitron', monospace;
            animation: pulse-text 1.5s infinite;
        }
        @keyframes pulse-text { 0%,100%{opacity:.3} 50%{opacity:.9} }

        /* ── Badge collection tab ── */
        #badges .section { margin-bottom: 28px; }

        .badge-tab-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            flex-wrap: wrap;
            gap: 12px;
            margin-bottom: 20px;
        }
        .badge-count-pills {
            display: flex;
            gap: 8px;
            flex-wrap: wrap;
        }
        .bcp {
            padding: 4px 12px;
            border-radius: 20px;
            font-family: 'Orbitron', monospace;
            font-size: .65rem;
            letter-spacing: .07em;
            border: 1px solid rgba(255,255,255,0.15);
            color: rgba(255,255,255,0.5);
            cursor: pointer;
            transition: all .2s;
        }
        .bcp.active, .bcp:hover {
            border-color: var(--accent-cyan);
            color: var(--accent-cyan);
            background: rgba(0,245,255,0.08);
        }
        .bcp.all.active    { border-color:#fff;color:#fff }
        .bcp.standard.active{ border-color:#c77dff;color:#c77dff;background:rgba(199,125,255,0.08)}
        .bcp.gang.active   { border-color:#f72585;color:#f72585;background:rgba(247,37,133,0.08)}
        .bcp.achievement.active{ border-color:#00f5ff;color:#00f5ff;background:rgba(0,245,255,0.08)}
        .bcp.fitness.active{ border-color:#7bf1a8;color:#7bf1a8;background:rgba(123,241,168,0.08)}
        .bcp.leaderboard.active{ border-color:#ffd700;color:#ffd700;background:rgba(255,215,0,0.08)}
        .bcp.event.active  { border-color:#ff9f43;color:#ff9f43;background:rgba(255,159,67,0.08)}
        .bcp.story.active  { border-color:#a29bfe;color:#a29bfe;background:rgba(162,155,254,0.08)}

        .badge-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
            gap: 14px;
        }
        @media (max-width: 600px) {
            .badge-grid { grid-template-columns: repeat(auto-fill, minmax(90px, 1fr)); gap: 10px; }
        }

        .badge-card {
            background: rgba(22,22,40,0.75);
            border: 1px solid rgba(157,78,221,0.2);
            border-radius: 12px;
            padding: 14px 8px 12px;
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 8px;
            cursor: pointer;
            transition: all .2s;
            position: relative;
            overflow: hidden;
        }
        .badge-card:hover {
            border-color: rgba(0,245,255,0.45);
            background: rgba(0,245,255,0.06);
            transform: translateY(-3px);
            box-shadow: 0 6px 24px rgba(0,245,255,0.1);
        }
        .badge-card.locked {
            opacity: .45;
            filter: saturate(.3);
        }
        .badge-card.locked:hover {
            opacity: .65;
            filter: saturate(.5);
        }
        .badge-card canvas { display: block; }

        .bc-name {
            font-family: 'Orbitron', monospace;
            font-size: .62rem;
            color: #fff;
            text-align: center;
            letter-spacing: .04em;
            line-height: 1.35;
        }
        .bc-level-label {
            font-size: .68rem;
            color: var(--accent-cyan);
            font-family: 'Orbitron', monospace;
            letter-spacing: .04em;
        }
        .bc-locked-label {
            font-size: .62rem;
            color: rgba(255,255,255,0.3);
            font-family: 'Orbitron', monospace;
            letter-spacing: .05em;
        }

        /* level dots on badge card */
        .bc-dots {
            display: flex;
            gap: 4px;
            justify-content: center;
        }
        .bc-dot {
            width: 6px;
            height: 6px;
            border-radius: 50%;
            background: rgba(255,255,255,0.1);
            border: 1px solid rgba(255,255,255,0.18);
        }
        .bc-dot.filled { background: var(--accent-cyan); border-color: var(--accent-cyan); }
        .bc-dot.current { background: var(--neon-gold); border-color: var(--neon-gold); box-shadow: 0 0 5px rgba(255,215,0,.7); }

        /* progress bar inside card */
        .bc-prog-wrap {
            width: 100%;
            padding: 0 4px;
        }
        .bc-prog-track {
            height: 3px;
            background: rgba(255,255,255,0.07);
            border-radius: 2px;
            overflow: hidden;
        }
        .bc-prog-fill {
            height: 100%;
            border-radius: 2px;
            background: linear-gradient(90deg, var(--accent-purple), var(--accent-cyan));
            transition: width .6s ease;
        }

        /* category accent stripe at top of card */
        .badge-card::before {
            content: '';
            position: absolute;
            top: 0; left: 0; right: 0;
            height: 2px;
            opacity: 0;
            transition: opacity .2s;
        }
        .badge-card:not(.locked):hover::before { opacity: 1; }
        .badge-card[data-cat=standard]::before     { background: #c77dff; }
        .badge-card[data-cat=gang]::before         { background: #f72585; }
        .badge-card[data-cat=achievement]::before  { background: #00f5ff; }
        .badge-card[data-cat=fitness]::before      { background: #7bf1a8; }
        .badge-card[data-cat=leaderboard]::before  { background: #ffd700; }
        .badge-card[data-cat=event]::before        { background: #ff9f43; }
        .badge-card[data-cat=story]::before        { background: #a29bfe; }

        /* ── Badge detail modal ── */
        .badge-modal-backdrop {
            position: fixed;
            inset: 0;
            background: rgba(0,0,0,0.75);
            backdrop-filter: blur(6px);
            z-index: 1000;
            display: flex;
            align-items: center;
            justify-content: center;
            padding: 20px;
        }
        .badge-modal {
            background: rgba(14,14,28,0.98);
            border: 1px solid rgba(157,78,221,0.4);
            border-radius: 18px;
            padding: 28px 24px;
            max-width: 340px;
            width: 100%;
            box-shadow: 0 0 40px rgba(0,245,255,0.15);
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 12px;
            position: relative;
        }
        .badge-modal-close {
            position: absolute;
            top: 12px; right: 16px;
            color: rgba(255,255,255,0.3);
            font-size: 1.3rem;
            cursor: pointer;
            transition: color .2s;
            line-height: 1;
        }
        .badge-modal-close:hover { color: #fff; }
        .bm-name {
            font-family: 'Orbitron', monospace;
            font-size: 1rem;
            color: #fff;
            text-align: center;
            letter-spacing: .07em;
        }
        .bm-desc {
            font-size: .88rem;
            color: rgba(255,255,255,0.55);
            text-align: center;
            line-height: 1.5;
        }
        .bm-cat-chip {
            padding: 3px 12px;
            border-radius: 20px;
            font-family: 'Orbitron', monospace;
            font-size: .65rem;
            letter-spacing: .06em;
            border: 1px solid currentColor;
        }
        .bm-level-row {
            width: 100%;
            background: rgba(0,0,0,0.3);
            border-radius: 10px;
            padding: 12px 14px;
            border: 1px solid rgba(255,255,255,0.07);
        }
        .bm-level-title {
            font-family: 'Orbitron', monospace;
            font-size: .7rem;
            color: var(--accent-cyan);
            margin-bottom: 8px;
            letter-spacing: .07em;
        }
        .bm-prog-label {
            display: flex;
            justify-content: space-between;
            font-size: .72rem;
            color: rgba(255,255,255,0.4);
            margin-bottom: 4px;
        }
        .bm-prog-track {
            height: 5px;
            background: rgba(255,255,255,0.07);
            border-radius: 3px;
            overflow: hidden;
        }
        .bm-prog-fill {
            height: 100%;
            border-radius: 3px;
            background: linear-gradient(90deg, var(--accent-purple), var(--accent-cyan));
            transition: width .7s ease;
        }
        .bm-dots {
            display: flex;
            gap: 8px;
            justify-content: center;
            margin-top: 8px;
        }
        .bm-dot {
            width: 10px; height: 10px;
            border-radius: 50%;
            background: rgba(255,255,255,0.1);
            border: 1px solid rgba(255,255,255,0.18);
        }
        .bm-dot.filled { background: var(--accent-cyan); border-color: var(--accent-cyan); }
        .bm-dot.current { background: var(--neon-gold); border-color: var(--neon-gold); box-shadow: 0 0 6px rgba(255,215,0,.8); }

        .bm-feature-btn {
            font-family: 'Orbitron', monospace;
            font-size: .68rem;
            letter-spacing: .09em;
            text-transform: uppercase;
            padding: 9px 18px;
            border-radius: 8px;
            cursor: pointer;
            border: 1px solid rgba(0,245,255,0.4);
            background: transparent;
            color: var(--accent-cyan);
            transition: all .2s;
            width: 100%;
            margin-top: 4px;
        }
        .bm-feature-btn:hover {
            background: rgba(0,245,255,0.1);
            box-shadow: 0 0 12px rgba(0,245,255,0.25);
        }
        .bm-feature-btn.featured {
            border-color: var(--neon-gold);
            color: var(--neon-gold);
        }
        .bm-feature-btn.featured:hover {
            background: rgba(255,215,0,0.1);
            box-shadow: 0 0 12px rgba(255,215,0,0.25);
        }

        .badge-tab-loading {
            text-align: center;
            padding: 60px 20px;
            font-family: 'Orbitron', monospace;
            font-size: .8rem;
            color: rgba(0,245,255,0.35);
            letter-spacing: .1em;
            animation: pulse-text 1.5s infinite;
        }
        
        
        
        
        
        
        
                /* ══ BADGE SYSTEM ══════════════════════════════════════ */
 
        /* Featured strip badges */
        .fb-wrap {
            position: relative;
            cursor: pointer;
            flex-shrink: 0;
            transition: transform .18s;
        }
        .fb-wrap:hover { transform: scale(1.12) translateY(-3px); }
        .fb-wrap canvas { display: block; filter: drop-shadow(0 0 5px rgba(0,245,255,0.3)); transition: filter .18s; }
        .fb-wrap:hover canvas { filter: drop-shadow(0 0 12px rgba(0,245,255,0.7)); }
        .fb-tip {
            position: absolute;
            bottom: calc(100% + 7px);
            left: 50%;
            transform: translateX(-50%);
            background: rgba(8,8,18,0.98);
            border: 1px solid rgba(0,245,255,0.35);
            border-radius: 8px;
            padding: 6px 11px;
            white-space: nowrap;
            pointer-events: none;
            opacity: 0;
            transition: opacity .14s;
            z-index: 9999;           /* above everything */
        }
        .fb-wrap:hover .fb-tip { opacity: 1; }
        .fb-tip-name { font-family: 'Orbitron', monospace; font-size: .64rem; color: #fff; letter-spacing: .05em; }
        .fb-tip-lv   { font-size: .68rem; color: #00f5ff; margin-top: 2px; }
 
        /* Category filter pills */
        .bdg-cat-pill {
            padding: 4px 12px;
            border-radius: 20px;
            font-family: 'Orbitron', monospace;
            font-size: .62rem;
            letter-spacing: .06em;
            border: 1px solid rgba(255,255,255,0.12);
            color: rgba(255,255,255,0.38);
            cursor: pointer;
            transition: all .15s;
            user-select: none;
        }
        .bdg-cat-pill:hover { border-color: rgba(0,245,255,0.4); color: rgba(0,245,255,0.7); }
        .bdg-cat-pill.active { border-color: #00f5ff; color: #00f5ff; background: rgba(0,245,255,0.07); }
        .bdg-cat-pill[data-cat=achievement].active { border-color:#00f5ff; color:#00f5ff; }
        .bdg-cat-pill[data-cat=fitness].active     { border-color:#7bf1a8; color:#7bf1a8; background:rgba(123,241,168,0.07); }
        .bdg-cat-pill[data-cat=gang].active        { border-color:#f72585; color:#f72585; background:rgba(247,37,133,0.07); }
        .bdg-cat-pill[data-cat=leaderboard].active { border-color:#ffd700; color:#ffd700; background:rgba(255,215,0,0.07); }
        .bdg-cat-pill[data-cat=event].active       { border-color:#ff9f43; color:#ff9f43; background:rgba(255,159,67,0.07); }
        .bdg-cat-pill[data-cat=story].active       { border-color:#a29bfe; color:#a29bfe; background:rgba(162,155,254,0.07); }
        .bdg-cat-pill[data-cat=standard].active    { border-color:#c77dff; color:#c77dff; background:rgba(199,125,255,0.07); }
 
        /* Badge grid */
        .bdg-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
            gap: 14px;
        }
        @media (max-width: 600px) {
            .bdg-grid { grid-template-columns: repeat(auto-fill, minmax(95px, 1fr)); gap: 10px; }
        }
        .bdg-loading {
            grid-column: 1/-1;
            text-align: center;
            padding: 60px 20px;
            font-family: 'Orbitron', monospace;
            font-size: .75rem;
            color: rgba(0,245,255,0.3);
            letter-spacing: .1em;
            animation: bdg-pulse 1.5s infinite;
        }
        @keyframes bdg-pulse { 0%,100%{opacity:.3} 50%{opacity:.9} }
 
        /* Individual badge card */
        .bdg-card {
            background: rgba(20,20,38,0.8);
            border: 1px solid rgba(157,78,221,0.18);
            border-radius: 12px;
            padding: 14px 8px 11px;
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 7px;
            cursor: pointer;
            transition: all .18s;
            position: relative;
            overflow: hidden;
        }
        .bdg-card:hover {
            border-color: rgba(0,245,255,0.4);
            background: rgba(0,245,255,0.05);
            transform: translateY(-3px);
            box-shadow: 0 6px 20px rgba(0,245,255,0.08);
        }
        .bdg-card.bdg-locked { opacity: .4; filter: saturate(.25); }
        .bdg-card.bdg-locked:hover { opacity: .65; filter: saturate(.45); }
        .bdg-card canvas { display: block; }
 
        /* Category accent top stripe */
        .bdg-card::before {
            content: '';
            position: absolute;
            top: 0; left: 0; right: 0;
            height: 2px;
            opacity: 0;
            transition: opacity .18s;
        }
        .bdg-card:not(.bdg-locked):hover::before { opacity: 1; }
        .bdg-card[data-cat=standard]::before     { background:#c77dff; }
        .bdg-card[data-cat=gang]::before         { background:#f72585; }
        .bdg-card[data-cat=achievement]::before  { background:#00f5ff; }
        .bdg-card[data-cat=fitness]::before      { background:#7bf1a8; }
        .bdg-card[data-cat=leaderboard]::before  { background:#ffd700; }
        .bdg-card[data-cat=event]::before        { background:#ff9f43; }
        .bdg-card[data-cat=story]::before        { background:#a29bfe; }
 
        .bdg-card-name {
            font-family: 'Orbitron', monospace;
            font-size: .6rem;
            color: #fff;
            text-align: center;
            line-height: 1.35;
            letter-spacing: .03em;
        }
        .bdg-card-lv {
            font-size: .65rem;
            color: #00f5ff;
            font-family: 'Orbitron', monospace;
        }
        .bdg-card-locked-lbl {
            font-size: .6rem;
            color: rgba(255,255,255,0.25);
            font-family: 'Orbitron', monospace;
        }
        .bdg-card-hint {
            font-size: .62rem;
            color: rgba(255,255,255,0.2);
            text-align: center;
            line-height: 1.4;
            font-family: 'Rajdhani', sans-serif;
        }
 
        /* Level dots */
        .bdg-dots { display:flex;gap:4px;justify-content:center; }
        .bdg-dot  { width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.15); }
        .bdg-dot.f{ background:#00f5ff;border-color:#00f5ff; }
        .bdg-dot.c{ background:#ffd700;border-color:#ffd700;box-shadow:0 0 5px rgba(255,215,0,.7); }
 
        /* Progress bar */
        .bdg-prog { width:100%;padding:0 3px; }
        .bdg-prog-track { height:3px;background:rgba(255,255,255,0.06);border-radius:2px;overflow:hidden; }
        .bdg-prog-fill  { height:100%;border-radius:2px;background:linear-gradient(90deg,#9d4edd,#00f5ff);transition:width .5s; }
 
        /* Badge detail modal */
        .bdg-modal-back {
            position: fixed; inset: 0;
            background: rgba(0,0,0,0.78);
            backdrop-filter: blur(5px);
            z-index: 2000;
            display: flex;
            align-items: center;
            justify-content: center;
            padding: 20px;
        }
        .bdg-modal {
            background: rgba(12,12,24,0.99);
            border: 1px solid rgba(157,78,221,0.4);
            border-radius: 18px;
            padding: 26px 22px 22px;
            max-width: 320px;
            width: 100%;
            box-shadow: 0 0 40px rgba(0,245,255,0.1);
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 10px;
            position: relative;
        }
        .bdg-modal-close {
            position: absolute; top:12px; right:16px;
            color: rgba(255,255,255,0.28); font-size:1.2rem; cursor:pointer; line-height:1;
        }
        .bdg-modal-close:hover { color:#fff; }
        .bdg-modal-name  { font-family:'Orbitron',monospace;font-size:.95rem;color:#fff;text-align:center;letter-spacing:.07em; }
        .bdg-modal-desc  { font-size:.82rem;color:rgba(255,255,255,0.42);text-align:center;line-height:1.55; }
        .bdg-modal-chip  { padding:3px 12px;border-radius:20px;font-family:'Orbitron',monospace;font-size:.62rem;letter-spacing:.06em;border:1px solid currentColor; }
        .bdg-modal-block { width:100%;background:rgba(0,0,0,0.28);border-radius:9px;padding:11px 13px;border:1px solid rgba(255,255,255,0.06); }
        .bdg-modal-lv    { font-family:'Orbitron',monospace;font-size:.7rem;color:#00f5ff;letter-spacing:.07em;margin-bottom:7px; }
        .bdg-modal-dots  { display:flex;gap:8px;justify-content:center;margin-bottom:8px; }
        .bdg-modal-dot   { width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.15); }
        .bdg-modal-dot.f { background:#00f5ff;border-color:#00f5ff; }
        .bdg-modal-dot.c { background:#ffd700;border-color:#ffd700;box-shadow:0 0 6px rgba(255,215,0,.8); }
        .bdg-modal-prog-row { display:flex;justify-content:space-between;font-size:.68rem;color:rgba(255,255,255,0.32);margin-bottom:4px; }
        .bdg-modal-prog-track { height:4px;background:rgba(255,255,255,0.06);border-radius:2px;overflow:hidden; }
        .bdg-modal-prog-fill  { height:100%;border-radius:2px;background:linear-gradient(90deg,#9d4edd,#00f5ff);transition:width .6s; }
        .bdg-modal-next  { font-size:.7rem;color:rgba(255,255,255,0.22);margin-top:6px; }
        .bdg-modal-max   { font-size:.72rem;color:#ffd700;font-family:'Orbitron',monospace;margin-top:4px; }
        .bdg-modal-unlock{ font-size:.75rem;color:rgba(255,255,255,0.3);margin-top:4px; }
        .bdg-modal-how {
            width:100%;background:rgba(0,245,255,0.04);border:1px solid rgba(0,245,255,0.15);
            border-radius:9px;padding:10px 13px;
        }
        .bdg-modal-how-title { font-family:'Orbitron',monospace;font-size:.64rem;color:rgba(0,245,255,0.7);letter-spacing:.07em;margin-bottom:6px; }
        .bdg-modal-how-row   { display:flex;align-items:center;gap:8px;margin-bottom:5px; }
        .bdg-modal-how-dot   { width:7px;height:7px;border-radius:50%;flex-shrink:0; }
        .bdg-modal-how-text  { font-size:.78rem;color:rgba(255,255,255,0.45);line-height:1.4; }
        .bdg-modal-how-text.earned { color:rgba(0,245,255,0.7); }
        
        
         /* ── Profile identity row ── */
        .prf-identity-row {
            display: flex;
            align-items: center;
            gap: 8px;
            flex-wrap: wrap;
            margin: 4px 0 6px;
        }
        .prf-title-pill {
            font-family: 'Orbitron', monospace;
            font-size: .68rem;
            color: #ffd700;
            background: rgba(255,215,0,0.08);
            border: 1px solid rgba(255,215,0,0.35);
            border-radius: 20px;
            padding: 3px 11px;
            letter-spacing: .06em;
        }
        .prf-title-pill:empty { display: none; }
        .prf-ach-pill {
            font-family: 'Rajdhani', sans-serif;
            font-size: .82rem;
            color: rgba(0,245,255,0.65);
            border: 1px solid rgba(0,245,255,0.2);
            border-radius: 20px;
            padding: 3px 11px;
            letter-spacing: .03em;
        }
        .prf-ach-pill:empty { display: none; }
 
        /* Avatar hover */
        .avatar-container:hover #avatarChangebtn { display: block !important; }
 
        /* ── Avatar picker modal ── */
        .avp-back {
            position: fixed; inset: 0;
            background: rgba(0,0,0,0.82);
            backdrop-filter: blur(6px);
            z-index: 3000;
            display: flex; align-items: center; justify-content: center;
            padding: 16px;
        }
        .avp-modal {
            background: rgba(12,12,26,0.99);
            border: 1px solid rgba(157,78,221,0.4);
            border-radius: 18px;
            padding: 24px;
            max-width: 560px;
            width: 100%;
            max-height: 85vh;
            overflow-y: auto;
            position: relative;
        }
        .avp-title {
            font-family: 'Orbitron', monospace;
            font-size: .82rem;
            color: #00f5ff;
            letter-spacing: .1em;
            text-transform: uppercase;
            margin-bottom: 6px;
        }
        .avp-subtitle {
            font-size: .8rem;
            color: rgba(255,255,255,0.3);
            margin-bottom: 18px;
            line-height: 1.5;
        }
        .avp-close {
            position: absolute; top:14px; right:18px;
            color: rgba(255,255,255,0.3); font-size:1.2rem; cursor:pointer;
        }
        .avp-close:hover { color:#fff; }
        .avp-section-title {
            font-family: 'Orbitron', monospace;
            font-size: .65rem;
            color: rgba(255,255,255,0.3);
            letter-spacing: .1em;
            text-transform: uppercase;
            margin: 16px 0 10px;
            padding-top: 14px;
            border-top: 1px solid rgba(255,255,255,0.07);
        }
        .avp-section-title:first-of-type { margin-top: 0; padding-top: 0; border-top: none; }
 
        /* Badge picker grid */
        .avp-badge-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
            gap: 10px;
        }
        .avp-badge-item {
            display: flex; flex-direction: column; align-items: center; gap: 5px;
            padding: 10px 4px 8px;
            border-radius: 10px;
            border: 1px solid transparent;
            cursor: pointer;
            transition: all .18s;
            background: rgba(0,0,0,0.3);
        }
        .avp-badge-item:hover {
            border-color: rgba(0,245,255,0.4);
            background: rgba(0,245,255,0.05);
        }
        .avp-badge-item.selected {
            border-color: #00f5ff;
            background: rgba(0,245,255,0.1);
            box-shadow: 0 0 12px rgba(0,245,255,0.2);
        }
        .avp-badge-item canvas { display: block; }
        .avp-badge-label {
            font-family: 'Orbitron', monospace;
            font-size: .55rem;
            color: rgba(255,255,255,0.5);
            text-align: center;
            line-height: 1.3;
        }
 
        /* Title picker */
        .avp-title-list { display: flex; flex-direction: column; gap: 6px; }
        .avp-title-item {
            display: flex; align-items: center; justify-content: space-between;
            padding: 9px 14px;
            border-radius: 9px;
            border: 1px solid rgba(255,255,255,0.07);
            background: rgba(0,0,0,0.25);
            cursor: pointer;
            transition: all .15s;
        }
        .avp-title-item:hover { border-color: rgba(255,215,0,0.35); background: rgba(255,215,0,0.04); }
        .avp-title-item.selected { border-color: #ffd700; background: rgba(255,215,0,0.08); }
        .avp-title-name {
            font-family: 'Orbitron', monospace;
            font-size: .72rem;
            color: #ffd700;
            letter-spacing: .05em;
        }
        .avp-title-locked { font-size: .7rem; color: rgba(255,255,255,0.2); }
 
        /* Achievement picker */
        .avp-ach-list { display: flex; flex-direction: column; gap: 6px; }
        .avp-ach-item {
            display: flex; align-items: center; gap: 10px;
            padding: 9px 14px;
            border-radius: 9px;
            border: 1px solid rgba(255,255,255,0.07);
            background: rgba(0,0,0,0.25);
            cursor: pointer;
            transition: all .15s;
        }
        .avp-ach-item:hover { border-color: rgba(0,245,255,0.35); background: rgba(0,245,255,0.04); }
        .avp-ach-item.selected { border-color: #00f5ff; background: rgba(0,245,255,0.08); }
        .avp-ach-icon { font-size: 1.4rem; flex-shrink: 0; }
        .avp-ach-name { font-size: .82rem; color: rgba(255,255,255,0.7); flex: 1; }
        .avp-ach-check { color: #00f5ff; font-size: .9rem; }
 
        /* Save button */
        .avp-save-btn {
            width: 100%; margin-top: 20px;
            font-family: 'Orbitron', monospace;
            font-size: .72rem; letter-spacing: .1em; text-transform: uppercase;
            padding: 12px;
            border-radius: 10px;
            cursor: pointer;
            border: 1px solid #00f5ff;
            background: rgba(0,245,255,0.08);
            color: #00f5ff;
            transition: all .2s;
        }
        .avp-save-btn:hover { background: rgba(0,245,255,0.18); box-shadow: 0 0 16px rgba(0,245,255,0.3); }
        .avp-save-btn.saving { opacity: .5; cursor: not-allowed; }
        
        
        
        /* ── Ride card (overview + activity tab) ── */
        .ride-card {
            background: rgba(15,15,28,0.85);
            border: 1px solid rgba(0,245,255,0.12);
            border-radius: 14px;
            padding: 14px 16px;
            margin-bottom: 10px;
            cursor: pointer;
            transition: border-color 0.2s, transform 0.15s;
            position: relative;
            overflow: hidden;
        }
        .ride-card::before {
            content: '';
            position: absolute;
            left: 0; top: 0; bottom: 0;
            width: 3px;
            background: linear-gradient(180deg,#00f5ff,#9d4edd);
            border-radius: 3px 0 0 3px;
        }
        .ride-card:hover { border-color: rgba(0,245,255,0.35); transform: translateY(-2px); }
        .ride-card-header {
            display: flex;
            justify-content: space-between;
            align-items: flex-start;
            margin-bottom: 8px;
        }
        .ride-card-mode {
            font-family: 'Orbitron', monospace;
            font-size: 0.7em;
            font-weight: 700;
            color: #00f5ff;
            text-transform: uppercase;
            letter-spacing: 1px;
        }
        .ride-card-score {
            font-family: 'Orbitron', monospace;
            font-size: 1.15em;
            font-weight: 900;
            background: linear-gradient(135deg,#ffd700,#ff9500);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
        }
        .ride-card-time-row {
            display: flex;
            gap: 6px;
            align-items: center;
            margin-bottom: 8px;
        }
        .ride-card-ago {
            font-size: 12px;
            color: rgba(255,255,255,0.5);
        }
        .ride-card-date {
            font-size: 11px;
            color: rgba(255,255,255,0.25);
            font-family: 'Orbitron', monospace;
        }
        .ride-card-stats {
            display: flex;
            gap: 14px;
            flex-wrap: wrap;
        }
        .ride-stat {
            display: flex;
            flex-direction: column;
            align-items: center;
            min-width: 48px;
        }
        .ride-stat-val {
            font-family: 'Orbitron', monospace;
            font-size: 0.85em;
            font-weight: 700;
            color: #00ff88;
        }
        .ride-stat-lbl {
            font-size: 9px;
            color: rgba(255,255,255,0.3);
            text-transform: uppercase;
            letter-spacing: 0.4px;
            margin-top: 2px;
            white-space: nowrap;
        }
        .ride-card-expand {
            font-size: 10px;
            color: rgba(0,245,255,0.4);
            font-family: 'Orbitron', monospace;
            margin-top: 8px;
            text-align: right;
        }
         
        /* ── Expanded run detail ── */
        .ride-detail {
            display: none;
            margin-top: 10px;
            padding-top: 10px;
            border-top: 1px solid rgba(255,255,255,0.06);
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
            gap: 8px;
        }
        .ride-detail.hidden { display: none !important; }
        .rd-item {
            background: rgba(0,0,0,0.25);
            border-radius: 8px;
            padding: 8px 10px;
            text-align: center;
        }
        .rd-val {
            font-family: 'Orbitron', monospace;
            font-size: 0.9em;
            font-weight: 700;
            color: #e0e0ff;
        }
        .rd-lbl {
            font-size: 9px;
            color: rgba(255,255,255,0.3);
            text-transform: uppercase;
            letter-spacing: 0.4px;
            margin-top: 3px;
        }
         
        /* ── Activity tab load-more ── */
        .load-more-btn {
            width: 100%;
            margin-top: 12px;
            padding: 12px;
            background: rgba(0,245,255,0.07);
            border: 1px solid rgba(0,245,255,0.2);
            border-radius: 10px;
            color: #00f5ff;
            font-family: 'Orbitron', monospace;
            font-size: 0.7em;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 1px;
            cursor: pointer;
            transition: all 0.2s;
        }
        .load-more-btn:hover { background: rgba(0,245,255,0.15); }
         
        /* ── Activity tab filter bar ── */
        .activity-filter-bar {
            display: flex;
            gap: 8px;
            margin-bottom: 16px;
            flex-wrap: wrap;
        }
        .act-filter {
            background: rgba(30,30,45,0.7);
            border: 1px solid rgba(0,245,255,0.2);
            padding: 6px 14px;
            border-radius: 10px;
            cursor: pointer;
            font-size: 11px;
            font-family: 'Orbitron', monospace;
            font-weight: 700;
            color: rgba(0,245,255,0.5);
            text-transform: uppercase;
            letter-spacing: 0.5px;
            transition: all 0.2s;
        }
        .act-filter.active {
            background: linear-gradient(135deg,rgba(0,245,255,0.2),rgba(157,78,221,0.15));
            border-color: #00f5ff;
            color: #00f5ff;
        }
        
        

