.login-page{align-items:center;background:radial-gradient(ellipse at center,#0f2027 0,#0f172a 60%);display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:2rem}.login-container{background:#1e293b;border:1px solid #334155;border-radius:16px;box-shadow:0 25px 60px #00000080;max-width:420px;padding:2.5rem;width:100%}.login-header{margin-bottom:2rem;text-align:center}.login-logo{font-size:3rem;margin-bottom:.5rem}.login-header h1{color:#f1f5f9;font-size:1.8rem;font-weight:800;margin-bottom:.3rem}.login-header h1 em{color:#60a5fa;font-style:normal}.login-quiz-name{background:#3b82f61f;border:1px solid #60a5fa4d;border-radius:20px;color:#60a5fa;display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:.12em;margin-bottom:.6rem;padding:.25rem .85rem;text-transform:uppercase}.login-header p{color:#64748b;font-size:.9rem}.login-tabs{background:#0f172a;border-radius:10px;display:flex;margin-bottom:1.5rem;padding:4px}.tab{background:none;border:none;border-radius:7px;flex:1 1;padding:.6rem}.tab.active{background:#3b82f6;color:#fff}.login-form{gap:1.2rem}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:.4rem}.form-group label{color:#94a3b8;font-size:.85rem;font-weight:600}.form-group input{background:#0f172a;border:1px solid #334155;border-radius:8px;color:#f1f5f9;font-family:Inter,sans-serif;font-size:.95rem;padding:.75rem 1rem;transition:border-color .2s}.form-group input:focus{border-color:#3b82f6;outline:none}.form-group input::placeholder{color:#475569}.form-select{-webkit-appearance:none;appearance:none;background:#0f172a;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%2364748b' d='M6 8 1 3h10z'/%3E%3C/svg%3E");background-position:right 1rem center;background-repeat:no-repeat;border:1px solid #334155;border-radius:8px;color:#f1f5f9;cursor:pointer;font-family:Inter,sans-serif;font-size:.95rem;padding:.75rem 1rem;transition:border-color .2s}.form-select:focus{border-color:#3b82f6;outline:none}.form-select option{background:#1e293b;color:#f1f5f9}.error-msg{background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;color:#f87171;font-size:.9rem;padding:.75rem 1rem}.login-btn{margin-top:.5rem;width:100%}.login-footer{color:#64748b;font-size:.85rem;margin-top:1.5rem;text-align:center}.login-footer span{color:#60a5fa;cursor:pointer;font-weight:600}.login-footer span:hover{text-decoration:underline}.login-features{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center;margin-top:2rem}.feature{align-items:center;background:#ffffff0a;border:1px solid #1e293b;border-radius:12px;display:flex;flex-direction:column;gap:.4rem;min-width:80px;padding:1rem;text-align:center}.feature span{font-size:1.5rem}.feature p{color:#64748b;font-size:.75rem;font-weight:500}.admin-link-wrap{margin-top:1.2rem;text-align:center}.admin-link{background:none;border:none;border-radius:4px;color:#334155;cursor:pointer;font-size:.75rem;padding:4px 8px;transition:color .2s}.admin-link:hover{color:#64748b}@media (max-width:480px){.login-page{padding:1rem}.login-container{padding:1.5rem}.login-header h1{font-size:1.4rem}.login-features{gap:.75rem}.feature{min-width:60px;padding:.75rem}.feature span{font-size:1.2rem}.feature p{font-size:.7rem}}.quiz-page{margin:0 auto;max-width:700px}.quiz-error,.quiz-loading{align-items:center;color:#94a3b8;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:300px}.quiz-header{justify-content:space-between;margin-bottom:.75rem}.quiz-header,.quiz-meta{align-items:center;display:flex}.quiz-meta{gap:1rem}.quiz-progress-text{color:#f1f5f9;font-weight:700}.quiz-answered{background:#1e293b;border-radius:20px;color:#64748b;font-size:.85rem;padding:.3rem .75rem}.quiz-timer{background:#1e293b;border:1px solid #334155;border-radius:10px;color:#60a5fa;font-size:1.3rem;font-weight:800;padding:.4rem 1rem}.quiz-timer.warning{animation:pulse 1s infinite;border-color:#f59e0b66;color:#f59e0b}.quiz-timer.danger{animation:pulse .5s infinite;border-color:#ef444466;color:#f87171}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.progress-bar{background:#1e293b;border-radius:3px;height:6px;margin-bottom:.5rem;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:3px;height:100%;transition:width .4s ease}.timer-bar-wrap{background:#1e293b;border-radius:3px;height:5px;margin-bottom:1.25rem;overflow:hidden}.timer-bar-fill{background:#22c55e;border-radius:3px;height:100%}.timer-bar-fill.warning{background:#f59e0b}.timer-bar-fill.danger{background:#ef4444}.question-card{background:#1e293b;border:1px solid #334155;border-radius:14px;margin-bottom:1.5rem;padding:1.75rem}.question-top{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.question-number{background:#3b82f626;color:#60a5fa}.question-number,.skip-badge{border-radius:6px;font-size:.8rem;font-weight:700;padding:.3rem .75rem}.skip-badge{animation:fadeIn .2s ease;background:#ef444426;color:#f87171}.difficulty-badge{border-radius:6px;font-size:.8rem;font-weight:700;padding:.3rem .75rem}.difficulty-easy{background:#22c55e26;color:#4ade80}.difficulty-medium{background:#eab30826;color:#facc15}.difficulty-hard{background:#ef444426;color:#f87171}@keyframes fadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.auto-skip-flash{animation:skipFlash .8s ease}@keyframes skipFlash{0%{background:#0000}30%{background:#ef444414}to{background:#0000}}.question-text{color:#f1f5f9;font-size:1.1rem;font-weight:600;line-height:1.6;margin-bottom:1.5rem}.options-list{display:flex;flex-direction:column;gap:.75rem}.option{align-items:center;background:#0f172a;border:1px solid #334155;border-radius:10px;color:#94a3b8;cursor:pointer;display:flex;font-size:.95rem;gap:1rem;padding:.85rem 1rem;text-align:left;transition:all .2s}.option:hover{background:#3b82f60d;border-color:#3b82f6;color:#e2e8f0}.option.selected{background:#3b82f61f;border-color:#3b82f6;color:#f1f5f9}.option-letter{align-items:center;background:#1e293b;border-radius:6px;color:#64748b;display:flex;font-size:.8rem;font-weight:700;height:28px;justify-content:center;min-width:28px}.option.selected .option-letter{background:#3b82f6;color:#fff}.quiz-nav{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.question-dots{display:flex;flex:1 1;flex-wrap:wrap;gap:.4rem;justify-content:center;margin:0 1rem}.dot{background:#1e293b;border:1px solid #334155;border-radius:6px;color:#64748b;cursor:pointer;font-size:.75rem;font-weight:700;height:30px;transition:all .2s;width:30px}.dot.active,.dot:hover{border-color:#3b82f6;color:#60a5fa}.dot.active{background:#3b82f626}.dot.done{background:#22c55e1a;border-color:#22c55e;color:#4ade80}.quiz-footer{align-items:center;display:flex;justify-content:space-between;margin-top:.5rem}.unanswered-warning{color:#f59e0b;font-size:.85rem}@media (max-width:600px){.quiz-nav{flex-direction:column;gap:.5rem}.question-dots{margin:0}.quiz-footer{align-items:stretch;flex-direction:column;gap:.75rem}.quiz-footer .btn{text-align:center;width:100%}.option{font-size:.88rem;padding:.75rem .85rem}}.results-page{margin:0 auto;max-width:720px}.score-summary{background:#1e293b;border:1px solid #334155;border-radius:16px;gap:2.5rem;margin-bottom:1.5rem;padding:2rem 2.5rem}.score-circle,.score-summary{align-items:center;display:flex}.score-circle{background:conic-gradient(#3b82f6 calc(var(--pct)*1%),#0f172a 0);border-radius:50%;flex-shrink:0;height:130px;justify-content:center;position:relative;width:130px}.score-circle:before{background:#1e293b;border-radius:50%;content:"";inset:10px;position:absolute}.score-inner{align-items:center;display:flex;flex-direction:column;gap:.1rem;position:relative;z-index:1}.score-pct{color:#f1f5f9;font-size:1.6rem;font-weight:800}.score-fraction{color:#64748b;font-size:.8rem;font-weight:600}.score-details h1{color:#f1f5f9;font-size:1.5rem;font-weight:800;margin-bottom:.3rem}.player-name{color:#64748b;font-size:.9rem;margin-bottom:.75rem}.grade-badge{border-radius:20px;display:inline-block;font-size:.9rem;font-weight:700;margin-bottom:1rem;padding:.4rem 1rem}.score-stats{display:flex;gap:1.5rem}.score-stat{align-items:center;display:flex;flex-direction:column;gap:.2rem}.s-val{font-size:1.4rem;font-weight:800}.s-val.correct{color:#4ade80}.s-val.wrong{color:#f87171}.s-val.pct{color:#60a5fa}.s-lbl{color:#64748b;font-size:.75rem;font-weight:500}.results-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.results-breakdown-title{color:#94a3b8;font-size:1.1rem;margin-bottom:1rem}.results-list{display:flex;flex-direction:column;gap:1rem}.result-item{background:#1e293b;border-left:4px solid #0000;border-radius:12px;padding:1.25rem 1.5rem}.result-item.correct{border-left-color:#22c55e}.result-item.incorrect{border-left-color:#ef4444}.result-header{align-items:center;display:flex;gap:.75rem;margin-bottom:.6rem}.result-num{background:#0f172a;color:#94a3b8;padding:.2rem .6rem}.result-badge,.result-num{border-radius:5px;font-size:.8rem;font-weight:700}.result-badge{padding:.2rem .7rem}.badge-correct{background:#22c55e1a;color:#4ade80}.badge-wrong{background:#ef44441a;color:#f87171}.result-question{color:#e2e8f0;font-weight:600;line-height:1.5;margin-bottom:.75rem}.result-answers{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.75rem}.answer-row{display:flex;font-size:.85rem;gap:.75rem}.answer-row span:first-child{color:#64748b;min-width:100px}.your-answer span:last-child{color:#f87171;font-weight:600}.correct-answer span:last-child{color:#4ade80;font-weight:600}.result-explanation{background:#ffffff08;border:1px solid #334155;border-radius:8px;color:#94a3b8;font-size:.85rem;line-height:1.5;padding:.6rem .9rem}.leaderboard-page{margin:0 auto;max-width:800px}.lb-loading{align-items:center;color:#94a3b8;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:300px}.spinner{animation:spin .8s linear infinite;border:3px solid #334155;border-radius:50%;border-top-color:#3b82f6;height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.lb-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1.5rem}.lb-header h1{color:#f1f5f9;font-size:1.8rem;font-weight:800}.lb-header p{color:#64748b;font-size:.9rem;margin-top:.25rem}.my-rank-banner{align-items:center;background:#3b82f61a;border:1px solid #3b82f64d;border-radius:10px;color:#94a3b8;display:flex;font-size:.9rem;gap:.75rem;margin-bottom:1.5rem;padding:.75rem 1.25rem}.my-rank-num{color:#60a5fa;font-size:1.2rem;font-weight:800}.lb-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem}.tab{background:#1e293b;border:1px solid #334155;border-radius:8px;color:#64748b;cursor:pointer;font-size:.9rem;font-weight:600;padding:.6rem 1.2rem;transition:all .2s}.tab:hover{border-color:#475569;color:#e2e8f0}.tab.active{background:#3b82f626;border-color:#3b82f6;color:#60a5fa}.podium{align-items:flex-end;background:#1e293b;border:1px solid #334155;border-radius:12px;display:flex;gap:1rem;justify-content:center;margin-bottom:2rem;padding:1.5rem}.podium-item{align-items:center;display:flex;flex-direction:column;gap:.3rem;min-width:100px}.podium-avatar{font-size:1.8rem}.podium-name{color:#e2e8f0;font-size:.85rem;font-weight:700;max-width:90px;overflow:hidden;text-align:center;text-overflow:ellipsis;white-space:nowrap}.podium-score{color:#64748b;font-size:.8rem}.podium-rank{font-size:1.5rem}.podium-bar{border-radius:4px 4px 0 0;opacity:.5;width:100%}.lb-table{background:#1e293b;border:1px solid #334155;border-collapse:collapse;border-radius:12px;overflow:hidden;width:100%}.lb-table th{background:#0f172a;border-bottom:1px solid #334155;color:#64748b;font-size:.8rem;font-weight:700;letter-spacing:.5px;padding:.9rem 1rem;text-align:left;text-transform:uppercase}.lb-table td{border-bottom:1px solid #1a2744;color:#94a3b8;font-size:.9rem;padding:.85rem 1rem}.lb-table tr:last-child td{border-bottom:none}.lb-table tr:hover td{background:#ffffff05}.lb-table tr.my-row td{background:#3b82f60f}.rank-cell{font-size:1.1rem;font-weight:800}.player-cell{align-items:center;display:flex;gap:.5rem}.player-name{color:#e2e8f0;font-weight:600}.you-badge{background:#3b82f626;border-radius:4px;font-size:.7rem;padding:.1rem .5rem}.score-cell,.you-badge{color:#60a5fa;font-weight:700}.acc-cell{color:#4ade80;font-weight:600}.lb-empty{align-items:center;background:#1e293b;border:1px solid #334155;border-radius:12px;color:#64748b;display:flex;flex-direction:column;gap:1rem;padding:3rem;text-align:center}@media (max-width:600px){.lb-table td:nth-child(4),.lb-table td:nth-child(5),.lb-table th:nth-child(4),.lb-table th:nth-child(5){display:none}.lb-table td,.lb-table th{font-size:.85rem;padding:.6rem .75rem}}.navbar{background:#0f172a;border-bottom:1px solid #1e293b;justify-content:space-between;padding:1rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.navbar,.navbar-brand{align-items:center;display:flex}.navbar-brand{cursor:pointer;gap:.6rem}.brand-logo{font-size:1.4rem}.brand-name{color:#f1f5f9;font-size:1.25rem;font-weight:800;letter-spacing:-.5px}.brand-name em{color:#60a5fa;font-style:normal}.navbar-links{display:flex;gap:.5rem}.nav-link{background:none;border:none;border-radius:8px;color:#64748b;cursor:pointer;font-size:.9rem;font-weight:500;padding:.5rem 1rem;transition:all .2s}.nav-link:hover{background:#1e293b;color:#e2e8f0}.nav-link.active{background:#3b82f626;color:#60a5fa}.user-info{align-items:flex-end;display:flex;flex-direction:column;line-height:1.2}.user-dept{color:#64748b;font-size:.7rem}.navbar-user{align-items:center;display:flex;gap:1rem}.user-badge{background:#1e293b;border:1px solid #334155;border-radius:20px;color:#94a3b8;font-size:.85rem;padding:.4rem .9rem}@media (max-width:768px){.navbar{flex-wrap:wrap;gap:.5rem;padding:.75rem 1rem}.navbar-brand{flex:1 1}.brand-name{font-size:1rem}.navbar-links{gap:.25rem;justify-content:center;order:3;width:100%}.nav-link{font-size:.8rem;padding:.4rem .7rem}.navbar-user{gap:.5rem}.user-info{display:none}.user-badge{font-size:.75rem;padding:.3rem .6rem}.btn.btn-danger{font-size:.8rem;padding:.4rem .7rem}}.admin-page{align-items:flex-start;background:#0f1117;display:flex;justify-content:center;min-height:100vh;padding:40px 16px}.admin-login-box{background:#1a1d2e;border:1px solid #2a2d3e;border-radius:12px;margin-top:80px;max-width:380px;padding:40px;text-align:center;width:100%}.admin-login-box h2{color:#fff;margin-bottom:8px}.admin-login-box p{color:#8b949e;margin-bottom:24px}.admin-login-box input{background:#0d1117;border:1px solid #30363d;border-radius:8px;box-sizing:border-box;color:#fff;font-size:14px;margin-bottom:16px;padding:12px 16px;width:100%}.admin-login-actions{display:flex;gap:10px;justify-content:center}.btn-admin-login{background:#238636;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 24px}.btn-admin-login:hover{background:#2ea043}.btn-back{background:#0000;border:1px solid #30363d;border-radius:8px;color:#8b949e;cursor:pointer;font-size:14px;padding:10px 16px}.btn-back:hover{border-color:#8b949e;color:#fff}.admin-panel{max-width:1000px;width:100%}.admin-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:24px}.admin-header h2{color:#fff;margin:0}.admin-header-actions{align-items:center;display:flex;gap:12px}.admin-count{color:#8b949e;font-size:14px}.btn-logout-admin{background:#da3633;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:13px;padding:8px 16px}.btn-logout-admin:hover{background:#f85149}.admin-error{background:#3d1f1f;border:1px solid #da3633;border-radius:8px;color:#f85149;font-size:14px;margin-bottom:16px;padding:10px 16px}.admin-table-wrap{border:1px solid #21262d;border-radius:12px;overflow-x:auto}.admin-table{border-collapse:collapse;font-size:14px;width:100%}.admin-table th{background:#161b22;color:#8b949e;font-weight:600;text-align:left}.admin-table td,.admin-table th{border-bottom:1px solid #21262d;padding:12px 16px}.admin-table td{color:#c9d1d9}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:#161b22}.admin-username{color:#58a6ff;font-family:monospace;font-size:12px}.btn-delete{background:#0000;border:1px solid #da3633;border-radius:6px;color:#f85149;cursor:pointer;font-size:12px;padding:5px 12px}.btn-delete:hover{background:#3d1f1f}.confirm-btns{display:flex;gap:6px}.btn-confirm-yes{background:#da3633;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:5px 10px}.btn-confirm-yes:hover{background:#f85149}.btn-confirm-no{background:#0000;border:1px solid #30363d;border-radius:6px;color:#8b949e;cursor:pointer;font-size:12px;padding:5px 10px}.btn-confirm-no:hover{color:#fff}@media (max-width:768px){.admin-page{padding:16px}.admin-header{align-items:flex-start;flex-direction:column}.admin-table td:nth-child(3),.admin-table td:nth-child(4),.admin-table th:nth-child(3),.admin-table th:nth-child(4){display:none}.admin-login-box{margin-top:40px;padding:24px}}.app{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1 1;margin:0 auto;max-width:1000px;padding:2rem;width:100%}.btn{border:none;border-radius:8px;cursor:pointer;font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;padding:.6rem 1.4rem;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.btn-primary:hover{box-shadow:0 4px 20px #3b82f666;transform:translateY(-1px)}.btn-outline{background:#0000;border:1.5px solid #3b82f666;color:#60a5fa}.btn-outline:hover{background:#3b82f61a;border-color:#60a5fa;transform:translateY(-1px)}.btn-secondary{background:#1e293b;border:1px solid #334155;color:#94a3b8}.btn-secondary:hover{background:#334155;color:#e2e8f0}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.btn-success{background:#22c55e;color:#fff}.btn-success:hover{background:#16a34a}.btn-large{font-size:1rem;padding:.85rem 2rem}.btn:disabled{box-shadow:none!important;cursor:not-allowed;opacity:.5;transform:none!important}.home-page{padding:1rem 0}.hero{background:linear-gradient(135deg,#1e293b,#0f172a);border:1px solid #1e3a5f;border-radius:16px;margin-bottom:2rem;padding:3rem 2rem;text-align:center}.hero-badge{background:#3b82f626;border:1px solid #3b82f64d;border-radius:20px;color:#60a5fa;display:inline-block;font-size:.85rem;font-weight:600;letter-spacing:.5px;margin-bottom:1.5rem;padding:.35rem 1rem}.hero-title{color:#f1f5f9;font-size:2.2rem;font-weight:800;margin-bottom:1rem}.highlight{color:#60a5fa}.hero-subtitle{color:#94a3b8;font-size:1.05rem;line-height:1.6;margin:0 auto 2rem;max-width:540px}.hero-stats{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center;margin-bottom:2.5rem}.stat-card{align-items:center;background:#ffffff0d;border:1px solid #1e3a5f;border-radius:12px;display:flex;flex-direction:column;gap:.3rem;min-width:90px;padding:1rem 1.5rem}.stat-icon,.stat-value{font-size:1.4rem}.stat-value{color:#60a5fa;font-weight:800}.stat-label{color:#64748b;font-size:.75rem;font-weight:500}.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.hero-dept{color:#60a5fa;font-size:.9rem;margin-bottom:.5rem;margin-top:-.5rem}.prefetch-hint{animation:pulse 1.5s infinite;color:#64748b;font-size:.85rem;margin-top:1rem}.prefetch-hint.ready{animation:none;color:#22c55e}.topic-cards h2{color:#94a3b8;font-size:1.2rem;margin-bottom:1rem}.topics-grid{display:flex;flex-wrap:wrap;gap:.75rem}.topic-pill{background:#1e293b;border:1px solid #334155;border-radius:8px;color:#94a3b8;font-size:.9rem;font-weight:500;padding:.5rem 1rem}@media (max-width:768px){.main-content{padding:1rem}.hero{padding:2rem 1rem}.hero-title{font-size:1.5rem}.hero-subtitle{font-size:.9rem}.hero-stats{gap:.75rem}.stat-card{min-width:70px;padding:.75rem 1rem}.stat-value{font-size:1.1rem}.hero-actions{align-items:stretch;flex-direction:column}.hero-actions .btn{text-align:center;width:100%}.score-summary{align-items:center;flex-direction:column;gap:1.5rem;padding:1.5rem 1rem}.score-circle{height:110px;width:110px}.score-details{text-align:center}.score-stats{justify-content:center}.results-actions{flex-direction:column}.results-actions .btn{text-align:center;width:100%}.answer-row{flex-direction:column;gap:.2rem}.answer-row span:first-child{min-width:0;min-width:auto}}.card{background:#1e293b;border:1px solid #334155;border-radius:12px;padding:1.5rem}*{box-sizing:border-box;margin:0;padding:0}body{background:#0f172a;color:#e2e8f0;font-family:Inter,sans-serif;min-height:100vh}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#1e293b}::-webkit-scrollbar-thumb{background:#3b82f6;border-radius:3px}