html,body,#root{min-height:100vh;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root{--bg-primary:#050508;--bg-secondary:#0f0f14;--bg-card:#141419;--bg-card-hover:#1a1a22;--bg-input:#0a0a0f;--gold:#d4a017;--gold-bright:gold;--gold-dark:#8b6914;--gold-gradient:linear-gradient(135deg, gold 0%, #d4a017 50%, #b8860b 100%);--purple:#7c3aed;--purple-bright:#a78bfa;--purple-mid:#8b5cf6;--purple-dark:#5b21b6;--purple-glow:#7c3aed73;--purple-gradient:linear-gradient(135deg, #c4b5fd 0%, #8b5cf6 50%, #5b21b6 100%);--gold-purple-gradient:linear-gradient(135deg, gold 0%, #d4a017 30%, #8b5cf6 70%, #5b21b6 100%);--silver:#c8c8d0;--silver-bright:#e8e8f0;--silver-dark:#808090;--blue:#2563eb;--blue-bright:#3b82f6;--blue-glow:#2563eb66;--red:#dc2626;--red-bright:#ef4444;--red-glow:#dc262666;--border:#1e1e28;--border-light:#2a2a38;--border-purple:#8b5cf640;--text-primary:#f0f0f8;--text-secondary:#888898;--text-muted:#556}*{box-sizing:border-box}body{background:var(--bg-primary);color:var(--text-primary);background-image:radial-gradient(80% 50% at 15% 0,#5b21b61f 0%,#0000 60%),radial-gradient(60% 40% at 85% 100%,#7c3aed14 0%,#0000 55%);min-height:100vh;margin:0;font-family:Segoe UI,system-ui,-apple-system,sans-serif}.app{max-width:900px;margin:0 auto;padding:1.5rem 1.5rem 3rem}h1{letter-spacing:-.02em;background:var(--gold-gradient);-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 18px #ffd70066)drop-shadow(0 2px 4px #00000080);-webkit-background-clip:text;background-clip:text;margin:0;font-size:2.5rem;font-weight:800}h1 .words{background:linear-gradient(135deg, var(--silver-bright) 0%, var(--silver) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}h2{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.15em;margin:0 0 1rem;font-size:.75rem;font-weight:600}.subtitle{color:var(--text-secondary);margin-top:.5rem}.nav{border-bottom:1px solid var(--border-purple);justify-content:space-between;align-items:center;gap:1rem;width:100%;margin-bottom:1.4rem;padding:.8rem 0 1.4rem;display:flex;position:relative}.nav-slash{pointer-events:none;width:calc(100% + 3rem);height:8px;position:absolute;bottom:-5px;left:-1.5rem}.nav-slash-line{clip-path:polygon(0 0,100% 0,calc(100% - 4px) 100%,0 100%);width:100%;height:50%;position:absolute;left:0}.nav-slash-line-yellow{background:var(--gold-bright);top:0}.nav-slash-line-purple{background:var(--purple-mid);top:50%}.nav-top{align-items:center;gap:.9rem;display:flex}.nav-brand{align-items:center;gap:.65rem;min-width:0;display:flex}.nav-brand-link{align-items:center;gap:.65rem;text-decoration:none;display:inline-flex}.nav-logo{font-size:1.75rem}.nav-logo-img{object-fit:contain;border-radius:8px;flex-shrink:0;width:52px;height:52px}.nav-title{letter-spacing:-.01em;background:var(--gold-gradient);-webkit-text-fill-color:transparent;white-space:nowrap;filter:drop-shadow(0 0 8px #ffd70080);-webkit-background-clip:text;background-clip:text;font-size:1.2rem;font-weight:800;line-height:1}.nav-version{color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border);border-radius:4px;flex-shrink:0;padding:2px 6px;font-size:.6rem}.nav-toggle{border:1px solid var(--border);background:var(--bg-card);width:38px;height:38px;color:var(--text-primary);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;padding:0;display:none}.nav-toggle span{background:currentColor;border-radius:999px;width:16px;height:2px;transition:transform .2s,opacity .2s;display:block}.nav-toggle span+span{margin-top:3px}.nav-toggle.open span:first-child{transform:translateY(5px)rotate(45deg)}.nav-toggle.open span:nth-child(2){opacity:0}.nav-toggle.open span:nth-child(3){transform:translateY(-5px)rotate(-45deg)}.nav-body{flex:1;justify-content:space-between;align-items:center;gap:1rem;min-width:0;display:flex}.nav-links{flex-wrap:nowrap;align-items:center;gap:.15rem;display:flex}.nav-link{color:var(--text-secondary);white-space:nowrap;border-radius:8px;flex-shrink:0;padding:.45rem .8rem;font-size:.82rem;font-weight:600;text-decoration:none;transition:all .18s}.nav-link:hover{color:var(--gold-bright);background:#d4a01714}.nav-link.active{color:var(--bg-primary);background:var(--gold-gradient);border:1px solid var(--purple-mid)}.nav-auth{align-items:center;gap:.35rem;display:flex}.sound-toggle{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:.9rem;transition:all .15s;display:inline-flex}.sound-toggle:hover{color:var(--text-primary);border-color:var(--gold-dark);background:var(--bg-card)}.sound-toggle.muted{color:var(--text-muted)}.nav-login{background:var(--gold-gradient);border:2px solid var(--purple-mid);border-radius:6px;padding:.5rem 1.25rem;font-size:.875rem;font-weight:700;text-decoration:none;transition:all .2s;color:var(--bg-primary)!important}.nav-login:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 16px #7c3aed59}@media (width<=900px){.nav{flex-direction:column;align-items:stretch;gap:.65rem}.nav-top{justify-content:space-between}.nav-toggle{display:inline-flex}.nav-body{flex-direction:column;align-items:stretch;gap:.65rem;width:100%;display:none}.nav-body.open{display:flex}.nav-links{flex-direction:column;gap:.35rem;width:100%;margin-left:0}.nav-link{width:100%}.nav-auth{flex-wrap:wrap;justify-content:flex-start;width:100%;margin-left:0}.nav-auth .user-menu{width:100%}.nav-auth .user-menu-trigger{justify-content:space-between;width:100%}.nav-brand-link{min-width:0}.nav-title{font-size:1.05rem}.nav-logo-img{width:42px;height:42px}}@media (width<=520px){.nav{margin-bottom:1rem}.nav-top{align-items:center}.nav-brand{flex-wrap:nowrap}.nav-title{font-size:.95rem}}section,.card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:1.5rem}.section-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.section-header h2{color:var(--silver-bright);text-transform:none;letter-spacing:normal;margin:0;font-size:1rem;font-weight:700}.page{animation:.3s fadeUp}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.4rem;padding:.7rem 1.4rem;font-size:.9rem;font-weight:700;transition:all .2s;display:inline-flex}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}.btn-primary{background:var(--gold-gradient);color:var(--bg-primary);border:2px solid var(--purple-mid)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #d4a01759}.btn-play{background:var(--bg-card-hover);color:var(--text-primary);border:1px solid var(--border-light);padding:.5rem .85rem;font-size:.8rem}.btn-play:hover:not(:disabled){border-color:var(--gold);color:var(--gold-bright);background:#d4a01714}.btn-play-active{background:var(--gold-gradient);color:var(--bg-primary);border:none;padding:.5rem .85rem;font-size:.8rem;animation:2s ease-in-out infinite accentPulse}@keyframes accentPulse{0%,to{box-shadow:0 0 #d4a01766}50%{box-shadow:0 0 14px 3px #d4a01766,0 0 28px 6px #7c3aed33}}.btn-record{background:linear-gradient(135deg, var(--red) 0%, #991b1b 100%);color:#fff;border:none;border-radius:10px;width:100%;padding:1rem;font-size:1.1rem}.btn-record:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #dc262666}.btn-record.recording{animation:1s ease-in-out infinite goldRecordPulse}@keyframes goldRecordPulse{0%,to{box-shadow:0 0 #ffd70080,0 0 #8b5cf64d}50%{box-shadow:0 0 20px 4px #ffd70099,0 0 40px 8px #8b5cf64d}}.nav-logo-img{animation:3s ease-in-out infinite logoGlow}@keyframes logoGlow{0%,to{filter:drop-shadow(0 0 4px #ffd7004d)}50%{filter:drop-shadow(0 0 12px #ffd700b3)}}.btn-save{color:#fff;background:linear-gradient(135deg,#059669 0%,#047857 100%)}.btn-save:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #05966959}.btn-rerecord{background:var(--bg-card-hover);color:var(--text-primary);border:1px solid var(--border-light)}.btn-rerecord:hover:not(:disabled){border-color:var(--silver-dark);background:var(--bg-secondary)}.btn-small{padding:.35rem .75rem;font-size:.8rem}.btn-delete{background:var(--bg-card-hover);color:var(--red-bright);border:1px solid #dc262640}.btn-delete:hover:not(:disabled){border-color:var(--red);background:#dc26261a}.btn-secondary{background:var(--bg-card-hover);color:var(--text-primary);border:1px solid var(--border-light)}.btn-secondary:hover{border-color:var(--silver-dark)}.btn-live{background:linear-gradient(135deg, var(--red) 0%, #991b1b 100%);color:#fff}.btn-complete{color:#fff;background:linear-gradient(135deg,#059669 0%,#047857 100%)}.btn-promote{background:var(--gold-gradient);color:var(--bg-primary)}.btn-promote:hover{opacity:.9;box-shadow:0 4px 16px #d4a0174d}.btn-demote{background:var(--bg-card-hover);color:var(--text-primary);border:1px solid var(--border-light)}.text-input{background:var(--bg-input);border:1px solid var(--border-light);width:100%;color:var(--text-primary);border-radius:8px;padding:.8rem 1rem;font-size:.95rem;transition:border-color .2s}.text-input:focus{border-color:var(--purple-mid);outline:none;box-shadow:0 0 0 3px #8b5cf626}.text-input::placeholder{color:var(--text-muted)}.form-group{margin-bottom:1rem}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.8rem;font-weight:600;display:block}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.beat-selector{margin-top:1rem}.beat-selector-loading,.beat-selector-error,.beat-selector-empty{text-align:center;color:var(--text-muted);padding:1rem;font-size:.85rem}.beat-selector-error{color:var(--red-bright);justify-content:center;align-items:center;gap:.75rem;display:flex}.beat-selector-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.6rem;display:grid}.beat-selector-card{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;text-align:left;border-radius:10px;align-items:center;gap:.75rem;padding:.85rem 1rem;transition:all .15s;display:flex}.beat-selector-card:hover{border-color:var(--gold-dark);background:var(--bg-card-hover)}.beat-selector-card.selected{border-color:var(--purple-mid);background:#8b5cf614}.beat-selector-icon{background:var(--bg-input);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.4rem;display:flex}.beat-selector-info{flex:1;min-width:0}.beat-selector-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:700;display:block;overflow:hidden}.beat-selector-meta{color:var(--text-muted);margin-top:.15rem;font-size:.72rem;display:block}.beat-selector-check{color:var(--gold-bright);flex-shrink:0;font-size:.9rem}.beat-player{flex-direction:column;gap:.85rem;display:flex}.beat-info{justify-content:space-between;align-items:center;display:flex}.beat-title{color:var(--silver-bright);font-weight:700}.beat-position{color:var(--gold);font-family:Courier New,monospace;font-size:.8rem}.beat-controls{gap:.75rem;display:flex}.beat-volume{align-items:center;gap:.75rem;display:flex}.beat-volume label{color:var(--text-muted);font-size:.8rem}.beat-volume input[type=range]{flex:1}.recorder{flex-direction:column;gap:1rem;display:flex}.drop-in-selector{align-items:center;gap:.75rem;display:flex}.drop-in-selector label{color:var(--text-muted);min-width:84px;font-size:.8rem}.recorder-status{align-items:center;gap:.5rem;display:flex}.status-label{color:var(--text-muted);font-size:.8rem}.status-value{font-size:.875rem;font-weight:700}.status-idle{color:#10b981}.status-countdown{color:var(--gold-bright)}.status-recording{color:var(--red-bright)}.status-review{color:var(--blue-bright)}.recorder-hint{color:var(--text-muted);text-align:center;margin:0;font-size:.8rem}.input-level{gap:.35rem;display:grid}.input-level-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.75rem}.input-level-meter{border:1px solid var(--border);background:#ffffff0f;border-radius:999px;width:100%;height:10px;overflow:hidden}.input-level-fill{border-radius:inherit;background:linear-gradient(90deg,#22c55e 0%,#facc15 65%,#ef4444 100%);width:0;height:100%;transition:width 80ms linear}.input-level-fill.hot{box-shadow:0 0 10px #ef444473}.countdown-overlay{z-index:100;background:#050508eb;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.countdown-number{color:var(--gold-bright);text-shadow:0 0 40px #ffd70080,0 0 80px #8b5cf659;font-size:10rem;font-weight:900;animation:.5s ease-out countPulse}@keyframes countPulse{0%{opacity:0;transform:scale(.4)}60%{transform:scale(1.15)}to{opacity:1;transform:scale(1)}}.playback-progress{background:var(--border);border-radius:3px;height:6px;overflow:hidden}.progress-bar{background:var(--gold-purple-gradient);height:100%;transition:width .1s}.playback-controls,.playback-actions{gap:.75rem;display:flex}.waveform-grid{grid-template-columns:1fr;gap:.75rem;display:grid}.mix-controls{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem;display:grid}.mix-control{flex-direction:column;gap:.45rem;display:flex}.mix-control label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.75rem}.mix-control input[type=range]{width:100%}.audio-waveform{background:var(--bg-input);border:1px solid var(--border);border-radius:8px;padding:.6rem .7rem}.audio-waveform-header{justify-content:space-between;align-items:center;margin-bottom:.45rem;display:flex}.audio-waveform-label{color:var(--text-secondary);font-size:.75rem;font-weight:700}.audio-waveform-duration{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:.72rem}.audio-waveform-visual{width:100%}.audio-waveform-viewport{overflow:hidden}.audio-waveform-track{will-change:transform;transition:transform .18s ease-out}.effects-preview{background:var(--bg-input);border:1px solid var(--border);border-radius:8px;padding:.85rem}.effects-preview h4{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin:0 0 .5rem;font-size:.7rem}.effect-item{color:var(--text-secondary);margin:.2rem 0;font-size:.8rem}.recordings-list{flex-direction:column;gap:.6rem;display:flex}.recording-item{background:var(--bg-input);border:1px solid var(--border);border-radius:8px;justify-content:space-between;align-items:flex-start;gap:1rem;padding:.9rem 1rem;display:flex}.recording-title{font-size:.9rem;font-weight:700}.recording-info{flex-direction:column;flex:1;gap:.6rem;min-width:0;display:flex}.recording-meta{color:var(--text-muted);margin-top:.15rem;font-size:.75rem;display:block}.recording-actions{flex-shrink:0;gap:.5rem;display:flex}.login-page{justify-content:center;align-items:center;min-height:75vh;display:flex}.login-container{text-align:center;width:100%;max-width:360px}.login-error-banner{color:#f87171;text-align:left;background:linear-gradient(135deg,#dc262626,#b91c1c1a);border:1px solid #dc262659;border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding:.75rem 1rem;font-size:.85rem;font-weight:600;display:flex}.login-notice-banner{color:#fcd34d;text-align:center;background:linear-gradient(135deg,#eab3081f,#ca8a0414);border:1px solid #eab3084d;border-radius:10px;justify-content:center;align-items:center;margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.85rem;line-height:1.4;display:flex}.login-notice-banner a{color:#fbbf24;text-underline-offset:2px;text-decoration:underline}.login-notice-banner a:hover{color:#f59e0b}.login-error-banner button{color:#ffffff80;cursor:pointer;background:0 0;border:none;padding:0 .25rem;font-size:1.1rem}.login-error-banner button:hover{color:#fff}.login-header{margin-bottom:2.5rem}.login-logo{margin-bottom:1.25rem;font-size:4.5rem;display:block}.login-splash{object-fit:contain;width:180px;height:180px;margin-bottom:1.5rem;margin-left:auto;margin-right:auto;display:block}.toggle-row{justify-content:space-between;align-items:center;gap:1rem;display:flex}.toggle-label{color:var(--text-primary);font-size:.88rem;font-weight:700;display:block}.toggle-desc{color:var(--text-muted);margin:.2rem 0 0;font-size:.75rem}.toggle-btn{background:var(--bg-input);border:1px solid var(--border);cursor:pointer;border-radius:14px;flex-shrink:0;width:52px;height:28px;transition:all .2s;position:relative}.toggle-btn.active{background:var(--purple-gradient);border-color:var(--purple-mid)}.toggle-knob{background:var(--text-muted);border-radius:50%;width:20px;height:20px;transition:all .2s;display:block;position:absolute;top:3px;left:3px}.toggle-btn.active .toggle-knob{background:var(--bg-primary);left:calc(100% - 23px)}.login-header h1{margin-bottom:.5rem;font-size:2.25rem}.login-header p{color:var(--text-muted);margin:0;font-size:.9rem}.login-actions{flex-direction:column;gap:.9rem;display:flex}.btn-google{color:#1a1a2e;cursor:pointer;background:#fff;border:none;border-radius:10px;justify-content:center;align-items:center;gap:.75rem;width:100%;padding:.9rem 1.5rem;font-size:.95rem;font-weight:700;transition:all .2s;display:flex}.btn-google:hover{background:#f5f5f5;transform:translateY(-1px)}.btn-discord{color:#fff;cursor:pointer;background:#5865f2;border:none;border-radius:10px;justify-content:center;align-items:center;gap:.75rem;width:100%;padding:.9rem 1.5rem;font-size:.95rem;font-weight:700;transition:all .2s;display:flex}.btn-discord:hover{background:#4752c4;transform:translateY(-1px)}.login-terms{color:var(--text-muted);margin-top:2.5rem;font-size:.7rem;line-height:1.6}.user-menu{position:relative}.user-menu-trigger{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;border-radius:999px;align-items:center;gap:.5rem;padding:.3rem .6rem .3rem .3rem;transition:all .2s;display:flex}.user-menu-trigger:hover{border-color:var(--gold-dark);background:var(--bg-card-hover)}.user-avatar{background:var(--gold-gradient);border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;display:flex;overflow:hidden}.user-avatar img{object-fit:cover;width:100%;height:100%}.user-avatar span{color:var(--bg-primary);font-size:.7rem;font-weight:700}.user-name{color:var(--text-primary);font-size:.85rem;font-weight:600}.dropdown-arrow{color:var(--text-muted)}.user-dropdown{background:var(--bg-card);border:1px solid var(--border);z-index:100;border-radius:14px;min-width:210px;animation:.15s dropIn;position:absolute;top:calc(100% + .5rem);right:0;overflow:hidden;box-shadow:0 12px 40px #0009}@keyframes dropIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.user-dropdown-header{padding:1rem}.user-dropdown-name{color:var(--text-primary);font-weight:700}.user-dropdown-email{color:var(--text-muted);margin-top:.2rem;font-size:.8rem}.user-dropdown-divider{background:var(--border);height:1px}.user-dropdown-item{width:100%;color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.75rem;padding:.7rem 1rem;font-size:.875rem;transition:all .15s;display:flex}.user-dropdown-item:hover{color:var(--purple-bright);background:#8b5cf61a}.admin-tabs{border-bottom:1px solid var(--border);gap:.4rem;margin-bottom:2rem;padding-bottom:1rem;display:flex}.admin-tab{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;padding:.65rem 1.25rem;font-size:.85rem;font-weight:600;transition:all .2s}.admin-tab:hover{border-color:var(--gold-dark);color:var(--gold-bright)}.admin-tab.active{background:var(--gold-gradient);color:var(--bg-primary);border-color:#0000}.admin-loading{text-align:center;color:var(--text-muted);padding:4rem}.user-table{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.table-header{background:var(--bg-input);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);grid-template-columns:2fr 2fr 1fr 1fr 40px;padding:.85rem 1rem;font-size:.7rem;display:grid}.table-row{border-bottom:1px solid var(--border);cursor:pointer;grid-template-columns:2fr 2fr 1fr 1fr 40px;align-items:center;padding:.85rem 1rem;transition:background .15s;display:grid}.table-row:last-child{border-bottom:none}.table-row:hover{background:#d4a0170a}.table-row.selected{background:#d4a01714}.user-name-cell{align-items:center;gap:.75rem;display:flex}.user-avatar-small{background:var(--gold-gradient);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex;overflow:hidden}.user-avatar-small img{object-fit:cover;width:100%;height:100%}.user-avatar-small span{color:var(--bg-primary);font-size:.7rem;font-weight:700}.role-badge{text-transform:uppercase;letter-spacing:.04em;border-radius:4px;padding:.2rem .55rem;font-size:.7rem;font-weight:700;display:inline-block}.role-badge.admin{color:var(--gold-bright);background:#d4a01726;border:1px solid #d4a0174d}.role-badge.user,.role-badge.standard{background:var(--bg-input);color:var(--text-muted);border:1px solid var(--border)}.role-badge.judge{color:#a78bfa;background:#643cc826;border:1px solid #643cc84d}.role-badges-cell{flex-wrap:wrap;gap:.3rem;display:flex}.role-hint{color:var(--text-secondary);margin:0 0 .85rem;font-size:.78rem}.role-toggles{flex-wrap:wrap;gap:.5rem;display:flex}.role-toggle-btn{border:1px solid var(--border);background:var(--bg-input);color:var(--text-muted);cursor:pointer;border-radius:8px;padding:.45rem 1rem;font-size:.8rem;font-weight:600;transition:all .15s}.role-toggle-btn:hover:not(:disabled){border-color:var(--gold-dark);color:var(--text-primary)}.role-toggle-btn.active{border-color:var(--gold-dark);color:var(--gold-bright);background:#d4a01726}.role-toggle-btn.role-judge.active{color:#a78bfa;background:#643cc826;border-color:#643cc866}.role-toggle-btn:disabled{opacity:.5;cursor:not-allowed}.saving-msg{color:var(--text-muted);margin-top:.5rem;font-size:.75rem}.battles-list{flex-direction:column;gap:1rem;display:flex}.battle-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.5rem;transition:border-color .2s}.battle-card:hover{border-color:var(--gold-dark);box-shadow:0 0 0 1px #d4a01726}.battle-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;display:flex}.battle-card-header h3{color:var(--silver-bright);margin:0;font-size:1.1rem;font-weight:800}.battle-description{color:var(--text-muted);margin:.4rem 0 0;font-size:.85rem}.status-badge{text-transform:uppercase;letter-spacing:.06em;border-radius:999px;padding:.2rem .65rem;font-size:.68rem;font-weight:700;display:inline-block}.status-badge.draft{background:var(--bg-input);color:var(--text-muted);border:1px solid var(--border)}.status-badge.open{color:#10b981;background:#05966926;border:1px solid #0596694d}.status-badge.live{color:var(--red-bright);background:#dc262626;border:1px solid #dc26264d}.status-badge.completed,.status-badge.finalized{color:var(--blue-bright);background:#2563eb26;border:1px solid #2563eb4d}.status-badge.cancelled{background:var(--bg-input);color:var(--text-muted);border:1px solid var(--border)}.status-badge.awaiting_judgment{color:var(--gold-bright);background:#d4a01726;border:1px solid #d4a0174d}.battle-card-meta{color:var(--text-muted);gap:1.5rem;margin:.5rem 0;font-size:.8rem;display:flex}.battle-card-footer{border-top:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.85rem;padding-top:.85rem;display:flex}.winner-label{color:var(--text-muted);margin-right:.25rem;font-size:.82rem}.awaiting-judgment{color:var(--gold-bright);font-size:.82rem;font-weight:600}.battle-card-footer .btn{margin-left:auto}.battle-card-actions{border-top:1px solid var(--border);flex-wrap:wrap;gap:.5rem;margin-top:1rem;padding-top:1rem;display:flex}.battle-participants{border-top:1px solid var(--border);margin-top:1.25rem;padding-top:1.25rem}.battle-participants h4{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin:0 0 .85rem;font-size:.75rem}.participants-list{flex-direction:column;gap:.4rem;margin-bottom:.85rem;display:flex}.participant-item{background:var(--bg-input);border-radius:7px;justify-content:space-between;align-items:center;padding:.65rem .85rem;display:flex}.participant-status{text-transform:uppercase;letter-spacing:.04em;border-radius:4px;padding:.15rem .5rem;font-size:.68rem;font-weight:700}.participant-status.pending{background:var(--bg-card-hover);color:var(--text-muted)}.participant-status.ready{color:#10b981;background:#0596691f}.participant-status.recorded{color:var(--blue-bright);background:#2563eb1f}.participant-status.winner{color:var(--gold-bright);background:#d4a01726;border:1px solid #d4a0174d}.no-participants{color:var(--text-muted);text-align:center;padding:.85rem;font-size:.85rem}.add-participant{gap:.5rem;display:flex}.participant-select{background:var(--bg-input);border:1px solid var(--border-light);color:var(--text-primary);border-radius:8px;flex:1;padding:.65rem .85rem;font-size:.85rem}.user-detail-panel{background:var(--bg-card);border:1px solid var(--gold-dark);border-radius:14px;margin-top:1.25rem;animation:.2s slideUp;overflow:hidden}.user-detail-header{background:var(--bg-input);align-items:center;gap:1rem;padding:1.25rem;display:flex}.user-detail-avatar{background:var(--gold-purple-gradient);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex;overflow:hidden}.user-detail-avatar img{object-fit:cover;width:100%;height:100%}.user-detail-avatar span{color:var(--bg-primary);font-size:1.3rem;font-weight:800}.user-detail-info{flex:1}.user-detail-info h3{color:var(--text-primary);margin:0;font-size:1rem;font-weight:700}.user-detail-info p{color:var(--text-muted);margin:.2rem 0 .4rem;font-size:.8rem}.detail-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.4rem;transition:all .15s}.detail-close:hover{background:var(--bg-card-hover);color:var(--text-primary)}.user-detail-meta{border-bottom:1px solid var(--border);grid-template-columns:1fr 1fr;gap:.85rem;padding:1.25rem;display:grid}.meta-item{flex-direction:column;gap:.2rem;display:flex}.meta-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:.68rem}.meta-value{color:var(--silver-bright);font-family:Courier New,monospace;font-size:.85rem}.user-detail-actions{padding:1.25rem}.user-detail-actions h4{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin:0 0 .85rem;font-size:.75rem}.action-buttons{flex-wrap:wrap;gap:.6rem;display:flex}.beats-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.85rem;display:grid}.beat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:.75rem;padding:1.1rem;transition:border-color .2s;display:flex}.beat-card:hover{border-color:var(--gold-dark);box-shadow:0 0 0 1px #d4a01726}.beat-card-header{align-items:flex-start;gap:.85rem;display:flex}.beat-icon{background:var(--purple-gradient);width:44px;height:44px;color:var(--bg-primary);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.2rem;display:flex}.beat-info{flex:1;min-width:0}.beat-info h3{color:var(--silver-bright);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.9rem;font-weight:700;overflow:hidden}.beat-info p{color:var(--text-muted);margin:.2rem 0 0;font-size:.78rem}.beat-tags{flex-wrap:wrap;gap:.4rem;display:flex}.beat-tag{background:var(--bg-input);color:var(--text-muted);border:1px solid var(--border);border-radius:4px;padding:.15rem .55rem;font-size:.7rem}.beat-card-footer{justify-content:space-between;align-items:center;margin-top:auto;padding-top:.5rem;display:flex}.beat-duration{color:var(--gold);font-family:Courier New,monospace;font-size:.8rem}.beat-actions{gap:.4rem;display:flex}.file-upload{border:2px dashed var(--border-light);text-align:center;cursor:pointer;border-radius:10px;padding:2rem;transition:all .2s}.file-upload:hover{border-color:var(--gold-dark);background:#d4a0170a}.fighter-creator-page{max-width:1100px}.fighter-creator-layout{grid-template-columns:340px 1fr;align-items:start;gap:1.75rem;display:grid}.fighter-preview-panel{background:var(--bg-card);border:1px solid var(--border);text-align:center;border-radius:16px;padding:1.75rem;position:sticky;top:1.5rem}.fighter-preview-panel canvas{background:linear-gradient(180deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);border-radius:10px;max-width:100%}.fighter-preview-name{margin-top:1.25rem}.fighter-preview-name h2{background:var(--gold-gradient);-webkit-text-fill-color:transparent;text-transform:none;letter-spacing:normal;-webkit-background-clip:text;background-clip:text;margin:0;font-size:1.5rem;font-weight:800}.fighter-tagline{color:var(--text-muted);margin:.4rem 0 0;font-size:.82rem;font-style:italic}.fighter-stats{justify-content:center;gap:2rem;margin:1rem 0;display:flex}.stat{flex-direction:column;align-items:center;display:flex}.stat-value{color:var(--gold-bright);font-size:1.5rem;font-weight:800}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.68rem}.fighter-customize-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;overflow:hidden}.customize-tabs{border-bottom:1px solid var(--border);display:flex}.customize-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex:1;padding:.9rem;font-size:.85rem;font-weight:600;transition:all .2s}.customize-tab:hover{color:var(--purple-bright);background:#8b5cf612}.customize-tab.active{color:var(--purple-bright);border-bottom:2px solid var(--purple-mid);background:#8b5cf61a}.customize-content{padding:1.5rem}.customize-section{flex-direction:column;gap:1.25rem;display:flex}.option-group{flex-direction:column;gap:.65rem;display:flex}.option-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;font-weight:600}.option-label-text{color:var(--gold-dark);font-size:.72rem}.option-selector{flex-wrap:wrap;gap:.5rem;display:flex}.option-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:7px;padding:.45rem .9rem;font-size:.82rem;transition:all .15s}.option-btn:hover{border-color:var(--purple-mid);color:var(--purple-bright)}.option-btn.selected{border-color:var(--purple-mid);color:var(--purple-bright);background:#8b5cf61f}.color-selector{flex-wrap:wrap;gap:.5rem;display:flex}.color-btn{cursor:pointer;border:2px solid #0000;border-radius:50%;width:34px;height:34px;transition:all .15s}.color-btn:hover{transform:scale(1.1)}.color-btn.selected{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--bg-primary), 0 0 0 4px var(--gold)}.accessory-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:.4rem;display:grid}.accessory-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;text-align:center;border-radius:8px;padding:.65rem .5rem;font-size:.72rem;transition:all .15s}.accessory-btn:hover{border-color:var(--purple-mid);color:var(--purple-bright)}.accessory-btn.selected{border-color:var(--purple-mid);color:var(--purple-bright);background:#8b5cf61f}.fighter-preview-info{border-top:1px solid var(--border);margin-top:1.25rem;padding-top:1.25rem}.fighter-preview-info h3{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin:0 0 .85rem;font-size:.75rem}.summary-grid{grid-template-columns:repeat(3,1fr);gap:.75rem;display:grid}.summary-item{flex-direction:column;gap:.15rem;display:flex}.summary-label{color:var(--text-muted);text-transform:uppercase;font-size:.68rem}.summary-value{color:var(--silver-bright);font-size:.82rem;font-weight:600}.modal-overlay{z-index:200;background:#050508d9;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:460px;padding:2rem;animation:.2s slideUp}.modal h3{color:var(--purple-bright);margin:0 0 1.5rem;font-size:1.2rem;font-weight:800}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--purple-mid);outline:none;box-shadow:0 0 0 3px #8b5cf626}.modal-actions{justify-content:flex-end;gap:.65rem;margin-top:1.5rem;display:flex}.settings-manager{flex-direction:column;gap:1.5rem;display:flex}.settings-section{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.5rem}.settings-section h3{color:var(--silver-bright);text-transform:uppercase;letter-spacing:.06em;margin:0 0 1.25rem;font-size:.9rem;font-weight:700}.coming-soon{text-align:center;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:4rem 2rem}.coming-soon-icon{margin-bottom:1rem;font-size:3.5rem;display:block}.coming-soon h2{color:var(--text-primary);text-transform:none;letter-spacing:normal;background:var(--gold-purple-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 .5rem;font-size:1.4rem}.coming-soon p{color:var(--text-muted);margin:.4rem 0}.coming-soon ul{text-align:left;margin-top:1.5rem;padding:0;list-style:none;display:inline-block}.coming-soon li{color:var(--text-secondary);padding:.3rem 0;font-size:.875rem}.coming-soon li:before{content:"→ ";color:var(--gold)}input[type=range]{appearance:none;background:var(--border);border-radius:2px;outline:none;height:4px}input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--purple-gradient);cursor:pointer;border-radius:50%;width:14px;height:14px}input[type=range]::-moz-range-thumb{background:var(--purple-gradient);cursor:pointer;border:none;border-radius:50%;width:14px;height:14px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:linear-gradient(135deg, var(--gold-bright), var(--gold-dark));border-radius:3px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg, var(--gold-bright), var(--purple-mid))}.row-action{color:var(--text-muted);text-align:right;transition:color .15s}.table-row:hover .row-action,.table-row.selected .row-action{color:var(--gold)}.loading-placeholder{text-align:center;color:var(--text-muted);padding:4rem}.battle-list{flex-direction:column;gap:.75rem;display:flex}.battle-row{background:var(--bg-card);border:2px solid var(--border);border-radius:12px;justify-content:space-between;align-items:center;padding:1.25rem;text-decoration:none;transition:all .15s;display:flex}.battle-row:hover{transform:translate(2px)}.battle-row-live{border-color:var(--gold-dark)}.battle-row-live:hover{border-color:var(--gold-bright)}.battle-row-win{border-color:#4ade80}.battle-row-win:hover{border-color:#22c55e}.battle-row-loss{border-color:#f87171}.battle-row-loss:hover{border-color:#ef4444}.battle-row-draw{border-color:var(--text-muted)}.battle-row-draw:hover{border-color:var(--text-secondary)}.battle-row-pending{border-color:#d4a01766}.battle-row-pending:hover{border-color:var(--gold-bright)}.battle-row-info h3{color:var(--text-primary);margin:0;font-size:1rem;font-weight:700}.battle-row-meta{color:var(--text-muted);margin:.25rem 0 0;font-size:.78rem}.battle-row-arrow{color:var(--text-muted);font-size:1.2rem}.home-page .page-header{text-align:center;margin-bottom:2.5rem}.home-page .page-header h1{background:var(--gold-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.25rem;font-size:2.2rem;font-weight:800}.home-page .subtitle{color:var(--text-muted);margin:0;font-size:1rem}.home-actions{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:2.5rem;display:grid}.home-action-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;align-items:center;gap:1rem;padding:1.2rem;text-decoration:none;transition:all .15s;display:flex;position:relative}.home-action-card:before{content:"";border:2px solid var(--gold-bright);clip-path:polygon(0 0,calc(100% - 14px) 0,100% 14px,100% 100%,0 100%);pointer-events:none;z-index:-1;border-radius:16px;position:absolute;inset:-3px}.home-action-card:after{content:"";border:2px solid var(--purple-mid);clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,0 100%);pointer-events:none;z-index:-1;border-radius:15px;position:absolute;inset:-1px}.home-action-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #7c3aed26}.home-action-icon{font-size:2rem}.home-action-card h3{color:var(--text-primary);margin:0 0 .2rem;font-size:1rem}.home-action-card p{color:var(--text-muted);margin:0;font-size:.78rem}.section-title{color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem;font-size:1.1rem;font-weight:700}.announcements-list{flex-direction:column;gap:1rem;display:flex}.announcement-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.4rem}.announcement-card.pinned{background:linear-gradient(135deg,#d4a0170d,#0000);border-color:#d4a01766}.announcement-header{align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}.announcement-header h3{color:var(--text-primary);margin:0;font-size:1rem}.pinned-badge{color:var(--gold-bright);font-size:.7rem}.announcement-content{color:var(--text-secondary);font-size:.9rem;line-height:1.6}.announcement-content h1{color:var(--text-primary);margin:0 0 .5rem;font-size:1.2rem}.announcement-content h2{color:var(--text-primary);margin:.5rem 0 .4rem;font-size:1.1rem}.announcement-content h3{color:var(--text-primary);margin:.4rem 0 .3rem;font-size:1rem}.announcement-content strong{color:var(--text-primary)}.announcement-date{color:var(--text-muted);margin-top:.75rem;font-size:.72rem;display:block}.no-announcements{color:var(--text-muted);font-size:.85rem}.admin-edit-link{color:var(--gold-dark);margin-top:.75rem;font-size:.78rem;text-decoration:none;display:inline-block}.admin-edit-link:hover{color:var(--gold-bright)}.announcements-section{margin-top:1rem}.battle-arena-page .admin-tabs{margin-bottom:1.5rem}.tab-badge{background:var(--red);color:#fff;border-radius:999px;margin-left:.3rem;padding:.1rem .4rem;font-size:.65rem;display:inline-block}.success-banner{color:#4ade80;background:linear-gradient(135deg,#4ade8026,#22c55e1a);border:1px solid #4ade804d;border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.85rem 1.1rem;font-size:.9rem;font-weight:600;animation:.3s slideIn;display:flex}@keyframes slideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.success-close,.error-close{color:#ffffff80;cursor:pointer;background:0 0;border:none;padding:0 .3rem;font-size:1.2rem}.success-close:hover,.error-close:hover{color:#fff}.error-banner{color:#f87171;background:linear-gradient(135deg,#dc262626,#b91c1c1a);border:1px solid #dc262659;border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.85rem 1rem;font-size:.9rem;font-weight:600;animation:.3s slideIn;display:flex}.challengers-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.85rem;display:grid}.challenger-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;align-items:center;gap:1rem;padding:1.25rem;transition:border-color .15s;display:flex}.challenger-card:hover{border-color:var(--gold-dark)}.challenger-avatar{background:var(--gold-gradient);width:48px;height:48px;color:var(--bg-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.2rem;font-weight:700;display:flex;overflow:hidden}.challenger-avatar img{object-fit:cover;width:100%;height:100%}.challenger-info{flex:1;min-width:0}.challenger-info h3{color:var(--text-primary);margin:0;font-size:.95rem;font-weight:700}.challenger-rank{color:var(--gold-bright);text-transform:uppercase;letter-spacing:.06em;margin:.15rem 0 0;font-size:.66rem;font-weight:700}.challenger-bio{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin:.25rem 0 0;font-size:.78rem;overflow:hidden}.challenges-list{flex-direction:column;gap:.85rem;display:flex}.challenge-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem;display:flex}.challenge-card.incoming{border-color:#d4a0174d}.challenge-header{align-items:center;gap:.85rem;display:flex}.challenge-avatar{background:var(--gold-gradient);width:42px;height:42px;color:var(--bg-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex;overflow:hidden}.challenge-avatar img{object-fit:cover;width:100%;height:100%}.challenge-header h3{color:var(--text-primary);margin:0;font-size:.9rem;font-weight:700}.challenge-meta{color:var(--text-muted);margin:.2rem 0 0;font-size:.75rem}.challenge-actions{flex-shrink:0;gap:.5rem;display:flex}.time-limit-options{flex-wrap:wrap;gap:.5rem;display:flex}.btn-danger{background:var(--red);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.5rem 1rem;font-weight:600;transition:opacity .15s}.btn-danger:hover{opacity:.85}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.error-boundary-page{justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.error-boundary-card{text-align:center;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;max-width:420px;padding:2.5rem 2rem}.error-boundary-icon{margin-bottom:1rem;font-size:3rem;display:block}.error-boundary-card h2{color:var(--text-primary);margin:0 0 .75rem;font-size:1.4rem}.error-boundary-message{color:var(--text-muted);word-break:break-word;margin-bottom:1.75rem;font-size:.85rem}
