:root{--bg: #0f1419;--bg-elevated: #1a2332;--surface: rgba(26, 35, 50, .72);--border: rgba(255, 255, 255, .08);--text: #e8eef4;--text-muted: #8b9cb3;--primary: #3b82f6;--primary-hover: #60a5fa;--success: #22c55e;--danger: #ef4444;--radius: 14px;--shadow: 0 8px 32px rgba(0, 0, 0, .35);--transition: .2s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box}html,body,#root{min-height:100%}@keyframes bgDrift{0%,to{transform:translate(0) scale(1)}33%{transform:translate(2%,-1%) scale(1.02)}66%{transform:translate(-1%,2%) scale(.98)}}@keyframes bgPulse{0%,to{opacity:.4}50%{opacity:.7}}body{margin:0;font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;position:relative;min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;inset:-50%;z-index:-1;background-image:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(59,130,246,.18),transparent 50%),radial-gradient(ellipse 60% 40% at 100% 100%,rgba(139,92,246,.12),transparent 50%),radial-gradient(ellipse 50% 60% at 0% 80%,rgba(59,130,246,.06),transparent 45%);background-size:100% 100%;animation:bgDrift 50s ease-in-out infinite;pointer-events:none}body:after{content:"";position:fixed;inset:0;z-index:-1;background:radial-gradient(ellipse 100% 80% at 50% 50%,transparent 0%,rgba(15,23,42,.3) 100%);animation:bgPulse 24s ease-in-out infinite;pointer-events:none}@media(prefers-reduced-motion:reduce){body:before,body:after{animation:none}}a{color:var(--primary);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--primary-hover)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-6px)}40%,80%{transform:translate(6px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.app-shell{min-height:100vh;display:flex;flex-direction:column}.glass{background:var(--surface);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.card-hover{transition:transform var(--transition),box-shadow var(--transition)}.card-hover:hover{transform:translateY(-4px);box-shadow:0 16px 48px #0006}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1.25rem;border:none;border-radius:10px;font-weight:600;font-size:.95rem;cursor:pointer;transition:transform var(--transition),filter var(--transition)}.btn:active{transform:scale(.98)}.btn-primary{background:linear-gradient(135deg,var(--primary),#6366f1);color:#fff}.btn-primary:hover{filter:brightness(1.1)}.btn:disabled,.btn[disabled]{opacity:.55;cursor:not-allowed;filter:grayscale(.4)}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.btn-ghost:hover{background:#ffffff0f;color:var(--text)}.btn-danger{background:var(--danger);color:#fff}.input{width:100%;padding:.75rem 1rem;border:1px solid var(--border);border-radius:10px;background:#00000040;color:var(--text);font-size:1rem;transition:border-color var(--transition),box-shadow var(--transition)}.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f633}.input::placeholder{color:var(--text-muted)}label{display:block;margin-bottom:.35rem;font-size:.875rem;color:var(--text-muted)}.container-narrow{max-width:480px;margin:0 auto;padding:1.5rem}.page-enter{animation:slideUp .4s ease-out both}.error-page-wrap{max-width:960px;margin:0 auto;padding:1.5rem}.error-title{font-size:1.6rem;font-weight:700;margin:0 0 .6rem}.error-subtitle{color:var(--text-muted);margin:0 0 1.5rem;font-size:.95rem;line-height:1.6}.nav-bar{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--border);background:#0f1419cc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.nav-brand{font-weight:800;font-size:1.15rem;color:var(--text)}.nav-links{display:flex;align-items:center;gap:1rem}.nav-links a,.nav-links button{color:var(--text-muted);background:none;border:none;cursor:pointer;font-size:.95rem}.nav-links a:hover,.nav-links button:hover{color:var(--text)}.nav-session-remaining{font-size:.8rem;color:var(--text-muted);font-variant-numeric:tabular-nums;margin-right:.25rem}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease}.modal-content{width:100%;max-width:520px;max-height:90vh;overflow:auto;padding:1.5rem}.toast-wrap{position:fixed;bottom:1.5rem;right:1.5rem;z-index:1100;display:flex;flex-direction:column;gap:.5rem}.toast{padding:.85rem 1.25rem;border-radius:10px;background:var(--bg-elevated);border:1px solid var(--border);box-shadow:var(--shadow);animation:slideUp .3s ease}.toast.success{border-left:4px solid var(--success)}.toast.error{border-left:4px solid var(--danger)}.form-error{margin-bottom:1rem;padding:.85rem 1rem;border-radius:10px;background:#1e293b80;border:1px solid rgba(148,163,184,.2);color:var(--text-muted);font-size:.9rem}.tabs{display:flex;gap:.25rem;border-bottom:1px solid var(--border);margin-bottom:1.25rem}.tab{padding:.65rem 1rem;background:none;border:none;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--transition),border-color var(--transition)}.tab:hover{color:var(--text)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}table{width:100%;border-collapse:collapse}th,td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border)}th{color:var(--text-muted);font-weight:600;font-size:.8rem;text-transform:uppercase}tr:hover td{background:#ffffff08}.skeleton{background:linear-gradient(90deg,var(--bg-elevated) 25%,rgba(255,255,255,.06) 50%,var(--bg-elevated) 75%);background-size:200% 100%;animation:pulse 1.2s ease-in-out infinite;border-radius:8px}.assignment-layout{display:grid;grid-template-columns:1fr 380px;gap:1.5rem;padding:1.5rem;max-width:1100px;margin:0 auto;align-items:start}.assignment-info-card{padding:1.5rem}.assignment-info-card--scrolls{position:sticky;top:1rem}@media(max-width:768px){.assignment-layout{grid-template-columns:1fr}.assignment-right{order:-1}}.assignment-markdown{color:var(--text)}.assignment-markdown h1{font-size:1.4rem;font-weight:700;color:var(--text);margin:1rem 0 .5rem;padding-bottom:.35rem;border-bottom:1px solid var(--border)}.assignment-markdown h1:first-child{margin-top:0}.assignment-markdown h2{font-size:1.2rem;font-weight:600;color:var(--text);margin:1rem 0 .5rem}.assignment-markdown h3{font-size:1.05rem;font-weight:600;color:var(--text);margin:.85rem 0 .4rem}.assignment-markdown h4,.assignment-markdown h5,.assignment-markdown h6{font-size:1rem;font-weight:600;color:var(--text-muted);margin:.75rem 0 .35rem}.assignment-markdown p{margin:.5rem 0}.assignment-markdown strong{font-weight:700;color:var(--text)}.assignment-markdown em{font-style:italic;color:var(--text-muted)}.assignment-markdown a{color:var(--primary);text-decoration:underline}.assignment-markdown a:hover{color:var(--primary-hover)}.assignment-markdown code{font-family:ui-monospace,Cascadia Code,Source Code Pro,Menlo,Consolas,monospace;font-size:.88em;padding:.2em .4em;border-radius:6px;background:#1e293be6;color:#e2e8f0;border:1px solid var(--border)}.assignment-markdown pre{margin:.75rem 0;padding:1rem;border-radius:8px;background:#0f172af2;border:1px solid var(--border);overflow-x:auto}.assignment-markdown pre code{padding:0;font-size:.85rem;line-height:1.5}.assignment-markdown pre code:not([class*=language-]){background:none;border:none}.assignment-markdown blockquote{margin:.75rem 0;padding:.5rem 1rem;border-left:4px solid var(--primary);background:#3b82f614;color:var(--text);border-radius:0 8px 8px 0}.assignment-markdown ul,.assignment-markdown ol{margin:.5rem 0;padding-left:1.5rem}.assignment-markdown li{margin:.25rem 0}.assignment-markdown hr{margin:1rem 0;border:none;border-top:1px solid var(--border)}.timer-block{display:flex;align-items:center;gap:10px;padding:.85rem 1rem;border-radius:10px;background:#0f172a99;border:1px solid rgba(59,130,246,.3);margin-bottom:1rem;color:var(--text);transition:border-color .2s ease,background .2s ease}.timer-block-inner{display:flex;flex-direction:column;gap:6px;width:100%}.timer-block--urgent{border-color:#3b82f64d;box-shadow:none}.timer-segments{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.timer-segment{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:2.5rem;padding:.35rem .5rem;border-radius:8px;background:var(--bg-elevated);border:1px solid var(--border);transition:opacity .15s ease}.timer-block--urgent .timer-segment{border-color:#f59e0b33}.timer-number{font-size:1.1rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:.02em;line-height:1.2;color:var(--text)}.timer-unit{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;margin-top:2px}.timer-separator{font-size:1rem;font-weight:700;color:var(--text-muted);opacity:.6;padding:0 2px}.timer-value{font-size:1.15rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:.02em}.timer-warn{color:#f59e0b}.timer-closed{color:var(--danger)}.timer-progress-wrap{position:relative;width:100%;height:10px;border-radius:999px;background:#ffffff0f;overflow:hidden}.timer-progress-bar{position:absolute;inset:0;width:0%;background:linear-gradient(90deg,var(--primary),#6366f1);box-shadow:0 0 8px #3b82f680,0 0 20px #6366f140;transition:width .4s ease-out}.timer-progress-bar--warn{background:linear-gradient(90deg,#f59e0b,#ef4444);box-shadow:0 0 8px #f59e0b99,0 0 20px #ef44444d}.timer-label{font-size:1.05rem;font-weight:700;font-variant-numeric:tabular-nums}.timer-closed-text{font-size:.95rem;font-weight:600;color:var(--danger)}.timer-label.timer-long{color:#4ade80}.timer-label.timer-medium{color:#fbbf24}.timer-label.timer-short{color:#f87171}.timer-label.timer-pending{color:var(--text-muted)}.timer-label.timer-closed{color:var(--danger)}.status-badge.timer-long{color:#4ade80}.status-badge.timer-medium{color:#fbbf24}.status-badge.timer-short{color:#f87171;background:#f8717126;border:1px solid rgba(248,113,113,.35)}.status-badge.timer-pending{color:var(--text-muted)}.status-badge.timer-closed{color:var(--danger)}.timer-warning-text{font-size:.8rem;color:var(--text-muted);margin:.35rem 0 0;padding-bottom:30px}.info-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:.75rem}.status-badge{display:inline-block;padding:.25rem .65rem;border-radius:20px;font-size:.78rem;font-weight:600;letter-spacing:.02em}.status-open{background:#22c55e26;color:#4ade80;border:1px solid rgba(34,197,94,.3)}.status-closing-soon{background:#f59e0b26;color:#fbbf24;border:1px solid rgba(245,158,11,.3)}.status-closed{background:#ef444426;color:#f87171;border:1px solid rgba(239,68,68,.3)}.status-pending{background:#8b9cb31f;color:var(--text-muted);border:1px solid var(--border)}.ext-badge{display:inline-block;padding:.2rem .55rem;border-radius:6px;font-size:.8rem;font-weight:600;background:#6366f126;color:#a5b4fc;border:1px solid rgba(99,102,241,.3);font-family:Courier New,monospace}.dropzone-root{padding:1.75rem;text-align:center;border:2px dashed var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .2s,background .2s;background:#00000026}.dropzone-root[data-drag=true]{border-color:var(--primary);background:#3b82f60f}.dropzone-root[data-filled=true]{cursor:default;border-style:solid;border-color:#22c55e66;background:#22c55e0a}.dropzone-upload-icon{opacity:.5;margin-bottom:8px;color:var(--primary)}.dropzone-hint{margin:0 0 .35rem;color:var(--text-muted);font-size:.9rem}.dropzone-accept-hint{margin:0;font-size:.78rem;color:var(--text-muted);opacity:.7}.dropzone-file-info{display:flex;align-items:center;gap:12px;text-align:left}.dropzone-file-icon{color:var(--primary);flex-shrink:0}.dropzone-file-meta{flex:1;min-width:0}.dropzone-filename{display:block;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.95rem}.dropzone-filesize{font-size:.78rem;color:var(--text-muted)}.dropzone-clear{flex-shrink:0;padding:.35rem!important}.twofa-gate{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;padding:2rem;text-align:center}.twofa-gate h2{margin:0 0 .75rem}.submit-success-banner{display:flex;align-items:center;gap:10px;padding:.85rem 1.25rem;border-radius:10px;background:#22c55e1f;border:1px solid rgba(34,197,94,.3);color:#4ade80;font-weight:600;margin-bottom:1rem}.verify-key-badge{display:inline-flex;align-items:center;gap:4px;padding:.2rem .55rem;border-radius:6px;font-family:Courier New,monospace;font-size:.8rem;background:#6366f11f;color:#a5b4fc;border:1px solid rgba(99,102,241,.3);cursor:default}.verify-expand{margin-top:.5rem;padding:.75rem;border-radius:10px;background:#0f172acc;border:1px solid var(--border)}.verify-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:.4rem;font-size:.82rem}.verify-row:last-child{margin-bottom:0}.verify-label{font-weight:600;color:var(--text-muted);min-width:90px;flex-shrink:0;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;padding-top:2px}.verify-value{font-family:Courier New,monospace;word-break:break-all;color:var(--text);flex:1}.account-layout{display:grid;grid-template-columns:280px minmax(0,1fr);gap:1.5rem;align-items:flex-start}@media(max-width:768px){.account-layout{grid-template-columns:1fr}}.profile-card{padding:1.5rem;display:flex;flex-direction:column;gap:.75rem}.avatar-circle{width:64px;height:64px;border-radius:999px;background:radial-gradient(circle at 30% 20%,#60a5fa,#1d4ed8);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.8rem;font-weight:700;margin-bottom:.5rem}.avatar-circle span{transform:translateY(2px)}.profile-username{font-weight:600}.profile-fullname{font-size:.9rem;color:var(--text-muted)}.profile-badges{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.5rem}.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:999px;font-size:.78rem;border:1px solid var(--border);color:var(--text-muted)}.badge-success{border-color:#22c55e66;background:#22c55e29;color:#4ade80}.badge-danger{border-color:#ef444466;background:#ef44441f;color:#f87171}.badge-ghost{background:#0f172a80}.account-tabs{display:flex;gap:.25rem;border-bottom:1px solid var(--border);margin:-.25rem 0 1.25rem}.account-tabs .tab{padding:.65rem 1rem;border:none;background:none;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;font-size:.9rem}.account-tabs .tab.active{color:var(--primary);border-bottom-color:var(--primary)}.security-steps{display:flex;flex-direction:column;gap:1rem}.security-step{padding-top:.5rem}.copy-field{padding:.6rem .8rem;border-radius:8px;border:1px dashed var(--border);background:#0f172ab3;font-family:Courier New,monospace;font-size:.85rem;word-break:break-all}.course-card.glass{backdrop-filter:none;-webkit-backdrop-filter:none;background:var(--surface)}.course-card{position:relative;padding:0;overflow:hidden;display:flex;flex-direction:column}.course-card-image-wrap{position:relative;width:100%;height:160px;overflow:hidden}.course-card-image{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.course-card-image--crossfade{transition:opacity .6s ease}.course-card-image-wrap--stacked .course-card-image{position:absolute;inset:0}.course-card:hover .course-card-image{transform:scale(1.05)}.course-card-image-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(2,6,23,.65) 100%);transition:opacity .3s}.course-card-body{padding:1rem;flex:1;display:flex;flex-direction:column;justify-content:space-between;gap:.75rem}.course-card-badge-corner{position:absolute;top:.5rem;right:.5rem;z-index:2;display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .6rem;border-radius:8px;font-size:.8rem;font-weight:600;color:#86efacf2;background:#0f172ad9;border:1px solid rgba(74,222,128,.5);box-shadow:0 0 6px #4ade8040;text-shadow:0 0 6px rgba(74,222,128,.35)}.course-detail-wrap{position:relative;min-height:100vh}.course-page-bg{position:fixed;inset:0;z-index:-1;overflow:hidden}.course-page-bg-slide{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;opacity:.22;filter:blur(14px) saturate(.6)}.course-page-bg:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#080c18eb,#0f0f23e0,#080c18f2);pointer-events:none}.course-detail-content{position:relative;z-index:1}.course-gallery{border-radius:12px;overflow:hidden}.course-gallery-main{position:relative;width:100%;height:280px;background:#0f172a99;border-radius:12px;overflow:hidden}@media(max-width:600px){.course-gallery-main{height:220px}}.course-gallery-img{width:100%;height:100%;object-fit:cover;display:block}.course-gallery-caption{position:absolute;bottom:0;left:0;right:0;padding:.5rem .75rem;background:linear-gradient(transparent,#020617bf);font-size:.85rem;color:#ffffffd9}.course-gallery-arrow{position:absolute;top:50%;transform:translateY(-50%);background:#0f172aa6;border:1px solid var(--border);border-radius:50%;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text);transition:background .2s;z-index:2}.course-gallery-arrow:hover{background:#6366f173}.course-gallery-arrow-left{left:10px}.course-gallery-arrow-right{right:10px}.course-gallery-dots{display:flex;justify-content:center;gap:6px;margin-top:10px}.course-gallery-dot{width:8px;height:8px;border-radius:50%;background:var(--border);border:none;cursor:pointer;padding:0;transition:background .2s,transform .2s}.course-gallery-dot.active{background:var(--primary);transform:scale(1.3)}.admin-shell{min-height:100vh;display:flex;background:var(--bg)}.admin-sidebar{width:220px;min-width:220px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:0;position:sticky;top:0;height:100vh;overflow-y:hidden;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.admin-sidebar-brand{display:flex;align-items:center;gap:10px;padding:1.2rem 1.25rem;font-size:1rem;font-weight:700;color:var(--text);border-bottom:1px solid var(--border);letter-spacing:.01em}.admin-sidebar-nav{flex:1;padding:.75rem .5rem;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.admin-nav-item{display:flex;align-items:center;gap:10px;padding:.55rem .85rem;border-radius:8px;color:var(--text-muted);font-size:.875rem;transition:background var(--transition),color var(--transition);text-decoration:none}.admin-nav-item:hover{background:#ffffff0f;color:var(--text)}.admin-nav-item.active{background:#3b82f62e;color:var(--primary)}.admin-sidebar-footer{border-top:1px solid var(--border);padding:.75rem 1rem;display:flex;align-items:center;gap:8px;justify-content:space-between}.admin-sidebar-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;flex-shrink:0}.admin-sidebar-userinfo{flex:1;min-width:0}.admin-sidebar-username{font-size:.8rem;font-weight:600;overflow:hidden;text-overflow:ellipsis}.admin-sidebar-role{font-size:.7rem;color:var(--text-muted)}.admin-sidebar-logout{display:inline-flex;align-items:center;gap:6px;background:#0f172ab3;border:1px solid var(--border);color:var(--text-muted);cursor:pointer;padding:4px 10px;border-radius:999px;font-size:.78rem;transition:background var(--transition),color var(--transition),border-color var(--transition)}.admin-sidebar-logout:hover{background:#ef444426;border-color:#ef444499;color:var(--danger)}.admin-content{flex:1;min-width:0;overflow-y:auto}.admin-page{padding:1.75rem 2rem;max-width:1400px}.admin-page-title{font-size:1.5rem;font-weight:700;margin:0 0 1.5rem}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1rem;margin-bottom:1.5rem}.admin-stat-card{display:flex;align-items:center;gap:1rem;padding:1.1rem 1.25rem}.admin-stat-icon{width:42px;height:42px;border-radius:10px;background:#3b82f626;display:flex;align-items:center;justify-content:center;color:var(--primary);flex-shrink:0}.admin-stat-label{font-size:.75rem;color:var(--text-muted);margin-bottom:2px}.admin-stat-value{font-size:1.65rem;font-weight:700;line-height:1}.admin-stat-sub{font-size:.72rem;color:var(--text-muted);margin-top:3px}.admin-chart-card{padding:1.25rem;margin-bottom:1.5rem}.admin-chart-title{font-size:.9rem;font-weight:600;color:var(--text-muted);margin:0 0 1rem;text-transform:uppercase;letter-spacing:.05em}.admin-two-col{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}@media(max-width:860px){.admin-two-col{grid-template-columns:1fr}}.admin-bar-chart{display:flex;align-items:flex-end;gap:3px;height:110px}.admin-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;height:100%;justify-content:flex-end}.admin-bar-count{font-size:.6rem;color:var(--text-muted);min-height:14px}.admin-bar{background:var(--primary);border-radius:3px 3px 0 0;width:100%;min-height:2px;transition:background .15s}.admin-bar:hover{background:var(--primary-hover)}.admin-bar-label{font-size:.6rem;color:var(--text-muted);white-space:nowrap}.admin-label-row{display:flex;align-items:center;gap:10px;padding:5px 0;border-bottom:1px solid rgba(255,255,255,.04)}.admin-label-name{flex:1;font-size:.82rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-label-bar{height:6px;border-radius:3px;flex-shrink:0}.admin-label-count{font-size:.78rem;color:var(--text-muted);min-width:26px;text-align:right}.admin-filter-bar{display:flex;align-items:center;gap:10px;padding:.75rem 1rem;margin-bottom:1rem;flex-wrap:wrap}.admin-select{background:#0f172ab3;border:1px solid var(--border);border-radius:8px;color:var(--text);padding:6px 10px;font-size:.83rem;outline:none;cursor:pointer;transition:border-color var(--transition)}.admin-select:focus{border-color:var(--primary)}.admin-search-wrap{position:relative;flex:1;min-width:180px}.admin-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.admin-search{width:100%;background:#0f172ab3;border:1px solid var(--border);border-radius:8px;color:var(--text);padding:6px 10px 6px 32px;font-size:.83rem;outline:none;transition:border-color var(--transition)}.admin-search:focus{border-color:var(--primary)}.admin-table-wrap{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:.85rem}.admin-table th{text-align:left;padding:.6rem .85rem;color:var(--text-muted);font-weight:500;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border)}.admin-table td{padding:.6rem .85rem;border-bottom:1px solid rgba(255,255,255,.04);vertical-align:middle}.admin-table-row{cursor:pointer;transition:background var(--transition)}.admin-table-row:hover td{background:#3b82f60f}.admin-detail-topbar{display:flex;align-items:center;gap:12px;margin-bottom:1.5rem;flex-wrap:wrap}.admin-detail-grid{display:grid;grid-template-columns:320px 1fr;gap:1.5rem}@media(max-width:960px){.admin-detail-grid{grid-template-columns:1fr}}.admin-detail-left,.admin-detail-right{display:flex;flex-direction:column;gap:1rem}.admin-detail-section{padding:1.1rem 1.25rem}.admin-section-title{display:flex;align-items:center;gap:8px;font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.85rem}.admin-student-card{display:flex;align-items:center;gap:12px}.admin-student-avatar{width:46px;height:46px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;flex-shrink:0}.timing-container{padding:.25rem 0}.timing-row{display:flex;align-items:center;gap:0;flex-wrap:nowrap;margin-bottom:1rem;overflow-x:auto}.timing-event{display:flex;align-items:flex-start;gap:8px;flex-shrink:0}.timing-dot{width:12px;height:12px;border-radius:50%;margin-top:4px;flex-shrink:0}.timing-dot-view{background:#3b82f6}.timing-dot-start{background:#f59e0b}.timing-dot-submit{background:#22c55e}.timing-line{flex:1;min-width:24px;height:2px;background:var(--border);margin:0 4px;align-self:center}.timing-event-label{font-size:.75rem;color:var(--text-muted)}.timing-event-time{font-size:.78rem;font-weight:500}.timing-stats{display:flex;flex-direction:column;gap:6px}.timing-stat{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--text-muted)}.admin-flags-grid{display:flex;flex-wrap:wrap;gap:8px}.flag-chip{border:1px solid var(--border);background:#ffffff0a;color:var(--text-muted);border-radius:20px;padding:4px 12px;font-size:.78rem;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;gap:5px}.flag-chip:hover{border-color:var(--primary);color:var(--text)}.flag-chip.flag-active{background:#3b82f62e;border-color:var(--primary);color:var(--primary)}.flag-chip-sm{padding:2px 8px;font-size:.7rem;border-radius:12px}.admin-comment{background:#0003;border:1px solid var(--border);border-radius:8px;padding:.6rem .85rem}.admin-comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px;gap:8px}@media(max-width:600px){.admin-page{padding:1rem}.admin-stats-grid{grid-template-columns:1fr 1fr}}
