:root{--accent:#facc15;--accent-2:#f97316;--bg:#0b1220;--bg-panel:#0f172a;--text:#e5e7eb;--muted:#94a3b8;--border:#1f2937;--success:#22c55e;--danger:#ef4444}.display-none{display:none !important}.display-block{display:block !important}.display-flex{display:flex !important}.lobby-hidden,.overlay-hidden,.popup-hidden,.store-modal-hidden,.reward-hidden,.footer-hidden{display:none !important;pointer-events:none !important}.lobby-visible,.overlay-visible,.popup-visible,.store-modal-visible,.reward-visible,.footer-visible{pointer-events:auto}.lobby-visible,.store-modal-visible{display:flex !important}:root{--bg-dark:#0f1115;--panel-bg:#161b22;--accent:#f59e0b;--text-main:#e2e8f0;--text-sub:#94a3b8;--green:#22c55e;--red:#ef4444}*{box-sizing:border-box}body{margin:0;background:var(--bg-dark);color:var(--text-main);font-family:'Segoe UI',sans-serif;height:100vh;display:flex;flex-direction:column;overflow:hidden;user-select:none;position:relative}body::before{content:"";position:fixed;inset:0;background-image:url('/images/menu-car-bg-hero.jpg');background-size:cover;background-position:center;background-repeat:no-repeat;opacity:1;filter:blur(8px);transform:scale(1.05);transform-origin:center;pointer-events:none;z-index:50}body.racing{background:var(--bg-dark)}body.racing::before{opacity:0}body.finish-overlay-open::before{opacity:0 !important}body.racing header{transition:transform 0.25s ease,height 0.25s ease,padding 0.25s ease,border-bottom-width 0.25s ease}body.racing.header-collapsed header{display:none}body.racing.header-collapsed main{padding-top:6px}.header-toggle{position:fixed;top:4px;right:10px;z-index:30;background:#020617;border:1px solid #334155;color:#e5e7eb;border-radius:999px;padding:3px 8px;font-size:0.7rem;cursor:pointer;display:none}body.racing .header-toggle{display:inline-flex;align-items:center;justify-content:center;animation:headerTogglePulse 1.15s ease-in-out infinite}.ios-home-banner{display:none;align-items:center;justify-content:space-between;gap:14px;width:100%;margin:0 0 14px;padding:12px 14px;border-radius:16px;border:1px solid rgba(245,158,11,0.34);background:linear-gradient(180deg,rgba(15,23,42,0.96) 0%,rgba(17,24,39,0.94) 100%);box-shadow:0 18px 40px rgba(2,6,23,0.28),inset 0 1px 0 rgba(255,255,255,0.04);position:relative;z-index:1;pointer-events:auto}.ios-home-banner.active{display:flex}.ios-home-banner-copy{min-width:0;display:flex;flex-direction:column;gap:4px}.ios-home-banner-actions{flex:0 0 auto;display:inline-flex;align-items:center;gap:8px}.ios-home-banner-title{color:#f8fafc;font-size:0.78rem;font-weight:900;letter-spacing:0.08em;text-transform:uppercase}.ios-home-banner-text{color:#cbd5e1;font-size:0.9rem;line-height:1.45}.ios-home-banner-text strong{color:#f8fafc}.ios-home-banner-dismiss{flex:0 0 auto;height:38px;padding:0 14px;border-radius:999px;border:1px solid rgba(245,158,11,0.64);background:rgba(245,158,11,0.12);color:#facc15;font-size:0.74rem;font-weight:900;letter-spacing:0.08em;cursor:pointer;transition:background 0.16s ease,border-color 0.16s ease,transform 0.16s ease}.ios-home-banner-share{flex:0 0 auto;height:38px;padding:0 14px;border-radius:999px;border:1px solid rgba(56,189,248,0.55);background:rgba(14,165,233,0.12);color:#7dd3fc;font-size:0.74rem;font-weight:900;letter-spacing:0.08em;cursor:pointer;transition:background 0.16s ease,border-color 0.16s ease,transform 0.16s ease}.ios-home-banner-share:hover{background:rgba(14,165,233,0.18);border-color:rgba(56,189,248,0.9);transform:translateY(-1px)}.ios-home-banner-dismiss:hover{background:rgba(245,158,11,0.18);border-color:rgba(251,191,36,0.9);transform:translateY(-1px)}.ios-home-banner.manual-hint .ios-home-banner-text::after{content:" If the share sheet does not open here,use the browser share button and choose Add to Home Screen."}body.racing .ios-home-banner{display:none !important}@keyframes headerTogglePulse{0%,100%{border-color:#f97316;box-shadow:0 0 0 rgba(249,115,22,0);transform:translateZ(0) scale(1)}50%{border-color:#fb923c;box-shadow:0 0 0 4px rgba(249,115,22,0.16),0 0 18px rgba(249,115,22,0.42);transform:translateZ(0) scale(1.06)}}.modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.85);backdrop-filter:blur(5px);z-index:1000;display:flex;align-items:center;justify-content:center}.modal-panel{background:#1e293b;width:400px;padding:30px;border-radius:10px;border:1px solid #334155;box-shadow:0 20px 50px rgba(0,0,0,0.7);position:relative;text-align:center;animation:slideIn 0.3s ease}.modal-panel.wide{width:700px;max-width:95%;text-align:left}@media (max-width:1024px) and (orientation:landscape){#matchmaking-lobby .modal-panel.wide{max-height:90vh;overflow-y:auto}}@keyframes slideIn{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-title{margin:0 0 20px 0;color:var(--accent);font-weight:900}.close-modal{position:absolute;top:10px;right:15px;background:none;border:none;color:#64748b;font-size:1.2rem;cursor:pointer}.close-modal:hover{color:#fff}.auth-input{width:100%;padding:12px;margin-bottom:0;background:#0f172a;border:1px solid #334155;color:#fff;border-radius:5px}.auth-input:focus{border-color:var(--accent);outline:none}.auth-country-field{position:relative;margin-bottom:10px}.auth-country-trigger{width:100%;padding:12px;background:#0f172a;border:1px solid #334155;color:#fff;border-radius:5px;display:flex;align-items:center;justify-content:space-between;gap:10px;cursor:pointer;transition:border-color 0.18s ease,box-shadow 0.18s ease,background 0.18s ease}.auth-country-field.open .auth-country-trigger,.auth-country-field.has-selection .auth-country-trigger{border-color:rgba(245,158,11,0.8)}.auth-country-field.open .auth-country-trigger{box-shadow:0 0 0 1px rgba(245,158,11,0.18)}.auth-country-trigger-copy{min-width:0;display:flex;flex-direction:column;align-items:flex-start;gap:2px}.auth-country-trigger-label{font-size:0.65rem;text-transform:uppercase;letter-spacing:0.08em;color:#94a3b8}.auth-country-trigger-value{font-size:0.92rem;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.auth-country-trigger-flag{width:28px;height:28px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:rgba(148,163,184,0.12);border:1px solid rgba(148,163,184,0.18);line-height:1;flex:0 0 auto;overflow:hidden}.auth-country-menu{position:absolute;top:calc(100% + 8px);left:0;right:0;display:none;max-height:240px;overflow-y:auto;padding:6px;border-radius:10px;border:1px solid #334155;background:#020617;box-shadow:0 18px 40px rgba(0,0,0,0.45);z-index:40}.auth-country-field.open .auth-country-menu{display:block}.auth-country-option{width:100%;border:none;background:transparent;color:#e2e8f0;border-radius:8px;padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer;text-align:left;transition:background 0.18s ease,color 0.18s ease}.auth-country-option:hover,.auth-country-option.selected{background:rgba(148,163,184,0.12)}.auth-country-option-name{font-size:0.9rem}.auth-country-option-flag{width:22px;height:22px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;flex:0 0 auto}.country-flag-img{width:100%;height:100%;display:block;object-fit:cover}.country-flag-fallback{font-size:0.72rem;line-height:1;font-weight:700;color:#e2e8f0}.auth-country-empty,.auth-country-note{font-size:0.72rem;color:#94a3b8}.auth-country-empty{padding:10px 12px}.auth-country-note{margin:-2px 0 10px}.link-text{font-size:0.8rem;color:var(--text-sub);cursor:pointer;text-decoration:underline;margin-top:10px}.link-text:hover{color:var(--accent)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #334155;padding-bottom:15px;margin-bottom:20px}.player-stats{display:flex;gap:15px;align-items:center}.stat-badge{background:#0f172a;padding:5px 10px;border-radius:4px;font-family:monospace;font-size:1rem}.stat-badge.money{color:#ffd700;border:1px solid rgba(255,215,0,0.3);text-shadow:0 0 10px rgba(255,215,0,0.4);font-weight:bold;letter-spacing:1px;display:inline-flex;align-items:center;gap:6px}.stat-badge.xp-stat{color:#22c55e;border:1px solid rgba(34,197,94,0.34);text-shadow:0 0 10px rgba(34,197,94,0.22);font-weight:bold;letter-spacing:1px;display:inline-flex;align-items:center;gap:6px;background:linear-gradient(180deg,rgba(6,78,59,0.44),rgba(15,23,42,0.92))}.garage-grid{display:flex;gap:20px}.garage-col{flex:1;background:#0f172a;padding:15px;border-radius:8px;border:1px solid #334155}.garage-col h3{margin-top:0;color:var(--text-sub);font-size:0.9rem;text-transform:uppercase}.upgrade-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #1e293b}.up-info{display:flex;flex-direction:column}.up-info span{font-weight:600;font-size:0.9rem}.up-info small{color:#64748b;font-size:0.75rem}.career-btn{background:linear-gradient(45deg,#f59e0b,#d97706);box-shadow:0 4px 15px rgba(245,158,11,0.3);border:none;color:#fff;padding:10px 20px;font-size:1rem;border-radius:5px;font-weight:700;cursor:pointer;transition:all 0.1s}.car-preview-box{height:100px;display:flex;align-items:center;justify-content:center;background:#1e293b;margin-top:10px;border-radius:5px}#preview-car{width:44px;height:24px;background:var(--accent);border-radius:2px;position:relative}#preview-car::before{content:'';position:absolute;top:4px;left:16px;width:16px;height:16px;background:#0f172a}#setup-menu{position:absolute;inset:0;background:#000;z-index:900;display:flex;justify-content:center;align-items:center}.bg-ready #setup-menu{animation:setupMenuFade 2s ease forwards}@keyframes setupMenuFade{from{background:#000}to{background:rgba(0,0,0,0)}}.menu-panel{background:#1e293b;padding:30px;border-radius:10px;border:1px solid #334155;text-align:center}.menu-group{margin-bottom:20px;text-align:left}.menu-depth-divider{position:relative;height:1px;margin:18px 0 22px;border:0;background:linear-gradient( 90deg,transparent 0%,rgba(71,85,105,0.18) 16%,rgba(248,250,252,0.58) 50%,rgba(71,85,105,0.18) 84%,transparent 100% );box-shadow:0 1px 0 rgba(255,255,255,0.05),0 8px 18px rgba(2,6,23,0.24);overflow:visible;filter:grayscale(1);opacity:0.65}.menu-depth-divider::after{content:'';position:absolute;left:18%;right:18%;top:-4px;height:8px;background:radial-gradient(circle,rgba(245,158,11,0.18) 0%,rgba(245,158,11,0) 72%);filter:blur(5px);pointer-events:none}.menu-or-divider{position:relative;display:flex;align-items:center;justify-content:center;margin:20px 0 10px}.menu-or-divider::before,.menu-or-divider::after{content:'';flex:1;height:1px;background:linear-gradient( 90deg,transparent 0%,rgba(71,85,105,0.18) 10%,rgba(248,250,252,0.48) 50%,rgba(71,85,105,0.18) 90%,transparent 100% );opacity:0.72}.menu-or-divider span{position:relative;z-index:1;padding:0 12px;background:#111827;color:#94a3b8;font-size:0.68rem;font-weight:800;letter-spacing:1.6px;text-transform:uppercase;line-height:1}.menu-group label{display:block;margin-bottom:8px;font-size:0.9rem;color:var(--text-sub);font-weight:600}.menu-group input[type="range"]{width:100%;cursor:pointer}.track-options{display:flex;gap:10px}.track-card{flex:1;background:#0f172a;border:2px solid #334155;border-radius:8px;padding:15px;cursor:pointer;transition:all 0.2s;text-align:center}.track-card:hover{border-color:#64748b}.track-card.selected{border-color:var(--accent);background:rgba(245,158,11,0.1)}.t-icon{font-size:1.5rem}.big-btn{width:100%;padding:15px;font-size:1.2rem;margin-top:10px;min-height:45px;display:inline-flex;align-items:center;justify-content:center;text-align:center;line-height:1.15}.test-match-btn{background:#0f172a;color:#e5e7eb;margin-bottom:0;border:1px dashed #475569;font-size:0.9rem;margin-top:10px}header{height:50px;background:var(--panel-bg);display:flex;align-items:center;justify-content:space-between;padding:0 20px;border-bottom:1px solid #334155;z-index:20}.header-title{font-weight:900;font-size:1rem;letter-spacing:0.5px}.header-controls{display:flex;gap:10px}main{flex:1;display:flex;padding:10px;gap:10px;position:relative}#game-area{flex:1;background:#16a34a;border-radius:8px;position:relative;overflow:hidden;box-shadow:inset 0 0 80px rgba(0,0,0,0.6);border:1px solid #334155}#game-area.time-night{background:#14532d}.perf-overlay{position:fixed;top:12px;right:12px;background:rgba(2,6,23,0.72);border:1px solid rgba(148,163,184,0.4);border-radius:10px;padding:10px 12px;color:#e5e7eb;font-family:'Segoe UI',sans-serif;font-size:12px;letter-spacing:0.3px;box-shadow:0 10px 35px rgba(0,0,0,0.45);z-index:1200;display:grid;gap:6px;min-width:96px;text-align:right;pointer-events:none}.perf-line{display:flex;align-items:center;justify-content:space-between;gap:8px}.perf-line span{color:#94a3b8;font-weight:600;font-size:11px;text-transform:uppercase}.perf-line b{color:#f8fafc;font-size:14px;font-weight:800}body:not(.racing) #game-area{background:transparent}#weather-image-overlay{position:fixed;inset:0;pointer-events:none;z-index:60;opacity:0;transition:opacity 0.35s ease}#weather-image-overlay img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 0.35s ease}#weather-image-overlay.active{opacity:1}#weather-image-overlay img.active{opacity:0.075;filter:blur(2px)}#weather-image-overlay.weather-snow img.active{opacity:0.5;filter:blur(1px)}#weather-overlay-rain{opacity:0}#game-area::before,#game-area::after{content:"";position:absolute;inset:0;pointer-events:none;z-index:30;opacity:0;transition:opacity 0.5s ease}#game-area.weather-rain::before{opacity:0;background:none;animation:none}#game-area.weather-snow::before{opacity:0;background:none;animation:none}#game-area.weather-fog::before{opacity:0.80;background:radial-gradient(circle at 10% 10%,rgba(148,163,184,0.82),transparent 60%),radial-gradient(circle at 90% 30%,rgba(148,163,184,0.98),transparent 60%),radial-gradient(circle at 40% 80%,rgba(148,163,184,0.54),transparent 60%),rgba(15,23,42,0.75);filter:none;background-size:140% 140%;animation:fogPulse 8s ease-in-out infinite alternate}#game-area.weather-rain.weather-fog::before{opacity:0.40;animation:none}#game-area.weather-sunny::before{opacity:0}body.racing #game-area.time-night::after,body.spectator-mode #game-area.time-night::after{opacity:0.92;z-index:31;background:radial-gradient(circle at 50% 12%,rgba(148,163,184,0.08),transparent 22%),radial-gradient(circle at 20% 20%,rgba(59,130,246,0.10),transparent 42%),radial-gradient(circle at 82% 28%,rgba(37,99,235,0.08),transparent 36%),linear-gradient(180deg,rgba(2,6,23,0.34) 0%,rgba(2,6,23,0.66) 58%,rgba(2,6,23,0.78) 100%)}#weather-image-overlay.time-night::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(2,6,23,0.12),rgba(2,6,23,0.38));opacity:1;pointer-events:none}#fog-overlay{display:none}#game-area.weather-fog #fog-overlay{opacity:1}#fog-overlay .fog-layer{position:absolute;inset:-15% -25%;width:150%;height:130%;background:none;filter:blur(8px);mix-blend-mode:normal;will-change:transform}#fog-overlay .fog-layer.layer1{opacity:0.92;background:radial-gradient(circle at 15% 30%,rgba(255,255,255,0.55),transparent 48%),radial-gradient(circle at 75% 60%,rgba(210,235,255,0.35),transparent 56%),rgba(20,24,35,0.12);mix-blend-mode:color;animation:fogDriftLayer1 10s ease-in-out infinite alternate}#fog-overlay .fog-layer.layer2{opacity:0.30;background:radial-gradient(circle at 30% 50%,rgb(68 74 77),transparent 52% 52%),radial-gradient(circle at 70% 35%,rgb(112 126 141 / 36%),#00000030 60%),rgba(6,22,46,0.12);mix-blend-mode:color;animation:fogDriftLayer2 14s ease-in-out infinite alternate}@keyframes fogDrift{0%{background-position:0px 0px,0px 0px,0px 0px,0px 0px}100%{background-position:20px -10px,-25px 15px,10px 20px,0px 0px}}@keyframes fogPulse{0%{opacity:0.99}100%{opacity:0.60}}@keyframes rainFall{0%{background-position:0 -40px,12px -32px,-8px -20px}100%{background-position:-16px 40px,0 24px,-20px 36px}}@keyframes snowFall{0%{background-position:0 0}100%{background-position:0 260px}}canvas{display:block;width:100%;height:100%}.vehicle-preview canvas{width:auto;height:100%}aside{width:165px;background:var(--panel-bg);border-radius:8px;padding:7px;display:flex;flex-direction:column;gap:5px;border:1px solid #334155;z-index:20}.panel-header{color:var(--accent);font-weight:bold;font-size:0.62rem;text-transform:uppercase;letter-spacing:0.5px;border-bottom:1px solid #334155;padding-bottom:3px}.racer-card{background:#0f172a;padding:4px 6px;border-radius:5px;border:1px solid #334155;display:flex;flex-direction:column;gap:1px;transition:transform 0.2s}.racer-card.player{border-color:var(--accent);background:rgba(245,158,11,0.15)}.top-info{display:flex;justify-content:space-between;font-weight:bold;font-size:0.66rem}.sub-info{font-size:0.56rem;color:var(--text-sub);display:flex;justify-content:space-between;align-items:center;margin-top:0px}.xp-badge{background:#334155;color:#fff;padding:0px 3px;border-radius:3px;font-size:0.52rem;font-family:monospace}.hp-track{width:100%;height:4px;background:#020617;margin-top:2px;border-radius:3px;overflow:hidden;border:1px solid rgba(255,255,255,0.1)}.hp-fill{height:100%}.info-box{margin-top:auto;font-size:0.56rem;color:#64748b;text-align:center;line-height:1.4}.btn{background:var(--accent);color:#000;border:none;padding:5px 20px;font-size:1rem;border-radius:5px;font-weight:700;cursor:pointer;transition:all 0.1s;position:relative}.btn.sm{padding:6px 12px;font-size:0.75rem}.btn.outline{background:transparent;border:1px solid var(--accent);color:var(--accent)}.btn:hover{filter:brightness(1.1)}.btn.outline:hover{background:rgba(245,158,11,0.1)}.btn:active{transform:scale(0.95)}.btn:disabled{cursor:not-allowed;filter:saturate(0.88)}.btn.is-loading{pointer-events:none}.btn.is-loading .btn-loading-text{opacity:0}.btn-loading-spinner{position:absolute;top:50%;left:50%;width:18px;height:18px;margin-left:-9px;margin-top:-9px;border-radius:999px;border:2px solid rgba(255,255,255,0.22);border-top-color:rgba(255,255,255,0.98);animation:btnLoadingSpin 0.7s linear infinite}@keyframes btnLoadingSpin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}#countdown-layer{position:absolute;inset:0;display:flex;justify-content:center;align-items:center;pointer-events:none;z-index:50}.traffic-light{display:flex;gap:15px;background:#000;padding:15px;border-radius:40px;border:3px solid #333;opacity:0;transform:scale(0.8);transition:all 0.2s}.traffic-light.visible{opacity:1;transform:scale(1)}.traffic-light.hidden{opacity:0}.light{width:50px;height:50px;border-radius:50%;background:#333;box-shadow:inset 0 0 10px #000}.light.red.active{background:#ef4444;box-shadow:0 0 40px #ef4444}.light.yellow.active{background:#f59e0b;box-shadow:0 0 40px #f59e0b}.light.green.active{background:#22c55e;box-shadow:0 0 40px #22c55e}#go-text{position:absolute;font-size:6rem;font-weight:900;color:#22c55e;text-shadow:0 0 20px #000;opacity:0;transform:scale(0.5);transition:all 0.3s}#overlay{position:absolute;inset:0;z-index:90;background:rgba(2,6,23,0.9);backdrop-filter:blur(6px);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#e2e8f0;opacity:0;pointer-events:none;transition:opacity 0.3s}#overlay.active{opacity:1;pointer-events:all}#reward-display,#leaderboard-cont{text-align:center}#end-title{color:#f8fafc;text-shadow:0 6px 22px rgba(0,0,0,0.55)}#reward-display{color:#e2e8f0}#rotate-device-overlay{position:fixed;inset:0;background:rgba(15,23,42,0.95);display:none;align-items:center;justify-content:center;z-index:4000;padding:20px}#rotate-device-overlay.active{display:flex}.rotate-device-box{background:#0f172a;border-radius:12px;border:1px solid #334155;position:relative;padding:20px 24px;max-width:320px;width:100%;text-align:center;color:#e5e7eb;box-shadow:0 15px 40px rgba(0,0,0,0.7)}.rotate-device-icon{font-size:2.4rem;margin-bottom:8px}.rotate-device-title{font-size:1rem;font-weight:700;margin-bottom:6px;color:var(--accent)}.rotate-device-text{font-size:0.85rem;color:#cbd5f5;margin-bottom:12px}.leaderboard-container{width:90%;max-width:400px;background:rgba(15,23,42,0.95);border:1px solid #334155;border-radius:8px;padding:10px;margin-bottom:20px}.lb-row{display:flex;align-items:center;padding:10px;border-bottom:1px solid rgba(255,255,255,0.1);font-size:0.9rem}.lb-row:last-child{border-bottom:none}.lb-row.is-player{background:rgba(245,158,11,0.15);border-left:3px solid var(--accent)}.lb-pos{width:30px;font-weight:900;color:var(--text-sub)}.lb-pos.podium{color:var(--accent)}.lb-name{flex-grow:1;font-weight:600;text-align:left}.lb-dist{font-family:monospace;color:var(--text-sub);font-size:0.8rem}#mobile-ui{display:none;position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:100}@media (max-width:1024px) and (pointer:coarse){#mobile-ui{display:block}}#mobile-ui.force-show{display:block !important}#joystick-zone{position:absolute;bottom:30px;right:30px;width:120px;height:120px;background:rgba(255,255,255,0.1);border:2px solid rgba(255,255,255,0.3);border-radius:50%;pointer-events:all;touch-action:none;transition:right 0.3s,left 0.3s}#mobile-ui.left-mode #joystick-zone{right:auto;left:30px}#joystick-stick{position:absolute;top:50%;left:50%;width:50px;height:50px;background:var(--accent);border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;box-shadow:0 0 15px var(--accent)}.shake{animation:shake 0.4s cubic-bezier(.36,.07,.19,.97) both}@keyframes shake{10%,90%{transform:translate3d(-3px,0,0)}20%,80%{transform:translate3d(5px,0,0)}30%,50%,70%{transform:translate3d(-5px,0,0)}40%,60%{transform:translate3d(5px,0,0)}}#nitro-btn{position:absolute;bottom:40px;left:30px;width:80px;height:80px;border-radius:50%;border:4px solid #fff;background:rgba(56,189,248,0.6);color:#fff;font-weight:900;font-size:1.2rem;pointer-events:all;box-shadow:0 0 20px rgba(56,189,248,0.4);transition:all 0.3s ease;touch-action:manipulation;cursor:pointer;z-index:101}#nitro-btn:active{transform:scale(0.9);background:#0ea5e9;box-shadow:0 0 30px #0ea5e9}#mobile-ui.left-mode #nitro-btn{left:auto;right:30px;background:rgba(239,68,68,0.6);box-shadow:0 0 20px rgba(239,68,68,0.4)}#mobile-ui.left-mode #nitro-btn:active{background:#dc2626}#fire-btn{position:absolute;bottom:130px;left:95px;width:70px;height:70px;border-radius:50%;border:4px solid #fff;background:rgba(248,113,113,0.7);color:#fff;font-size:1.5rem;pointer-events:all;box-shadow:0 0 20px rgba(248,113,113,0.5);transition:all 0.2s ease;touch-action:manipulation;cursor:pointer;z-index:101}#fire-btn:active{transform:scale(0.9);background:#ef4444;box-shadow:0 0 30px rgba(248,113,113,0.9)}#mobile-ui.left-mode #fire-btn{left:auto;right:95px}#oil-btn{position:absolute;bottom:210px;left:70px;width:60px;height:60px;border-radius:50%;border:3px solid #fff;background:rgba(15,23,42,0.75);color:#fff;font-weight:800;font-size:0.9rem;letter-spacing:0.5px;pointer-events:all;box-shadow:0 0 18px rgba(15,23,42,0.45);transition:all 0.2s ease;touch-action:manipulation;cursor:pointer;z-index:101}#oil-btn:active{transform:scale(0.92);background:rgba(2,6,23,0.9);box-shadow:0 0 26px rgba(2,6,23,0.8)}#mobile-ui.left-mode #oil-btn{left:auto;right:70px}#lights-btn{position:absolute;bottom:130px;left:30px;width:55px;height:55px;border-radius:50%;border:3px solid #fff;background:rgba(100,116,139,0.6);color:#fff;font-size:1.3rem;pointer-events:all;box-shadow:0 0 15px rgba(100,116,139,0.4);transition:all 0.2s ease;touch-action:manipulation;cursor:pointer;z-index:101}#lights-btn:active,#lights-btn.active{background:rgba(250,204,21,0.8);box-shadow:0 0 25px rgba(250,204,21,0.6);border-color:#facc15}#mobile-ui.left-mode #lights-btn{left:auto;right:30px}.lobby-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;max-height:400px;overflow-y:auto;margin-bottom:20px}.lobby-slot{background:#0f172a;border:1px solid #334155;padding:15px;border-radius:8px;display:flex;align-items:center;justify-content:space-between;transition:all 0.3s}.lobby-slot.empty{opacity:0.3;border-style:dashed}.lobby-slot.me{border-color:var(--accent);background:rgba(245,158,11,0.1)}.slot-info{display:flex;align-items:center;gap:10px}.slot-color{width:12px;height:12px;border-radius:50%}.slot-name{font-weight:bold;color:#fff}.slot-name-searching{display:inline-flex;align-items:baseline;gap:2px}.slot-search-dots{display:inline-flex;min-width:16px;color:rgba(255,255,255,0.82)}.slot-search-dots span{display:inline-block;width:4px;text-align:center;opacity:0.22;transform:translateY(0) scale(0.92);animation:lobbySearchingDotStep 1.2s cubic-bezier(0.22,1,0.36,1) infinite;will-change:opacity,transform}.slot-search-dots span:nth-child(1){animation-delay:0s}.slot-search-dots span:nth-child(2){animation-delay:0.18s}.slot-search-dots span:nth-child(3){animation-delay:0.36s}@keyframes lobbySearchingDotStep{0%,100%{opacity:0.22;transform:translateY(0)}25%{opacity:0.48;transform:translateY(-0.5px) scale(0.98)}45%{opacity:1;transform:translateY(-1.4px) scale(1.06)}65%{opacity:0.55;transform:translateY(0) scale(0.98)}}.player-name-line{display:inline-flex;align-items:center;gap:6px}.player-name-text{min-width:0}.lobby-country-badge{width:18px;height:18px}.slot-status{font-size:0.8rem;font-weight:bold;color:#64748b;text-transform:uppercase}.slot-status.connected{color:#facc15;animation:blink 1s infinite}.slot-status.ready{color:#22c55e;animation:none}@keyframes blink{50%{opacity:0.5}}button:disabled{opacity:0.5;cursor:not-allowed;filter:grayscale(100%);pointer-events:none}.guest-alert{margin-top:15px;padding:10px;background:rgba(239,68,68,0.15);border:1px solid #ef4444;border-radius:6px;font-size:0.85rem;color:#fca5a5;text-align:center;line-height:1.45;animation:pulse 2s infinite}.guest-alert .btn,#guest-login-btn{display:inline-flex;align-items:center;justify-content:center;margin:12px auto 0}@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(239,68,68,0.4)}70%{box-shadow:0 0 0 10px rgba(239,68,68,0)}100%{box-shadow:0 0 0 0 rgba(239,68,68,0)}}.gold-coin{display:inline-block;width:14px;height:14px;background:radial-gradient(ellipse at center,#ffd700 0%,#d4af37 100%);border-radius:50%;border:1px solid #b8860b;box-shadow:inset 0 0 0 1px rgba(255,255,255,0.5),0 0 4px rgba(255,215,0,0.6);vertical-align:text-bottom;margin-right:4px;position:relative}.gold-coin::after{content:'';position:absolute;top:25%;left:25%;width:50%;height:50%;border-radius:50%;border:1px solid rgba(184,134,11,0.5)}.earned-money{display:inline-flex;align-items:center;justify-content:center;line-height:1;position:relative;top:1px}.reward-summary-line{display:inline-flex;align-items:center;justify-content:center;gap:7px;flex-wrap:wrap;line-height:1.1}.reward-label,.reward-divider,.reward-xp{display:inline-flex;align-items:center}.reward-label{color:#cbd5e1}.reward-divider{color:#64748b;margin:0 2px}.finish-results-container{margin-top:14px;width:min(92vw,420px)}.finish-results-title{font-size:0.76rem;letter-spacing:0.12em;text-transform:uppercase;color:#94a3b8;text-align:center;margin-bottom:8px}.finish-result-row{justify-content:space-between;gap:10px}.finish-result-name{flex:1 1 auto;min-width:0;overflow:hidden;display:inline-flex;align-items:center;gap:6px;text-align:left;font-weight:600}.finish-result-name-text{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.finish-style-tag{display:inline-flex;align-items:center;gap:4px;margin-left:6px;color:#94a3b8;font-size:0.7rem;font-weight:500;letter-spacing:0.01em;white-space:nowrap;vertical-align:middle}.finish-style-text{opacity:0.92}.finish-result-time{min-width:92px;text-align:right;font-family:monospace;font-size:0.82rem;color:#e2e8f0}.finish-result-time.pending{color:#94a3b8}.finish-result-time.eliminated{color:#fca5a5}.finish-result-row.is-unfinished{opacity:0.84}.finish-result-row.is-eliminated{opacity:0.92}.modal-panel.store-panel{width:960px;max-width:95vw;background:linear-gradient(135deg,#0f172a 0%,#1e293b 100%);border:1px solid #334155;box-shadow:0 0 50px rgba(0,0,0,0.8);padding:0;display:flex;flex-direction:column;max-height:94vh;overflow-x:hidden;overflow-y:auto}.modal-panel,.store-right{scrollbar-width:thin;scrollbar-color:rgba(245,158,11,0.78) rgba(15,23,42,0.72)}.modal-panel::-webkit-scrollbar,.store-right::-webkit-scrollbar{width:8px;height:8px}.modal-panel::-webkit-scrollbar-track,.store-right::-webkit-scrollbar-track{background:linear-gradient(180deg,rgba(15,23,42,0.92),rgba(30,41,59,0.88));border-radius:999px}.modal-panel::-webkit-scrollbar-thumb,.store-right::-webkit-scrollbar-thumb{background:linear-gradient(180deg,rgba(245,158,11,0.92),rgba(59,130,246,0.82));border-radius:999px;border:2px solid rgba(15,23,42,0.94);box-shadow:inset 0 0 0 1px rgba(255,255,255,0.08)}.modal-panel::-webkit-scrollbar-thumb:hover,.store-right::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,rgba(251,191,36,0.98),rgba(96,165,250,0.9))}.modal-panel::-webkit-scrollbar-corner,.store-right::-webkit-scrollbar-corner{background:transparent}.store-header{padding:20px 30px;background:rgba(0,0,0,0.3);border-bottom:1px solid rgba(255,255,255,0.1);display:flex;justify-content:space-between;align-items:center}.store-layout{display:grid;grid-template-columns:320px 1fr;height:715px}.store-left{background:rgba(0,0,0,0.2);padding:16px;border-right:1px solid rgba(255,255,255,0.05);display:flex;flex-direction:column;gap:14px}.vehicle-preview{height:90px;background:radial-gradient(circle at center,#334155 0%,#0f172a 70%);border-radius:10px;border:1px solid #475569;display:flex;align-items:center;justify-content:center;position:relative;box-shadow:inset 0 0 20px #000}.stats-container{background:#0f172a;padding:12px;border-radius:8px;border:1px solid #334155;display:flex;flex-direction:column;gap:10px}.stat-row{margin-bottom:12px}.stats-group{display:flex;flex-direction:column;gap:0;padding:10px 10px 8px;border-radius:10px;border:1px solid rgba(51,65,85,0.92);background:linear-gradient(180deg,rgba(30,41,59,0.78),rgba(15,23,42,0.96)),radial-gradient(circle at top right,rgba(245,158,11,0.08),transparent 45%);box-shadow:inset 0 1px 0 rgba(255,255,255,0.03),0 10px 20px rgba(2,6,23,0.12)}.stats-group .stat-row:last-child{margin-bottom:0}.stat-row-status{margin-bottom:4px}.stat-label{display:flex;justify-content:space-between;color:#94a3b8;font-size:0.8rem;margin-bottom:4px;text-transform:uppercase;font-weight:bold}.stat-status-value{padding:2px 8px;border-radius:999px;background:rgba(59,130,246,0.14);border:1px solid rgba(59,130,246,0.3);color:#dbeafe;letter-spacing:0.04em}.progress-bg{height:8px;background:#1e293b;border-radius:4px;overflow:hidden;position:relative}.bar-current{height:100%;background:linear-gradient(90deg,#3b82f6,#2563eb);width:0%;transition:width 0.3s ease;position:absolute;top:0;left:0;z-index:2}.bar-preview{height:100%;background:#22c55e;width:0%;position:absolute;top:0;left:0;opacity:0.6;z-index:1;animation:pulseBar 1s infinite}@keyframes pulseBar{0%{opacity:0.4}50%{opacity:0.8}100%{opacity:0.4}}.store-right{padding:16px;overflow-y:auto}.tabs{display:flex;gap:8px;margin-bottom:14px;border-bottom:2px solid #334155}.tab-btn{background:none;border:none;color:#64748b;padding:10px 20px;font-size:1rem;font-weight:bold;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all 0.3s}.tab-btn:hover{color:#fff}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:10px}.performance-groups{display:flex;flex-direction:column;gap:16px}.shop-group{position:relative;padding:16px;border-radius:14px;border:1px solid rgba(71,85,105,0.72);background:linear-gradient(180deg,rgba(30,41,59,0.96),rgba(15,23,42,0.98)),radial-gradient(circle at top right,rgba(245,158,11,0.12),transparent 42%);box-shadow:inset 0 1px 0 rgba(255,255,255,0.04),0 14px 28px rgba(2,6,23,0.18);overflow:hidden}.shop-group::before{content:"";position:absolute;inset:0 auto auto 0;width:100%;height:2px;background:linear-gradient(90deg,rgba(245,158,11,0.95),rgba(56,189,248,0.5),transparent 82%);pointer-events:none}.shop-group-header{display:flex;flex-direction:column;gap:3px;margin-bottom:12px}.shop-group-title{color:#f8fafc;font-size:0.82rem;font-weight:900;letter-spacing:0.12em;text-transform:uppercase}.shop-group-subtitle{color:#94a3b8;font-size:0.72rem;line-height:1.4}.shop-group-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:16px}.shop-group-single .shop-group-grid{grid-template-columns:minmax(0,220px)}.shop-group-headlights .shop-group-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.visuals-groups{display:flex;flex-direction:column;gap:14px}.visuals-groups .shop-group{padding:14px 16px}.visuals-groups .shop-group-header{margin-bottom:10px}.visuals-groups .shop-group-title{font-size:0.78rem;letter-spacing:0.14em}.visuals-groups .shop-group-subtitle{font-size:0.68rem}.shop-group-paint .shop-group-grid{grid-template-columns:1fr}.visuals-paint-shell{display:flex;flex-direction:column;gap:10px}.visuals-color-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;padding:2px 0 0}.visuals-groups .color-swatch{width:26px;height:26px;border-width:2px;border-color:rgba(148,163,184,0.28);box-shadow:0 8px 16px rgba(2,6,23,0.18)}.visuals-paint-actions{display:grid;grid-template-columns:52px minmax(0,1fr);gap:10px;align-items:center}.custom-color-picker{width:52px;height:38px;padding:0;border:1px solid rgba(71,85,105,0.84);border-radius:10px;background:rgba(15,23,42,0.92);cursor:pointer}.visuals-apply-btn{justify-content:center;min-height:38px;padding:8px 12px;border-radius:10px}.headlight-customizer-card{display:flex;flex-direction:column;gap:12px;min-height:100%}.headlight-customizer-top{display:flex;flex-direction:column;align-items:flex-start;gap:4px}.headlight-customizer-copy{display:flex;flex-direction:column;gap:4px;min-width:0}.headlight-customizer-actions{display:grid;grid-template-columns:52px minmax(0,1fr);gap:10px;align-items:center;margin-top:auto}.headlight-color-picker{width:52px;height:40px}.neon-color-picker{width:52px;height:40px}.visuals-groups .item-card{min-height:98px;border-radius:12px;padding:9px 10px}.visuals-groups .item-name,.visuals-groups .item-description,.visuals-groups .item-price{width:100%}.visuals-groups .item-price{justify-content:center;margin-top:auto}.performance-groups .item-card{min-height:140px;border-radius:12px;background:linear-gradient(180deg,rgba(30,41,59,0.96),rgba(15,23,42,0.98));align-items:flex-start;text-align:left;padding:10px 11px}.performance-groups .item-card .item-icon{align-self:flex-start}.performance-groups .item-card .item-name,.performance-groups .item-card .item-level,.performance-groups .item-card .item-description{width:100%}.performance-groups .item-card .item-price{margin-top:0}.performance-groups .upgrade-item-card .item-actions{width:100%;margin-top:auto}.item-card{background:#1e293b;border:1px solid #334155;border-radius:6px;padding:9px;cursor:pointer;transition:transform 0.14s ease-out,border-color 0.14s ease-out,box-shadow 0.14s ease-out,background-color 0.14s ease-out;position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;will-change:transform,box-shadow;transform:translateZ(0)}.item-card:hover{transform:translateY(-2px) translateZ(0);border-color:var(--accent);box-shadow:0 8px 18px rgba(2,6,23,0.28)}.item-card.locked{opacity:0.6;filter:grayscale(0.8);cursor:not-allowed;border-color:#ef4444}.item-card.locked:hover{transform:none;box-shadow:none}.item-card.purchase-disabled{border-color:rgba(71,85,105,0.92);cursor:default}.item-icon{font-size:1.4rem;margin-bottom:6px}.item-name{font-weight:bold;color:#fff;margin-bottom:5px}.item-level{font-size:0.75rem;color:#94a3b8;margin-bottom:10px}.item-price{background:#0f172a;padding:4px 8px;border-radius:14px;color:#ffd700;font-weight:bold;display:flex;align-items:center;gap:4px}.item-card.locked .item-price{color:#ef4444}.item-actions{display:flex;align-items:center;gap:8px}.item-actions .item-price{flex:1 1 auto;justify-content:center}.item-downgrade-btn{min-width:72px;height:30px;padding:0 10px;border:1px solid rgba(148,163,184,0.26);border-radius:999px;background:rgba(15,23,42,0.92);color:#cbd5e1;font-size:0.68rem;font-weight:800;letter-spacing:0.08em;cursor:pointer;transition:all 0.18s ease}.item-downgrade-btn:hover:not(:disabled){border-color:rgba(248,113,113,0.7);background:rgba(127,29,29,0.24);color:#fecaca}.item-downgrade-btn:disabled,.item-downgrade-btn.disabled{opacity:0.45;cursor:not-allowed}.color-grid{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:4px}.color-swatch{width:18px;height:18px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform 0.2s;justify-self:center}.color-swatch:hover{transform:scale(1.2);border-color:#fff}.color-swatch.active{border-color:var(--accent);box-shadow:0 0 10px var(--accent)}#setup-menu{display:flex;justify-content:center;align-items:center;padding:20px}.menu-layout-wrapper{display:flex;flex-direction:row;align-items:stretch;max-width:1010px;width:100%;height:85%;padding:5px;position:absolute;opacity:0.98}@media (max-height:550px){.menu-layout-wrapper{height:auto;max-height:90vh;overflow-y:auto}.side-settings-panel{top:auto !important;transform:none !important}.side-leaderboard-panel{margin-top:0 !important;transform:none !important}.side-rail-cluster{margin-top:0 !important;transform:none !important;height:auto !important}}.side-settings-panel{width:232px;background:#1e293b;padding:13px;display:flex;flex-direction:column;flex-shrink:0;height:90%;box-shadow:inset -1px 0px 0px 2px #0b111f70;position:relative;z-index:20;top:50%;transform:translateY(-50%);border-radius:12px 0 0 12px}.side-rail-cluster{display:flex;align-items:center;flex-shrink:0;height:82%;align-self:center;justify-content:center;margin-top:0;transform:none;position:relative;z-index:20}.side-settings-panel .settings-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:2px}.side-settings-panel .settings-content::-webkit-scrollbar{width:4px}.side-settings-panel .settings-content::-webkit-scrollbar-track{background:#0f172a;border-radius:2px}.side-settings-panel .settings-content::-webkit-scrollbar-thumb{background:#334155;border-radius:2px}.side-title{color:#94a3b8;font-size:0.75rem;font-weight:800;margin-top:0;margin-bottom:10px;text-transform:uppercase;letter-spacing:1px}.config-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.config-icon{font-size:1rem;filter:grayscale(0.3)}.side-settings-panel .menu-group{margin-bottom:10px}.side-settings-panel .menu-group label{font-size:0.7rem;color:#94a3b8;margin-bottom:4px;display:block}.side-settings-panel input[type="range"]{width:100%;height:4px;-webkit-appearance:none;appearance:none;background:#0f172a;border-radius:2px;outline:none}.side-settings-panel input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;background:var(--accent);border-radius:50%;cursor:pointer}.side-settings-panel .track-options.vertical{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:3px}.side-settings-panel .track-card{padding:2px;background:#0f172a;border-radius:5px;font-size:0.62rem;border:1px solid transparent;transition:all 0.2s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;text-align:center}.side-settings-panel .track-card:hover{background:#334155;border-color:#facc15}.side-settings-panel .track-card.selected{border-color:var(--accent);background:rgba(245,158,11,0.18) !important}.side-settings-panel .track-card .t-icon{font-size:0.9rem}.side-settings-panel .track-card span{font-size:0.54rem;line-height:1;margin-bottom:0.35rem}.side-settings-panel .track-card canvas.track-mini{width:42px;height:27px;display:block}.side-settings-panel .pole-checkbox-wrapper{font-size:0.75rem}.side-settings-panel .pole-checkbox-wrapper input[type="checkbox"]{width:14px !important;height:14px !important}.side-settings-panel .tooltip-icon{width:14px;height:14px;font-size:0.6rem}.menu-panel.main-section{flex-grow:1;min-width:400px;border-radius:12px;background:linear-gradient(180deg,rgba(15,23,42,0.94),rgba(15,23,42,0.9));border:1px solid rgba(51,65,85,0.92);box-shadow:0 18px 42px rgba(2,6,23,0.34);padding:25px 30px}#logged-in-welcome{display:flex;flex-direction:column;align-items:stretch;justify-content:center;gap:5px}.logged-in-topline{display:flex;align-items:center;justify-content:center;gap:8px}.logged-in-statsline{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;margin-top:15px}.driver-label{display:inline-flex;align-items:center}.logout-btn{margin-left:15px}.stat-badge.followers-stat{color:#cbd5e1;border:1px solid rgba(148,163,184,0.34);text-shadow:0 0 10px rgba(148,163,184,0.16);font-weight:bold;letter-spacing:1px;display:inline-flex;align-items:center;gap:6px;background:linear-gradient(180deg,rgba(30,41,59,0.94),rgba(15,23,42,0.92))}.menu-panel.main-section .track-options.vertical{display:flex;flex-direction:column;gap:8px}.menu-panel.main-section .track-options.vertical .track-card{padding:8px 12px;display:flex;align-items:center;gap:15px;text-align:left;background:#1e293b}.track-preview{margin-top:8px;background:#020617;border-radius:8px;border:1px solid #334155;padding:6px;width:60%}.track-preview canvas{width:100%;height:auto;display:block;background:radial-gradient(circle at center,#020617 0%,#020617 100%)}.track-preview-name{margin-top:4px;font-size:0.7rem;color:#94a3b8;text-align:center;text-transform:uppercase;letter-spacing:0.06em}@media (max-width:768px) and (orientation:landscape){.track-preview{width:30%}#matchmaking-lobby{align-items:stretch;justify-content:stretch}#matchmaking-lobby .modal-panel.wide{width:100%;max-width:100%;height:100dvh;max-height:100dvh;border-radius:0;padding:14px 14px calc(12px + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;overflow:hidden}#matchmaking-lobby .dashboard-header,#matchmaking-lobby #race-details,#matchmaking-lobby #private-room-panel,#matchmaking-lobby #spectators-section{flex-shrink:0}#matchmaking-lobby #lobby-list{flex:1 1 auto;min-height:0;max-height:none;overflow-y:auto;margin-bottom:12px}#matchmaking-lobby .ready-button-container{margin-top:auto;flex-shrink:0;padding-top:10px;position:sticky;bottom:0;background:linear-gradient(180deg,rgba(30,41,59,0),rgba(30,41,59,0.94) 24%,rgba(30,41,59,1))}#matchmaking-lobby #btn-lobby-ready{width:100%}}.side-leaderboard-panel{width:245px;background:#1e293b;padding:15px;display:flex;flex-direction:column;flex-shrink:0;height:100%;margin-top:0;box-shadow:inset 1px 0px 0px 2px #0b111f70;position:relative;z-index:20;transform:none;border-radius:0 14px 14px 0}.side-leaderboard-panel .leaderboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.leaderboard-search-wrap{margin-bottom:12px}.leaderboard-search-input{width:100%;min-width:0;height:34px;padding:0 12px;border-radius:10px;border:1px solid rgba(71,85,105,0.72);background:rgba(2,6,23,0.9);color:#e2e8f0;box-shadow:inset 0 1px 0 rgba(255,255,255,0.03)}.leaderboard-search-input::placeholder{color:#64748b}.leaderboard-search-input:focus{border-color:rgba(250,204,21,0.58);box-shadow:0 0 0 1px rgba(250,204,21,0.18),0 0 18px rgba(250,204,21,0.08)}.side-leaderboard-panel .side-title{margin:0;padding:0;border:none}.online-indicator{width:10px;height:10px;background:#22c55e;border-radius:50%;box-shadow:0 0 8px #22c55e,0 0 16px #22c55e;animation:pulse-online 1.5s ease-in-out infinite}@keyframes pulse-online{0%,100%{opacity:1;transform:scale(1);box-shadow:0 0 8px #22c55e,0 0 16px #22c55e}50%{opacity:0.6;transform:scale(0.85);box-shadow:0 0 4px #22c55e,0 0 8px #22c55e}}@keyframes pulse-warming{0%,100%{opacity:1;transform:scale(1);box-shadow:0 0 8px #facc15,0 0 16px rgba(250,204,21,0.92)}50%{opacity:0.58;transform:scale(0.84);box-shadow:0 0 4px #facc15,0 0 9px rgba(250,204,21,0.72)}}#btn-join-next.logged-in-glow{animation:pulse-join-btn 2s ease-in-out infinite}@keyframes pulse-join-btn{0%,100%{background:#22c55e;box-shadow:0 0 15px rgba(34,197,94,0.4)}50%{background:#16a34a;box-shadow:0 0 25px rgba(34,197,94,0.7),0 0 40px rgba(34,197,94,0.3)}}.side-leaderboard-panel .leaderboard-list{flex:1;overflow-y:auto;overflow-x:hidden}.side-panel-tabs{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:10px}.side-panel-tab{border:1px solid rgba(148,163,184,0.18);background:rgba(15,23,42,0.86);color:#cbd5e1;border-radius:999px;padding:7px 10px;font-size:0.68rem;font-weight:800;letter-spacing:0.08em;text-transform:uppercase;cursor:pointer;transition:all 0.18s ease}.side-panel-tab.active{background:linear-gradient(135deg,rgba(250,204,21,0.2),rgba(249,115,22,0.22));color:#f8fafc;border-color:rgba(250,204,21,0.38);box-shadow:0 0 0 1px rgba(250,204,21,0.14)}.side-panel-view{display:none;min-height:0;flex:1}.side-panel-view.active{display:flex;flex-direction:column}.live-races-list{display:flex;flex-direction:column;gap:8px}.live-race-card{background:linear-gradient(180deg,rgba(15,23,42,0.96),rgba(30,41,59,0.96));border:1px solid rgba(51,65,85,0.9);border-radius:10px;padding:10px;box-shadow:inset 0 1px 0 rgba(255,255,255,0.02)}.live-race-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}.live-race-title{font-size:0.8rem;font-weight:800;color:#f8fafc;letter-spacing:0.02em}.live-race-status{padding:3px 7px;border-radius:999px;background:rgba(34,197,94,0.14);color:#86efac;font-size:0.58rem;font-weight:800;letter-spacing:0.08em;text-transform:uppercase;white-space:nowrap}.live-race-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px 8px;margin-bottom:8px;font-size:0.66rem;color:#94a3b8}.live-race-meta strong{color:#e2e8f0;font-weight:700}.live-race-pilots{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.live-race-pilot{display:inline-flex;align-items:center;gap:5px;min-width:0;padding:4px 7px;border-radius:999px;background:rgba(15,23,42,0.9);border:1px solid rgba(51,65,85,0.72);font-size:0.62rem;color:#cbd5e1}.live-race-pilot-dot{width:8px;height:8px;border-radius:50%;flex:0 0 auto;box-shadow:0 0 8px currentColor}.live-race-pilot-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.live-race-actions{display:grid;grid-template-columns:1fr 1fr;gap:6px}.live-race-btn{border:0;border-radius:8px;padding:8px 10px;font-size:0.67rem;font-weight:800;letter-spacing:0.08em;text-transform:uppercase;cursor:pointer;transition:transform 0.16s ease,opacity 0.16s ease,box-shadow 0.16s ease}.live-race-btn:hover{transform:translateY(-1px)}.live-race-btn:disabled{cursor:default;opacity:0.45;transform:none;box-shadow:none}.live-race-btn.watch{background:linear-gradient(135deg,#22c55e,#16a34a);color:#04110a;box-shadow:0 8px 18px rgba(34,197,94,0.18)}.live-race-btn.challenge{background:linear-gradient(135deg,#facc15,#f59e0b);color:#111827;box-shadow:0 8px 18px rgba(250,204,21,0.16)}.live-race-empty{padding:18px 10px;border-radius:10px;background:rgba(15,23,42,0.86);border:1px dashed rgba(51,65,85,0.7);color:#94a3b8;font-size:0.72rem;text-align:center}.side-leaderboard-panel .leaderboard-list::-webkit-scrollbar{width:4px}.side-leaderboard-panel .leaderboard-list::-webkit-scrollbar-track{background:#0f172a;border-radius:2px}.side-leaderboard-panel .leaderboard-list::-webkit-scrollbar-thumb{background:#334155;border-radius:2px}.side-lb-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 0;color:#94a3b8;font-size:0.8rem}.side-lb-spinner{width:18px;height:18px;border-radius:999px;border:2px solid rgba(148,163,184,0.4);border-top-color:#22c55e;animation:side-lb-spin 0.8s linear infinite;margin-bottom:6px}@keyframes side-lb-spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}.side-lb-item{display:grid;grid-template-columns:20px minmax(0,1fr) 18px auto;align-items:center;gap:8px;padding:6px 8px;background:#0f172a;border-radius:6px;margin-bottom:6px;font-size:0.75rem;transition:background 0.2s,box-shadow 0.24s ease;will-change:transform,opacity;transform-origin:center center}.side-lb-item:hover{background:#334155}.side-lb-rank{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;background:#334155;border-radius:4px;font-weight:bold;font-size:0.65rem;color:#94a3b8;position:relative;overflow:visible}.side-lb-rank-number{display:inline-flex;align-items:center;justify-content:center;width:100%;height:100%}.side-lb-item:nth-child(1) .side-lb-rank{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#000}.side-lb-item:nth-child(2) .side-lb-rank{background:linear-gradient(135deg,#94a3b8,#64748b);color:#000}.side-lb-item:nth-child(3) .side-lb-rank{background:linear-gradient(135deg,#cd7f32,#a0522d);color:#fff}.side-lb-name{flex:1;color:#e2e8f0;min-width:0;cursor:pointer;overflow:hidden}.side-lb-name-wrap{display:flex;align-items:center;gap:6px;min-width:0;justify-content:flex-start;width:100%}.side-lb-name-text{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.side-lb-country{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:rgba(148,163,184,0.12);border:1px solid rgba(148,163,184,0.18);font-size:0.78rem;line-height:1;flex:0 0 auto;box-shadow:inset 0 1px 0 rgba(255,255,255,0.04);overflow:hidden}.detail-identity{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:4px}.detail-country-flag{width:32px;height:32px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:rgba(148,163,184,0.12);border:1px solid rgba(148,163,184,0.18);box-shadow:inset 0 1px 0 rgba(255,255,255,0.04);overflow:hidden;flex:0 0 auto}.detail-country-name{text-align:center;color:#94a3b8;font-size:0.8rem;margin-bottom:12px}.detail-medals{min-height:24px;display:flex;align-items:center;justify-content:center;gap:6px;margin:-4px 0 14px}.detail-medals .medal{margin-left:0;width:20px;height:20px;font-size:0.82rem}.detail-medals-empty{color:#64748b;font-size:0.76rem;letter-spacing:0.02em;text-transform:uppercase}.detail-country-flag.is-hidden,.detail-country-name.is-hidden{display:none}.side-lb-xp{color:#22c55e;font-weight:bold;font-size:0.65rem}.side-lb-live{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:999px;background:rgba(34,197,94,0.12);color:#86efac;font-size:0.72rem;font-weight:800;flex:0 0 auto}.side-lb-live-rank{position:absolute;top:-7px;left:-7px;width:15px;height:15px;border-radius:999px;background:rgba(8,15,30,0.96);border:1px solid rgba(34,197,94,0.3);color:#86efac;font-size:0.58rem;box-shadow:0 2px 8px rgba(2,6,23,0.34);pointer-events:none}.side-lb-watch{border:1px solid rgba(148,163,184,0.24);width:20px;height:20px;border-radius:999px;padding:0;background:rgba(15,23,42,0.72);color:#cbd5e1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex:0 0 auto;box-shadow:inset 0 1px 0 rgba(255,255,255,0.03);transition:border-color 0.18s ease,color 0.18s ease,background 0.18s ease,transform 0.18s ease}.side-lb-watch-slot{width:20px;height:20px;display:inline-flex;flex:0 0 auto}.side-lb-watch svg{width:11px;height:11px;stroke:currentColor;stroke-width:1.8;fill:none}.side-lb-watch:hover{background:rgba(30,41,59,0.92);color:#f8fafc;border-color:rgba(248,250,252,0.32);transform:translateY(-1px)}.side-lb-item.finished{background:rgba(34,197,94,0.1);border:1px solid rgba(34,197,94,0.3)}.side-lb-finished{margin-left:4px;font-size:0.8rem;opacity:0.8}.side-lb-watch-slot{width:20px;height:20px;display:inline-flex;flex:0 0 auto}.home-chat-shell{position:relative;top:auto;right:auto;transform:none;transform-origin:left top;width:250px;max-height:min(62vh,430px);display:flex;flex-direction:column;gap:8px;padding:10px 12px 11px 15px;margin-left:-8px;border-radius:0 18px 18px 0;border:1px solid rgba(71,85,105,0.68);background:linear-gradient(180deg,rgba(2,6,23,0.96),rgba(15,23,42,0.95) 28%,rgba(30,41,59,0.92)),radial-gradient(circle at top right,rgba(34,197,94,0.1),transparent 42%);box-shadow:0 18px 38px rgba(2,6,23,0.38),inset 0 1px 0 rgba(255,255,255,0.04);z-index:19;backdrop-filter:blur(14px);overflow:hidden;transition:width 0.34s cubic-bezier(0.22,1,0.36,1),max-height 0.34s cubic-bezier(0.22,1,0.36,1),transform 0.34s cubic-bezier(0.22,1,0.36,1),border-radius 0.28s ease,box-shadow 0.28s ease,padding 0.28s ease,gap 0.24s ease}.home-chat-shell::before{content:"";position:absolute;left:-14px;top:50%;transform:translateY(-50%);width:18px;height:70%;border-radius:14px 0 0 14px;border:1px solid rgba(71,85,105,0.5);border-right:0;background:linear-gradient(180deg,rgba(15,23,42,0.9),rgba(30,41,59,0.9));box-shadow:inset 0 1px 0 rgba(255,255,255,0.03);pointer-events:none;transition:height 0.3s ease,transform 0.3s ease,opacity 0.24s ease,left 0.3s ease}body.racing .home-chat-shell,body.spectator-mode .home-chat-shell{opacity:0;pointer-events:none;transform:translateX(18px)}.home-chat-shell.is-hidden-state{opacity:0;pointer-events:none;transform:translateX(18px)}.home-chat-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:-10px -12px 2px -15px;padding:10px 12px 10px 15px;background:#1e293b;border-bottom:1px solid rgba(51,65,85,0.72);border-radius:0 18px 0 0;transition:margin 0.28s cubic-bezier(0.22,1,0.36,1),padding 0.28s cubic-bezier(0.22,1,0.36,1),background 0.18s ease,border-bottom-color 0.18s ease}.home-chat-header-copy{min-width:0;max-width:140px;transition:opacity 0.16s ease,transform 0.24s cubic-bezier(0.22,1,0.36,1),max-width 0.24s cubic-bezier(0.22,1,0.36,1),flex-basis 0.24s cubic-bezier(0.22,1,0.36,1)}.home-chat-header-actions{display:inline-flex;align-items:center;gap:8px;flex:0 0 auto;transition:transform 0.22s cubic-bezier(0.22,1,0.36,1)}.home-chat-title{color:#94a3b8;font-size:0.75rem;font-weight:800;letter-spacing:1px;text-transform:uppercase}.home-chat-pulse{width:10px;height:10px;border-radius:999px;background:#22c55e;box-shadow:0 0 0 rgba(34,197,94,0.22),0 0 14px rgba(34,197,94,0.42);animation:pulse-online 1.5s ease-in-out infinite;flex:0 0 auto;margin-top:4px}.home-chat-shell.is-warming .home-chat-pulse{background:#facc15;box-shadow:0 0 0 rgba(250,204,21,0.24),0 0 14px rgba(250,204,21,0.46);animation:pulse-warming 1.35s ease-in-out infinite}.home-chat-toggle{width:24px;height:24px;border-radius:999px;border:1px solid rgba(71,85,105,0.72);background:rgba(2,6,23,0.72);color:transparent;display:inline-flex;align-items:center;justify-content:center;font-size:0;font-weight:900;line-height:1;cursor:pointer;position:relative;transition:background 0.18s ease,border-color 0.18s ease,transform 0.18s ease}.home-chat-toggle::before,.home-chat-toggle::after{content:"";position:absolute;left:50%;top:50%;border-radius:999px;background:#e2e8f0;transform:translate(-50%,-50%)}.home-chat-toggle::before{width:10px;height:2px}.home-chat-toggle::after{width:2px;height:10px}.home-chat-toggle[aria-expanded="true"]::after{opacity:0}.home-chat-toggle:hover{background:rgba(15,23,42,0.92);border-color:rgba(148,163,184,0.88)}.home-chat-toggle:active{transform:scale(0.95)}.home-chat-shell.is-collapsed{gap:0}.home-chat-shell.is-collapsed .home-chat-list,.home-chat-shell.is-collapsed .home-chat-compose{min-height:0;max-height:0;opacity:0;overflow:hidden;pointer-events:none;transform:translate3d(-12px,-8px,0);margin:0;padding-top:0;border-top-color:transparent}.home-chat-list{min-height:150px;max-height:min(34vh,250px);overflow-y:auto;display:flex;flex-direction:column;gap:7px;padding-right:2px;transition:max-height 0.28s cubic-bezier(0.22,1,0.36,1),opacity 0.22s ease,transform 0.28s cubic-bezier(0.22,1,0.36,1),margin 0.22s ease}.home-chat-list::-webkit-scrollbar{width:4px}.home-chat-list::-webkit-scrollbar-thumb{background:rgba(71,85,105,0.9);border-radius:999px}.home-chat-empty{min-height:120px;display:flex;align-items:center;justify-content:center;text-align:center;border:1px dashed rgba(71,85,105,0.56);border-radius:16px;color:#94a3b8;font-size:0.74rem;background:rgba(15,23,42,0.52)}.home-chat-item{padding:7px 8px 8px;border-radius:12px;border:1px solid rgba(51,65,85,0.72);background:linear-gradient(145deg,rgba(15,23,42,0.92),rgba(30,41,59,0.82));box-shadow:inset 0 1px 0 rgba(255,255,255,0.03);transition:opacity 0.2s ease,transform 0.2s ease,border-color 0.2s ease}.home-chat-item.is-self{border-color:rgba(34,197,94,0.32);background:linear-gradient(145deg,rgba(6,78,59,0.28),rgba(15,23,42,0.92))}.home-chat-item.is-fading{opacity:0.56}.home-chat-meta{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}.home-chat-meta-left{min-width:0;display:inline-flex;align-items:center;gap:7px}.home-chat-flag{width:18px;height:18px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;flex:0 0 auto;background:rgba(148,163,184,0.12);border:1px solid rgba(148,163,184,0.18)}.home-chat-name{min-width:0;color:#e2e8f0;font-size:0.66rem;font-weight:800;letter-spacing:0.02em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.home-chat-age{color:#64748b;font-size:0.58rem;font-weight:800;letter-spacing:0.08em;text-transform:uppercase;flex:0 0 auto}.home-chat-text{color:#dbe4ef;font-size:0.69rem;line-height:1.36;word-break:break-word}.home-chat-compose{border-top:1px solid rgba(71,85,105,0.38);padding-top:8px;max-height:160px;display:flex;flex-direction:column;gap:7px;transition:max-height 0.28s cubic-bezier(0.22,1,0.36,1),opacity 0.22s ease,transform 0.28s cubic-bezier(0.22,1,0.36,1),padding-top 0.22s ease,border-top-color 0.18s ease,margin 0.22s ease}.home-chat-input{margin-bottom:0;padding:8px 9px;min-height:38px;font-size:0.69rem;border-radius:12px;background:rgba(2,6,23,0.8)}.home-chat-shell.is-guest .home-chat-input{cursor:not-allowed;opacity:0.88}.home-chat-compose-footer{display:flex;align-items:center;justify-content:space-between;gap:6px}.home-chat-count{color:#64748b;font-size:0.58rem;font-weight:800;letter-spacing:0.08em;text-transform:uppercase}.home-chat-send{min-width:62px;justify-content:center;padding:6px 10px;border-radius:5px;background:var(--accent);color:#000;font-weight:700;letter-spacing:0.02em;border:none;box-shadow:none;font-size:0.75rem}.home-chat-send:disabled{cursor:not-allowed;opacity:0.45;box-shadow:none}@media (min-width:769px){.home-chat-shell.is-collapsed{width:60px;max-height:52px;padding:8px 8px 8px 10px;transform:translateX(-22px);box-shadow:0 12px 24px rgba(2,6,23,0.26),inset 0 1px 0 rgba(255,255,255,0.04)}.home-chat-shell.is-collapsed::before{opacity:0;left:-8px;transform:translateY(-50%) scaleY(0.72)}.home-chat-shell.is-collapsed .home-chat-header{margin:-8px -8px -2px -10px;padding:8px 8px 8px 10px;justify-content:center;align-items:center;background:transparent;border-bottom-color:transparent}.home-chat-shell.is-collapsed .home-chat-header-copy{opacity:0;transform:translateX(-12px);max-width:0;flex:0 0 0;overflow:hidden}.home-chat-shell.is-collapsed .home-chat-header-actions{position:relative;width:100%;min-height:24px;justify-content:center;gap:0;transform:translateY(-1px);transition-delay:0.08s}.home-chat-shell.is-collapsed .home-chat-pulse{position:absolute;top:50%;left:calc(50% - 18px);margin-top:0;transform:translate(-50%,-50%)}.home-chat-shell.is-collapsed .home-chat-toggle{left:7px;top:2px}}.chat-warning-panel{width:min(430px,calc(100vw - 24px))}.chat-warning-list{display:flex;flex-direction:column;gap:10px;margin:18px 0 20px;text-align:left}.chat-warning-item{padding:11px 12px;border-radius:12px;background:rgba(15,23,42,0.82);border:1px solid rgba(51,65,85,0.72)}.chat-warning-item-title{color:#f8fafc;font-size:0.82rem;font-weight:800;margin-bottom:4px}.chat-warning-item-detail{color:#94a3b8;font-size:0.75rem;line-height:1.45}.activity-ticker-band{position:fixed;left:50%;bottom:18px;transform:translateX(-50%);width:min(1100px,calc(100% - 40px));display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:12px;padding:10px 14px;border-radius:14px;background:linear-gradient(90deg,rgba(2,6,23,0.95),rgba(15,23,42,0.92),rgba(30,41,59,0.9));border:1px solid rgba(71,85,105,0.68);box-shadow:0 12px 32px rgba(2,6,23,0.42);z-index:24;overflow:hidden;pointer-events:auto}body.racing .activity-ticker-band,body.spectator-mode .activity-ticker-band{display:none !important}.activity-ticker-label{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;background:rgba(250,204,21,0.12);color:#fde68a;font-size:0.62rem;font-weight:900;letter-spacing:0.14em;text-transform:uppercase;white-space:nowrap}.activity-ticker-viewport{position:relative;overflow:hidden;min-width:0;pointer-events:auto;mask-image:linear-gradient(to right,transparent 0,black 4%,black 96%,transparent 100%);-webkit-mask-image:linear-gradient(to right,transparent 0,black 4%,black 96%,transparent 100%)}.activity-ticker-track{display:inline-flex;align-items:center;gap:0;min-width:max-content;white-space:nowrap;will-change:transform;transform:translate3d(0,0,0)}.activity-ticker-track.is-static{min-width:100%;animation:none;transform:translate3d(0,0,0)}.activity-ticker-segment{display:inline-flex;align-items:center;gap:16px;flex:0 0 auto;padding-right:16px}.activity-ticker-item{display:inline-flex;align-items:center;gap:9px;padding-right:16px;position:relative}.activity-ticker-item::after{content:'';position:absolute;right:0;top:50%;width:5px;height:5px;border-radius:999px;background:rgba(148,163,184,0.4);transform:translateY(-50%)}.activity-ticker-item:last-child::after{display:none}.activity-ticker-icon{width:22px;height:22px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:rgba(148,163,184,0.1);font-size:0.78rem;flex:0 0 auto}.activity-ticker-item.accent-upgrade .activity-ticker-icon,.activity-ticker-item.accent-winner .activity-ticker-icon{background:rgba(250,204,21,0.14)}.activity-ticker-item.accent-duel .activity-ticker-icon,.activity-ticker-item.accent-hot .activity-ticker-icon{background:rgba(248,113,113,0.14)}.activity-ticker-item.accent-style .activity-ticker-icon,.activity-ticker-item.accent-cash .activity-ticker-icon{background:rgba(34,197,94,0.14)}.activity-ticker-text{color:#e2e8f0;font-size:0.72rem;line-height:1.2}.activity-ticker-time{color:#64748b;font-size:0.58rem;font-weight:800;letter-spacing:0.08em;text-transform:uppercase}.activity-ticker-empty{color:#94a3b8;font-size:0.68rem;font-weight:700;letter-spacing:0.04em}.live-toast-stack{position:fixed;left:18px;bottom:calc(90px + env(safe-area-inset-bottom,0px));width:min(340px,calc(100vw - 24px));display:flex;flex-direction:column;align-items:flex-start;gap:10px;z-index:5001;pointer-events:none}body.racing .live-toast-stack,body.spectator-mode .live-toast-stack{display:none !important}body.racing .live-toast-stack.allow-in-race,body.spectator-mode .live-toast-stack.allow-in-race{display:flex !important}.live-toast{width:100%;display:grid;grid-template-columns:42px minmax(0,1fr);gap:10px;position:relative;padding:12px 14px;border-radius:16px;border:1px solid rgba(71,85,105,0.48);background:linear-gradient(145deg,rgba(15,23,42,0.96),rgba(30,41,59,0.94));box-shadow:0 16px 34px rgba(2,6,23,0.34);color:#e2e8f0;pointer-events:auto;opacity:1;transform:translate3d(0,0,0);transition:opacity 220ms ease,transform 220ms ease}.live-toast.is-exiting{opacity:0;transform:translate3d(-16px,0,0)}.live-toast-icon{width:42px;height:42px;border-radius:13px;display:inline-flex;align-items:center;justify-content:center;font-size:1.05rem;font-weight:900;color:#f8fafc;background:rgba(148,163,184,0.16);border:1px solid rgba(148,163,184,0.24)}.live-toast-content{min-width:0;display:flex;flex-direction:column;gap:3px;padding-right:18px}.live-toast-close{position:absolute;top:8px;right:8px;width:22px;height:22px;border:0;border-radius:999px;background:rgba(148,163,184,0.12);color:#cbd5e1;display:inline-flex;align-items:center;justify-content:center;font-size:0.9rem;line-height:1;cursor:pointer;transition:background 0.18s ease,color 0.18s ease,transform 0.18s ease}.live-toast-close:hover{background:rgba(239,68,68,0.18);color:#fee2e2}.live-toast-close:active{transform:scale(0.94)}.live-toast-title{color:#f8fafc;font-size:0.72rem;font-weight:900;letter-spacing:0.12em;text-transform:uppercase}.live-toast-message{color:#cbd5e1;font-size:0.76rem;line-height:1.35}.live-toast-time{color:#64748b;font-size:0.58rem;font-weight:800;letter-spacing:0.1em;text-transform:uppercase}.live-toast[data-accent="winner"] .live-toast-icon{background:rgba(250,204,21,0.16);border-color:rgba(250,204,21,0.3);color:#fde68a}.live-toast[data-accent="duel"] .live-toast-icon{background:rgba(249,115,22,0.16);border-color:rgba(249,115,22,0.3);color:#fdba74}.live-toast[data-accent="follow"] .live-toast-icon{background:rgba(59,130,246,0.16);border-color:rgba(96,165,250,0.3);color:#93c5fd}.live-toast[data-accent="hot"] .live-toast-icon{background:rgba(239,68,68,0.16);border-color:rgba(248,113,113,0.3);color:#fca5a5}@keyframes activityTickerScroll{from{transform:translate3d(0,0,0)}to{transform:translate3d(calc(var(--ticker-distance,0px) * -1),0,0)}}@media (max-width:768px){.home-chat-shell{width:100%;max-height:min(44vh,420px);margin-left:0;border-radius:12px;padding:12px}.home-chat-shell.is-collapsed{width:100%}.home-chat-shell::before{display:none}body.racing .home-chat-shell,body.spectator-mode .home-chat-shell{transform:translateY(12px)}.home-chat-shell.is-hidden-state{transform:translateY(12px)}.home-chat-list{min-height:160px;max-height:28vh}.home-chat-text{font-size:0.74rem}.activity-ticker-band{width:calc(100% - 18px);bottom:10px;grid-template-columns:1fr;gap:8px;padding:9px 10px}.activity-ticker-label{justify-self:start}.activity-ticker-text{font-size:0.67rem}.live-toast-stack{left:9px;right:auto;width:min(340px,calc(100vw - 18px));bottom:calc(84px + env(safe-area-inset-bottom,0px));gap:8px;align-items:flex-start}.live-toast{grid-template-columns:38px minmax(0,1fr);gap:9px;padding:10px 11px;border-radius:14px}.live-toast-icon{width:38px;height:38px;border-radius:12px}.live-toast-message{font-size:0.72rem}.live-toast-close{width:24px;height:24px;top:6px;right:6px}}.cookie-banner.hidden{display:none}.cookie-text{max-width:700px;color:var(--text-sub)}.modal-actions{display:grid !important;grid-template-columns:1fr 1fr !important;gap:10px !important;justify-content:center !important;align-items:center !important;margin-top:24px !important;width:100% !important}.modal-actions button{height:48px !important;padding:0 !important;margin:0 !important;display:flex !important;align-items:center !important;justify-content:center !important;box-sizing:border-box !important;font-size:0.95rem !important;font-weight:700 !important;white-space:nowrap !important;border:none !important;border-radius:6px !important;text-transform:uppercase !important;cursor:pointer !important;line-height:1 !important;outline:none !important}#btn-follow-user{background:linear-gradient(135deg,#0f172a,#1e293b) !important;color:#e2e8f0 !important;border:1px solid #475569 !important}#btn-follow-user.following{background:linear-gradient(135deg,#1d4ed8,#1e40af) !important;border-color:#60a5fa !important;color:white !important}#btn-follow-user:disabled{background:#334155 !important;border-color:#475569 !important;color:#94a3b8 !important;cursor:not-allowed !important}#btn-challenge-user{background:linear-gradient(135deg,#f97316,#ea580c) !important;color:white !important}.modal-actions .close-button{background:#334155 !important;color:#e2e8f0 !important;grid-column:1 / -1 !important}.btn-orange{background:linear-gradient(135deg,#f97316,#ea580c);color:white}.btn-orange:hover:not(:disabled){background:linear-gradient(135deg,#ea580c,#c2410c);box-shadow:0 0 15px rgba(234,88,12,0.4)}.btn-orange:disabled{background:#475569;cursor:not-allowed;opacity:0.7}.btn-red{background:linear-gradient(135deg,#ef4444,#dc2626);color:white}.challenge-panel{border:2px solid #f97316}.challenge-msg{margin:20px 0;font-size:1.1rem;color:#e2e8f0}#btn-challenge-user.waiting{background:#64748b}#btn-challenge-user.accepted{background:#22c55e !important}#btn-challenge-user.rejected{background:#ef4444 !important}#btn-challenge-user.racing{background:#334155 !important;color:#cbd5e1 !important;opacity:0.9;letter-spacing:0.04em}#site-footer{height:32px;background:var(--panel-bg);border-top:1px solid #334155;display:flex;align-items:center;justify-content:space-between;padding:0 16px;font-size:0.75rem;color:var(--text-sub);position:relative;z-index:950}#site-footer .footer-link-btn{background:none;border:none;color:var(--accent);font-size:0.75rem;cursor:pointer;text-decoration:underline;padding:0}.tooltip-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;background:#334155;color:#94a3b8;border-radius:50%;font-size:0.7rem;font-weight:bold;cursor:help;position:relative;line-height:1;flex-shrink:0;box-sizing:border-box}#global-tooltip{position:fixed;left:-9999px;top:-9999px;transform:translateX(-50%);background:#1e293b;color:#e2e8f0;padding:10px 12px;border-radius:6px;font-size:0.75rem;font-weight:normal;white-space:normal;width:220px;text-align:center;box-shadow:0 4px 12px rgba(0,0,0,0.4);border:1px solid #475569;z-index:99999;line-height:1.4;pointer-events:none;opacity:0}#global-tooltip.active{opacity:1}.tooltip-icon:hover::after,.tooltip-icon:hover::before,.weather-option[data-tooltip]:hover::after,.weather-option[data-tooltip]:hover::before{content:none !important;display:none !important}.tooltip-icon:hover::after{content:attr(data-tooltip);position:absolute;bottom:130%;left:50%;transform:translateX(-50%);background:#1e293b;color:#e2e8f0;padding:10px 12px;border-radius:6px;font-size:0.75rem;font-weight:normal;white-space:normal;width:220px;text-align:center;box-shadow:0 4px 12px rgba(0,0,0,0.4);border:1px solid #475569;z-index:9999;line-height:1.4}.tooltip-icon:hover::before{content:'';position:absolute;bottom:115%;left:50%;transform:translateX(-50%);border:6px solid transparent;border-top-color:#1e293b;z-index:9999}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.afk-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:5000;display:none}.afk-popup.display-block{display:block;animation:afk-pulse 0.5s ease-in-out infinite alternate}@keyframes afk-pulse{0%{transform:translate(-50%,-50%) scale(1)}100%{transform:translate(-50%,-50%) scale(1.02)}}.afk-popup-content{background:linear-gradient(135deg,#1e293b 0%,#0f172a 100%);border:3px solid #ef4444;border-radius:16px;position:relative;padding:30px 40px;text-align:center;box-shadow:0 0 40px rgba(239,68,68,0.5),0 0 80px rgba(239,68,68,0.2);opacity:0.95}.afk-popup .afk-icon{font-size:3rem;margin-bottom:10px;animation:afk-shake 0.3s ease-in-out infinite}@keyframes afk-shake{0%,100%{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}.afk-popup h3{color:#ef4444;font-size:1.5rem;margin:0 0 10px 0;text-transform:uppercase;letter-spacing:2px}.afk-popup p{color:#94a3b8;margin:5px 0;font-size:0.9rem}.afk-popup .afk-countdown{color:#fbbf24;font-weight:bold;font-size:1rem;margin-top:15px}.afk-popup .afk-countdown span{color:#ef4444;font-size:1.5rem;font-weight:900}.afk-popup .afk-warning-count{margin-top:15px;padding:8px 16px;background:rgba(239,68,68,0.2);border-radius:20px;color:#ef4444;font-weight:bold;font-size:0.85rem}.racer-card .afk-indicator{display:inline-block;margin-left:5px;color:#ef4444;font-size:0.7rem;animation:blink 0.5s ease-in-out infinite}@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}.racer-card.eliminated{opacity:0.5;background:rgba(239,68,68,0.1);border-left:3px solid #ef4444}@media (max-width:1024px){.menu-layout-wrapper{max-width:100%;padding:10px;height:auto;max-height:90vh;overflow-y:auto}.side-settings-panel,.side-leaderboard-panel{width:180px;height:auto;margin-top:0;top:auto;transform:none}.side-rail-cluster{margin-top:0;transform:none;height:auto}.home-chat-shell{width:210px}.menu-panel.main-section{min-width:300px;padding:20px}.modal-panel.store-panel{width:95vw;max-height:93vh}.store-layout{grid-template-columns:280px 1fr;height:auto;max-height:76vh}}@media (max-width:768px){#matchmaking-lobby{background:#0f172a;overscroll-behavior-y:none}#matchmaking-lobby .modal-panel.wide{background:#1e293b;overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch}#setup-menu{padding:0;top:0;padding-top:var(--hourly-race-mobile-offset,0px);align-items:stretch;background:#0f172a;overscroll-behavior-y:none;box-sizing:border-box}.bg-ready #setup-menu{animation:none;background:#0f172a}header{height:20px;padding:0 10px}.header-title{font-size:0.85rem}.header-controls{gap:5px}.header-controls .btn{padding:6px 10px;font-size:0.7rem}.racer-card{min-width:100px;max-width:100px;flex-shrink:0;padding:4px 6px;font-size:0.65rem}.racer-card .top-info{font-size:0.6rem}.racer-card .sub-info{font-size:0.55rem;display:none}.racer-card .hp-track{height:2px}#game-area{margin-top:0}#game-area{border-radius:5px}.menu-panel{padding:20px;width:95%;max-width:400px}.menu-panel h1{font-size:1.5rem}.big-btn{padding:12px;font-size:1rem}.menu-layout-wrapper{position:relative;inset:auto;flex-direction:column;width:100%;max-width:none;height:auto;min-height:0;max-height:none;padding:0;overflow-y:auto;overflow-x:hidden;background:#0f172a;overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch}.side-settings-panel{width:100%;height:auto;margin-top:0;top:auto;transform:none;border-radius:0;padding:14px 16px 16px;border-left:0;border-right:0;box-shadow:inset 0 1px 0 rgba(255,255,255,0.04);order:2}.side-settings-panel .settings-content{flex:0 0 auto;overflow:visible;padding:2px 0 0}.menu-panel{width:100%;max-width:none;margin:0;border-radius:0}.menu-panel.main-section{min-width:100%;width:100%;border-radius:0;padding:20px 16px 18px;border-left:0;border-right:0;box-shadow:none;order:1}.side-rail-cluster{width:100%;display:flex;flex-direction:column;gap:0;margin-top:0;transform:none;height:auto;order:3}.side-leaderboard-panel{width:100%;height:auto;max-height:none;min-height:0;margin-top:0;transform:none;border-radius:0;padding:10px 12px 0;border-left:0;border-right:0;order:1;overflow:visible;margin-bottom:0}.side-leaderboard-panel .leaderboard-list{max-height:min(48vh,410px)}.activity-ticker-band{position:static;left:auto;bottom:auto;transform:none;width:100%;align-self:stretch;flex:0 0 auto;order:4;margin-top:0;margin-bottom:0;grid-template-columns:1fr;gap:8px;padding:10px 12px max(12px,env(safe-area-inset-bottom,0px));border-radius:0;border-left:0;border-right:0;z-index:auto}.activity-ticker-label{justify-self:start}.home-chat-shell{width:100%;max-height:none;margin-left:0;margin-top:-1px;border-radius:0;border-top:0;order:2}.home-chat-list{min-height:120px;max-height:min(22vh,190px)}.home-chat-compose{max-height:none;flex:0 0 auto}.home-chat-shell.is-collapsed{width:100%}.home-chat-shell::before{display:none}.side-leaderboard-panel h4{font-size:0.8rem;margin-bottom:8px}.side-lb-item{padding:4px 6px;font-size:0.7rem}.side-lb-rank{width:18px;height:18px;font-size:0.6rem}.side-lb-live-rank{top:-5px;left:-5px;width:13px;height:13px;font-size:0.49rem}.side-lb-country{width:16px;height:16px}.detail-country-flag{width:28px;height:28px}.side-settings-panel .track-options.vertical{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.side-settings-panel .track-card{flex:0 0 auto;min-width:0;padding:4px 3px}.side-settings-panel .track-card .t-icon{font-size:0.82rem}.side-settings-panel .track-card span{font-size:0.5rem;line-height:1.05;margin-bottom:0.15rem}.side-settings-panel .track-card canvas.track-mini{width:34px;height:22px}.modal-panel{width:95%;max-width:360px;padding:20px}.modal-panel.wide{max-width:95%}.modal-panel.store-panel{width:100%;max-width:100%;max-height:100dvh;height:100dvh;border-radius:0;overflow:hidden}.store-layout{display:flex;flex-direction:column;grid-template-columns:none;height:100%;min-height:0}.store-left{order:1;flex:0 0 min(23vh,220px);max-height:min(23vh,220px);overflow-y:auto;border-right:none;border-bottom:1px solid rgba(255,255,255,0.05);border-top:none}.store-right{order:2;flex:1 1 auto;min-height:0;max-height:none;display:flex;flex-direction:column;overflow:hidden;min-height:min(70vh,560px)}#store-content-area{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding-bottom:max(16px,env(safe-area-inset-bottom,0px))}.vehicle-preview{height:74px}.shop-grid{grid-template-columns:repeat(2,1fr);gap:8px}.shop-group{padding:14px;border-radius:12px}.shop-group-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.visuals-color-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.shop-group-single .shop-group-grid{grid-template-columns:minmax(0,1fr)}.shop-group-headlights .shop-group-grid{grid-template-columns:1fr}.item-card{padding:8px}.item-icon{font-size:1.2rem}.item-name{font-size:0.8rem}.tabs{position:sticky;top:0;z-index:3;flex-wrap:wrap;margin:0 0 12px;padding:8px 0 8px;background:linear-gradient(180deg,rgba(15,23,42,0.98) 0%,rgba(15,23,42,0.92) 100%)}.tab-btn{padding:8px 12px;font-size:0.85rem}.lobby-grid{grid-template-columns:1fr}.cookie-banner{flex-direction:column;gap:10px;padding:15px;text-align:center}.cookie-text{font-size:0.75rem}#site-footer{height:28px;font-size:0.65rem;padding:0 10px;flex-wrap:wrap;justify-content:center;gap:5px}#end-title{font-size:1.5rem}.leaderboard-container{width:95%;padding:8px}.lb-row{padding:8px;font-size:0.8rem}.traffic-light{gap:10px;padding:10px}.light{width:35px;height:35px}#go-text{font-size:4rem}#joystick-zone{width:100px;height:100px;bottom:20px;right:118px}#joystick-stick{width:40px;height:40px}#nitro-btn{width:65px;height:65px;bottom:25px;left:20px;font-size:1rem}#fire-btn{width:60px;height:60px;bottom:100px;left:80px;font-size:1.2rem}#oil-btn{width:55px;height:55px;bottom:165px;left:60px;font-size:0.8rem}#mobile-ui.left-mode #joystick-zone{left:20px}#mobile-ui.left-mode #nitro-btn{right:20px}#mobile-ui.left-mode #fire-btn{left:auto;right:80px}#mobile-ui.left-mode #oil-btn{left:auto;right:60px}#lights-btn{width:45px;height:45px;bottom:100px;left:20px;font-size:1.1rem}#mobile-ui.left-mode #lights-btn{left:auto;right:20px}.afk-popup-content{padding:20px 25px}.afk-popup .afk-icon{font-size:2.5rem}.afk-popup h3{font-size:1.2rem}}@media (max-width:375px){.menu-panel{padding:15px}.menu-panel h1{font-size:1.3rem}.big-btn{padding:10px;font-size:0.9rem}.btn.sm{padding:5px 8px;font-size:0.7rem}#joystick-zone{width:85px;height:85px;bottom:15px;right:92px}#joystick-stick{width:35px;height:35px}#nitro-btn{width:55px;height:55px;bottom:20px;left:15px;font-size:0.85rem}#fire-btn{width:50px;height:50px;bottom:80px;left:70px;font-size:1.1rem}#oil-btn{width:45px;height:45px;bottom:135px;left:55px;font-size:0.75rem}#mobile-ui.left-mode #fire-btn{left:auto;right:70px}#mobile-ui.left-mode #oil-btn{left:auto;right:55px}#lights-btn{bottom:80px;left:15px}#mobile-ui.left-mode #lights-btn{left:auto;right:15px}.shop-grid{grid-template-columns:1fr}.shop-group-grid{grid-template-columns:1fr}.visuals-paint-actions{grid-template-columns:46px minmax(0,1fr);gap:8px}.custom-color-picker{width:46px;height:36px}.headlight-customizer-actions{grid-template-columns:46px minmax(0,1fr);gap:8px}.headlight-color-picker{width:46px;height:36px}.neon-color-picker{width:46px;height:36px}}body.racing main{flex-direction:row}body.racing aside{position:static;width:165px;max-height:none;height:auto;overflow:auto;padding:7px;background:var(--panel-bg);backdrop-filter:none;border:1px solid #334155}body.racing #racer-list{display:flex;flex-direction:column;gap:5px;overflow-y:auto;overflow-x:hidden}@media (max-width:900px){body.racing aside{width:105px;height:calc(100vh - 62px);max-height:calc(100vh - 62px);min-height:0;overflow:hidden}body.racing .panel-header{font-size:0.6rem}body.racing #racer-list{flex:1 1 auto;min-height:0;padding-right:2px;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}body.racing .racer-card{min-width:auto;max-width:100%;padding:4px 5px;font-size:0.6rem}body.racing .top-info{font-size:0.6rem}body.racing .sub-info{display:flex;flex-direction:column;align-items:flex-start;gap:1px;font-size:0.5rem}body.racing .xp-badge{font-size:0.5rem}body.racing .info-box{font-size:0.55rem}body.racing .hp-track{height:4px}}.direction-option{display:flex;align-items:center;justify-content:center;flex-direction:row;cursor:pointer;padding:4px 8px;min-width:20px;border-radius:10px;border:1px solid #334155;background:transparent;overflow:hidden;transition:all 0.2s ease}.direction-option:hover{border-color:#facc15}.direction-option.selected{border-color:var(--accent);border-width:1px;background:rgba(245,158,11,0.18)}.direction-arrows{display:flex;justify-content:center;align-items:center;height:16px;overflow:hidden;position:relative}.direction-arrows .arrow{font-size:13px;font-weight:bold;color:#facc15;display:inline-block;margin:0 1px;animation:none}.direction-option.selected .direction-arrows.rtl .arrow,.direction-option:hover .direction-arrows.rtl .arrow{animation:dirSlideRight 1.4s infinite linear}.direction-option.selected .direction-arrows.ltr .arrow,.direction-option:hover .direction-arrows.ltr .arrow{animation:dirSlideLeft 1.4s infinite linear}.direction-option .direction-arrows .arrow:nth-child(1){animation-delay:0s}.direction-option .direction-arrows .arrow:nth-child(2){animation-delay:0.15s}.direction-option .direction-arrows .arrow:nth-child(3){animation-delay:0.30s}.weather-options{display:flex;align-items:center;justify-content:flex-start;gap:6px;margin-top:0}.time-of-day-options{display:flex;align-items:center;justify-content:flex-start;gap:6px;margin-top:0}.time-of-day-option{position:relative;flex:0 0 auto;width:32px;height:32px;padding:0;font-size:0.75rem;border-radius:999px;border:1px solid #1e293b;background:#020617;color:#cbd5f5;cursor:pointer;letter-spacing:0;font-weight:600;display:flex;align-items:center;justify-content:center;gap:0;transition:all 0.15s ease}.time-of-day-option:hover{border-color:#facc15;background:rgba(250,204,21,0.08);z-index:9999}.time-of-day-option.selected{border-color:var(--accent);background:rgba(245,158,11,0.18);color:#fde68a;box-shadow:0 0 12px rgba(250,204,21,0.2)}.time-of-day-option[data-time-of-day="night"]{color:#c4b5fd}.time-of-day-option[data-time-of-day="night"].selected{border-color:#a78bfa;background:rgba(79,70,229,0.22);color:#e9d5ff;box-shadow:0 0 12px rgba(129,140,248,0.22)}.weather-option{position:relative;flex:0 0 auto;width:32px;height:32px;padding:0;font-size:0.75rem;border-radius:999px;border:1px solid #1e293b;background:#020617;color:#cbd5f5;cursor:pointer;text-transform:uppercase;letter-spacing:0;font-weight:600;display:flex;align-items:center;justify-content:center;gap:0;transition:all 0.15s ease}.weather-option:hover{border-color:#facc15;background:rgba(250,204,21,0.08);z-index:9999}.weather-option.selected{border-color:var(--accent);background:rgba(245,158,11,0.18);color:#fde68a;box-shadow:0 0 12px rgba(250,204,21,0.2)}.weather-group{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:4px}.weather-group>label{margin-bottom:0;white-space:nowrap}.time-of-day-group{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:4px}.time-of-day-group>label{margin-bottom:0;white-space:nowrap}.time-of-day-icon{position:relative;display:inline-block;font-size:1.1rem;line-height:1}.time-of-day-option[data-time-of-day="night"] .time-of-day-icon::before,.time-of-day-option[data-time-of-day="night"] .time-of-day-icon::after{content:'✦';position:absolute;color:#f8fafc;line-height:1;opacity:0.9;text-shadow:0 0 4px rgba(248,250,252,0.22)}.time-of-day-option[data-time-of-day="night"] .time-of-day-icon{transform:translateX(-2px)}.time-of-day-option[data-time-of-day="night"] .time-of-day-icon::before{top:2px;right:-7px;font-size:0.34rem;text-shadow:0 0 4px rgba(248,250,252,0.22),-5px 3px 0 rgba(248,250,252,0.9)}.time-of-day-option[data-time-of-day="night"] .time-of-day-icon::after{top:7px;right:-7px;font-size:0.26rem}.time-of-day-copy{display:none}.weather-icon{font-size:1.1rem;line-height:1}.weather-icon-sun-moon{position:relative;display:inline-block;width:30px;height:30px;line-height:1;overflow:hidden;transform:none;border-radius:999px;box-shadow:inset 0 0 0 1px rgba(226,232,240,0.08)}.weather-icon-sun-moon::before{content:'';position:absolute;inset:0;background:linear-gradient(118deg,#3b82f6 0%,#60a5fa 32%,#72a8e6 41%,#57759a 48%,#314767 54%,#0f172a 64%,#020617 100%)}.weather-icon-sun-moon::after{content:'';position:absolute;inset:0;border-radius:999px;background:linear-gradient(180deg,rgba(255,255,255,0.14) 0%,rgba(255,255,255,0.02) 45%,rgba(2,6,23,0.14) 100%);pointer-events:none}.weather-option[data-weather="sunny"]{overflow:hidden}.weather-option[data-weather="sunny"] .weather-icon-sun-moon{position:absolute;inset:1px;width:auto;height:auto;border-radius:inherit}.weather-icon-sun{position:absolute;left:4px;top:5px;z-index:1;font-size:0.72rem;line-height:1;color:#facc15;text-shadow:0 0 6px rgba(250,204,21,0.34)}.weather-icon-moon{position:absolute;right:4px;top:10px;z-index:1;font-size:0.72rem;line-height:1;color:#c4b5fd;text-shadow:0 0 6px rgba(196,181,253,0.3)}.time-of-day-option[data-tooltip]:hover::after,.weather-option[data-tooltip]:hover::after{content:attr(data-tooltip);position:absolute;bottom:135%;left:50%;transform:translateX(-50%);background:#1e293b;color:#e2e8f0;padding:8px 10px;border-radius:6px;font-size:0.7rem;font-weight:normal;white-space:normal;width:190px;text-align:center;box-shadow:0 4px 12px rgba(0,0,0,0.4);border:1px solid #475569;z-index:9999;line-height:1.4}.time-of-day-option[data-tooltip]:hover::before,.weather-option[data-tooltip]:hover::before{content:'';position:absolute;bottom:118%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:#1e293b;z-index:9999}@keyframes dirSlideRight{0%{transform:translateX(-20px);opacity:0}10%{opacity:1}90%{opacity:1}100%{transform:translateX(20px);opacity:0}}@keyframes dirSlideLeft{0%{transform:translateX(20px);opacity:0}10%{opacity:1}90%{opacity:1}100%{transform:translateX(-20px);opacity:0}}#hourly-race-widget-slot{display:none;width:100%;min-width:0;box-sizing:border-box}.hourly-race-widget{position:fixed;top:20px;left:20px;background:linear-gradient(135deg,#1a1a2e 0%,#16213e 100%);border:2px solid #f59e0b;border-radius:12px;padding:12px 16px;z-index:1001;min-width:160px;box-shadow:0 4px 20px rgba(245,158,11,0.3),inset 0 1px 0 rgba(255,255,255,0.1);cursor:help;transition:transform 0.2s,box-shadow 0.2s,opacity 0.3s;display:none}.hourly-race-widget:hover{transform:translateY(-2px);box-shadow:0 6px 25px rgba(245,158,11,0.4),inset 0 1px 0 rgba(255,255,255,0.1)}.hourly-race-widget.is-collapsed{min-width:0;padding:10px 12px;cursor:default}.hourly-race-widget.is-collapsed:hover{transform:none}.hourly-race-widget.is-collapsed .hourly-race-tooltip,.hourly-race-widget.is-collapsed .hourly-join-btn{display:none}.hourly-race-widget.is-collapsed .hourly-race-countdown{margin:0;text-align:left}.hourly-race-widget.is-collapsed #hourly-countdown-timer{display:inline-block;font-size:1rem}.hourly-race-widget.is-collapsed:hover .hourly-race-tooltip{opacity:0;visibility:hidden;transform:translateY(-10px)}.hourly-race-tooltip{position:absolute;top:100%;left:0;margin-top:10px;background:linear-gradient(135deg,#1a1a2e 0%,#0f0f1a 100%);border:2px solid #f59e0b;border-radius:10px;padding:12px 16px;min-width:260px;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all 0.3s ease;z-index:200;box-shadow:0 8px 30px rgba(0,0,0,0.5),0 0 20px rgba(245,158,11,0.2);pointer-events:none}.hourly-race-tooltip::before{content:'';position:absolute;top:-8px;left:20px;width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:8px solid #f59e0b}.hourly-race-tooltip::after{content:'';position:absolute;top:-5px;left:22px;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:6px solid #1a1a2e}.hourly-race-widget:hover .hourly-race-tooltip{opacity:1;visibility:visible;transform:translateY(0)}.tooltip-title{font-size:0.85rem;font-weight:700;color:#f59e0b;text-align:center;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid rgba(245,158,11,0.3);letter-spacing:1px}.tooltip-row{display:flex;align-items:center;gap:8px;font-size:0.75rem;color:#e2e8f0;margin:6px 0}.tooltip-medal{font-size:1rem;width:24px;text-align:center}.tooltip-note{font-size:0.65rem;color:#94a3b8;text-align:center;margin-top:10px;padding-top:8px;border-top:1px solid rgba(148,163,184,0.2);font-style:italic}.tooltip-note.tooltip-warning{color:#f59e0b;border-top:none;margin-top:6px;padding-top:0}.gold-coin-mini{display:inline-block;width:12px;height:12px;background:linear-gradient(135deg,#ffd700 0%,#ffb300 50%,#ff8c00 100%);border-radius:50%;vertical-align:middle;margin-right:2px;box-shadow:0 1px 2px rgba(0,0,0,0.3),inset 0 1px 1px rgba(255,255,255,0.5)}.hourly-test-btn{position:absolute;top:5px;right:40px;padding:2px 6px;font-size:0.6rem;background:#ef4444;border:none;color:#fff;cursor:pointer;z-index:5}.hourly-test-btn:hover{background:#dc2626}.hourly-race-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;padding-right:36px}.hourly-race-icon{font-size:1.2rem;animation:pulse-glow 2s infinite}@keyframes pulse-glow{0%,100%{filter:drop-shadow(0 0 3px #f59e0b)}50%{filter:drop-shadow(0 0 8px #f59e0b)}}.hourly-race-title{font-size:0.75rem;font-weight:700;color:#f59e0b;letter-spacing:1px}.hourly-race-toggle{position:absolute;top:8px;right:8px;z-index:20;display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;padding:0;border:1px solid rgba(248,113,113,0.45);border-radius:999px;background:rgba(239,68,68,0.16);color:#f8fafc;font-size:1.1rem;font-weight:700;line-height:1;cursor:pointer;pointer-events:auto;transition:background 0.2s ease,border-color 0.2s ease,transform 0.2s ease}.hourly-race-toggle:hover{background:rgba(239,68,68,0.28);border-color:rgba(248,113,113,0.78);transform:scale(1.05)}.hourly-race-toggle:focus-visible{outline:2px solid rgba(248,113,113,0.9);outline-offset:2px}.hourly-race-countdown{text-align:center;margin:8px 0}#hourly-countdown-timer{font-size:1.8rem;font-weight:700;color:#fff;font-family:'Courier New',monospace;text-shadow:0 0 10px rgba(245,158,11,0.5)}.hourly-race-widget.join-open #hourly-countdown-timer{color:#22c55e;animation:countdown-pulse 1s infinite}@keyframes countdown-pulse{0%,100%{opacity:1}50%{opacity:0.7}}.hourly-race-info{text-align:center;font-size:0.7rem;color:#94a3b8;margin-bottom:8px}.hourly-join-btn{width:100%;padding:8px 12px;font-size:0.8rem;font-weight:700;background:linear-gradient(135deg,#374151 0%,#1f2937 100%);border:1px solid #4b5563;color:#6b7280;cursor:not-allowed;transition:all 0.3s}.hourly-join-btn:not(:disabled){background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);border-color:#f59e0b;color:#000;cursor:pointer;animation:join-ready 0.5s ease-out}.hourly-join-btn:not(:disabled):hover{background:linear-gradient(135deg,#fbbf24 0%,#f59e0b 100%);transform:scale(1.02)}.hourly-join-btn.joined{background:linear-gradient(135deg,#22c55e 0%,#16a34a 100%);border-color:#22c55e;color:#fff}.hourly-join-btn.pulse-success{animation:pulse-success 0.5s ease-out}@keyframes pulse-success{0%{transform:scale(1);box-shadow:0 0 0 0 rgba(34,197,94,0.7)}50%{transform:scale(1.05);box-shadow:0 0 0 10px rgba(34,197,94,0)}100%{transform:scale(1);box-shadow:0 0 0 0 rgba(34,197,94,0)}}.hourly-race-widget.race-imminent{border-color:#22c55e;animation:race-imminent-pulse 1s infinite}@keyframes race-imminent-pulse{0%,100%{box-shadow:0 4px 20px rgba(34,197,94,0.3),inset 0 1px 0 rgba(255,255,255,0.1)}50%{box-shadow:0 4px 30px rgba(34,197,94,0.6),inset 0 1px 0 rgba(255,255,255,0.1)}}#hourly-countdown-timer.race-starting{color:#22c55e;animation:race-starting-blink 0.5s infinite}@keyframes race-starting-blink{0%,100%{opacity:1}50%{opacity:0.5}}@keyframes join-ready{0%{transform:scale(0.95)}50%{transform:scale(1.05)}100%{transform:scale(1)}}.player-medals{display:inline-flex;gap:4px;margin-left:6px;vertical-align:middle}.medal{position:relative;display:inline-flex;align-items:center;justify-content:center;margin-left:3px;width:18px;height:18px;font-size:0.75rem;border-radius:50%}.medal-gold{background:linear-gradient(135deg,#ffd700 0%,#ffb300 100%);box-shadow:0 2px 4px rgba(255,215,0,0.4)}.medal-silver{background:linear-gradient(135deg,#c0c0c0 0%,#a8a8a8 100%);box-shadow:0 2px 4px rgba(192,192,192,0.4)}.medal-bronze{background:linear-gradient(135deg,#cd7f32 0%,#b87333 100%);box-shadow:0 2px 4px rgba(205,127,50,0.4)}.medal-count{position:absolute;top:-4px;right:-4px;background:#1f2937;color:#fff;font-size:0.5rem;font-weight:700;min-width:12px;height:12px;border-radius:6px;display:flex;align-items:center;justify-content:center;border:1px solid #374151}.medal[title]{cursor:help}.hourly-race-result{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:linear-gradient(135deg,#1a1a2e 0%,#16213e 100%);border:3px solid #f59e0b;border-radius:20px;padding:30px 50px;text-align:center;z-index:1000;animation:result-popup 0.5s ease-out}@keyframes result-popup{0%{transform:translate(-50%,-50%) scale(0.5);opacity:0}100%{transform:translate(-50%,-50%) scale(1);opacity:1}}.hourly-race-result h2{font-size:1.5rem;color:#f59e0b;margin-bottom:15px}.hourly-race-result .medal-earned{font-size:4rem;margin:15px 0}.hourly-race-result .reward-text{font-size:1rem;color:#94a3b8}.spectator-cheer-menu{position:fixed;left:0;top:0;z-index:1400;display:none;gap:6px;min-width:152px;padding:8px;border:1px solid rgba(245,158,11,0.38);border-radius:14px;background:linear-gradient(180deg,rgba(15,23,42,0.98) 0%,rgba(17,24,39,0.96) 100%);box-shadow:0 18px 34px rgba(2,6,23,0.42);backdrop-filter:blur(10px)}.spectator-cheer-menu.is-visible{display:grid}.spectator-cheer-option{min-width:0;padding:9px 12px;border:1px solid rgba(71,85,105,0.76);border-radius:10px;background:rgba(30,41,59,0.92);color:#f8fafc;font-size:0.75rem;font-weight:800;letter-spacing:0.06em;text-align:left;cursor:pointer;transition:transform 0.12s ease,border-color 0.12s ease,background 0.12s ease}.spectator-cheer-option:hover{border-color:rgba(245,158,11,0.92);background:rgba(51,65,85,0.98);transform:translateY(-1px)}.spectator-cheer-option:focus-visible{outline:2px solid rgba(56,189,248,0.95);outline-offset:2px}@media (max-width:768px){.ios-home-banner{width:100%;padding:11px 12px;border-radius:14px;align-items:flex-start;flex-direction:column}.ios-home-banner-title{font-size:0.72rem}.ios-home-banner-text{font-size:0.82rem;line-height:1.4}.ios-home-banner-dismiss{width:100%;height:36px}.ios-home-banner-actions{width:100%;flex-direction:column;gap:8px}.ios-home-banner-share{width:100%;height:36px}#hourly-race-widget-slot{display:none;position:relative;top:auto;left:auto;width:100%;min-width:0;flex:0 0 auto;align-self:stretch;justify-content:center;padding:8px 0;background:#0f172a;z-index:1001;box-sizing:border-box}.hourly-race-widget{position:relative;top:auto;right:auto;bottom:auto;left:auto;width:calc(100% - 20px);max-width:none;margin:0 10px;padding:12px 14px;min-width:0}#hourly-countdown-timer{font-size:1.4rem}.hourly-race-title{font-size:0.65rem}.hourly-race-widget.is-collapsed{padding:8px 10px}.hourly-race-widget.is-collapsed #hourly-countdown-timer{font-size:0.95rem}.hourly-race-tooltip{top:100%;bottom:auto;margin-top:10px;margin-bottom:0;min-width:min(220px,calc(100vw - 32px));left:0}.hourly-race-tooltip::before{top:-8px;bottom:auto;border-bottom:8px solid #f59e0b;border-top:none}.hourly-race-tooltip::after{top:auto;bottom:-5px;border-bottom:none;border-top:6px solid #1a1a2e}}