:root{--v: #7c3aed;--vd: #5b21b6;--vl: #ede9fe;--text: #0f0f23;--muted: #6b7280;--border: #e9eaf0;--surface: #ffffff;--bg: #f9f8ff;--r: 16px;--sha: 0 1px 3px rgba(0,0,0,.05), 0 4px 16px rgba(0,0,0,.06);--sha-lg: 0 8px 40px rgba(124,58,237,.1), 0 2px 8px rgba(0,0,0,.06)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased}@keyframes fadeUp{0%{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}@keyframes blobFloat{0%,to{transform:translate(0) scale(1)}50%{transform:translate(30px,-20px) scale(1.08)}}.anim-1{animation:fadeUp .45s cubic-bezier(.22,1,.36,1) both}.anim-2{animation:fadeUp .45s .08s cubic-bezier(.22,1,.36,1) both}.anim-3{animation:fadeUp .45s .14s cubic-bezier(.22,1,.36,1) both}.anim-4{animation:fadeUp .45s .2s cubic-bezier(.22,1,.36,1) both}.page{min-height:100vh;display:flex;flex-direction:column}.header{position:sticky;top:0;z-index:100;background:#ffffffd1;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid var(--border)}.hdr-inner{max-width:1100px;margin:0 auto;padding:0 28px;height:62px;display:flex;align-items:center;justify-content:space-between}.brand-icon{width:38px;height:38px;border-radius:10px;background:var(--v);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px #7c3aed59}.hdr-badge{font-size:12px;font-weight:700;color:var(--v);background:var(--vl);padding:4px 12px;border-radius:20px}.hero{position:relative;overflow:hidden;padding:100px 28px 90px;min-height:100vh;display:flex;align-items:center;background:radial-gradient(ellipse 60% 50% at 15% 50%,rgba(124,58,237,.1) 0%,transparent 70%),radial-gradient(ellipse 50% 60% at 85% 30%,rgba(79,70,229,.09) 0%,transparent 70%),radial-gradient(ellipse 40% 40% at 50% 90%,rgba(16,185,129,.07) 0%,transparent 70%),linear-gradient(180deg,#f5f0ff,#f0f4ff);border-bottom:1px solid var(--border)}.blob{position:absolute;border-radius:50%;filter:blur(70px);opacity:.55;pointer-events:none;animation:blobFloat 8s ease-in-out infinite}.b1{width:340px;height:340px;background:#7c3aed2e;top:-80px;left:-80px;animation-delay:0s}.b2{width:280px;height:280px;background:#4f46e524;top:20px;right:-60px;animation-delay:-3s}.b3{width:200px;height:200px;background:#10b9811f;bottom:-40px;left:40%;animation-delay:-5s}.hero-content{position:relative;z-index:2;max-width:600px;margin:0 auto;text-align:center}.eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--v);background:#7c3aed14;border:1px solid rgba(124,58,237,.2);padding:5px 14px;border-radius:20px;margin-bottom:20px}.eyebrow-dot{width:6px;height:6px;border-radius:50%;background:var(--v);display:inline-block}.hero-h1{font-size:clamp(30px,6vw,52px);font-weight:900;letter-spacing:-1.5px;line-height:1.08;color:var(--text);margin-bottom:14px}.grad-text{background:linear-gradient(135deg,#7c3aed,#4f46e5,#06b6d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-p{font-size:15.5px;color:var(--muted);line-height:1.65;margin-bottom:36px}.sbar-wrap{display:flex;flex-direction:column;gap:10px}.sbar{display:flex;align-items:center;background:var(--surface);border:1.5px solid var(--border);border-radius:60px;padding:6px 6px 6px 20px;box-shadow:0 8px 32px #7c3aed1f,0 2px 8px #0000000f;transition:border-color .2s,box-shadow .2s}.sbar:focus-within{border-color:var(--v);box-shadow:0 0 0 4px #7c3aed1f,0 8px 32px #7c3aed26}.sbar-err{border-color:#fca5a5}.sbar-ico{width:17px;height:17px;color:var(--muted);flex-shrink:0;margin-right:10px}.sbar-input{flex:1;border:none;outline:none;font-size:15px;font-family:inherit;color:var(--text);background:transparent;min-width:0}.sbar-input::placeholder{color:#b0b8c8}.sbar-btn{display:flex;align-items:center;justify-content:center;gap:8px;min-width:100px;padding:11px 22px;background:var(--v);color:#fff;border:none;border-radius:50px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;letter-spacing:.2px;transition:background .15s,transform .1s,box-shadow .15s;white-space:nowrap;box-shadow:0 4px 14px #7c3aed66}.sbar-btn:hover{background:var(--vd);box-shadow:0 6px 20px #7c3aed73}.sbar-btn:active{transform:scale(.97)}.sbar-btn:disabled{opacity:.75;cursor:not-allowed;transform:none}.err-box{display:flex;align-items:center;gap:8px;background:#fff5f5;border:1px solid #fecaca;color:#dc2626;font-size:13px;font-weight:500;padding:10px 16px;border-radius:12px;text-align:left}.quick-try{margin-top:22px;display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;font-size:13px;color:var(--muted)}.q-chip{padding:5px 14px;border:1.5px solid rgba(124,58,237,.25);border-radius:20px;background:#7c3aed0f;color:var(--v);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s,transform .1s}.q-chip:hover{background:#7c3aed1f;border-color:var(--v);transform:translateY(-1px)}.main{max-width:1100px;margin:0 auto;padding:36px 28px 56px;flex:1;width:100%}.results{display:flex;flex-direction:column;gap:20px}.profile-card{background:var(--surface);border-radius:var(--r);border:1px solid var(--border);box-shadow:var(--sha);padding:24px 28px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}.pc-left{display:flex;align-items:center;gap:18px}.av{width:58px;height:58px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:900;flex-shrink:0;letter-spacing:1px}.pc-name{font-size:19px;font-weight:800;color:var(--text);margin-bottom:4px;letter-spacing:-.3px}.pc-meta{font-size:13px;color:var(--muted);margin-bottom:3px}.pc-reg{font-size:12.5px;color:var(--muted)}.pc-reg strong{color:var(--text);font-weight:700}.big-badge{display:flex;align-items:center;gap:8px;padding:9px 22px;border-radius:50px;font-size:13px;font-weight:900;letter-spacing:2.5px;flex-shrink:0}.bb-dot{width:8px;height:8px;border-radius:50%}.bb-pass{background:#dcfce7;color:#15803d}.bb-pass .bb-dot{background:#22c55e}.bb-fail{background:#fee2e2;color:#dc2626}.bb-fail .bb-dot{background:#ef4444}.stats-row{display:grid;grid-template-columns:auto 1fr 1fr 1fr;gap:16px}.stat-card{background:var(--surface);border-radius:var(--r);border:1px solid var(--border);box-shadow:var(--sha);padding:22px 24px;display:flex;flex-direction:column;justify-content:center}.sc-ring{align-items:center;justify-content:center;padding:16px}.ring-svg{display:block}.sc-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-bottom:10px}.sc-num{font-size:38px;font-weight:900;color:var(--text);letter-spacing:-1.5px;line-height:1;margin-bottom:4px}.sc-denom{font-size:12px;color:var(--muted);font-weight:500;margin-bottom:12px}.sc-bar-track{height:4px;background:#f0f0f0;border-radius:4px;overflow:hidden}.sc-bar-fill{height:100%;border-radius:4px;transition:width 1.2s cubic-bezier(.4,0,.2,1)}.sc-grade{font-size:44px;font-weight:900;letter-spacing:-1px;line-height:1;margin-bottom:6px}.sc-grade-label{font-size:12px;font-weight:600;opacity:.7}.rank-wrap{display:flex;align-items:baseline;gap:2px;margin-bottom:4px}.rank-hash{font-size:22px;font-weight:800;color:var(--muted);line-height:1}.subjects-card{background:var(--surface);border-radius:var(--r);border:1px solid var(--border);box-shadow:var(--sha);overflow:hidden}.card-head{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:15px;font-weight:800;color:var(--text);margin-bottom:2px}.card-sub{font-size:12.5px;color:var(--muted)}.tbl-scroll{overflow-x:auto}.tbl{width:100%;border-collapse:collapse;font-size:14px}.tbl th{padding:11px 18px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);background:#fcfcfd;border-bottom:1px solid var(--border);white-space:nowrap}.tbl td{padding:15px 18px;border-bottom:1px solid #f4f4f8;vertical-align:middle}.tbl tbody tr:last-child td{border-bottom:none}.tbl tbody tr{transition:background .12s}.tbl tbody tr:hover{background:#fafaff}.tbl tbody tr.tr-fail{background:#fff8f8}.tbl tbody tr.tr-fail:hover{background:#fff0f0}.td-i{width:40px;font-size:12px;font-weight:700;color:#c4c8d4}.td-subj{min-width:200px}.subj-name{display:block;font-weight:600;color:var(--text);margin-bottom:8px;font-size:13.5px}.prog-track{height:3px;background:#f0f0f4;border-radius:3px;overflow:hidden;width:100%}.prog-fill{height:100%;border-radius:3px;transition:width .9s cubic-bezier(.4,0,.2,1)}.td-max{color:var(--muted);font-size:13px}.obt-num{font-size:18px;font-weight:800;letter-spacing:-.5px}.g-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:8px;font-size:12px;font-weight:800;white-space:nowrap}.g-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.s-pill{display:inline-block;padding:5px 14px;border-radius:20px;font-size:12px;font-weight:700;letter-spacing:.4px}.sp-pass{background:#f0fdf4;color:#15803d;border:1.5px solid #bbf7d0}.sp-fail{background:#fff5f5;color:#dc2626;border:1.5px solid #fecaca}.action-bar{display:flex;gap:12px;justify-content:flex-end}.act-ghost{display:flex;align-items:center;gap:8px;padding:11px 20px;background:var(--surface);color:var(--muted);border:1.5px solid var(--border);border-radius:12px;font-size:13.5px;font-weight:600;cursor:pointer;font-family:inherit;transition:border-color .15s,color .15s,background .15s}.act-ghost:hover{border-color:#9ca3af;color:var(--text);background:#f9f9fb}.act-primary{display:flex;align-items:center;gap:8px;padding:11px 26px;background:var(--v);color:#fff;border:none;border-radius:12px;font-size:13.5px;font-weight:700;cursor:pointer;font-family:inherit;box-shadow:0 4px 14px #7c3aed59;transition:background .15s,box-shadow .15s}.act-primary:hover{background:var(--vd);box-shadow:0 6px 20px #7c3aed66}.footer{background:var(--surface);border-top:1px solid var(--border);padding:16px 28px;display:flex;align-items:center;justify-content:center;gap:14px;font-size:12.5px;color:var(--muted);flex-wrap:wrap}.f-sep{width:3px;height:3px;border-radius:50%;background:#d1d5db;display:inline-block}@keyframes slideInRight{0%{opacity:0;transform:translate(32px)}to{opacity:1;transform:translate(0)}}.rpage{min-height:100vh;display:flex;flex-direction:column;background:var(--bg);animation:slideInRight .38s cubic-bezier(.22,1,.36,1) both}.rpage-header{background:#ffffffe0;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}.rpage-hdr-inner{max-width:1100px;margin:0 auto;padding:0 28px;height:60px;display:flex;align-items:center;justify-content:space-between;gap:16px}.rpage-back{display:flex;align-items:center;gap:7px;padding:8px 16px;background:var(--vl);color:var(--v);border:1.5px solid #c4b5fd;border-radius:9px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s;white-space:nowrap}.rpage-back:hover{background:#ddd6fe;border-color:var(--v)}.rpage-brand{display:flex;align-items:center;gap:10px}.rpage-brand-icon{width:32px;height:32px;background:var(--v);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 3px 10px #7c3aed4d}.rpage-brand-name{font-size:14px;font-weight:700;color:var(--text)}.rpage-print{padding:8px 16px!important;font-size:13px!important;white-space:nowrap}.result-banner{padding:36px 0}.banner-pass{background:linear-gradient(135deg,#f5f0ff,#eef2ff);border-bottom:1px solid #ddd6fe}.banner-fail{background:linear-gradient(135deg,#fff5f5,#fef2f2);border-bottom:1px solid #fecaca}.rb-inner{max-width:1100px;margin:0 auto;padding:0 28px;display:flex;align-items:center;gap:22px;flex-wrap:wrap}.rb-av{width:72px;height:72px;border-radius:18px;background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:900;color:var(--v);flex-shrink:0;box-shadow:0 4px 16px #7c3aed26;letter-spacing:1px;border:2px solid rgba(124,58,237,.15)}.banner-fail .rb-av{color:#dc2626;box-shadow:0 4px 16px #dc26261f;border-color:#dc262626}.rb-info{flex:1;min-width:0}.rb-name{font-size:24px;font-weight:900;color:var(--text);letter-spacing:-.5px;margin-bottom:5px}.rb-meta{font-size:13.5px;color:var(--muted);margin-bottom:4px}.rb-reg{font-size:13px;color:var(--muted)}.rb-reg strong{color:var(--text);font-weight:700}.rb-verdict{text-align:center;padding:16px 28px;border-radius:16px;flex-shrink:0}.verdict-pass{background:#22c55e1f;border:2px solid rgba(34,197,94,.3)}.verdict-fail{background:#ef44441a;border:2px solid rgba(239,68,68,.25)}.verdict-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:4px}.verdict-text{font-size:26px;font-weight:900;letter-spacing:3px}.verdict-pass .verdict-text{color:#15803d}.verdict-fail .verdict-text{color:#dc2626}.rpage-main{max-width:1100px;margin:0 auto;padding:28px 28px 52px;flex:1;width:100%;display:flex;flex-direction:column;gap:20px}.rpage-footer{background:var(--surface);border-top:1px solid var(--border)}@media (max-width: 860px){.stats-row{grid-template-columns:1fr 1fr}.sc-ring{grid-column:span 2}}@media (max-width: 580px){.hdr-inner{padding:0 16px}.brand-title{font-size:13px}.hero{padding:70px 16px 60px;min-height:100svh}.rpage-hdr-inner{padding:0 16px}.rpage-brand-name,.rpage-print{display:none}.rb-inner{padding:0 16px;gap:16px}.rb-av{width:56px;height:56px;font-size:20px;border-radius:14px}.rb-name{font-size:19px}.rb-verdict{padding:12px 20px}.result-banner{padding:24px 0}.rpage-main,.main{padding:20px 16px 40px}.profile-card{padding:18px}.stats-row{grid-template-columns:1fr 1fr;gap:12px}.sc-ring{grid-column:span 2}.action-bar{flex-direction:column}.sbar{border-radius:16px;padding:8px 8px 8px 14px}.sbar-btn{border-radius:10px}.hdr-badge{display:none}.hero-h1{letter-spacing:-.8px}}@media print{.hero,.action-bar,.footer{display:none!important}.header{position:static;background:#fff;-webkit-backdrop-filter:none;backdrop-filter:none}.main{padding:0}.results{gap:12px}*{box-shadow:none!important}.blob{display:none}}:root{--v: #7c3aed;--vd: #5b21b6;--vl: #ede9fe;--text: #0f0f23;--muted: #6b7280;--border: #e9eaf0;--surface: #ffffff;--bg: #f9f8ff;--r: 12px;--sha: 0 1px 3px rgba(0,0,0,.05), 0 4px 16px rgba(0,0,0,.06)}@keyframes spin{to{transform:rotate(360deg)}}.btn-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .65s linear infinite;flex-shrink:0}.btn-spinner-white{border-color:#ffffff59;border-top-color:#fff}.btn-spinner-sm{width:11px;height:11px}.loading-state{display:flex;flex-direction:column;align-items:center;gap:16px;padding:64px 24px;color:var(--muted)}.loading-spinner{width:40px;height:40px;border:3px solid var(--vl);border-top-color:var(--v);border-radius:50%;animation:spin .75s linear infinite}.loading-state p{font-size:14px;font-weight:500;color:var(--muted)}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-8px)}40%,80%{transform:translate(8px)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.toast{position:fixed;top:20px;right:24px;z-index:9999;display:flex;align-items:center;gap:10px;padding:13px 20px;border-radius:12px;font-size:13.5px;font-weight:600;box-shadow:0 8px 32px #0000001f;animation:slideDown .3s cubic-bezier(.22,1,.36,1) both;max-width:360px}.toast-success{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0}.toast-error{background:#fff5f5;color:#dc2626;border:1px solid #fecaca}.auth-checking{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:linear-gradient(160deg,#f5f0ff,#f0f4ff);color:var(--muted);font-size:14px;font-weight:500}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:linear-gradient(160deg,#f5f0ff,#f0f4ff)}.login-bg-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5}.lb1{width:400px;height:400px;background:#7c3aed2e;top:-100px;left:-100px}.lb2{width:300px;height:300px;background:#4f46e521;bottom:-80px;right:-60px}.login-card{background:var(--surface);border-radius:20px;border:1px solid var(--border);box-shadow:0 24px 64px #7c3aed26,0 4px 16px #0000000f;padding:44px 40px;width:100%;max-width:420px;position:relative;z-index:2;text-align:center;animation:fadeIn .4s ease both}.login-card.shake{animation:shake .4s ease}.login-icon-wrap{width:64px;height:64px;background:var(--vl);color:var(--v);border-radius:18px;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;box-shadow:0 4px 16px #7c3aed33}.login-title{font-size:22px;font-weight:800;color:var(--text);margin-bottom:8px;letter-spacing:-.4px}.login-desc{font-size:13.5px;color:var(--muted);margin-bottom:28px;line-height:1.6}.login-form{text-align:left}.lf-group{margin-bottom:18px}.lf-label{display:block;font-size:13px;font-weight:700;color:var(--text);margin-bottom:8px}.lf-pass-wrap{position:relative}.lf-input{width:100%;padding:12px 44px 12px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:15px;font-family:inherit;color:var(--text);background:#fafafa;outline:none;transition:border-color .2s,box-shadow .2s}.lf-input:focus{border-color:var(--v);box-shadow:0 0 0 3px #7c3aed1a;background:#fff}.lf-input-err{border-color:#fca5a5!important}.lf-eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center}.lf-eye:hover{color:var(--text)}.lf-err{font-size:12px;color:#dc2626;margin-top:6px}.lf-hint{font-size:12px;color:#9ca3af;margin-top:5px}.lf-submit{width:100%;padding:13px;display:flex;align-items:center;justify-content:center;gap:10px;background:var(--v);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;box-shadow:0 4px 16px #7c3aed59;transition:background .15s,transform .1s;margin-bottom:16px}.lf-submit:hover{background:var(--vd)}.lf-submit:active{transform:scale(.98)}.lf-back{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:color .15s}.lf-back:hover{color:var(--text)}.dash-page{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}.dash-header{background:#ffffffd9;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.dash-hdr-inner{max-width:1300px;margin:0 auto;padding:0 28px;height:62px;display:flex;align-items:center;justify-content:space-between;gap:16px}.brand{display:flex;align-items:center;gap:12px}.brand-icon{width:38px;height:38px;border-radius:10px;background:var(--v);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #7c3aed59;flex-shrink:0}.brand-title{font-size:14.5px;font-weight:700;color:var(--text);line-height:1.25}.brand-caption{font-size:11.5px;color:var(--muted)}.dash-hdr-right{display:flex;align-items:center;gap:10px}.admin-badge{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--v);background:var(--vl);padding:5px 12px;border-radius:20px}.hdr-btn{display:flex;align-items:center;gap:7px;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;border:none;transition:background .15s,color .15s}.hdr-btn-ghost{background:#f3f4f6;color:var(--muted)}.hdr-btn-ghost:hover{background:#e5e7eb;color:var(--text)}.hdr-btn-danger{background:#fff5f5;color:#dc2626;border:1.5px solid #fecaca}.hdr-btn-danger:hover{background:#fee2e2}.dash-body{max-width:1300px;margin:0 auto;padding:28px 28px 56px;width:100%}.dash-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.ds-card{background:var(--surface);border-radius:var(--r);border:1px solid var(--border);box-shadow:var(--sha);padding:20px 22px;display:flex;align-items:center;gap:16px}.ds-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ds-blue .ds-icon{background:#eff6ff;color:#2563eb}.ds-green .ds-icon{background:#f0fdf4;color:#15803d}.ds-red .ds-icon{background:#fff5f5;color:#dc2626}.ds-violet .ds-icon{background:var(--vl);color:var(--v)}.ds-num{font-size:28px;font-weight:900;color:var(--text);letter-spacing:-1px;line-height:1}.ds-label{font-size:12px;font-weight:600;color:var(--muted);margin-top:2px}.dash-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px;flex-wrap:wrap}.toolbar-left{display:flex;align-items:center;gap:12px}.tb-search{display:flex;align-items:center;gap:10px;background:var(--surface);border:1.5px solid var(--border);border-radius:10px;padding:9px 14px;width:340px;box-shadow:var(--sha);transition:border-color .2s}.tb-search:focus-within{border-color:var(--v)}.tb-search svg{color:var(--muted);flex-shrink:0}.tb-search input{flex:1;border:none;outline:none;font-size:14px;font-family:inherit;color:var(--text);background:transparent;min-width:0}.tb-search input::placeholder{color:#b0b8c8}.tb-clear{background:none;border:none;color:var(--muted);cursor:pointer;padding:2px;border-radius:4px;display:flex;align-items:center}.tb-clear:hover{color:var(--text)}.tb-count{font-size:13px;color:var(--muted);white-space:nowrap}.tb-add{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--v);color:#fff;border:none;border-radius:10px;font-size:13.5px;font-weight:700;cursor:pointer;font-family:inherit;box-shadow:0 4px 14px #7c3aed59;transition:background .15s;white-space:nowrap}.tb-add:hover{background:var(--vd)}.dash-table-wrap{background:var(--surface);border-radius:var(--r);border:1px solid var(--border);box-shadow:var(--sha);overflow:hidden}.dash-table{width:100%;border-collapse:collapse;font-size:13.5px}.dash-table th{padding:11px 14px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);background:#fafafa;border-bottom:1px solid var(--border);white-space:nowrap}.dash-table td{padding:13px 14px;border-bottom:1px solid #f4f4f8;vertical-align:middle}.dash-table tbody tr:last-child td{border-bottom:none}.dash-table tbody tr{transition:background .1s}.dash-table tbody tr:hover{background:#fafaff}.dash-table tbody tr.tr-deleting{background:#fff5f5}.td-idx{width:36px;font-size:12px;font-weight:700;color:#c4c8d4}.td-c{text-align:center}.td-pct{font-weight:700;color:var(--text)}.td-reg{font-family:monospace;font-size:13px;font-weight:600;color:var(--v)}.td-dept{font-size:12.5px;color:var(--muted);max-width:160px}.td-student{display:flex;align-items:center;gap:10px}.st-av{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0;letter-spacing:.5px}.st-name{font-weight:600;color:var(--text)}.dt-grade{display:inline-block;padding:3px 10px;border-radius:6px;font-size:12px;font-weight:800}.dt-status{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:700}.dt-pass{background:#dcfce7;color:#15803d}.dt-fail{background:#fee2e2;color:#dc2626}.td-actions{white-space:nowrap}.action-btns{display:flex;gap:6px}.ab-edit,.ab-del{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;border:none;transition:background .15s,color .15s}.ab-edit{background:#f0f4ff;color:#2563eb}.ab-edit:hover{background:#dbeafe}.ab-del{background:#fff5f5;color:#dc2626}.ab-del:hover{background:#fee2e2}.del-confirm{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;color:var(--text)}.dc-yes{padding:5px 12px;background:#dc2626;color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;transition:background .15s}.dc-yes:hover{background:#b91c1c}.dc-no{padding:5px 12px;background:#f3f4f6;color:var(--muted);border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s}.dc-no:hover{background:#e5e7eb}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:64px 24px;color:var(--muted);text-align:center}.empty-state svg{opacity:.35}.empty-state p{font-size:14px;font-weight:500}.form-page{min-height:100vh;background:var(--bg);display:flex;flex-direction:column}.form-topbar{background:#ffffffe0;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 28px;height:62px}.ftb-back{display:flex;align-items:center;gap:7px;padding:8px 14px;background:#f3f4f6;border:none;border-radius:8px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;font-family:inherit;transition:background .15s,color .15s;white-space:nowrap}.ftb-back:hover{background:#e5e7eb;color:var(--text)}.ftb-center{text-align:center}.ftb-title{font-size:15px;font-weight:800;color:var(--text)}.ftb-sub{font-size:12px;color:var(--muted)}.ftb-save{display:flex;align-items:center;gap:8px;padding:9px 20px;background:var(--v);color:#fff;border:none;border-radius:10px;font-size:13.5px;font-weight:700;cursor:pointer;font-family:inherit;box-shadow:0 4px 14px #7c3aed59;transition:background .15s;white-space:nowrap}.ftb-save:hover{background:var(--vd)}.form-err-banner{display:flex;align-items:center;gap:10px;background:#fff5f5;border-bottom:1px solid #fecaca;color:#dc2626;font-size:13.5px;font-weight:600;padding:12px 28px}.form-body{flex:1;max-width:1100px;margin:0 auto;padding:32px 28px 56px;width:100%}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}.form-section{background:var(--surface);border-radius:var(--r);border:1px solid var(--border);box-shadow:var(--sha);overflow:hidden}.fs-head{display:flex;align-items:center;gap:14px;padding:18px 22px;border-bottom:1px solid var(--border);background:#fafafa}.fs-num{width:28px;height:28px;border-radius:8px;background:var(--v);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;flex-shrink:0}.fs-title{font-size:14px;font-weight:700;color:var(--text)}.fs-sub{font-size:12px;color:var(--muted);margin-top:2px}.field-grid{padding:20px 22px;display:grid;grid-template-columns:1fr 1fr;gap:16px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:12.5px;font-weight:700;color:var(--text)}.req{color:#dc2626;margin-left:2px}.field input,.field select{padding:10px 13px;border:1.5px solid var(--border);border-radius:9px;font-size:14px;font-family:inherit;color:var(--text);background:#fafafa;outline:none;transition:border-color .2s,box-shadow .2s;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.field input:focus,.field select:focus{border-color:var(--v);box-shadow:0 0 0 3px #7c3aed1a;background:#fff}.field input:disabled{background:#f3f4f6;color:var(--muted);cursor:not-allowed}.field-err input,.field-err select{border-color:#fca5a5!important}.field-msg{font-size:11.5px;color:#dc2626;font-weight:500}.subject-table-wrap{padding:0 22px 4px}.subject-table-head{display:grid;grid-template-columns:32px 1fr 90px 110px 100px;gap:8px;padding:10px 0;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);border-bottom:1px solid var(--border);margin:0}.subject-row{display:grid;grid-template-columns:32px 1fr 90px 110px 100px;gap:8px;align-items:start;padding:10px 0;border-bottom:1px solid #f4f4f8;transition:background .1s}.subject-row:last-child{border-bottom:none}.subject-row-err{background:#fff8f8}.sub-idx{font-size:12px;font-weight:700;color:#c4c8d4;padding-top:10px}.sub-field{display:flex;flex-direction:column;gap:4px}.sub-field input{padding:9px 11px;border:1.5px solid var(--border);border-radius:8px;font-size:13.5px;font-family:inherit;color:var(--text);background:#fafafa;outline:none;transition:border-color .2s,box-shadow .2s;width:100%}.sub-field input:focus{border-color:var(--v);box-shadow:0 0 0 3px #7c3aed1a;background:#fff}.sub-field.field-err input{border-color:#fca5a5!important}.sub-narrow input{text-align:center}.sub-preview{display:flex;align-items:center;gap:6px;padding-top:9px}.prev-grade{padding:3px 9px;border-radius:6px;font-size:12px;font-weight:800}.prev-status{font-size:11.5px;font-weight:700}.prev-pass{color:#15803d}.prev-fail{color:#dc2626}.prev-empty{color:#c4c8d4;font-size:13px}.live-summary{margin:0 22px 20px;background:linear-gradient(135deg,#f5f0ff,#f0f4ff);border:1px solid #ddd6fe;border-radius:10px;padding:14px 20px;display:flex;gap:24px;flex-wrap:wrap}.ls-item{display:flex;flex-direction:column;gap:2px}.ls-label{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--muted)}.ls-val{font-size:14px;font-weight:700;color:var(--text)}.ls-result{font-size:14px;font-weight:900;letter-spacing:2px}.ls-pass{color:#15803d}.ls-fail{color:#dc2626}.form-footer{display:flex;align-items:center;justify-content:flex-end;gap:12px}.ff-cancel{padding:11px 22px;background:var(--surface);border:1.5px solid var(--border);border-radius:10px;font-size:14px;font-weight:600;color:var(--muted);cursor:pointer;font-family:inherit;transition:background .15s,color .15s}.ff-cancel:hover{background:#f3f4f6;color:var(--text)}.ff-submit{display:flex;align-items:center;gap:8px;padding:11px 26px;background:var(--v);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;box-shadow:0 4px 16px #7c3aed59;transition:background .15s}.ff-submit:hover{background:var(--vd)}.hdr-right{display:flex;align-items:center;gap:10px}.hdr-admin-btn{display:flex;align-items:center;gap:7px;padding:7px 14px;background:var(--vl);color:var(--v);border:1.5px solid #c4b5fd;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s}.hdr-admin-btn:hover{background:#ddd6fe;border-color:var(--v)}.wiz-page{min-height:100vh;background:var(--bg);display:flex;flex-direction:column}.wiz-header{background:#ffffffe6;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 28px;height:64px}.wiz-back-btn{display:flex;align-items:center;gap:7px;padding:8px 14px;background:#f3f4f6;border:none;border-radius:8px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;font-family:inherit;transition:background .15s,color .15s;white-space:nowrap;flex-shrink:0}.wiz-back-btn:hover{background:#e5e7eb;color:var(--text)}.wiz-steps{display:flex;align-items:center;gap:0;flex-shrink:0}.wiz-step{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:#c4c8d4;transition:color .2s}.wiz-step-done{color:var(--v)}.wiz-step-circle{width:28px;height:28px;border-radius:50%;background:#f0eefc;color:#c4c8d4;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;border:2px solid #e5e1fc;transition:background .2s,color .2s,border-color .2s;flex-shrink:0}.wiz-step-done .wiz-step-circle{background:var(--v);color:#fff;border-color:var(--v)}.wiz-connector{width:40px;height:2px;background:#e9eaf0;margin:0 4px;border-radius:2px;transition:background .3s}.wiz-connector-done{background:var(--v)}.wiz-title-block{flex-shrink:0}.wiz-title{font-size:14px;font-weight:700;color:var(--muted)}.wiz-body{max-width:760px;margin:0 auto;padding:36px 28px 64px;width:100%}.wiz-step-heading{margin-bottom:24px}.wsh-badge{display:inline-block;padding:4px 12px;background:var(--vl);color:var(--v);font-size:11.5px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;border-radius:20px;margin-bottom:10px}.wsh-title{font-size:22px;font-weight:900;color:var(--text);letter-spacing:-.5px;margin-bottom:6px}.wsh-desc{font-size:14px;color:var(--muted);line-height:1.6}.wiz-fields-card{background:var(--surface);border-radius:16px;border:1px solid var(--border);box-shadow:var(--sha);padding:24px;margin-bottom:20px;display:flex;flex-direction:column;gap:20px}.wf-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}.wf-field{display:flex;flex-direction:column;gap:6px}.wf-label{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;color:var(--text)}.wf-label svg{color:var(--muted);flex-shrink:0}.wf-input{padding:11px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:14.5px;font-family:inherit;color:var(--text);background:#fafafa;outline:none;transition:border-color .2s,box-shadow .2s;width:100%;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.wf-input:focus{border-color:var(--v);box-shadow:0 0 0 3px #7c3aed1a;background:#fff}.wf-input:disabled{background:#f3f4f6;color:var(--muted);cursor:not-allowed}.wf-err .wf-input{border-color:#fca5a5!important}.wf-err-msg{font-size:12px;color:#dc2626;font-weight:500;margin:0}.wiz-info-strip{display:flex;align-items:center;flex-wrap:wrap;gap:8px;background:var(--vl);border:1px solid #ddd6fe;border-radius:12px;padding:12px 18px;font-size:13.5px;font-weight:600;color:var(--v);margin-bottom:20px}.wis-sep{display:inline-block;width:4px;height:4px;background:#c4b5fd;border-radius:50%;flex-shrink:0}.wis-edit{margin-left:auto;background:none;border:1.5px solid #c4b5fd;border-radius:7px;padding:4px 12px;font-size:12px;font-weight:700;color:var(--v);cursor:pointer;font-family:inherit;transition:background .15s}.wis-edit:hover{background:#ddd6fe}.sub-cards{display:flex;flex-direction:column;gap:14px;margin-bottom:20px}.sub-card{background:var(--surface);border:2px solid var(--border);border-radius:16px;padding:20px;display:flex;gap:16px;transition:border-color .2s,box-shadow .2s;position:relative}.sub-card:hover{border-color:#ddd6fe;box-shadow:0 4px 16px #7c3aed14}.sub-card-err{border-color:#fca5a5!important;background:#fff8f8}.sub-card-ok{border-color:#a7f3d0;background:#f0fdf4}.sub-card-fail{border-color:#fca5a5;background:#fff5f5}.sc-left{flex-shrink:0;padding-top:2px}.sc-num{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:900}.sc-body{flex:1;display:flex;flex-direction:column;gap:14px;min-width:0}.sc-name-row{display:flex;flex-direction:column;gap:6px}.sc-label{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}.sc-name-input{padding:10px 14px;border:1.5px solid var(--border);border-radius:9px;font-size:14.5px;font-family:inherit;color:var(--text);background:#fafafa;outline:none;transition:border-color .2s,box-shadow .2s;width:100%}.sc-name-input:focus{border-color:var(--sub-accent, var(--v));box-shadow:0 0 0 3px #7c3aed1a;background:#fff}.sc-input-err{border-color:#fca5a5!important}.sc-err-msg{font-size:11.5px;color:#dc2626;font-weight:500;margin:0}.sc-marks-row{display:flex;align-items:flex-start;gap:12px;flex-wrap:wrap}.sc-marks-group{display:flex;flex-direction:column;gap:5px}.sc-marks-box{display:flex;border:1.5px solid var(--border);border-radius:9px;overflow:hidden;background:#fafafa;transition:border-color .2s,box-shadow .2s}.sc-marks-box:focus-within{border-color:var(--sub-accent, var(--v));box-shadow:0 0 0 3px #7c3aed1a;background:#fff}.sc-marks-box.sc-input-err{border-color:#fca5a5}.sc-marks-input{width:80px;padding:10px 12px;border:none;outline:none;font-size:18px;font-weight:800;font-family:inherit;color:var(--text);background:transparent;text-align:center}.sc-max-box .sc-marks-input{width:72px;font-size:15px;font-weight:600;color:var(--muted)}.sc-divider{font-size:12px;font-weight:600;color:var(--muted);padding-top:28px}.sc-result-chip{display:flex;align-items:center;gap:8px;padding-top:24px;margin-left:auto}.sc-grade-badge{padding:4px 12px;border-radius:7px;font-size:13px;font-weight:900;letter-spacing:.5px}.sc-pass-chip{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:700}.spc-pass{background:#dcfce7;color:#15803d}.spc-fail{background:#fee2e2;color:#dc2626}.sc-progress{display:flex;align-items:center;gap:10px}.sc-prog-track{flex:1;height:6px;background:#f0eefc;border-radius:10px;overflow:hidden}.sc-prog-fill{height:100%;border-radius:10px;transition:width .6s cubic-bezier(.4,0,.2,1)}.sc-pct-label{font-size:12px;font-weight:700;color:var(--muted);white-space:nowrap;width:36px;text-align:right}.wiz-summary{border-radius:16px;border:2px solid;padding:20px 24px;margin-bottom:20px;animation:slideDown .3s ease both}.ws-pass{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#86efac}.ws-fail{background:linear-gradient(135deg,#fff5f5,#fee2e2);border-color:#fca5a5}.ws-title{font-size:11.5px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);margin-bottom:14px}.ws-stats{display:flex;gap:28px;flex-wrap:wrap;align-items:center}.ws-stat{display:flex;flex-direction:column;gap:2px}.ws-sl{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}.ws-sv{font-size:16px;font-weight:800;color:var(--text)}.ws-verdict{font-size:18px;font-weight:900;letter-spacing:3px;margin-left:auto;padding:6px 20px;border-radius:10px}.wsv-pass{background:#dcfce7;color:#15803d}.wsv-fail{background:#fee2e2;color:#dc2626}.wiz-nav{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding-top:4px}.wiz-btn-primary{display:flex;align-items:center;gap:8px;padding:12px 26px;background:var(--v);color:#fff;border:none;border-radius:12px;font-size:14.5px;font-weight:700;cursor:pointer;font-family:inherit;box-shadow:0 4px 16px #7c3aed59;transition:background .15s,transform .1s}.wiz-btn-primary:hover{background:var(--vd)}.wiz-btn-primary:active{transform:scale(.98)}.wiz-btn-primary:disabled{opacity:.65;cursor:not-allowed}.wiz-btn-ghost{display:flex;align-items:center;gap:7px;padding:12px 22px;background:var(--surface);border:1.5px solid var(--border);border-radius:12px;font-size:14px;font-weight:600;color:var(--muted);cursor:pointer;font-family:inherit;transition:background .15s,color .15s}.wiz-btn-ghost:hover{background:#f3f4f6;color:var(--text)}.wiz-btn-ghost:disabled{opacity:.65;cursor:not-allowed}@media (max-width:1000px){.form-grid{grid-template-columns:1fr}}@media (max-width:768px){.dash-stats{grid-template-columns:repeat(2,1fr)}.form-topbar{flex-wrap:wrap;height:auto;padding:12px 16px;gap:10px}.dash-hdr-inner{padding:0 16px}.dash-body,.form-body{padding:20px 16px 40px}.wiz-body{padding:28px 20px 56px}.wf-row{grid-template-columns:1fr}}@media (max-width:580px){.dash-stats{grid-template-columns:1fr 1fr}.tb-search{width:100%}.dash-toolbar,.toolbar-left{flex-direction:column;align-items:stretch}.field-grid{grid-template-columns:1fr}.subject-table-head{display:none}.subject-row{grid-template-columns:24px 1fr 76px 90px}.sub-preview{display:none}.login-card{padding:32px 22px;margin:16px}.dash-hdr-inner{flex-wrap:wrap;height:auto;padding:10px 16px}.admin-badge{display:none}.wiz-header{padding:12px 16px;height:auto;flex-wrap:wrap;gap:10px}.wiz-steps span,.wiz-title-block{display:none}.wiz-body{padding:24px 16px 48px}.wf-row{grid-template-columns:1fr}.sc-result-chip{margin-left:0}.sc-marks-row{gap:8px}.ws-verdict{margin-left:0}.ws-stats{gap:16px}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}#root{min-height:100vh}
