*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#1a1a2e;color:#fff;min-height:100vh}h1{font-size:2.5rem;color:#e94560;text-align:center;margin-bottom:1rem}h2{font-size:1.5rem;margin-bottom:1rem}.loading{display:flex;align-items:center;justify-content:center;height:100vh;font-size:1.5rem}.auth-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem}.auth-page form{background:#16213e;padding:2rem;border-radius:12px;width:100%;max-width:400px;display:flex;flex-direction:column;gap:1rem}input[type=text],input[type=email],input[type=password],select{padding:.75rem 1rem;border:2px solid #0f3460;border-radius:8px;background:#1a1a2e;color:#fff;font-size:1rem;outline:none;transition:border-color .2s}input:focus,select:focus{border-color:#e94560}button{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .2s;background:#e94560;color:#fff}button:hover{opacity:.9}button:disabled{opacity:.5;cursor:not-allowed}button.danger{background:#533;color:#e94560}button.primary{background:#e94560}a{color:#e94560;text-decoration:none}.error{color:#e94560;background:#e945601a;padding:.5rem 1rem;border-radius:8px;font-size:.9rem}.dashboard{max-width:800px;margin:0 auto;padding:2rem}.dashboard header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.dashboard header h1{margin-bottom:0}.dashboard header div{display:flex;align-items:center;gap:1rem}.upload-section{background:#16213e;padding:1.5rem;border-radius:12px;margin-bottom:2rem}.upload-section form{display:flex;flex-direction:column;gap:.75rem}.quiz-list ul{list-style:none;display:flex;flex-direction:column;gap:.75rem}.quiz-list li{background:#16213e;padding:1rem 1.5rem;border-radius:12px;display:flex;justify-content:space-between;align-items:center}.quiz-list li div{display:flex;align-items:center;gap:1rem}.quiz-list li span{color:#888;font-size:.9rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:#16213e;padding:2rem;border-radius:12px;width:90%;max-width:450px;display:flex;flex-direction:column;gap:1rem}.modal label{font-weight:600;font-size:.9rem;color:#aaa}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}input[type=file]{color:#888}input[type=file]::file-selector-button{padding:.5rem 1rem;border:2px solid #0f3460;border-radius:8px;background:#1a1a2e;color:#fff;cursor:pointer;margin-right:1rem}.game-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center}.room-code{margin:2rem 0}.room-code .code{font-size:5rem;font-weight:900;color:#e94560;letter-spacing:.3em;display:block;margin:.5rem 0}.join-url{color:#888;font-size:1.2rem}.player-chips{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin:1rem 0}.player-chip{background:#0f3460;padding:.5rem 1rem;border-radius:20px;font-weight:600}.start-btn{margin-top:2rem;padding:1rem 3rem;font-size:1.5rem;border-radius:12px;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.player-lobby .waiting{color:#888;font-size:1.2rem;margin:1rem 0}.timer{width:100%;max-width:600px;height:12px;background:#16213e;border-radius:6px;overflow:hidden;position:relative;margin-bottom:1.5rem}.timer-bar{height:100%;border-radius:6px;transition:width 1s linear}.timer-text{position:absolute;right:0;top:-2rem;font-size:1.5rem;font-weight:700}.timer-text.urgent{color:#e94560}.question-header{width:100%;max-width:800px;margin-bottom:1rem}.question-count{color:#888;font-size:1rem;display:block;margin-bottom:.5rem}.question-text{font-size:2rem;margin-bottom:2rem;max-width:800px}.pick-answer{font-size:2rem;margin-bottom:2rem;color:#888}.host-options{display:grid;grid-template-columns:1fr 1fr;gap:1rem;width:100%;max-width:800px}.host-option{background:#16213e;padding:1.5rem;border-radius:12px;font-size:1.2rem;text-align:left;border-left:6px solid}.answered-status{margin-top:1.5rem;width:100%;max-width:800px}.answered-count{color:#888;font-size:1.1rem;margin-bottom:.5rem}.answered-chips{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.answered-chip{background:#45e96b33;color:#45e96b;padding:.3rem .8rem;border-radius:16px;font-size:.85rem;font-weight:600;animation:chipAppear .3s ease-out}@keyframes chipAppear{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.answer-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:1rem;width:100%;max-width:500px;flex:1}.answer-btn{border:none;border-radius:12px;font-size:1rem;font-weight:600;color:#fff;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;transition:transform .1s,opacity .2s;padding:2rem 1rem;min-height:120px}.answer-btn:active:not(:disabled){transform:scale(.95)}.answer-btn .shape{font-size:2rem}.answer-btn .label{font-size:.9rem;line-height:1.2}.answer-btn.selected{outline:4px solid #fff;transform:scale(.95)}.answer-btn.correct{outline:4px solid #45e96b}.answer-btn.wrong{opacity:.4}.answer-btn:disabled{cursor:not-allowed;opacity:.6}.answer-feedback{padding:2rem;border-radius:12px;margin:1rem 0}.answer-feedback.correct{background:#45e96b26;color:#45e96b}.answer-feedback.wrong{background:#e9456026;color:#e94560}.answer-feedback h2{font-size:2rem}.answer-feedback p{font-size:1.2rem;margin-top:.5rem}.correct-answer{font-size:1.8rem;font-weight:700;color:#45e96b;background:#45e96b1a;padding:1rem 2rem;border-radius:12px;margin:1rem 0}.stats{color:#888;font-size:1.1rem;margin-bottom:1.5rem}.next-btn{margin-top:1.5rem;padding:1rem 3rem;font-size:1.2rem}.scoreboard{width:100%;max-width:400px;margin:1rem 0}.scoreboard ol{list-style:none}.scoreboard-entry{display:flex;align-items:center;gap:1rem;padding:.5rem 1rem;background:#16213e;border-radius:8px;margin-bottom:.5rem}.scoreboard-entry .position{color:#888;width:2rem}.scoreboard-entry .name{flex:1}.scoreboard-entry .score{font-weight:700;color:#e9a945}.podium{text-align:center}.podium-entries{display:flex;justify-content:center;align-items:flex-end;gap:1rem;margin:2rem 0}.podium-entry{background:#16213e;border-radius:12px;padding:1.5rem 2rem;display:flex;flex-direction:column;align-items:center;gap:.5rem}.podium-1{order:2;transform:scale(1.15)}.podium-2{order:1}.podium-3{order:3}.podium-entry .medal{font-size:3rem}.podium-entry .name{font-size:1.2rem;font-weight:700}.podium-entry .score{color:#e9a945}.podium-rest{max-width:400px;margin:1rem auto}.podium-rest-entry{display:flex;justify-content:space-between;padding:.5rem 1rem;background:#16213e;border-radius:8px;margin-bottom:.5rem}
