:root{--primary:#eb6623;--primary-glow:#eb662366;--primary-dark:#c9541a;--primary-light:#ff8042;--bg-dark:#0a0a0f;--bg-card:#ffffff08;--bg-glass:#ffffff0d;--text-primary:#fff;--text-secondary:#fff9;--text-muted:#fff6;--border-glass:#ffffff1a;--success:#22c55e;--danger:#ef4444}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-tap-highlight-color:transparent;font-size:16px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0a0a0f;background:var(--bg-dark);color:#fff;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100vh;min-height:100dvh;overflow-x:hidden;position:relative}body:before{background:radial-gradient(ellipse 80% 50% at 50% -20%,#eb662366,#0000),radial-gradient(ellipse 60% 40% at 100% 100%,#eb662326,#0000);background:radial-gradient(ellipse 80% 50% at 50% -20%,var(--primary-glow),#0000),radial-gradient(ellipse 60% 40% at 100% 100%,#eb662326,#0000);bottom:0;content:"";left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:0}#root{min-height:100vh;min-height:100dvh;position:relative;z-index:1}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}@keyframes glow{0%,to{box-shadow:0 0 20px #eb662366;box-shadow:0 0 20px var(--primary-glow)}50%{box-shadow:0 0 40px #eb662366,0 0 60px #eb662333;box-shadow:0 0 40px var(--primary-glow),0 0 60px #eb662333}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@keyframes ripple{0%{opacity:.5;transform:scale(0)}to{opacity:0;transform:scale(4)}}.glass{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#ffffff0d;background:var(--bg-glass);border:1px solid #ffffff1a;border:1px solid var(--border-glass);border-radius:20px}.btn{-webkit-tap-highlight-color:transparent;align-items:center;border:none;border-radius:14px;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:8px;justify-content:center;overflow:hidden;padding:14px 28px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn:before{background:linear-gradient(135deg,#ffffff1a,#0000 50%);content:"";inset:0;opacity:0;position:absolute;transition:opacity .3s}.btn:active:before{opacity:1}.btn-primary{background:linear-gradient(135deg,#eb6623,#c9541a);background:linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);box-shadow:0 4px 20px #eb662366;box-shadow:0 4px 20px var(--primary-glow);color:#fff}.btn-primary:hover{box-shadow:0 8px 30px #eb662366;box-shadow:0 8px 30px var(--primary-glow);transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;background:var(--bg-glass);border:1px solid #ffffff1a;border:1px solid var(--border-glass);color:#fff;color:var(--text-primary)}.btn-secondary:hover{background:#ffffff1a;border-color:#fff3}.btn:disabled{cursor:not-allowed;opacity:.5;transform:none!important}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:400;src:url(https://fonts.gstatic.com/s/inter/v13/UcCO3FwrK3iLTeHuS_fvQtMwCp50KnMw2boKoduKmMEVuLyfAZ9hiJ-Ek-_EeA.woff2) format("woff2")}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:600;src:url(https://fonts.gstatic.com/s/inter/v13/UcCO3FwrK3iLTeHuS_fvQtMwCp50KnMw2boKoduKmMEVuI-fAZ9hiJ-Ek-_EeA.woff2) format("woff2")}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:700;src:url(https://fonts.gstatic.com/s/inter/v13/UcCO3FwrK3iLTeHuS_fvQtMwCp50KnMw2boKoduKmMEVuFuYAZ9hiJ-Ek-_EeA.woff2) format("woff2")}.app{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;padding:0;position:relative}.app-container{display:flex;flex:1 1;flex-direction:column;margin:0 auto;max-width:480px;padding:20px 20px 100px;width:100%}.nav-back{background:linear-gradient(to top,var(--bg-dark) 60%,#0000);bottom:0;left:0;padding:16px 20px max(16px,env(safe-area-inset-bottom));position:fixed;right:0;z-index:100}.nav-back .btn{display:flex;margin:0 auto;max-width:480px;width:100%}.header{animation:fadeIn .6s ease-out;padding:30px 0 40px;text-align:center}.logo{align-items:center;display:flex;gap:12px;justify-content:center;margin-bottom:8px}.logo-icon{animation:float 3s ease-in-out infinite;background:linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);border-radius:14px;box-shadow:0 4px 20px var(--primary-glow);font-size:24px;height:48px;width:48px}.logo-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--text-primary) 0,var(--text-secondary) 100%);-webkit-background-clip:text;background-clip:text;font-size:1.75rem}.app-header{display:flex;justify-content:flex-end;margin-bottom:10px;padding:10px 0}.header-user{align-items:center;display:flex;gap:12px}.user-email{color:var(--text-muted);font-size:.85rem}.avatar-button{background:none;border:none;cursor:pointer;padding:0}.header-avatar{border:2px solid var(--primary);border-radius:50%;height:36px;object-fit:cover;width:36px}.header-avatar-placeholder{align-items:center;background:linear-gradient(135deg,var(--primary),#ff8a50);border-radius:50%;color:#fff;display:flex;font-size:1rem;font-weight:600;height:36px;justify-content:center;width:36px}.user-name{color:var(--text-primary);font-size:.9rem;font-weight:500}.logo-subtitle{color:var(--text-muted);font-size:.85rem;letter-spacing:2px;text-transform:uppercase}.view-transition-enter{animation:slideUp .4s ease-out}.landing{min-height:100vh;overflow-x:hidden;position:relative}.landing-bg{inset:0;pointer-events:none;position:fixed;z-index:0}.landing-orb{border-radius:50%;filter:blur(100px);opacity:.4;position:absolute}.landing-orb-1{animation:orbFloat 8s ease-in-out infinite;background:var(--primary);height:400px;right:-100px;top:-100px;width:400px}.landing-orb-2{animation:orbFloat 10s ease-in-out infinite reverse;background:var(--secondary);bottom:20%;height:300px;left:-100px;width:300px}.landing-orb-3{animation:orbFloat 12s ease-in-out infinite;background:var(--primary);bottom:-50px;height:200px;right:30%;width:200px}@keyframes orbFloat{0%,to{transform:translate(0) scale(1)}50%{transform:translate(30px,-30px) scale(1.1)}}.landing-header{justify-content:space-between;padding:20px;position:relative;z-index:10}.landing-header,.landing-logo{align-items:center;display:flex}.landing-logo{gap:10px}.logo-icon{align-items:center;background:var(--primary);border-radius:10px;display:flex;font-size:20px;height:40px;justify-content:center;width:40px}.logo-text{font-size:1.5rem;font-weight:700}.btn-outline,.logo-text{color:var(--text-primary)}.btn-outline{background:#0000;border:1px solid #fff3;border-radius:10px;cursor:pointer;font-weight:500;padding:10px 20px;transition:all .2s}.btn-outline:hover{background:#ffffff1a;border-color:var(--primary)}.landing-hero{display:flex;flex-direction:column;gap:40px;padding:40px 20px 60px;position:relative;z-index:5}.hero-content{text-align:center}.hero-title{color:var(--text-primary);font-size:2.5rem;font-weight:800;line-height:1.1;margin:0 0 20px}.text-gradient{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#eb6623,#ff8042);-webkit-background-clip:text;background-clip:text;color:#eb6623}.hero-subtitle{color:var(--text-secondary);font-size:1.1rem;line-height:1.6;margin:0 auto 30px;max-width:400px}.hero-cta{align-items:center;display:flex;flex-direction:column;gap:10px}.hero-note{color:var(--text-muted);font-size:.8rem}.hero-visual{display:flex;justify-content:center}.phone-mockup{background:var(--bg-card);border:1px solid var(--border-glass);border-radius:30px;box-shadow:0 30px 60px #00000080;height:400px;padding:10px;width:200px}.phone-mockup,.phone-screen{overflow:hidden;position:relative}.phone-screen{background:var(--bg-dark);border-radius:22px;height:100%;width:100%}.mockup-beat{animation:beatDrop 2s ease-in infinite;background:var(--primary);border-radius:50%;box-shadow:0 0 20px var(--primary-glow);height:30px;left:50%;position:absolute;transform:translateX(-50%);width:30px}.mockup-beat-2{animation-delay:.5s;left:25%}.mockup-beat-3{animation-delay:1s;left:75%}@keyframes beatDrop{0%{opacity:1;top:-30px}80%{opacity:1}to{opacity:0;top:100%}}.mockup-lane{background:var(--primary);bottom:60px;box-shadow:0 0 20px var(--primary-glow);height:3px;left:10%;position:absolute;right:10%}.landing-features{grid-gap:30px;display:grid;gap:30px;grid-template-columns:1fr;padding:60px 20px;position:relative;z-index:5}.feature{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:var(--bg-glass);border:1px solid var(--border-glass);border-radius:20px;padding:30px;text-align:center}.feature-icon{font-size:2.5rem;margin-bottom:15px}.feature h3{color:var(--text-primary);font-size:1.2rem;margin:0 0 10px}.feature p{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:0}.landing-artists{background:linear-gradient(180deg,#0000,#eb66231a,#0000);padding:60px 20px;position:relative;text-align:center;z-index:5}.landing-artists h2{color:var(--text-primary);font-size:1.8rem;margin:0 0 15px}.landing-artists p{color:var(--text-secondary);font-size:1rem;line-height:1.6;margin:0 auto 25px;max-width:400px}.landing-footer{border-top:1px solid var(--border-glass);padding:30px 20px;position:relative;text-align:center;z-index:5}.landing-footer p{color:var(--text-muted);font-size:.85rem;margin:0}.header-right{align-items:center;display:flex;gap:12px}.lang-switcher{background:#ffffff0d;border-radius:8px;display:flex;overflow:hidden}.lang-btn-sm{background:#0000;border:none;color:#ffffff80;cursor:pointer;font-size:.75rem;font-weight:600;padding:6px 10px;transition:all .2s ease}.lang-btn-sm.active{background:var(--primary);color:#fff}.lang-btn-sm:hover:not(.active){color:#fff}@media (min-width:768px){.hero-title{font-size:3.5rem}.landing-features{grid-template-columns:repeat(3,1fr)}.phone-mockup{height:500px;width:250px}}.login{display:flex;flex-direction:column;min-height:100vh}.login-bg{inset:0;pointer-events:none;position:fixed;z-index:0}.login-orb{background:var(--primary);border-radius:50%;filter:blur(150px);height:400px;left:50%;opacity:.3;position:absolute;top:50%;transform:translate(-50%,-50%);width:400px}.login-header{align-items:center;display:flex;justify-content:space-between;padding:20px;position:relative;z-index:10}.login-header h1{color:var(--text-primary);font-size:1.2rem;margin:0}.login-content{align-items:center;display:flex;flex:1 1;justify-content:center;padding:20px;position:relative;z-index:5}.login-card{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:var(--bg-glass);border:1px solid var(--border-glass);border-radius:24px;max-width:400px;padding:40px 30px;text-align:center;width:100%}.login-icon{font-size:3rem;margin-bottom:20px}.login-card h2{color:var(--text-primary);font-size:1.5rem;margin:0 0 10px}.login-subtitle{color:var(--text-secondary);font-size:.95rem;line-height:1.5;margin:0 0 30px}.login-error{background:#ef44441a;border:1px solid #ef44444d;border-radius:10px;color:#ef4444}.login-error,.login-success{font-size:.9rem;margin-bottom:20px;padding:12px 16px}.login-success{background:#22c55e1a;border:1px solid #22c55e4d;border-radius:10px;color:#22c55e}.form-group{text-align:left}.form-group label{color:var(--text-secondary);font-size:.85rem;font-weight:500}.form-group input{background:#ffffff0d;border:1px solid var(--border-glass);border-radius:12px;color:var(--text-primary);font-size:1rem;padding:14px 16px;transition:all .2s;width:100%}.form-group input::placeholder{color:var(--text-muted)}.form-group input:focus{background:#ffffff14;border-color:var(--primary)}.btn-full{width:100%}.dev-token{background:#eb66231a;border:1px solid #eb66234d;border-radius:10px;margin-bottom:20px;padding:12px;text-align:left}.dev-token p{color:var(--text-muted);font-size:.75rem;margin:0 0 6px}.dev-token code{color:var(--primary);cursor:pointer;font-size:.8rem;word-break:break-all}.dev-token code:hover{text-decoration:underline}.btn-link{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.9rem;margin-top:16px;padding:8px;transition:color .2s ease;width:100%}.btn-link:hover{color:var(--primary)}.reset-success{text-align:center}.song-list{width:100%}.section-header{animation:fadeIn .5s ease-out .2s both;margin-bottom:24px}.section-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--text-primary) 0,var(--primary-light) 100%);-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700;margin-bottom:4px}.section-subtitle{color:var(--text-muted);font-size:.9rem}.loading{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.loading-spinner{animation:spin 1s linear infinite;border:3px solid var(--border-glass);border-radius:50%;border-top-color:var(--primary);height:40px;margin-bottom:16px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.songs-grid{display:flex;flex-direction:column;gap:12px}.song-card{align-items:center;animation:slideUp .5s ease-out both;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:var(--bg-glass);border:1px solid var(--border-glass);border-radius:16px;color:inherit;cursor:pointer;display:flex;font-family:inherit;gap:16px;overflow:hidden;padding:16px;position:relative;text-align:left;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.song-card:before{background:linear-gradient(135deg,var(--primary-glow) 0,#0000 50%);content:"";inset:0;opacity:0;position:absolute;transition:opacity .3s}.song-card:active:before,.song-card:hover:before{opacity:1}.song-card:hover{border-color:var(--primary);box-shadow:0 8px 32px #eb662326;transform:translateX(4px)}.song-card:active{transform:scale(.98)}.song-cover{background:linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);border-radius:12px;flex-shrink:0;height:64px;overflow:hidden;position:relative;width:64px}.song-cover img{height:100%;object-fit:cover;width:100%}.song-play-icon{align-items:center;background:#0006;color:#fff;display:flex;font-size:20px;inset:0;justify-content:center;opacity:0;position:absolute;transition:opacity .3s}.song-card:hover .song-play-icon{opacity:1}.song-info{flex:1 1;min-width:0;position:relative;z-index:1}.song-title{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-artist{color:var(--text-secondary);font-size:.85rem;margin-bottom:8px}.song-bpm,.song-lanes{background:#ffffff0d;border-radius:6px;color:var(--text-muted);font-size:.75rem;padding:4px 8px}.song-arrow{color:var(--primary);font-size:1.25rem;opacity:0;position:relative;transform:translateX(-10px);transition:all .3s;z-index:1}.song-card:hover .song-arrow{opacity:1;transform:translateX(0)}.game{display:flex;flex-direction:column;height:100vh;height:100dvh;margin:-20px;overflow:hidden;padding:0}.game-header{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:var(--bg-glass);border-bottom:1px solid var(--border-glass);gap:12px;padding:16px 20px;position:relative;z-index:10}.game-back,.game-header{align-items:center;display:flex}.game-back{background:#ffffff1a;border:none;border-radius:10px;color:var(--text-primary);cursor:pointer;font-size:18px;height:40px;justify-content:center;transition:all .2s;width:40px}.game-back:hover{background:#ffffff26}.game-title-wrap{flex:1 1;min-width:0}.game-title{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.game-artist{color:var(--text-muted);font-size:.8rem;margin:0}.game-bpm{background:#eb66231a;border-radius:8px;color:var(--primary);font-size:.75rem;font-weight:600;padding:6px 10px}.game-stats{background:linear-gradient(to bottom,var(--bg-glass),#0000);display:flex;gap:32px;justify-content:center;padding:16px 20px;position:relative;z-index:5}.stat{align-items:center;display:flex;flex-direction:column}.stat-value{color:var(--text-primary);font-size:1.75rem;font-weight:700;line-height:1}.stat-combo .stat-value{color:var(--primary);text-shadow:0 0 20px var(--primary-glow)}.stat-label{color:var(--text-muted);font-size:.7rem;letter-spacing:1px;margin-top:4px;text-transform:uppercase}.game-canvas-container{flex:1 1;overflow:hidden;position:relative;touch-action:none}.game-canvas{display:block;height:100%;touch-action:none;width:100%}.game-overlay{align-items:center;animation:fadeIn .3s ease-out;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#0a0a0fcc;display:flex;inset:0;justify-content:center;position:absolute}.btn-large{animation:pulse 2s ease-in-out infinite;border-radius:20px;font-size:1.25rem;padding:20px 40px}.countdown{align-items:center;animation:countdownPulse 1s ease-out;color:var(--primary);display:flex;font-size:6rem;font-weight:700;inset:0;justify-content:center;pointer-events:none;position:absolute;text-shadow:0 0 60px var(--primary-glow)}@keyframes countdownPulse{0%{opacity:0;transform:scale(1.5)}50%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.8)}}.hit-effect{animation:hitPop .3s ease-out forwards;color:var(--success);font-size:1rem;font-weight:700;pointer-events:none;position:absolute;text-shadow:0 0 10px currentColor;transform:translate(-50%,-50%)}.hit-perfect{color:var(--primary)}@keyframes hitPop{0%{opacity:1;transform:translate(-50%,-50%) scale(.5)}to{opacity:0;transform:translate(-50%,-100%) scale(1.2)}}.game-actions{background:linear-gradient(to top,var(--bg-dark),#0000);display:flex;justify-content:center;padding:16px 20px max(16px,env(safe-area-inset-bottom));position:relative;z-index:5}.game-actions .btn{min-width:160px}.game-background-effects{inset:0;overflow:hidden;pointer-events:none;position:fixed;z-index:0}.floating-shape{border-radius:30% 70% 70% 30%/30% 30% 70% 70%;filter:blur(40px);position:absolute;transition:all .5s ease-out}.hit-good{color:#4ade80}.results-container{align-items:center;background:linear-gradient(135deg,#0a0a0f,#1a1a2e);display:flex;justify-content:center;min-height:100vh;padding:20px}.results-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:24px;max-width:400px;padding:40px;text-align:center;width:100%}.results-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#eb6623,#ff8a50);-webkit-background-clip:text;background-clip:text;font-size:2rem;font-weight:700;margin-bottom:8px}.results-song{color:#fff9;font-size:1rem;margin-bottom:24px}.results-grade-container{margin-bottom:20px}.results-grade{align-items:center;animation:pulse-grade 2s ease-in-out infinite;border:4px solid;border-radius:50%;display:inline-flex;font-size:3rem;font-weight:800;height:100px;justify-content:center;width:100px}.grade-s{border-color:gold;box-shadow:0 0 30px #ffd70066;color:gold}.grade-a{border-color:#0f8;box-shadow:0 0 20px #00ff884d;color:#0f8}.grade-b{border-color:#0af;color:#0af}.grade-c{border-color:#f80;color:#f80}.grade-d{border-color:#f44;color:#f44}.grade-f{border-color:#888;color:#888}@keyframes pulse-grade{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.new-best-badge{animation:shine 2s ease-in-out infinite;background:linear-gradient(135deg,gold,#fa0);border-radius:20px;color:#000;display:inline-block;font-size:.9rem;font-weight:700;margin-bottom:20px;padding:8px 20px}@keyframes shine{0%,to{box-shadow:0 0 20px #ffd70066}50%{box-shadow:0 0 40px #ffd700cc}}.results-score{margin-bottom:24px}.score-label{color:#fff9;display:block;font-size:.9rem;margin-bottom:4px}.score-value{color:#fff;font-size:3rem;font-weight:800}.results-stats{background:#0003;border-radius:12px;margin-bottom:20px;padding:16px}.stat-row{display:flex;justify-content:space-between;padding:8px 0}.stat-row:not(:last-child){border-bottom:1px solid #ffffff1a}.stat-label{color:#fff9}.stat-value{color:#fff;font-weight:600}.results-hits{display:flex;gap:12px;margin-bottom:24px}.hit-stat{background:#0003;border-radius:12px;flex:1 1;padding:12px 8px;text-align:center}.hit-stat.perfect{border-bottom:3px solid #0f8}.hit-stat.good{border-bottom:3px solid #fa0}.hit-stat.miss{border-bottom:3px solid #f44}.hit-count{color:#fff;display:block;font-size:1.5rem;font-weight:700}.hit-label{color:#ffffff80;display:block;font-size:.75rem;margin-top:4px;text-transform:uppercase}.previous-best{color:#ffffff80;font-size:.85rem;margin-bottom:20px}.results-actions{display:flex;flex-direction:column;gap:12px}.results-actions .btn{border-radius:12px;cursor:pointer;font-size:1rem;font-weight:600;padding:14px;transition:all .2s ease;width:100%}.results-actions .btn-primary{background:linear-gradient(135deg,#eb6623,#ff8a50);border:none;color:#fff}.results-actions .btn-primary:hover{box-shadow:0 8px 20px #eb662366;transform:translateY(-2px)}.results-actions .btn-secondary{background:#ffffff1a;border:1px solid #fff3;color:#fff}.results-actions .btn-secondary:hover{background:#ffffff26}.results-actions .btn-outline{background:#0000;border:1px solid #fff3;color:#ffffffb3}.results-actions .btn-outline:hover{border-color:#fff6;color:#fff}.leaderboard{width:100%}.result-card{animation:slideUp .5s ease-out;background:linear-gradient(135deg,#eb662326,#eb66230d);border:1px solid #eb66234d;border-radius:24px;margin-bottom:32px;overflow:hidden;padding:32px 24px;position:relative;text-align:center}.result-card:before{background:linear-gradient(90deg,#0000,var(--primary),#0000);content:"";height:2px;left:0;position:absolute;right:0;top:0}.result-main{margin-bottom:24px}.result-score{-webkit-text-fill-color:#0000;animation:glow 2s ease-in-out infinite;background:linear-gradient(135deg,var(--primary-light) 0,var(--primary) 100%);-webkit-background-clip:text;background-clip:text;font-size:3.5rem;font-weight:700;line-height:1;margin-bottom:8px}.result-label{color:var(--text-muted);font-size:.9rem;letter-spacing:2px;text-transform:uppercase}.result-details{display:flex;gap:48px;justify-content:center}.result-stat{align-items:center;display:flex;flex-direction:column}.result-stat-value{color:var(--text-primary);font-size:1.5rem;font-weight:600}.result-stat-label{color:var(--text-muted);font-size:.75rem;letter-spacing:1px;margin-top:4px;text-transform:uppercase}.scores-section{animation:fadeIn .5s ease-out .2s both}.scores-title{color:var(--text-secondary);font-size:1rem;font-weight:600;margin-bottom:16px}.scores-list{display:flex;flex-direction:column;gap:8px}.score-item{align-items:center;animation:slideUp .4s ease-out both;background:var(--bg-glass);border:1px solid var(--border-glass);border-radius:12px;display:flex;gap:16px;padding:16px}.score-rank{color:var(--text-muted);font-size:.85rem;width:32px}.score-value{color:var(--text-primary);flex:1 1;font-size:1.1rem;font-weight:600}.score-combo{color:var(--primary);font-size:.85rem}.empty-state{align-items:center;animation:fadeIn .5s ease-out;display:flex;flex-direction:column;justify-content:center}.empty-icon{font-size:48px;opacity:.5}.empty-state h3{color:var(--text-secondary);font-size:1.25rem;margin-bottom:8px}.empty-state p{font-size:.9rem}.time-filters{display:flex;gap:8px;margin-bottom:20px;overflow-x:auto;padding-bottom:8px}.filter-btn{background:var(--bg-glass);border:1px solid var(--border-glass);border-radius:10px;color:var(--text-secondary);cursor:pointer;font-size:.85rem;font-weight:500;padding:10px 16px;transition:all .2s;white-space:nowrap}.filter-btn:hover{background:#ffffff1a}.filter-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.empty-scores{color:var(--text-muted);padding:40px;text-align:center}.score-player-info{flex:1 1;min-width:0}.score-player{color:var(--text-primary);display:block;font-size:1rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.score-meta{color:var(--text-muted);display:block;font-size:.75rem;margin-top:2px}.score-item.top-three{background:linear-gradient(135deg,#eb66231a,#0000);border-color:#eb66234d}.rank-1{font-size:1.2rem}.rank-2,.rank-3{font-size:1.1rem}.leaderboard-actions{display:flex;justify-content:center;margin-top:24px}.back-btn{background:none;border:none;color:#ffffffb3;cursor:pointer;font-size:1rem;margin-bottom:16px;padding:8px}.back-btn:hover{color:#fff}.filter-section{margin-bottom:16px}.filter-type-tabs{background:#ffffff0d;border-radius:12px;display:flex;margin-bottom:12px;padding:4px}.filter-type-btn{background:#0000;border:none;border-radius:8px;color:#fff9;cursor:pointer;flex:1 1;font-size:.85rem;font-weight:500;padding:10px 12px;transition:all .2s ease}.filter-type-btn.active{background:var(--primary);color:#fff}.filter-type-btn:hover:not(.active){color:#fff}.artist-select-wrap{margin-bottom:12px}.artist-select{background:#0000004d;border:1px solid #ffffff1a;border-radius:10px;color:#fff;cursor:pointer;font-size:.95rem;padding:12px 16px;width:100%}.artist-select option{background:#1a1a2e;color:#fff}.player-avatar{object-fit:cover}.player-avatar,.player-avatar-placeholder{border-radius:50%;height:36px;margin-right:10px;width:36px}.player-avatar-placeholder{align-items:center;background:linear-gradient(135deg,var(--primary),#ff8a50);color:#fff;display:flex;font-size:.9rem;font-weight:600;justify-content:center}.player-details{flex:1 1;min-width:0}.score-player.clickable{color:var(--primary);cursor:pointer}.score-player.clickable:hover{text-decoration:underline}.score-song{color:#ffffff80;display:block;font-size:.75rem;margin-top:2px}.score-values{text-align:right}.dashboard{min-height:100vh}.dashboard-header{align-items:center;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:var(--bg-glass);border-bottom:1px solid var(--border-glass);display:flex;justify-content:space-between;padding:20px}.dashboard-logo{align-items:center;display:flex;gap:12px}.dashboard-logo .logo-icon{align-items:center;background:var(--primary);border-radius:12px;display:flex;font-size:24px;height:50px;justify-content:center;width:50px}.dashboard-logo h1{color:var(--text-primary);font-size:1.2rem;margin:0}.dashboard-logo p{color:var(--text-muted);font-size:.85rem;margin:0}.dashboard-content{padding:20px}.dashboard-actions{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.dashboard-actions h2{color:var(--text-primary);font-size:1.3rem;margin:0}.loading{color:var(--text-muted);padding:40px;text-align:center}.empty-state{background:var(--bg-glass);border:1px solid var(--border-glass);border-radius:20px;padding:60px 20px;text-align:center}.empty-icon{font-size:4rem;margin-bottom:16px}.empty-state h3{color:var(--text-primary);font-size:1.3rem;margin:0 0 8px}.empty-state p{color:var(--text-muted);margin:0}.songs-grid{grid-gap:16px;display:grid;gap:16px}.song-card-dash{align-items:center;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:var(--bg-glass);border:1px solid var(--border-glass);border-radius:16px;display:flex;gap:16px;padding:16px}.song-cover-dash{border-radius:10px;flex-shrink:0;height:60px;overflow:hidden;width:60px}.song-cover-dash img{height:100%;object-fit:cover;width:100%}.cover-placeholder{align-items:center;background:var(--primary);display:flex;font-size:24px;height:100%;justify-content:center;width:100%}.song-info-dash{flex:1 1;min-width:0}.song-info-dash h3{color:var(--text-primary);font-size:1rem;margin:0 0 4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-info-dash p{color:var(--text-muted);font-size:.85rem;margin:0 0 6px}.status{border-radius:6px;display:inline-block;font-size:.7rem;font-weight:600;padding:4px 8px;text-transform:uppercase}.status-pending{background:#fbbf2433;color:#fbbf24}.status-active{background:#22c55e33;color:#22c55e}.song-actions-dash{display:flex;flex-direction:column;gap:8px}.btn-sm{font-size:.75rem;padding:8px 12px}.btn-danger{background:#ef44441a;border:1px solid #ef44444d;color:#ef4444}.btn-danger:hover{background:#ef444433}.modal-overlay{align-items:center;background:#000c;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:100}.modal{background:var(--bg-card);border:1px solid var(--border-glass);border-radius:20px;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid var(--border-glass);display:flex;justify-content:space-between;padding:20px}.modal-header h2{color:var(--text-primary);font-size:1.2rem;margin:0}.modal-close{align-items:center;background:#ffffff1a;border:none;border-radius:8px;color:var(--text-primary);cursor:pointer;display:flex;font-size:24px;height:36px;justify-content:center;width:36px}.upload-form{padding:20px}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.form-group select{background:#ffffff0d;border:1px solid var(--border-glass);border-radius:12px;color:var(--text-primary);font-size:1rem;padding:14px 16px;width:100%}.form-group select:focus{border-color:var(--primary);outline:none}.header-actions{gap:10px}.header-actions,.lanes-visual{align-items:center;display:flex}.lanes-visual{gap:4px}.lane-dot{background:var(--primary);border-radius:50%;height:8px;width:8px}.song-meta{align-items:center;display:flex;gap:12px;margin:8px 0}.bpm-badge{background:#ffffff1a;border-radius:4px;color:#fff9;font-size:.75rem;padding:2px 8px}.upload-id{color:#fff6;display:block;font-family:monospace;font-size:.7rem;margin-top:4px}.upload-overlay-btn{background:#000000b3;border:none;color:#fff;cursor:pointer;font-size:.8rem;inset:0;opacity:0;position:absolute;transition:opacity .2s ease}.song-cover-dash:hover .upload-overlay-btn{opacity:1}.label-with-toggle{align-items:center;display:flex;justify-content:space-between}.toggle-pills{display:flex;gap:4px}.pill{background:#ffffff1a;border:none;border-radius:6px;color:#fff9;cursor:pointer;font-size:.75rem;padding:4px 10px;transition:all .2s ease}.pill.active{background:var(--primary);color:#fff}.file-upload-note{background:#eb66231a;border:1px dashed #eb66234d;border-radius:10px;color:#fff9;font-size:.85rem;padding:16px;text-align:center}.form-hint{font-size:.75rem;margin-top:6px}.lanes-group{margin-top:12px}.lanes-group label{align-items:center;display:flex;gap:8px}.lanes-help{cursor:help;font-size:.8rem}.lanes-selector{display:flex;gap:10px;margin-top:12px}.lane-option{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;cursor:pointer;flex:1 1;padding:12px 8px;text-align:center;transition:all .2s ease}.lane-option.active{background:#eb662326;border-color:var(--primary)}.lane-option span{color:#fff;display:block;font-size:.85rem;margin-top:6px}.lane-preview{display:flex;gap:4px;height:30px;justify-content:center}.lane-bar{background:linear-gradient(to bottom,var(--primary),#eb66234d);border-radius:3px;height:100%;width:6px}.profile-container{background:linear-gradient(135deg,#0a0a0f,#1a1a2e);min-height:100vh;padding:20px}.profile-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:24px;margin:0 auto;max-width:500px;padding:30px}.back-button{background:none;border:none;color:#ffffffb3;cursor:pointer;font-size:1rem;margin-bottom:20px;padding:8px 0}.back-button:hover{color:#fff}.profile-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#eb6623,#ff8a50);-webkit-background-clip:text;background-clip:text;font-size:1.8rem;font-weight:700;margin-bottom:24px;text-align:center}.profile-avatar-section{display:flex;justify-content:center;margin-bottom:24px}.profile-avatar{border:3px solid #eb6623;border-radius:50%;height:100px;object-fit:cover;width:100px}.profile-avatar-placeholder{align-items:center;background:linear-gradient(135deg,#eb6623,#ff8a50);border-radius:50%;color:#fff;display:flex;font-size:2.5rem;font-weight:700;height:100px;justify-content:center;width:100px}.form-group{margin-bottom:20px}.form-group label{color:#ffffffb3;display:block;font-size:.9rem;margin-bottom:8px}.form-group input[type=text],.form-group input[type=url]{background:#0000004d;border:1px solid #ffffff1a;border-radius:12px;box-sizing:border-box;color:#fff;font-size:1rem;padding:14px 16px;transition:border-color .2s ease;width:100%}.form-group input:focus{border-color:#eb6623;outline:none}.language-toggle{display:flex;gap:8px}.lang-btn{background:#0000004d;border:1px solid #ffffff1a;border-radius:12px;color:#fff9;cursor:pointer;flex:1 1;font-size:.95rem;padding:12px;transition:all .2s ease}.lang-btn.active{background:#eb662333;border-color:#eb6623;color:#eb6623}.lang-btn:hover:not(.active){background:#ffffff0d}.visibility-group{background:#0003;border-radius:12px;padding:16px}.checkbox-label{align-items:center;cursor:pointer;display:flex;gap:12px}.checkbox-label input[type=checkbox]{accent-color:#eb6623;height:20px;width:20px}.checkbox-label span{color:#fff;font-size:1rem}.form-hint{color:#ffffff80;font-size:.85rem;margin-left:32px;margin-top:8px}.socials-section{margin-bottom:24px}.socials-section>label{color:#ffffffb3;display:block;font-size:.9rem;margin-bottom:12px}.social-input{align-items:center;display:flex;gap:12px;margin-bottom:10px}.social-icon{font-size:1.2rem;text-align:center;width:30px}.social-input input{background:#0000004d;border:1px solid #ffffff1a;border-radius:10px;color:#fff;flex:1 1;font-size:.95rem;padding:12px 14px}.social-input input:focus{border-color:#eb6623;outline:none}.message{border-radius:10px;font-size:.95rem;margin-bottom:16px;padding:12px;text-align:center}.message.success{background:#00ff881a;border:1px solid #0f83;color:#0f8}.message.error{background:#ff44441a;border:1px solid #f443;color:#f44}.save-btn{background:linear-gradient(135deg,#eb6623,#ff8a50);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:16px;transition:all .2s ease;width:100%}.save-btn:hover:not(:disabled){box-shadow:0 8px 20px #eb662366;transform:translateY(-2px)}.save-btn:disabled{cursor:not-allowed;opacity:.6}
/*# sourceMappingURL=main.847d6ee6.css.map*/