@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;600;700&display=swap";:root{--font-family: "Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--bg-color: #0f172a;--surface-color: rgba(30, 41, 59, .7);--surface-hover: rgba(51, 65, 85, .9);--primary-color: #3b82f6;--primary-hover: #2563eb;--accent-color: #10b981;--success-color: #10b981;--text-main: #f8fafc;--text-muted: #94a3b8;--border-color: rgba(255, 255, 255, .1);--error-color: #ef4444;--card-bg: var(--surface-color);color-scheme:dark;color:var(--text-main);background-color:var(--bg-color);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;min-width:320px;min-height:100vh;font-family:var(--font-family);background-color:var(--bg-color);background-image:radial-gradient(at 0% 0%,hsla(253,16%,7%,1) 0,transparent 50%),radial-gradient(at 50% 0%,hsla(225,39%,30%,.2) 0,transparent 50%),radial-gradient(at 100% 0%,hsla(339,49%,30%,.2) 0,transparent 50%);background-attachment:fixed;color:var(--text-main)}body{margin:0;display:flex;min-width:320px;min-height:100vh}#root{max-width:1024px;margin:0 auto;padding:1rem;width:100%}*{box-sizing:border-box}button{border-radius:12px;border:1px solid transparent;padding:.8em 1.5em;font-size:1rem;font-weight:600;font-family:inherit;background-color:var(--primary-color);color:#fff;cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none;touch-action:manipulation}button:hover{background-color:var(--primary-hover);transform:translateY(-1px)}button:active{transform:translateY(1px)}button:disabled{opacity:.5;cursor:not-allowed;transform:none}input{padding:1rem;font-size:1.2rem;border-radius:12px;border:2px solid var(--border-color);outline:none;width:100%;transition:border-color .2s;text-align:center}input:focus{border-color:var(--primary-color)}.card{background:var(--card-bg);border-radius:16px;padding:1.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;margin-bottom:1.5rem}h1,h2,h3{margin-top:0}@media(max-width:1024px){button{min-height:54px}}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1rem}.login-card{width:100%;max-width:480px;text-align:center;padding:3rem 2rem}.login-card h1{font-size:2.5rem;margin-bottom:.5rem;color:var(--primary-color)}.subtitle{color:var(--text-muted);margin-bottom:2.5rem;font-size:1.1rem}.input-group{margin-bottom:1.5rem}.input-group input{font-size:1.5rem;text-transform:uppercase;letter-spacing:2px}.submit-btn{width:100%;font-size:1.25rem;padding:1rem}.error-message{color:#ef4444;margin-bottom:1.5rem;font-weight:500;padding:.75rem;background-color:#fef2f2;border-radius:8px}.dashboard{padding:1rem;max-width:1200px;margin:0 auto}.dash-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1rem 1.5rem;background:var(--surface-color);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:20px;box-shadow:0 10px 30px #0003}.user-info h2{margin:0;color:var(--text-main);font-weight:300}.user-info h2 strong{color:var(--primary-color);font-weight:600}.role-badge{display:inline-block;background:#3b82f61a;color:var(--primary-color);padding:.25rem .75rem;border-radius:999px;font-size:.875rem;font-weight:500;text-transform:uppercase;margin-top:.5rem}.logout-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-main)}.logout-btn:hover{background:#ffffff1a;transform:translateY(-1px)}.categories-nav{display:flex;gap:1rem;margin-bottom:2rem;overflow-x:auto;padding-bottom:.5rem;-webkit-overflow-scrolling:touch}.cat-btn{padding:12px 24px;background:var(--surface-color);border:1px solid var(--border-color);border-radius:20px;font-size:1.1rem;color:var(--text-muted);white-space:nowrap;font-weight:400}.cat-btn:hover{background:var(--surface-hover)}.cat-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff;font-weight:600}.players-grid{display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.player-card{background:var(--surface-color);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:2px solid var(--error-color);border-radius:20px;padding:24px;display:flex;flex-direction:column;gap:20px;position:relative;overflow:hidden;transition:transform .2s,box-shadow .2s,border-color .2s}.player-card.status-partial{border-color:#fbbf24}.player-card.status-complete{border-color:var(--accent-color)}.player-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:transparent}.player-card.success-pulse{animation:voteHighlight 1s ease-out forwards}@keyframes voteHighlight{0%{border-color:var(--accent-color);box-shadow:0 0 15px var(--accent-color)}50%{border-color:var(--accent-color);box-shadow:0 0 25px var(--accent-color)}to{border-color:var(--border-color);box-shadow:0 10px 30px #0003}}.card-header{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:0;border-bottom:none;margin-bottom:0}.player-meta{display:flex;align-items:center;gap:1rem}.position{background:var(--primary-color);color:#fff;min-width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-weight:700;font-size:1.2rem}.player-meta h3{font-size:1.5rem;margin-bottom:0;text-transform:capitalize}.ranking-badge{background:#ffffff1a;color:var(--text-main);padding:4px 10px;border-radius:12px;font-size:.9rem;font-weight:600;margin-left:10px;border:1px solid rgba(255,255,255,.2);display:inline-flex;align-items:center;white-space:nowrap}.ranking-badge.rank-1{background:#fbbf2433;color:#fbbf24;border-color:#fbbf24}.ranking-badge.rank-2{background:#9ca3af33;color:#e5e7eb;border-color:#9ca3af}.ranking-badge.rank-3{background:#b4530933;color:#f59e0b;border-color:#b45309}.song-info{text-align:right;text-transform:capitalize}.song-title{display:block;font-weight:600;color:var(--text-main);font-size:1.1rem}.song-artist{color:var(--text-muted);font-size:.9rem}.card-parameters{display:flex;flex-direction:row;gap:12px;margin-top:1rem;justify-content:center}.param-btn{flex:1;min-width:0;background:#0000004d;border:1px solid var(--border-color);border-radius:12px;padding:10px 4px;display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:all var(--transition-fast)}.param-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.param-btn:not(:disabled):hover{background:#3b82f61a;border-color:#3b82f680;transform:translateY(-2px)}.param-name{font-size:.75rem;color:var(--text-muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.param-value{font-size:1.6rem;font-weight:700;color:var(--text-main);width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#ffffff0d}.param-btn.voted .param-value{background:var(--accent-color);color:#fff;box-shadow:0 0 10px #10b9814d}.modal-vote-controls{display:grid;grid-template-columns:repeat(5,1fr);gap:15px;margin:20px 0 10px}.modal-score-btn{background:#ffffff0d;border:2px solid var(--border-color);color:#fff;font-size:1.6rem;font-weight:700;border-radius:14px;padding:15px 0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-family:var(--font-family)}.modal-score-btn:hover{background:#ffffff1a;transform:scale(1.05)}.modal-score-btn.selected{background:var(--accent-color);border-color:var(--accent-color);box-shadow:0 0 20px #10b98166;transform:scale(1.1)}.modal-score-btn:disabled{opacity:.5;transform:none;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:100;display:flex;justify-content:center;align-items:center}.modal{width:90%;max-width:500px;background:var(--surface-color);border:1px solid var(--border-color);border-radius:20px;padding:30px;position:relative;box-shadow:0 20px 40px #00000080}.btn-close{position:absolute;top:15px;right:15px;background:#ffffff1a;border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;transition:background .2s;padding:0}.btn-close:hover{background:#fff3}.modal-header{text-align:center;margin-bottom:30px}.modal-header h3{font-size:1.8rem;margin-bottom:10px;text-transform:capitalize}.highlight-text{font-size:1.2rem;color:var(--primary-color);font-weight:600;text-transform:uppercase;letter-spacing:1px}.card-footer{margin-top:auto;padding-top:1rem;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.total-score{font-size:1.1rem;color:var(--text-muted);display:flex;align-items:center;text-transform:uppercase;letter-spacing:1px}.total-score.complete{color:var(--text-main)}.total-score strong{font-size:1.8rem;font-weight:700;margin-left:.5rem;color:var(--primary-color)}.total-score.complete strong{color:var(--accent-color)}.saving-indicator{color:var(--primary-color);font-weight:500}.success-indicator{color:var(--accent-color);font-weight:500}.empty-state{text-align:center;padding:3rem;color:var(--text-muted);font-size:1.2rem;background:var(--surface-color);border-radius:20px;grid-column:1 / -1}@media(max-width:768px){.players-grid{grid-template-columns:1fr}}.admin-dashboard{padding:1rem;max-width:1400px;margin:0 auto}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1rem 1.5rem;background:var(--surface-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:20px;box-shadow:0 10px 30px #0003}.admin-header h1{margin:0;font-size:1.4rem;font-weight:600;color:var(--text-main)}.admin-header-actions{display:flex;gap:12px;align-items:center}.btn-export{background:#10b9811a;border:2px solid var(--accent-color);color:var(--accent-color);padding:12px 24px;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}.btn-export:hover{background:#10b98133;transform:translateY(-1px)}.btn-logout-admin{background:transparent;border:1px solid var(--border-color);color:var(--text-main);padding:12px 20px;border-radius:12px;cursor:pointer;transition:all .2s}.btn-logout-admin:hover{background:#ffffff14}.admin-stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:2rem}.stat-card{background:var(--surface-color);border:1px solid var(--border-color);border-radius:16px;padding:20px 24px;text-align:center}.stat-label{font-size:.85rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.stat-value{font-size:2.2rem;font-weight:700;color:var(--primary-color)}.stat-value.complete{color:var(--accent-color)}.admin-section-title{font-size:1.1rem;font-weight:600;color:var(--text-main);text-transform:uppercase;letter-spacing:1px;margin-bottom:1rem;border-left:4px solid var(--primary-color);padding-left:12px}.judges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-bottom:2.5rem}.judge-card{background:var(--surface-color);border:2px solid var(--border-color);border-radius:16px;padding:18px 20px;transition:border-color .3s}.judge-card.complete{border-color:var(--accent-color)}.judge-card.behind{border-color:#f59e0b}.judge-name{font-size:1.1rem;font-weight:600;color:var(--text-main);margin-bottom:12px}.judge-progress-bar-wrap{background:#ffffff12;border-radius:8px;height:8px;overflow:hidden;margin-bottom:8px}.judge-progress-bar{height:100%;border-radius:8px;background:var(--primary-color);transition:width .5s ease}.judge-card.complete .judge-progress-bar{background:var(--accent-color)}.judge-card.behind .judge-progress-bar{background:#f59e0b}.judge-progress-text{font-size:.85rem;color:var(--text-muted);display:flex;justify-content:space-between}.judge-status-badge{display:inline-block;margin-top:10px;padding:3px 10px;border-radius:20px;font-size:.8rem;font-weight:600}.badge-complete{background:#10b98126;color:var(--accent-color)}.badge-behind{background:#f59e0b26;color:#f59e0b}.admin-tabs{display:flex;gap:10px;margin-bottom:1.5rem;overflow-x:auto}.admin-tab{padding:10px 22px;background:var(--surface-color);border:1px solid var(--border-color);border-radius:20px;font-size:1rem;color:var(--text-muted);cursor:pointer;white-space:nowrap;transition:all .2s}.admin-tab.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff;font-weight:600}.rankings-table-wrap{overflow-x:auto;border-radius:16px;border:1px solid var(--border-color)}.rankings-table{width:100%;border-collapse:collapse;background:var(--surface-color)}.rankings-table th{background:#3b82f633;color:var(--text-muted);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-color)}.rankings-table th.center{text-align:center}.rankings-table td{padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.04);color:var(--text-main);font-size:.95rem}.rankings-table tr:last-child td{border-bottom:none}.rankings-table tr:hover td{background:#ffffff08}.rank-pos{font-weight:700;font-size:1.2rem;color:var(--text-muted);text-align:center}.rank-1 .rank-pos{color:#fbbf24}.rank-2 .rank-pos{color:#9ca3af}.rank-3 .rank-pos{color:#cd7c2f}.player-name-cell{font-weight:600;display:flex;align-items:center;gap:8px}.semaphore{display:inline-block;width:12px;height:12px;border-radius:50%;flex-shrink:0;box-shadow:0 0 6px currentColor}.semaphore-red{background:#ef4444;color:#ef4444}.semaphore-yellow{background:#f59e0b;color:#f59e0b}.semaphore-green{background:#10b981;color:#10b981}.song-cell{color:var(--text-muted);font-size:.9rem}.total-score-cell{font-size:1.4rem;font-weight:700;color:var(--accent-color);text-align:center}.judge-score-cell{text-align:center}.judge-score-pill{display:inline-block;padding:3px 12px;border-radius:20px;font-weight:600;font-size:.9rem;background:#ffffff12}.judge-score-pill.missing{background:#ef444426;color:#f87171;font-size:.75rem}.loading-admin{text-align:center;padding:4rem;color:var(--text-muted);font-size:1.2rem}.error-admin{text-align:center;padding:2rem;color:#f87171;background:#ef44441a;border-radius:12px;margin:1rem 0}.refresh-btn{background:#3b82f61a;border:1px solid var(--primary-color);color:var(--primary-color);padding:8px 16px;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .2s;margin-left:12px}.refresh-btn:hover{background:#3b82f633}
