*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0a0e1a;--surface: #111827;--surface2: #1a2236;--border: rgba(255,255,255,.08);--text: #e0e0e0;--muted: #666;--accent: #00ffaa;--accent2: #00ddff;--danger: #ff4444;--warn: #ffaa00}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:40px;width:100%;max-width:400px}.auth-card h1{font-size:24px;color:var(--accent);margin-bottom:4px}.auth-card .subtitle{color:var(--muted);font-size:14px;margin-bottom:24px}.auth-card .error{background:#ff44441a;color:var(--danger);padding:8px 12px;border-radius:8px;margin-bottom:16px;font-size:13px}.auth-card form{display:flex;flex-direction:column;gap:12px}.auth-card input{padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:14px;outline:none}.auth-card input:focus{border-color:var(--accent)}.auth-card button{padding:10px;background:var(--accent);color:var(--bg);border:none;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer}.auth-card button:hover{opacity:.9}.role-select{display:flex;gap:8px}.role-select label{flex:1;text-align:center;padding:8px;border-radius:8px;border:1px solid var(--border);cursor:pointer;font-size:13px;transition:all .2s}.role-select label.active{border-color:var(--accent);background:#00ffaa14;color:var(--accent)}.role-select input{display:none}.alt-link{margin-top:16px;font-size:13px;color:var(--muted);text-align:center}.dashboard{max-width:900px;margin:0 auto;padding:20px}.dash-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:20px;border-bottom:1px solid var(--border);margin-bottom:20px;flex-wrap:wrap;gap:12px}.dash-header h1{font-size:20px;color:var(--accent)}.user-badge{margin-left:12px;font-size:12px;color:var(--muted)}.header-actions{display:flex;gap:8px;align-items:center}.btn{padding:6px 14px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;border:none;transition:all .2s}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text)}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.btn-ghost{background:transparent;color:var(--muted)}.btn-ghost:hover{color:var(--text)}.btn-primary{background:var(--accent);color:var(--bg)}.btn-danger{background:var(--danger);color:#fff}.btn-sm{padding:4px 10px;font-size:11px}.muted{color:var(--muted);font-size:13px}.access-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:20px}.access-panel h3{font-size:14px;margin-bottom:8px}.access-panel h4{font-size:13px;margin-top:12px;margin-bottom:6px;color:var(--muted)}.access-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px}.session-list h2{font-size:16px;margin-bottom:12px}.session-card{display:block;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 18px;margin-bottom:8px;text-decoration:none;color:var(--text);transition:border-color .2s}.session-card:hover{border-color:#00ffaa4d;text-decoration:none}.session-top{display:flex;align-items:center;gap:10px;margin-bottom:6px}.ex-badge{font-weight:700;font-size:13px;letter-spacing:.5px}.live-badge{background:var(--danger);color:#fff;font-size:9px;font-weight:700;padding:2px 8px;border-radius:10px;letter-spacing:1px;animation:pulse-live 1s infinite alternate}@keyframes pulse-live{0%{opacity:.7}to{opacity:1}}.date{font-size:12px;color:var(--muted);margin-left:auto}.session-stats{display:flex;gap:16px;font-size:13px}.session-stats .score{font-weight:700}.session-detail{max-width:900px;margin:0 auto;padding:20px}.detail-header{display:flex;align-items:center;gap:16px;padding-bottom:16px;border-bottom:1px solid var(--border);margin-bottom:20px;flex-wrap:wrap}.back-link{color:var(--muted);font-size:14px}.back-link:hover{color:var(--text);text-decoration:none}.detail-title{font-size:18px;font-weight:700}.detail-summary{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.stat-card{flex:1;min-width:100px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;text-align:center}.stat-value{font-size:28px;font-weight:700}.stat-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:1px}.rep-table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:20px;overflow-x:auto}.rep-table-wrap h3{font-size:13px;color:var(--muted);margin-bottom:10px;text-transform:uppercase;letter-spacing:1px}.rep-table{width:100%;border-collapse:collapse;font-size:12px}.rep-table th{text-align:left;padding:6px 8px;color:var(--muted);border-bottom:1px solid var(--border);font-size:10px;text-transform:uppercase;letter-spacing:1px}.rep-table td{padding:6px 8px;border-bottom:1px solid rgba(255,255,255,.03)}.rep-table tr:hover td{background:#00ffaa08}.score-high{color:#0f8;font-weight:700}.score-mid{color:#fa0}.score-low{color:#f44}.feedback-cell{font-size:11px;color:var(--muted);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chart-container{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:20px}.chart-container h3{font-size:13px;color:var(--muted);margin-bottom:12px;text-transform:uppercase;letter-spacing:1px}.comment-section{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px}.comment-section h3{font-size:13px;color:var(--muted);margin-bottom:12px;text-transform:uppercase;letter-spacing:1px}.comment-list{max-height:300px;overflow-y:auto}.comment{padding:8px 12px;margin-bottom:8px;background:var(--bg);border-radius:8px}.comment.own{border-left:3px solid var(--accent)}.comment-header{display:flex;justify-content:space-between;margin-bottom:4px}.comment-header strong{font-size:12px}.comment-body{font-size:13px}.comment-form{display:flex;gap:8px;margin-top:12px}.comment-form input{flex:1;padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;outline:none}.comment-form input:focus{border-color:var(--accent)}.comment-form button{padding:8px 16px;background:var(--accent);color:var(--bg);border:none;border-radius:8px;font-weight:600;font-size:13px;cursor:pointer}.progress-page{max-width:900px;margin:0 auto;padding:20px}.progress-filters{display:flex;gap:10px;margin-bottom:20px}.progress-filters select{padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;outline:none}.loading{padding:40px;text-align:center;color:var(--muted)}.admin-role-select{padding:3px 6px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:11px;outline:none}.admin-role-select:focus{border-color:var(--accent)}.raw-data-block{background:#0d1117;color:#8b949e;font-family:Fira Code,monospace;font-size:11px;padding:12px 16px;margin:0;border-top:1px solid var(--border);max-height:300px;overflow:auto;white-space:pre-wrap;word-break:break-all}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}@media(max-width:600px){.dash-header{flex-direction:column;align-items:flex-start}.detail-summary{flex-direction:column}.stat-card{min-width:auto}}
