@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600&family=Syne:wght@600;700;800&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600&family=Syne:wght@600;700;800&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600&family=Syne:wght@600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;font-family:Inter,sans-serif;background:#eef2f7;position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(99,102,241,.07) 0%,transparent 70%);top:-200px;right:-200px;border-radius:50%;pointer-events:none}.login-page:after{content:"";position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(59,130,246,.05) 0%,transparent 70%);bottom:-150px;left:-150px;border-radius:50%;pointer-events:none}.login-card{position:relative;z-index:1;background:#fff;border:1px solid #e2e8f0;border-radius:24px;padding:48px 40px;width:420px;max-width:90vw;box-shadow:0 20px 50px #6366f114,0 4px 16px #0000000d;animation:slideUp .6s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:36px}.login-logo{width:56px;height:56px;margin:0 auto 16px;background:linear-gradient(135deg,#6366f1,#3b82f6);border-radius:16px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px #6366f140}.login-logo svg{width:28px;height:28px;stroke:#fff;fill:none}.login-header h1{font-size:24px;font-weight:700;color:#0f172a;margin:0 0 6px;letter-spacing:-.3px}.login-header p{font-size:14px;color:#64748b;margin:0}.login-form .form-group{margin-bottom:20px}.login-form label{display:block;font-size:13px;font-weight:500;color:#475569;margin-bottom:8px;letter-spacing:.3px}.login-form input,.login-form select{width:100%;padding:12px 16px;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:12px;color:#0f172a;font-size:14px;font-family:Inter,sans-serif;outline:none;transition:all .3s ease;box-sizing:border-box}.login-form input::placeholder{color:#94a3b8}.login-form input:focus,.login-form select:focus{border-color:#6366f1;background:#fff;box-shadow:0 0 0 3px #6366f11a}.login-form select option{background:#fff;color:#0f172a}.role-selector{display:flex;gap:8px;margin-bottom:24px}.role-chip{flex:1;padding:10px 0;border:1.5px solid #e2e8f0;border-radius:10px;background:#f8fafc;color:#64748b;font-size:13px;font-weight:500;cursor:pointer;transition:all .3s ease;text-align:center;font-family:Inter,sans-serif}.role-chip:hover{border-color:#a5b4fc;background:#eef2ff;color:#4f46e5}.role-chip.active{border-color:#6366f1;background:#eef2ff;color:#4f46e5;font-weight:600;box-shadow:0 0 0 3px #6366f11a}.login-btn{width:100%;padding:14px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:12px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;font-family:Inter,sans-serif;letter-spacing:.3px;position:relative;overflow:hidden;box-shadow:0 4px 14px #6366f14d}.login-btn:hover{transform:translateY(-1px);box-shadow:0 8px 25px #6366f166}.login-btn:active{transform:translateY(0)}.login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-btn .spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle;margin-right:8px}.login-error{background:#fef2f2;border:1px solid #fecaca;border-radius:10px;padding:12px 16px;margin-bottom:20px;color:#dc2626;font-size:13px;display:flex;align-items:center;gap:8px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.otp-card{position:relative;z-index:1;background:#fff;border:1px solid #e2e8f0;border-radius:24px;padding:48px 40px;width:420px;max-width:90vw;box-shadow:0 20px 50px #6366f114,0 4px 16px #0000000d;animation:slideUp .6s ease-out;text-align:center}.otp-icon{width:72px;height:72px;margin:0 auto 20px;background:linear-gradient(135deg,#10b981,#059669);border-radius:20px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px #10b98140}.otp-icon svg{width:36px;height:36px;stroke:#fff;fill:none}.otp-card h1{font-size:22px;font-weight:700;color:#0f172a;margin:0 0 8px}.otp-card .otp-subtitle{font-size:14px;color:#64748b;margin:0 0 32px}.otp-inputs{display:flex;gap:10px;justify-content:center;margin-bottom:28px}.otp-inputs input{width:50px;height:56px;text-align:center;font-size:22px;font-weight:700;font-family:Inter,monospace;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:14px;color:#0f172a;outline:none;transition:all .3s ease;caret-color:#6366f1}.otp-inputs input:focus{border-color:#6366f1;background:#fff;box-shadow:0 0 0 3px #6366f11a}.otp-inputs input.filled{border-color:#10b981;background:#f0fdf4;color:#065f46}.otp-timer{font-size:13px;color:#94a3b8;margin-bottom:24px}.otp-timer span{color:#6366f1;font-weight:600}.otp-resend{background:none;border:none;color:#6366f1;font-size:13px;font-weight:500;cursor:pointer;text-decoration:underline;font-family:Inter,sans-serif}.otp-resend:disabled{color:#cbd5e1;cursor:not-allowed;text-decoration:none}.verify-btn{width:100%;padding:14px;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:12px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;font-family:Inter,sans-serif;box-shadow:0 4px 14px #10b98140}.verify-btn:hover{transform:translateY(-1px);box-shadow:0 8px 25px #10b98166}.verify-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.otp-back{display:inline-flex;align-items:center;gap:6px;margin-top:20px;color:#94a3b8;font-size:13px;cursor:pointer;background:none;border:none;font-family:Inter,sans-serif;transition:color .2s}.otp-back:hover{color:#475569}:root{--sidebar-width: 252px;--sidebar-collapsed-width: 68px;--topbar-height: 60px;--sidebar-bg: #f7f8fc;--sidebar-border: rgba(255, 255, 255, .05);--accent: #3b82f6;--accent-soft: rgba(59, 130, 246, .12);--accent-border: rgba(59, 130, 246, .25);--danger: #ef4444;--danger-soft: rgba(239, 68, 68, .08);--text-primary: #f1f5f9;--text-secondary: #64748b;--text-muted: #334155;--surface: #ffffff;--surface-hover: #f8fafc;--border: #e5e7eb;--content-bg: #f0f4f8;--font-body: "DM Sans", system-ui, sans-serif;--font-display: "Syne", sans-serif;--radius: 8px;--transition: .2s ease}*{box-sizing:border-box;margin:0;padding:0}.al-shell{display:flex;height:100vh;background:var(--content-bg);overflow:hidden;font-family:var(--font-body);color:#0f172a}.al-sidebar{width:var(--sidebar-width);height:100vh;background:var(--sidebar-bg);display:flex;flex-direction:column;flex-shrink:0;position:relative;border-right:1px solid var(--sidebar-border);transition:width .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.al-sidebar:before{content:"";position:absolute;top:-100px;left:-100px;width:260px;height:260px;background:radial-gradient(circle,rgba(59,130,246,.1) 0%,transparent 70%);pointer-events:none;z-index:0}.al-sidebar:after{content:"";position:absolute;bottom:-60px;right:-60px;width:200px;height:200px;background:radial-gradient(circle,rgba(168,85,247,.06) 0%,transparent 70%);pointer-events:none;z-index:0}.al-collapsed .al-sidebar{width:var(--sidebar-collapsed-width)}.al-collapse-btn{position:absolute;top:20px;right:-11px;width:22px;height:22px;background:#1e293b;border:1px solid rgba(255,255,255,.1);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:20;transition:all .2s ease;color:#64748b}.al-collapse-btn:hover{background:#334155;color:#fff;transform:scale(1.1)}.al-collapse-btn svg{width:11px;height:11px;transition:transform .3s ease}.al-collapsed .al-collapse-btn svg{transform:rotate(180deg)}.al-brand{background-color:#f0f4f8;display:flex;align-items:center;gap:11px;padding:20px 16px 18px;border-bottom:1px solid var(--sidebar-border);cursor:pointer;position:relative;z-index:1;min-height:72px;overflow:hidden;transition:padding .3s ease}.al-collapsed .al-brand{padding:20px 0;justify-content:center}.al-logo-wrap{flex-shrink:0}.al-logo{width:50%;height:50%;object-fit:contain;border-radius:7px;display:block}.al-brand-text{display:flex;flex-direction:column;overflow:hidden;white-space:nowrap;transition:opacity .2s ease,max-width .3s ease;opacity:1;max-width:200px}.al-collapsed .al-brand-text{opacity:0;max-width:0}.al-brand-name{font-family:var(--font-display);font-size:14px;font-weight:700;color:#f1f5f9;letter-spacing:-.2px;line-height:1.1}.al-brand-sub{font-size:10px;color:#475569;font-weight:400;letter-spacing:.05em;text-transform:uppercase;margin-top:2px}.al-nav{background-color:#f0f4f8;display:flex;flex-direction:column;gap:4px;padding:14px 10px;flex-grow:1;overflow-y:auto;overflow-x:hidden;position:relative;z-index:1}.al-nav::-webkit-scrollbar{width:0}.al-nav-section{display:flex;flex-direction:column;gap:1px;margin-bottom:6px}.al-nav-section-title{font-size:9.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#2d3f55;padding:8px 8px 4px;white-space:nowrap;overflow:hidden;transition:opacity .2s ease,height .3s ease;height:auto}.al-collapsed .al-nav-section-title{opacity:0;height:0;padding:0;overflow:hidden}.al-nav-link{text-decoration:none;display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--radius);font-size:13.5px;font-weight:500;color:#131212;transition:all var(--transition);position:relative;overflow:visible;white-space:nowrap}.al-collapsed .al-nav-link{justify-content:center;padding:10px 0}.al-nav-link:hover{background:#ffffff0a;color:#cbd5e1}.al-nav-link.active{background:linear-gradient(135deg,#3b82f629,#6366f11a);color:#090909;border:1px solid var(--accent-border)}.al-nav-link.active:after{content:"";position:absolute;left:0;top:22%;height:56%;width:3px;background:linear-gradient(to bottom,#60a5fa,#3b82f6);border-radius:0 3px 3px 0}.al-nav-icon{width:17px;height:17px;flex-shrink:0}.al-nav-icon svg{width:100%;height:100%}.al-nav-label{flex:1;overflow:hidden;transition:opacity .2s ease,max-width .3s ease;opacity:1;max-width:200px}.al-collapsed .al-nav-label{opacity:0;max-width:0}.al-nav-badge{font-size:9px;font-weight:700;letter-spacing:.06em;background:#ef444426;color:#f87171;border:1px solid rgba(239,68,68,.2);padding:2px 6px;border-radius:20px;flex-shrink:0;animation:badge-pulse 2s infinite;transition:opacity .2s ease}.al-collapsed .al-nav-badge{display:none}@keyframes badge-pulse{0%,to{opacity:1}50%{opacity:.6}}.al-tooltip{position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);background:#1e293b;color:#e2e8f0;font-size:12px;font-weight:500;padding:5px 10px;border-radius:6px;white-space:nowrap;pointer-events:none;opacity:0;display:none;border:1px solid rgba(255,255,255,.08);box-shadow:0 4px 12px #00000080;z-index:100}.al-collapsed .al-nav-link:hover .al-tooltip{display:block;opacity:1}.al-sidebar-footer{background-color:#f0f4f8;padding:12px 10px;border-top:1px solid var(--sidebar-border);position:relative;z-index:1}.al-admin-mini{display:flex;align-items:center;gap:9px;padding:8px;border-radius:var(--radius);background:#ffffff08;border:1px solid rgba(255,255,255,.05);cursor:pointer;transition:background .2s ease;overflow:hidden}.al-collapsed .al-admin-mini{justify-content:center;padding:8px 0;background:transparent;border-color:transparent}.al-admin-mini:hover{background:#ffffff0f}.al-admin-avatar{width:30px;height:30px;border-radius:7px;background:linear-gradient(135deg,#3b82f6,#6366f1);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:13px;font-weight:700;color:#fff;flex-shrink:0}.al-admin-info{display:flex;flex-direction:column;overflow:hidden;white-space:nowrap;transition:opacity .2s ease,max-width .3s ease;opacity:1;max-width:200px}.al-collapsed .al-admin-info{opacity:0;max-width:0}.al-admin-name-sm{font-size:12.5px;font-weight:600;color:#e2e8f0}.al-admin-role-sm{font-size:10.5px;color:#475569;margin-top:1px}.al-main{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--content-bg)}.al-topbar{height:var(--topbar-height);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 28px;flex-shrink:0;position:relative;z-index:10}.al-topbar:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,rgba(59,130,246,.15),transparent)}.al-topbar-left{display:flex;align-items:center}.al-breadcrumb{display:flex;align-items:center;gap:8px}.al-breadcrumb-icon{display:flex;align-items:center;color:#94a3b8}.al-topbar-title{font-family:var(--font-display);font-size:15px;font-weight:700;color:#0f172a;letter-spacing:-.2px}.al-topbar-right{display:flex;align-items:center;gap:8px}.al-icon-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#64748b;transition:all .18s ease;position:relative}.al-icon-btn:hover{background:var(--surface-hover);color:#0f172a}.al-notif-dot{position:absolute;top:7px;right:7px;width:7px;height:7px;border-radius:50%;background:#ef4444;border:1.5px solid #fff}.al-topbar-divider{width:1px;height:28px;background:var(--border);margin:0 6px}.al-profile{display:flex;align-items:center;gap:10px;padding:5px 10px 5px 5px;border-radius:var(--radius);border:1px solid transparent;cursor:pointer;transition:all .18s ease}.al-profile:hover{background:var(--surface-hover);border-color:var(--border)}.al-avatar{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#3b82f6,#6366f1);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:13px;font-weight:700;color:#fff;flex-shrink:0}.al-profile-info{display:flex;flex-direction:column}.al-admin-name{font-size:13px;font-weight:600;color:#111827;line-height:1.2}.al-admin-role{font-size:11px;color:#94a3b8;line-height:1.2}.al-logout-btn{display:flex;align-items:center;gap:7px;padding:7px 14px;background:#0f172a;color:#fff;border:none;border-radius:var(--radius);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;transition:all .18s ease;white-space:nowrap}.al-logout-btn:hover{background:#1e293b;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.al-logout-btn:active{transform:translateY(0)}.al-content{background-color:#f0f4f8;flex:1;overflow-y:auto;padding:28px 32px}.al-content::-webkit-scrollbar{width:5px}.al-content::-webkit-scrollbar-track{background:transparent}.al-content::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:8px}.al-content::-webkit-scrollbar-thumb:hover{background:#cbd5e1}@media(max-width:768px){.al-sidebar{width:var(--sidebar-collapsed-width)}.al-brand-text,.al-nav-label,.al-nav-section-title,.al-admin-info{display:none}.al-brand,.al-nav-link,.al-admin-mini{justify-content:center}.al-admin-name,.al-admin-role{display:none}.al-topbar{padding:0 16px}.al-content{padding:16px}}:root{--font-body: "DM Sans", system-ui, sans-serif;--font-display: "Syne", sans-serif;--blue: #3b82f6;--blue-soft: rgba(59, 130, 246, .08);--blue-border: rgba(59, 130, 246, .18);--green: #22c55e;--green-soft: rgba(34, 197, 94, .08);--green-border: rgba(34, 197, 94, .18);--amber: #f59e0b;--amber-soft: rgba(245, 158, 11, .08);--amber-border: rgba(245, 158, 11, .18);--red: #ef4444;--red-soft: rgba(239, 68, 68, .08);--red-border: rgba(239, 68, 68, .18);--surface: #ffffff;--border: #e9eef4;--bg: #f0f4f8;--text-1: #0f172a;--text-2: #64748b;--text-3: #94a3b8;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--shadow-card: 0 1px 3px rgba(15, 23, 42, .06), 0 4px 16px rgba(15, 23, 42, .04);--shadow-hover: 0 4px 20px rgba(15, 23, 42, .09), 0 1px 4px rgba(15, 23, 42, .04)}.adp-root{font-family:var(--font-body);display:flex;flex-direction:column;gap:24px;color:var(--text-1);animation:adp-fadein .4s ease both}@keyframes adp-fadein{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.adp-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.adp-header-left{display:flex;flex-direction:column;gap:4px}.adp-header-eyebrow{display:flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--blue)}.adp-live-dot{width:7px;height:7px;border-radius:50%;background:var(--blue);animation:adp-pulse 1.8s infinite}@keyframes adp-pulse{0%,to{box-shadow:0 0 #3b82f666}50%{box-shadow:0 0 0 5px #3b82f600}}.adp-heading{font-size:24px;font-weight:800;color:var(--text-1);letter-spacing:-.5px;line-height:1.1}.adp-subheading{font-size:13.5px;color:var(--text-2)}.adp-header-right{display:flex;align-items:center;gap:12px}.adp-clock{display:flex;flex-direction:column;align-items:flex-end;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:8px 14px;box-shadow:var(--shadow-card)}.adp-clock-time{font-family:var(--font-display);font-size:16px;font-weight:700;color:#0f172a;letter-spacing:-.3px;line-height:1}.adp-clock-date{font-size:11px;color:var(--text-3);margin-top:2px}.adp-filter-btn{display:flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--border);padding:9px 16px;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:13px;font-weight:500;color:#0f172a;cursor:pointer;transition:all .18s ease;box-shadow:var(--shadow-card)}.adp-filter-btn:hover{background:#f8fafc;border-color:#d1d5db;box-shadow:var(--shadow-hover)}.adp-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 22px 16px;display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden;transition:all .22s ease;box-shadow:var(--shadow-card)}.kpi-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover)}.kpi-card:before{content:"";position:absolute;top:-30px;right:-30px;width:80px;height:80px;border-radius:50%;opacity:.5}.kpi-blue:before{background:var(--blue-soft)}.kpi-green:before{background:var(--green-soft)}.kpi-amber:before{background:var(--amber-soft)}.kpi-red:before{background:var(--red-soft)}.kpi-top{display:flex;align-items:center;justify-content:space-between}.kpi-title{font-size:12.5px;font-weight:500;color:var(--text-2)}.kpi-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.kpi-blue .kpi-icon{background:var(--blue-soft);color:var(--blue);border:1px solid var(--blue-border)}.kpi-green .kpi-icon{background:var(--green-soft);color:var(--green);border:1px solid var(--green-border)}.kpi-amber .kpi-icon{background:var(--amber-soft);color:var(--amber);border:1px solid var(--amber-border)}.kpi-red .kpi-icon{background:var(--red-soft);color:var(--red);border:1px solid var(--red-border)}.kpi-value{font-size:34px;font-weight:800;color:#0f172a;letter-spacing:-1px;line-height:1}.kpi-sub{font-size:11.5px;color:var(--text-3)}.kpi-bar{position:absolute;bottom:0;left:0;right:0;height:3px;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.kpi-blue .kpi-bar{background:linear-gradient(to right,var(--blue),#6366f1)}.kpi-green .kpi-bar{background:linear-gradient(to right,var(--green),#10b981)}.kpi-amber .kpi-bar{background:linear-gradient(to right,var(--amber),#f97316)}.kpi-red .kpi-bar{background:linear-gradient(to right,var(--red),#f43f5e)}.adp-grid{display:grid;grid-template-columns:1fr 340px;gap:20px;align-items:start}.adp-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;display:flex;flex-direction:column;gap:18px;box-shadow:var(--shadow-card);transition:box-shadow .2s ease}.adp-card:hover{box-shadow:var(--shadow-hover)}.adp-card-header{color:#0f172a;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.adp-card-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:#0f172a;letter-spacing:-.2px}.adp-card-desc{font-size:12.5px;color:var(--text-3);margin-top:2px}.adp-table-wrap{overflow:hidden;border-radius:var(--radius-md);border:1px solid var(--border)}.adp-table{width:100%;border-collapse:collapse;font-size:13.5px}.adp-table thead{background:#f8fafc}.adp-table th{text-align:left;padding:11px 16px;font-size:11.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-3);border-bottom:1px solid var(--border)}.adp-table td{padding:13px 16px;color:#0f172a;border-bottom:1px solid #f1f5f9;transition:background .15s ease}.adp-table tr:last-child td{border-bottom:none}.adp-table tbody tr:hover td{background:#f8fafc}.adp-td-title{color:#0f172a;font-weight:500}.adp-badge-live{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:600;background:var(--green-soft);color:#16a34a;border:1px solid var(--green-border)}.adp-pulse{width:6px;height:6px;border-radius:50%;background:#22c55e;animation:adp-pulse 1.8s infinite}.adp-status-live{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:11.5px;font-weight:700;letter-spacing:.04em;background:var(--green-soft);color:#16a34a;border:1px solid var(--green-border)}.adp-status-dot{width:5px;height:5px;border-radius:50%;background:#22c55e;animation:adp-pulse 1.8s infinite}.adp-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:36px 0;color:var(--text-3);font-size:13.5px}.adp-loading{display:flex;align-items:center;gap:10px;padding:24px 0;color:var(--text-2);font-size:13.5px}.adp-spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:adp-spin .7s linear infinite}@keyframes adp-spin{to{transform:rotate(360deg)}}.adp-risk-body{display:flex;flex-direction:column;align-items:center;gap:20px}.adp-risk-score-wrap{position:relative;width:80px;height:80px}.adp-ring{width:80px;height:80px}.adp-ring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.adp-ring-value{font-family:var(--font-display);font-size:20px;font-weight:800;color:var(--text-1);line-height:1;letter-spacing:-.5px}.adp-ring-label{font-size:10px;color:var(--text-3);font-weight:500}.adp-risk-metrics{display:flex;flex-direction:column;gap:0;width:100%;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.adp-metric-row{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;font-size:13.5px;border-bottom:1px solid #f1f5f9;transition:background .15s ease}.adp-metric-row:last-child{border-bottom:none}.adp-metric-row:hover{background:#f8fafc}.adp-metric-label{color:var(--text-2);font-weight:500}.adp-metric-value{font-weight:600;color:var(--text-1)}.adp-risk-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:11.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.adp-risk-low{background:var(--green-soft);color:#16a34a;border:1px solid var(--green-border)}.adp-risk-medium{background:var(--amber-soft);color:#b45309;border:1px solid var(--amber-border)}.adp-risk-high{background:var(--red-soft);color:#b91c1c;border:1px solid var(--red-border)}.adp-risk-critical{background:#4c0519;color:#fda4af;border:1px solid rgba(244,63,94,.3);animation:adp-critical-pulse 1.5s infinite}@keyframes adp-critical-pulse{0%,to{box-shadow:0 0 #f43f5e4d}50%{box-shadow:0 0 0 4px #f43f5e00}}.adp-download-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 16px;border-radius:var(--radius-sm);border:none;background:var(--text-1);color:#0f172a;font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;transition:all .18s ease;margin-top:4px}.adp-download-btn:hover{background:#1e293b;transform:translateY(-1px);box-shadow:0 4px 14px #0f172a2e}.adp-download-btn:active{transform:translateY(0)}@media(max-width:900px){.adp-grid{grid-template-columns:1fr}.adp-card-wide{order:1}.adp-card-risk{order:0}}@media(max-width:600px){.adp-header{flex-direction:column}.adp-header-right{width:100%;justify-content:space-between}.adp-kpis{grid-template-columns:1fr 1fr}}:root{--font-body: "DM Sans", system-ui, sans-serif;--font-display: "Syne", sans-serif;--blue: #3b82f6;--blue-soft: rgba(59, 130, 246, .08);--blue-border: rgba(59, 130, 246, .2);--green: #22c55e;--green-soft: rgba(34, 197, 94, .09);--green-border: rgba(34, 197, 94, .2);--amber: #f59e0b;--amber-soft: rgba(245, 158, 11, .09);--amber-border: rgba(245, 158, 11, .2);--purple: #8b5cf6;--purple-soft: rgba(139, 92, 246, .09);--purple-border: rgba(139, 92, 246, .2);--teal: #14b8a6;--teal-soft: rgba(20, 184, 166, .09);--teal-border: rgba(20, 184, 166, .2);--red: #ef4444;--red-soft: rgba(239, 68, 68, .09);--red-border: rgba(239, 68, 68, .2);--surface: #ffffff;--border: #e9eef4;--bg: #f0f4f8;--text-1: #0f172a;--text-2: #64748b;--text-3: #94a3b8;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--shadow: 0 1px 3px rgba(15, 23, 42, .06), 0 4px 16px rgba(15, 23, 42, .04);--shadow-hover: 0 4px 20px rgba(15, 23, 42, .09), 0 1px 4px rgba(15, 23, 42, .04)}.aep-root{font-family:var(--font-body);display:flex;flex-direction:column;gap:22px;color:var(--text-1);animation:aep-in .35s ease both}@keyframes aep-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.aep-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.aep-header-left{display:flex;flex-direction:column;gap:4px}.aep-eyebrow{display:flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--blue)}.aep-heading{font-size:24px;font-weight:800;color:var(--text-1);letter-spacing:-.5px;line-height:1.1}.aep-subheading{font-size:13.5px;color:var(--text-2)}.aep-btn-primary{display:inline-flex;align-items:center;gap:7px;background:#fff;color:#000;border:none;padding:9px 18px;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:13.5px;font-weight:500;cursor:pointer;transition:all .18s ease;white-space:nowrap}.aep-btn-primary:hover:not(:disabled){background:#1e293b;transform:translateY(-1px);box-shadow:0 4px 14px #0f172a2e}.aep-btn-primary:active:not(:disabled){transform:none}.aep-btn-primary:disabled{opacity:.65;cursor:not-allowed}.aep-btn-outline{display:inline-flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--border);color:var(--text-1);padding:9px 18px;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:13.5px;font-weight:500;cursor:pointer;transition:all .18s ease}.aep-btn-outline:hover{background:#f8fafc;border-color:#cbd5e1;box-shadow:var(--shadow)}.aep-summary-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px}.aep-summary-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px 18px 14px;display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden;transition:all .2s ease;box-shadow:var(--shadow)}.aep-summary-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}.aep-summary-card:after{content:"";position:absolute;top:-20px;right:-20px;width:70px;height:70px;border-radius:50%;opacity:.5}.aep-ac-blue:after{background:var(--blue-soft)}.aep-ac-amber:after{background:var(--amber-soft)}.aep-ac-green:after{background:var(--green-soft)}.aep-ac-teal:after{background:var(--teal-soft)}.aep-summary-card:before{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;border-radius:0 0 var(--radius-md) var(--radius-md)}.aep-ac-blue:before{background:linear-gradient(to right,var(--blue),#6366f1)}.aep-ac-amber:before{background:linear-gradient(to right,var(--amber),#f97316)}.aep-ac-green:before{background:linear-gradient(to right,var(--green),#10b981)}.aep-ac-teal:before{background:linear-gradient(to right,var(--teal),#06b6d4)}.aep-summary-top{display:flex;align-items:center;justify-content:space-between}.aep-summary-label{font-size:12px;font-weight:500;color:var(--text-2)}.aep-summary-icon{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative}.aep-summary-icon svg{width:16px;height:16px}.aep-ac-blue .aep-summary-icon{background:var(--blue-soft);color:var(--blue);border:1px solid var(--blue-border)}.aep-ac-amber .aep-summary-icon{background:var(--amber-soft);color:var(--amber);border:1px solid var(--amber-border)}.aep-ac-green .aep-summary-icon{background:var(--green-soft);color:var(--green);border:1px solid var(--green-border)}.aep-ac-teal .aep-summary-icon{background:var(--teal-soft);color:var(--teal);border:1px solid var(--teal-border)}.aep-sum-pulse{position:absolute;top:-2px;right:-2px;width:8px;height:8px;border-radius:50%;background:var(--green);border:1.5px solid #fff;animation:aep-pulse 1.8s infinite}@keyframes aep-pulse{0%,to{box-shadow:0 0 #22c55e66}50%{box-shadow:0 0 0 4px #22c55e00}}.aep-summary-value{font-size:28px;font-weight:800;color:#0f172a;letter-spacing:-.8px;line-height:1}.aep-layout{display:grid;grid-template-columns:290px 1fr;gap:18px;align-items:start}.aep-list-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow)}.aep-search-wrap{position:relative;display:flex;align-items:center}.aep-search-icon{position:absolute;left:11px;color:var(--text-3);pointer-events:none}.aep-search{width:100%;padding:9px 36px;border-radius:var(--radius-sm);border:1px solid var(--border);font-family:var(--font-body);font-size:13.5px;color:var(--text-1);background:#f8fafc;transition:all .18s ease;outline:none}.aep-search:focus{background:var(--surface);border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft)}.aep-search::placeholder{color:var(--text-3)}.aep-search-clear{position:absolute;right:10px;background:none;border:none;cursor:pointer;color:var(--text-3);font-size:12px;padding:2px 4px;border-radius:4px;transition:color .15s ease}.aep-search-clear:hover{color:var(--text-1)}.aep-list{display:flex;flex-direction:column;gap:4px;max-height:520px;overflow-y:auto}.aep-list::-webkit-scrollbar{width:4px}.aep-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.aep-exam-item{padding:11px 12px;border-radius:var(--radius-sm);cursor:pointer;border:1px solid transparent;transition:all .16s ease}.aep-exam-item:hover{background:#f8fafc;border-color:var(--border)}.aep-exam-item.active{background:var(--blue-soft);border-color:var(--blue-border)}.aep-exam-item-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px}.aep-exam-title{font-size:13.5px;font-weight:600;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.aep-exam-meta{font-size:11.5px;color:var(--text-3)}.aep-status-pill{display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.03em;white-space:nowrap;flex-shrink:0}.aep-pill-lg{padding:4px 12px;font-size:12px}.aep-pill-dot{width:5px;height:5px;border-radius:50%;background:var(--green);animation:aep-pulse 1.8s infinite}.aep-s-gray{background:#f1f5f9;color:#64748b;border:1px solid #e2e8f0}.aep-s-blue{background:var(--blue-soft);color:#1d4ed8;border:1px solid var(--blue-border)}.aep-s-green{background:var(--green-soft);color:#15803d;border:1px solid var(--green-border)}.aep-s-purple{background:var(--purple-soft);color:#6d28d9;border:1px solid var(--purple-border)}.aep-s-red{background:var(--red-soft);color:#b91c1c;border:1px solid var(--red-border)}.aep-detail-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:26px 28px;display:flex;flex-direction:column;gap:20px;box-shadow:var(--shadow);min-height:320px}.aep-detail-header{color:#0f172a;display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.aep-detail-eyebrow{font-size:11px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--text-3);margin-bottom:4px}.aep-detail-title{font-size:20px;font-weight:800;color:#0f172a;letter-spacing:-.3px}.aep-divider{height:1px;background:var(--border);margin:-4px 0}.aep-detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.aep-detail-card{background:#f8fafc;border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 16px;display:flex;flex-direction:column;gap:6px;transition:all .18s ease}.aep-detail-card:hover{background:var(--surface);box-shadow:var(--shadow)}.aep-detail-card-icon{width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:var(--blue-soft);border:1px solid var(--blue-border);border-radius:7px;color:var(--blue);margin-bottom:2px}.aep-detail-card-icon svg{width:15px;height:15px}.aep-detail-label{font-size:11.5px;font-weight:500;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em}.aep-detail-value{font-size:14.5px;font-weight:600;color:#0f172a}.aep-actions{display:flex;gap:12px;flex-wrap:wrap}.aep-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px 0;color:var(--text-3);font-size:13.5px;text-align:center}.aep-empty-center{justify-content:center;flex:1;padding:60px 0}.aep-overlay{position:fixed;inset:0;background:#0f172a73;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:flex-end;z-index:1000;animation:aep-overlay-in .2s ease}@keyframes aep-overlay-in{0%{opacity:0}to{opacity:1}}.aep-drawer{width:400px;background:var(--surface);display:flex;flex-direction:column;box-shadow:-8px 0 40px #0f172a1f;animation:aep-drawer-in .28s cubic-bezier(.4,0,.2,1);height:100vh}@keyframes aep-drawer-in{0%{transform:translate(100%)}to{transform:translate(0)}}.aep-drawer-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:24px 24px 20px;border-bottom:1px solid var(--border)}.aep-drawer-title{font-size:17px;font-weight:700;color:var(--text-1);letter-spacing:-.2px}.aep-drawer-sub{font-size:13px;color:var(--text-2);margin-top:3px}.aep-drawer-close{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:7px;background:none;cursor:pointer;color:var(--text-2);transition:all .16s ease;flex-shrink:0}.aep-drawer-close:hover{background:#f1f5f9;color:var(--text-1)}.aep-drawer-body{flex:1;padding:24px;display:flex;flex-direction:column;gap:18px;overflow-y:auto}.aep-form-group{display:flex;flex-direction:column;gap:6px}.aep-form-group label{font-size:12.5px;font-weight:600;color:var(--text-2);letter-spacing:.02em}.aep-form-group input{padding:10px 13px;border-radius:var(--radius-sm);border:1px solid var(--border);font-family:var(--font-body);font-size:14px;color:var(--text-1);background:#f8fafc;outline:none;transition:all .18s ease}.aep-form-group input:focus{background:var(--surface);border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft)}.aep-form-group input::placeholder{color:var(--text-3)}.aep-drawer-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}.aep-spinner-sm{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:aep-spin .65s linear infinite;flex-shrink:0}@keyframes aep-spin{to{transform:rotate(360deg)}}@media(max-width:860px){.aep-layout{grid-template-columns:1fr}.aep-detail-grid{grid-template-columns:1fr 1fr}.aep-drawer{width:100%}}@media(max-width:560px){.aep-detail-grid{grid-template-columns:1fr}.aep-summary-bar{grid-template-columns:1fr 1fr}}.aqm-overlay{position:fixed;inset:0;background:#0a0f1e99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:aqm-fadeIn .2s ease}@keyframes aqm-fadeIn{0%{opacity:0}to{opacity:1}}.aqm-modal{background:#fff;width:640px;max-width:calc(100vw - 32px);max-height:calc(100vh - 40px);border-radius:16px;display:flex;flex-direction:column;box-shadow:0 25px 60px #0a0f1e40;animation:aqm-slideUp .25s ease;overflow:hidden}@keyframes aqm-slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.aqm-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 14px;border-bottom:1px solid #f1f5f9}.aqm-title{margin:0;font-size:1.15rem;font-weight:700;color:#0f172a}.aqm-close{background:none;border:none;font-size:1.1rem;color:#94a3b8;cursor:pointer;width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .15s}.aqm-close:hover{background:#f1f5f9;color:#334155}.aqm-modal{overflow-y:auto}.aqm-type-selector,.aqm-field,.aqm-mcq-section,.aqm-row-2,.aqm-marks-field{padding-left:24px;padding-right:24px}.aqm-type-selector{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding-top:16px;padding-bottom:8px}.aqm-type-btn{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:12px;padding:10px 6px;cursor:pointer;text-align:center;transition:all .18s;display:flex;flex-direction:column;align-items:center;gap:4px}.aqm-type-btn:hover{border-color:#93c5fd;background:#eff6ff}.aqm-type-btn.active{border-color:#2563eb;background:#eff6ff;box-shadow:0 0 0 3px #2563eb1a}.aqm-type-icon{font-size:1.2rem;line-height:1}.aqm-type-label{font-size:.78rem;font-weight:650;color:#0f172a}.aqm-type-desc{font-size:.65rem;color:#94a3b8;line-height:1.2}.aqm-type-btn.active .aqm-type-label{color:#2563eb}.aqm-field{margin-bottom:14px}.aqm-label{display:block;font-size:.78rem;font-weight:600;color:#334155;margin-bottom:6px}.aqm-optional{font-weight:400;color:#94a3b8;font-size:.72rem}.aqm-input,.aqm-textarea,.aqm-select{width:100%;padding:10px 14px;font-size:.88rem;border:1.5px solid #e2e8f0;border-radius:10px;background:#fff;color:#0f172a;font-family:inherit;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.aqm-input:focus,.aqm-textarea:focus,.aqm-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.aqm-textarea{resize:vertical;min-height:70px}.aqm-textarea-lg{min-height:110px}.aqm-code-area{font-family:Fira Code,Consolas,Monaco,monospace;font-size:.82rem;background:#1e293b;color:#e2e8f0;border-color:#334155;min-height:130px}.aqm-code-area:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa26}.aqm-code-area::placeholder{color:#64748b}.aqm-select{cursor:pointer;appearance:auto}.aqm-hint{margin:6px 0 0;font-size:.7rem;color:#94a3b8}.aqm-mcq-section{margin-bottom:14px}.aqm-options-grid{display:flex;flex-direction:column;gap:8px}.aqm-option-row{display:flex;align-items:center;gap:8px;border-radius:10px;padding:3px;transition:background .15s}.aqm-option-row.correct{background:#22c55e0f}.aqm-correct-btn{width:34px;height:34px;min-width:34px;border-radius:8px;border:1.5px solid #e2e8f0;background:#f8fafc;font-size:.8rem;font-weight:700;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.aqm-correct-btn:hover{border-color:#22c55e;color:#22c55e}.aqm-correct-btn.selected{background:#22c55e;border-color:#22c55e;color:#fff;box-shadow:0 2px 6px #22c55e4d}.aqm-option-input{flex:1;padding:9px 12px;font-size:.85rem;border:1.5px solid #e2e8f0;border-radius:8px;background:#fff;color:#0f172a;transition:border-color .15s}.aqm-option-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.aqm-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}.aqm-marks-field{max-width:160px}.aqm-marks-input{text-align:center;font-weight:600}.aqm-actions{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid #f1f5f9;background:#fafbfc}.aqm-btn-cancel{background:#fff;color:#475569;border:1.5px solid #e2e8f0;padding:9px 20px;border-radius:10px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s}.aqm-btn-cancel:hover{background:#f1f5f9}.aqm-btn-save{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;padding:9px 22px;border-radius:10px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s;box-shadow:0 2px 8px #2563eb40}.aqm-btn-save:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);box-shadow:0 4px 12px #2563eb59}.aqm-btn-save:disabled,.aqm-btn-cancel:disabled{opacity:.55;cursor:not-allowed}.aqm-image-dropzone{border:2px dashed #c7d2fe;border-radius:14px;padding:28px 20px;text-align:center;cursor:pointer;transition:all .2s;background:linear-gradient(135deg,#f5f3ff,#eef2ff)}.aqm-image-dropzone:hover{border-color:#818cf8;background:linear-gradient(135deg,#ede9fe,#e0e7ff);transform:translateY(-1px);box-shadow:0 4px 16px #6366f11a}.aqm-dropzone-content{display:flex;flex-direction:column;align-items:center;gap:8px;color:#6366f1}.aqm-dropzone-content svg{opacity:.6}.aqm-dropzone-content p{margin:0;font-size:.85rem;color:#475569}.aqm-dropzone-hint{font-size:.7rem;color:#94a3b8}.aqm-image-preview-card{position:relative;border-radius:14px;overflow:hidden;border:2px solid #e0e7ff;background:#f8fafc;animation:aqm-fadeIn .3s ease}.aqm-image-preview{display:block;width:100%;max-height:240px;object-fit:contain;background:#f1f5f9;padding:8px}.aqm-image-remove{position:absolute;top:10px;right:10px;display:flex;align-items:center;gap:4px;padding:6px 12px;background:#ef4444e6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;border:none;border-radius:8px;font-size:.72rem;font-weight:600;cursor:pointer;transition:all .15s;box-shadow:0 2px 8px #ef44444d}.aqm-image-remove:hover{background:#dc2626;box-shadow:0 4px 12px #ef444466;transform:scale(1.05)}@media(max-width:600px){.aqm-type-selector{grid-template-columns:repeat(2,1fr)}.aqm-row-2{grid-template-columns:1fr}}.pum-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:pum-fade-in .2s ease-out}@keyframes pum-fade-in{0%{opacity:0}to{opacity:1}}.pum-modal{background:#fff;width:90%;max-width:600px;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;overflow:hidden;display:flex;flex-direction:column;animation:pum-slide-up .3s ease-out}@keyframes pum-slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.pum-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid #e2e8f0;background:#f8fafc}.pum-header h3{margin:0;font-size:18px;color:#1e293b;font-weight:600}.pum-close{background:transparent;border:none;font-size:20px;color:#64748b;cursor:pointer;padding:4px;transition:color .15s}.pum-close:hover{color:#ef4444}.pum-content{padding:24px;max-height:70vh;overflow-y:auto}.pum-upload-section,.pum-review-section{display:flex;flex-direction:column;gap:20px}.pum-dropzone{border:2px dashed #cbd5e1;border-radius:8px;background:#f8fafc;padding:40px 20px;text-align:center;cursor:pointer;transition:all .2s ease}.pum-dropzone:hover{border-color:#6366f1;background:#eef2ff}.pum-dropzone-content{display:flex;flex-direction:column;align-items:center;gap:12px;color:#64748b}.pum-dropzone-content svg{color:#a3a8b4}.pum-filename{margin:0;font-weight:500;color:#334155}.pum-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:10px}.pum-btn-cancel{padding:10px 16px;border-radius:6px;border:1px solid #cbd5e1;background:#fff;color:#475569;font-weight:500;cursor:pointer;transition:all .2s}.pum-btn-cancel:hover:not(:disabled){background:#f1f5f9}.pum-btn-primary{padding:10px 20px;border-radius:6px;border:none;background:#6366f1;color:#fff;font-weight:600;cursor:pointer;transition:all .2s}.pum-btn-primary:hover:not(:disabled){background:#4f46e5;box-shadow:0 4px 6px -1px #6366f166}.pum-btn-primary:disabled{opacity:.6;cursor:not-allowed}.pum-error{background:#fef2f2;border:1px solid #fecaca;color:#ef4444;padding:12px;border-radius:6px;font-size:14px}.pum-review-header h4{margin:0 0 4px;font-size:16px;color:#1e293b}.pum-review-header p{margin:0;font-size:14px;color:#64748b}.pum-list{display:flex;flex-direction:column;gap:12px}.pum-q-card{border:1px solid #e2e8f0;border-radius:8px;padding:16px;background:#fff}.pum-q-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.pum-q-type{font-size:12px;font-weight:600;color:#4338ca;background:#e0e7ff;padding:2px 8px;border-radius:12px}.pum-q-remove{font-size:12px;color:#ef4444;background:none;border:none;cursor:pointer;padding:4px 8px}.pum-q-remove:hover{text-decoration:underline}.pum-q-text{font-size:14px;color:#334155;margin-bottom:12px;font-weight:500}.pum-q-options{display:flex;flex-direction:column;gap:4px;font-size:13px}.pum-q-opt{padding:6px 10px;border-radius:4px;background:#f8fafc;color:#475569}.pum-q-opt.correct{background:#dcfce7;color:#166534;font-weight:500}.pum-q-text-edit{width:100%;padding:10px;border:1px solid #e2e8f0;border-radius:6px;font-family:inherit;font-size:14px;color:#1e293b;background:#fbfcfd;resize:vertical;margin-bottom:12px;transition:border-color .2s}.pum-q-text-edit:focus{outline:none;border-color:#6366f1;background:#fff}.pum-marks-edit{display:flex;align-items:center;gap:6px;font-size:12px;color:#64748b;background:#f1f5f9;padding:2px 8px;border-radius:12px}.pum-marks-edit input{width:36px;border:none;background:transparent;font-weight:600;color:#1e293b;text-align:center}.pum-marks-edit input:focus{outline:none}.pum-q-options-edit{display:flex;flex-direction:column;gap:8px}.pum-hint{font-size:11px;color:#94a3b8;text-transform:uppercase;letter-spacing:.025em;font-weight:600;margin:0 0 4px}.pum-q-opt-edit{display:flex;align-items:center;gap:12px;padding:10px 14px;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s;background:#fff}.pum-q-opt-edit:hover{border-color:#cbd5e1;background:#f8fafc}.pum-q-opt-edit.correct{border-color:#22c55e;background:#f0fdf4;box-shadow:0 0 0 1px #22c55e}.pum-opt-radio{width:18px;height:18px;border:2px solid #cbd5e1;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}.pum-q-opt-edit.correct .pum-opt-radio{border-color:#22c55e}.radio-dot{width:10px;height:10px;background:#22c55e;border-radius:50%;transform:scale(0);transition:transform .2s cubic-bezier(.175,.885,.32,1.275)}.radio-dot.checked{transform:scale(1)}.pum-opt-id{font-weight:700;color:#64748b;font-size:13px;width:16px}.pum-q-opt-edit.correct .pum-opt-id{color:#166534}.pum-opt-text{font-size:13px;color:#334155}.pum-q-opt-edit.correct .pum-opt-text{color:#166534;font-weight:500}.pum-q-feedback{padding:10px;background:#f8fafc;border-radius:6px;border-left:3px solid #cbd5e1}.qt-root{display:flex;flex-direction:column;gap:0}.qt-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:20px}.qt-title{font-size:15px;font-weight:700;color:#0f172a;margin:0 0 2px}.qt-sub{font-size:12.5px;color:#64748b;margin:0}.qt-btn-add{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap;flex-shrink:0}.qt-btn-add:hover{background:#2563eb}.qt-loading,.qt-error{padding:24px;color:#64748b;font-size:13px}.qt-error{color:#ef4444}.qt-empty{display:flex;flex-direction:column;align-items:center;gap:10px;padding:48px 24px;color:#94a3b8;font-size:13px;text-align:center}.qt-list{display:flex;flex-direction:column;gap:12px}.qt-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:16px 18px;transition:border-color .15s,box-shadow .15s}.qt-card:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000000d}.qt-card-top{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px}.qt-q-num{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;background:#3b82f6;color:#fff;border-radius:6px;font-size:11px;font-weight:700;flex-shrink:0;margin-top:1px}.qt-q-text{flex:1;font-size:14px;font-weight:600;color:#0f172a;margin:0;line-height:1.5}.qt-card-actions{display:flex;gap:6px;flex-shrink:0}.qt-btn-edit,.qt-btn-delete{display:flex;align-items:center;gap:4px;padding:5px 10px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;border:1px solid}.qt-btn-edit{background:#eff6ff;color:#2563eb;border-color:#bfdbfe}.qt-btn-edit:hover{background:#dbeafe}.qt-btn-delete{background:#fef2f2;color:#dc2626;border-color:#fecaca}.qt-btn-delete:hover:not(:disabled){background:#fee2e2}.qt-btn-delete:disabled{opacity:.5;cursor:not-allowed}.qt-options{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.qt-option{display:flex;align-items:center;gap:6px;padding:5px 10px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;font-size:12.5px;color:#374151}.qt-option-correct{background:#f0fdf4;border-color:#bbf7d0;color:#15803d;font-weight:600}.qt-opt-label{font-weight:700;font-size:11px;background:#e2e8f0;padding:1px 5px;border-radius:4px;color:#374151}.qt-option-correct .qt-opt-label{background:#dcfce7;color:#15803d}.qt-meta{display:flex;align-items:center;gap:12px;margin-top:4px}.qt-marks{font-size:11.5px;color:#64748b;background:#f1f5f9;border:1px solid #e2e8f0;padding:2px 8px;border-radius:999px}.qt-answer{font-size:11.5px;color:#15803d;font-weight:500}.qt-type-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:6px;font-size:10.5px;font-weight:650;white-space:nowrap;flex-shrink:0;margin-top:3px}.qt-type-summary{display:inline-flex;gap:6px;margin-left:8px}.qt-type-pill{display:inline-flex;align-items:center;padding:1px 7px;border-radius:100px;font-size:10.5px;font-weight:600}.qt-answer-preview{padding:8px 12px;background:#f0fdf4;border:1px solid #dcfce7;border-radius:8px;margin-bottom:10px;font-size:12.5px}.qt-answer-label{font-weight:600;color:#15803d;margin-right:6px}.qt-answer-text{color:#166534;line-height:1.5}.qt-coding-preview{margin-bottom:10px}.qt-code-lang{display:inline-block;padding:2px 8px;background:#1e293b;color:#94a3b8;border-radius:6px 6px 0 0;font-size:10.5px;font-weight:600;font-family:Fira Code,monospace}.qt-code-block{margin:0;padding:10px 14px;background:#1e293b;color:#e2e8f0;border-radius:0 8px 8px;font-size:12px;font-family:Fira Code,Consolas,monospace;overflow-x:auto;white-space:pre-wrap;max-height:120px;overflow-y:auto}.qt-image-thumb{position:relative;margin-bottom:10px;border-radius:10px;overflow:hidden;border:1px solid #e0e7ff;background:#f8fafc;max-height:160px}.qt-image-thumb img{display:block;width:100%;max-height:150px;object-fit:contain;padding:6px}.qt-image-badge{position:absolute;top:6px;left:6px;background:#6366f1e6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;font-size:10px;font-weight:600;padding:2px 8px;border-radius:6px}:root{--font-body: "DM Sans", system-ui, sans-serif;--font-display: "Syne", sans-serif;--blue: #3b82f6;--blue-soft: rgba(59, 130, 246, .08);--blue-border: rgba(59, 130, 246, .2);--green: #22c55e;--green-soft: rgba(34, 197, 94, .09);--green-border: rgba(34, 197, 94, .2);--amber: #f59e0b;--amber-soft: rgba(245, 158, 11, .09);--amber-border: rgba(245, 158, 11, .22);--surface: #ffffff;--border: #e9eef4;--bg: #f0f4f8;--text-1: #0f172a;--text-2: #64748b;--text-3: #94a3b8;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--shadow: 0 1px 3px rgba(15, 23, 42, .06), 0 4px 16px rgba(15, 23, 42, .04);--shadow-hover: 0 4px 20px rgba(15, 23, 42, .09), 0 1px 4px rgba(15, 23, 42, .04)}.aed-root{font-family:var(--font-body);display:flex;flex-direction:column;gap:0;color:var(--text-1);animation:aed-in .35s ease both}@keyframes aed-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.aed-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:22px 26px;flex-wrap:wrap;border-bottom:none}.aed-header-left{display:flex;flex-direction:column;gap:6px}.aed-breadcrumb{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:500;color:var(--text-3);cursor:pointer;transition:color .15s ease;width:fit-content}.aed-breadcrumb:hover{color:var(--blue)}.aed-title{font-size:20px;font-weight:800;color:var(--text-1);letter-spacing:-.4px;line-height:1.1}.aed-status-chip{display:inline-flex;align-items:center;gap:6px;padding:3px 11px;border-radius:999px;font-size:11.5px;font-weight:600;width:fit-content}.aed-status-active{background:var(--green-soft);color:#15803d;border:1px solid var(--green-border)}.aed-status-draft{background:var(--amber-soft);color:#b45309;border:1px solid var(--amber-border)}.aed-chip-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:aed-pulse 1.8s infinite}@keyframes aed-pulse{0%,to{box-shadow:0 0 #22c55e66}50%{box-shadow:0 0 0 4px #22c55e00}}.aed-header-actions{display:flex;align-items:center;gap:10px;padding-top:4px}.aed-btn-back{display:inline-flex;align-items:center;gap:6px;padding:8px 15px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-2);cursor:pointer;transition:all .18s ease}.aed-btn-back:hover{background:#f8fafc;color:var(--text-1);border-color:#cbd5e1}.aed-btn-publish{display:inline-flex;align-items:center;gap:7px;padding:8px 18px;border-radius:var(--radius-sm);border:none;background:var(--text-1);color:#fff;font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;transition:all .18s ease}.aed-btn-publish:hover{background:#1e293b;transform:translateY(-1px);box-shadow:0 4px 14px #0f172a2e}.aed-btn-publish:active{transform:none}.aed-tabs{display:flex;gap:2px;background:var(--surface);border-left:1px solid var(--border);border-right:1px solid var(--border);border-bottom:1px solid var(--border);padding:0 18px;position:relative}.aed-tabs:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--border)}.aed-tab{display:inline-flex;align-items:center;gap:7px;padding:12px 14px;border:none;background:transparent;font-family:var(--font-body);font-size:13.5px;font-weight:500;color:var(--text-2);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .18s ease;position:relative;z-index:1;white-space:nowrap}.aed-tab:hover{color:var(--text-1)}.aed-tab.active{color:var(--blue);border-bottom-color:var(--blue);font-weight:600}.aed-tab-icon{width:15px;height:15px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.aed-tab-icon svg{width:100%;height:100%}.aed-tab-body{background:var(--surface);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius-lg) var(--radius-lg);padding:28px;min-height:300px}.aed-tab-section{display:flex;flex-direction:column;gap:22px;max-width:560px}.aed-section-header{display:flex;flex-direction:column;gap:3px;padding-bottom:16px;border-bottom:1px solid var(--border)}.aed-section-title{font-size:16px;font-weight:700;color:var(--text-1);letter-spacing:-.2px}.aed-section-sub{font-size:13px;color:var(--text-3)}.aed-fields{display:flex;flex-direction:column;gap:16px}.aed-field{display:flex;flex-direction:column;gap:6px}.aed-label{font-size:12.5px;font-weight:600;color:var(--text-2);letter-spacing:.02em}.aed-input,.aed-textarea{width:100%;padding:10px 13px;border-radius:var(--radius-sm);border:1px solid var(--border);font-family:var(--font-body);font-size:14px;color:var(--text-1);background:var(--surface);outline:none;transition:all .18s ease}.aed-textarea{min-height:110px;resize:vertical;line-height:1.5}.aed-input:focus,.aed-textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft)}.aed-input:disabled,.aed-textarea:disabled{background:#f8fafc;color:var(--text-2);cursor:not-allowed;border-color:#edf2f7}.aed-readonly-notice{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;border-radius:var(--radius-sm);background:var(--amber-soft);border:1px solid var(--amber-border);color:#b45309;font-size:12.5px;font-weight:500}.aed-proctor-list{display:flex;flex-direction:column;gap:10px}.aed-proctor-row{display:flex;align-items:center;gap:14px;padding:16px 18px;border-radius:var(--radius-md);border:1px solid var(--border);background:#fafbfd;cursor:pointer;transition:all .18s ease}.aed-proctor-row:hover:not(.disabled){background:var(--surface);border-color:#cbd5e1;box-shadow:var(--shadow)}.aed-proctor-row.disabled{opacity:.65;cursor:not-allowed}.aed-proctor-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:9px;background:var(--blue-soft);border:1px solid var(--blue-border);color:var(--blue);flex-shrink:0}.aed-proctor-icon svg{width:17px;height:17px}.aed-proctor-info{flex:1;display:flex;flex-direction:column;gap:2px}.aed-proctor-label{font-size:14px;font-weight:600;color:var(--text-1)}.aed-proctor-desc{font-size:12px;color:var(--text-3)}.aed-toggle-wrap{position:relative;display:flex;align-items:center;flex-shrink:0}.aed-toggle-input{position:absolute;opacity:0;width:0;height:0}.aed-toggle-track{display:flex;align-items:center;width:42px;height:24px;border-radius:999px;background:#e2e8f0;padding:2px;cursor:pointer;transition:background .2s ease;border:1px solid var(--border)}.aed-toggle-input:checked+.aed-toggle-track{background:var(--blue);border-color:var(--blue)}.aed-toggle-thumb{width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 4px #00000026;transition:transform .2s ease;flex-shrink:0}.aed-toggle-input:checked+.aed-toggle-track .aed-toggle-thumb{transform:translate(18px)}.aed-proctor-row.disabled .aed-toggle-track{cursor:not-allowed;opacity:.6}@media(max-width:640px){.aed-header{flex-direction:column;gap:14px}.aed-tabs{overflow-x:auto;padding:0 12px}.aed-tabs::-webkit-scrollbar{display:none}.aed-tab-body{padding:18px}.aed-tab-section{max-width:100%}}.live-page{display:flex;flex-direction:column;gap:16px;height:100%}.live-page>*:first-child{flex-shrink:0}.content{display:flex;gap:16px;flex:1;overflow:hidden}.content>*:first-child{width:260px;background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:16px;overflow-y:auto}.content>*:last-child{flex:1;background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:16px;overflow-y:auto}.live-page>div{color:#334155;font-size:14px}.content>*::-webkit-scrollbar{width:6px}.content>*::-webkit-scrollbar-thumb{background-color:#cbd5f5;border-radius:4px}.modal-backdrop,.student-focus-backdrop{background:#0f172a66}.um-container{padding:0}.um-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px}.um-header h1{font-size:24px;font-weight:700;color:#1e293b;margin:0}.um-header-right{display:flex;gap:12px;align-items:center}.um-search{padding:10px 16px;border:1px solid #e2e8f0;border-radius:10px;font-size:14px;width:240px;outline:none;transition:border-color .2s;font-family:Inter,sans-serif}.um-search:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.um-filter{padding:10px 16px;border:1px solid #e2e8f0;border-radius:10px;font-size:14px;outline:none;background:#fff;cursor:pointer;font-family:Inter,sans-serif}.um-create-btn{padding:10px 20px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s;font-family:Inter,sans-serif}.um-create-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.um-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}.um-stat-card{background:#fff;border:1px solid #f1f5f9;border-radius:14px;padding:20px;display:flex;align-items:center;gap:16px}.um-stat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center}.um-stat-icon.total{background:#6366f11a;color:#6366f1}.um-stat-icon.admin{background:#f59e0b1a;color:#f59e0b}.um-stat-icon.candidate{background:#10b9811a;color:#10b981}.um-stat-icon.proctor{background:#3b82f61a;color:#3b82f6}.um-stat-info h3{font-size:22px;font-weight:700;color:#1e293b;margin:0}.um-stat-info p{font-size:13px;color:#94a3b8;margin:4px 0 0}.um-table-wrap{background:#fff;border:1px solid #f1f5f9;border-radius:14px;overflow:hidden}.um-table{width:100%;border-collapse:collapse}.um-table th{padding:14px 20px;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #f1f5f9;text-align:left;background:#fafbfc}.um-table td{padding:14px 20px;font-size:14px;color:#334155;border-bottom:1px solid #f8fafc}.um-table tr:hover{background:#fafbfe}.um-table tr:last-child td{border-bottom:none}.um-role-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.um-role-badge.Admin{background:#f59e0b1a;color:#b45309}.um-role-badge.Candidate{background:#10b9811a;color:#047857}.um-role-badge.Proctor{background:#3b82f61a;color:#1d4ed8}.um-status-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.um-status-badge.Active{background:#10b9811a;color:#047857}.um-status-badge.Inactive{background:#ef44441a;color:#dc2626}.um-action-btn{padding:6px 14px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;font-size:12px;cursor:pointer;color:#475569;transition:all .2s;font-family:Inter,sans-serif;margin-right:6px}.um-action-btn:hover{background:#f8fafc;border-color:#cbd5e1}.um-action-btn.delete{color:#ef4444;border-color:#ef44444d}.um-action-btn.delete:hover{background:#ef44440d}.um-empty{text-align:center;padding:60px 20px;color:#94a3b8}.um-empty p{font-size:15px;margin:0}.um-modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.um-modal{background:#fff;border-radius:20px;width:500px;max-width:90vw;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px #00000026;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.um-modal-header{padding:24px 28px 0;display:flex;justify-content:space-between;align-items:center}.um-modal-header h2{font-size:18px;font-weight:700;color:#1e293b;margin:0}.um-modal-close{width:32px;height:32px;border:none;background:#f1f5f9;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#64748b;transition:all .2s}.um-modal-close:hover{background:#e2e8f0;color:#1e293b}.um-modal-body{padding:24px 28px}.um-modal-body .form-group{margin-bottom:18px}.um-modal-body label{display:block;font-size:13px;font-weight:500;color:#475569;margin-bottom:6px}.um-modal-body input,.um-modal-body select{width:100%;padding:10px 14px;border:1px solid #e2e8f0;border-radius:10px;font-size:14px;outline:none;transition:border-color .2s;font-family:Inter,sans-serif;box-sizing:border-box}.um-modal-body input:focus,.um-modal-body select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.um-modal-body .form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.um-modal-footer{padding:0 28px 24px;display:flex;justify-content:flex-end;gap:10px}.um-modal-cancel{padding:10px 20px;border:1px solid #e2e8f0;border-radius:10px;background:#fff;color:#475569;font-size:14px;font-weight:500;cursor:pointer;font-family:Inter,sans-serif}.um-modal-save{padding:10px 24px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;font-family:Inter,sans-serif}.um-modal-save:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.um-modal-save:disabled{opacity:.6;cursor:not-allowed;transform:none}.ps-container{padding:0}.ps-header{margin-bottom:28px}.ps-header h1{font-size:24px;font-weight:700;color:#1e293b;margin:0 0 6px}.ps-header p{font-size:14px;color:#94a3b8;margin:0}.ps-exam-select{margin-bottom:28px}.ps-exam-select label{display:block;font-size:13px;font-weight:500;color:#475569;margin-bottom:8px}.ps-exam-select select{width:100%;max-width:400px;padding:10px 14px;border:1px solid #e2e8f0;border-radius:10px;font-size:14px;outline:none;font-family:Inter,sans-serif}.ps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;margin-bottom:28px}.ps-card{background:#fff;border:1px solid #f1f5f9;border-radius:14px;padding:24px;display:flex;align-items:center;justify-content:space-between;transition:border-color .2s}.ps-card:hover{border-color:#e2e8f0}.ps-card-left{display:flex;align-items:center;gap:16px}.ps-card-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#6366f11a;color:#6366f1}.ps-card-info h3{font-size:15px;font-weight:600;color:#1e293b;margin:0 0 4px}.ps-card-info p{font-size:12px;color:#94a3b8;margin:0}.ps-toggle{position:relative;width:48px;height:26px}.ps-toggle input{opacity:0;width:0;height:0}.ps-toggle-slider{position:absolute;cursor:pointer;inset:0;background:#e2e8f0;border-radius:26px;transition:all .3s}.ps-toggle-slider:before{content:"";position:absolute;width:20px;height:20px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:all .3s;box-shadow:0 1px 3px #00000026}.ps-toggle input:checked+.ps-toggle-slider{background:#6366f1}.ps-toggle input:checked+.ps-toggle-slider:before{transform:translate(22px)}.ps-save-btn{padding:12px 28px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;font-family:Inter,sans-serif}.ps-save-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.ps-success{background:#10b9811a;border:1px solid rgba(16,185,129,.3);border-radius:10px;padding:12px 16px;color:#047857;font-size:13px;margin-bottom:20px;animation:fadeIn .3s ease}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.kpi-card{background:#fff;padding:18px;border-radius:12px;font-weight:600}.kpi-card span{font-size:28px}.danger{border-left:6px solid #ef4444}.warning{border-left:6px solid #f59e0b}.success{border-left:6px solid #10b981}.table-card{background:#fff;padding:24px;border-radius:14px;margin-top:20px;box-shadow:0 1px 4px #0000000a}.table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.table-card h3{margin:0;font-size:16px}.csv-download-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.csv-download-btn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.table-scroll{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:12px 14px;text-align:left;border-bottom:1px solid #f1f5f9;font-size:13px}th{background:#f8fafc;font-weight:600;color:#475569;text-transform:uppercase;font-size:11px;letter-spacing:.5px}tr:hover{background:#f8fafc}.td-mono{font-family:JetBrains Mono,monospace;font-size:12px;color:#64748b}.td-time{color:#64748b;font-size:12px;white-space:nowrap}.type-badge{display:inline-block;padding:3px 8px;border-radius:6px;background:#f1f5f9;color:#334155;font-size:11px;font-weight:600;text-transform:capitalize}.sev-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}.sev-badge.high{background:#fef2f2;color:#b91c1c}.sev-badge.medium{background:#fffbeb;color:#92400e}.sev-badge.low{background:#f0fdf4;color:#166534}.evidence-link{display:inline-flex;align-items:center;gap:4px;color:#3b82f6;font-size:12px;font-weight:600;text-decoration:none;padding:3px 10px;border-radius:6px;background:#eff6ff;transition:all .15s}.evidence-link:hover{background:#dbeafe;color:#1d4ed8}.table-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:40px 20px;color:#94a3b8;text-align:center}.table-empty span{font-weight:600;font-size:15px;color:#64748b}.table-empty p{font-size:13px;margin:0}.sev.high{color:#b91c1c;font-weight:700}.sev.medium{color:#92400e;font-weight:700}.sev.low{color:#166534;font-weight:700}.incidents-dashboard{padding:24px}.incidents-header{margin-bottom:24px}.incidents-header-top{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;flex-wrap:wrap}.incidents-header h1{font-size:22px;font-weight:700;margin:0 0 4px;color:#0f172a}.incidents-header p{font-size:14px;color:#64748b;margin:0}.incidents-filter{display:flex;flex-direction:column;gap:6px}.incidents-filter label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.incidents-filter select{padding:8px 14px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:13px;font-weight:500;color:#1e293b;background:#fff;cursor:pointer;min-width:220px;transition:all .15s;outline:none}.incidents-filter select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.incidents-charts{display:grid;grid-template-columns:2fr 1fr;gap:20px;margin:20px 0}.chart-card{background:#fff;padding:22px;border-radius:14px;box-shadow:0 1px 4px #0000000a}.chart-card h3{margin:0 0 16px;font-size:15px;color:#1e293b}@media(max-width:900px){.incidents-charts{grid-template-columns:1fr}.incidents-header-top{flex-direction:column}}.gd-page{padding:32px;color:#1e293b;min-height:100vh;font-family:var(--font-body)}.gd-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.gd-title{font-family:var(--font-display);font-size:28px;font-weight:700;color:#0f172a;margin:0 0 6px}.gd-subtitle{font-size:14px;color:#64748b;margin:0}.gd-exam-selector{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:24px;margin-bottom:28px;box-shadow:0 4px 6px -1px #0000001a}.gd-exam-selector h3{font-size:16px;font-weight:600;margin:0 0 16px;color:#334155}.gd-exam-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.gd-exam-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:16px;cursor:pointer;transition:all .2s ease}.gd-exam-card:hover{background:#f1f5f9;border-color:var(--accent);transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a}.gd-exam-card.selected{background:#eff6ff;border-color:var(--accent);box-shadow:0 0 0 2px #3b82f61a}.gd-exam-card-title{font-size:15px;font-weight:600;color:#1e293b;margin-bottom:6px}.gd-exam-card-meta{display:flex;gap:12px;font-size:12px;color:#64748b}.gd-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:28px}.gd-stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:20px;text-align:center;transition:all .2s ease;box-shadow:0 1px 3px #0000001a}.gd-stat-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a}.gd-stat-value{font-size:32px;font-weight:700;display:block;margin-bottom:4px}.gd-stat-value.total{color:#3b82f6}.gd-stat-value.auto{color:#10b981}.gd-stat-value.manual{color:#8b5cf6}.gd-stat-value.pending{color:#f59e0b}.gd-stat-label{font-size:13px;color:#64748b;font-weight:500}.gd-action-bar{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}.gd-btn{padding:10px 20px;border-radius:8px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:8px}.gd-btn-primary{background:var(--accent);color:#fff}.gd-btn-primary:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 6px -1px #3b82f666}.gd-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.gd-btn-success{background:#10b981;color:#fff}.gd-btn-secondary{background:#fff;border:1px solid #d1d5db;color:#374151}.gd-btn-secondary:hover{background:#f9fafb;border-color:#9ca3af}.gd-answer-list{display:flex;flex-direction:column;gap:16px}.gd-answer-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:24px;transition:all .2s ease;box-shadow:0 1px 3px #0000000d;animation:fadeInUp .3s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.gd-answer-card:hover{border-color:var(--accent-border);box-shadow:0 4px 6px -1px #0000001a}.gd-answer-card.graded{border-color:#10b981;background:#f0fdf4}.gd-answer-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:8px}.gd-answer-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.gd-candidate-badge{background:#eff6ff;color:#1d4ed8;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.gd-type-badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;background:#f5f3ff;color:#6d28d9}.gd-marks-badge{font-size:14px;font-weight:700;color:#b45309}.gd-question-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:16px;margin-bottom:14px}.gd-question-label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#64748b;margin-bottom:6px;font-weight:700}.gd-question-text{font-size:15px;color:#1e293b;line-height:1.6}.gd-answer-section{background:#f0f9ff;border:1px solid #bae6fd;border-radius:10px;padding:16px;margin-bottom:14px}.gd-answer-label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#0369a1;margin-bottom:6px;font-weight:700}.gd-answer-text{font-size:14px;color:#0f172a;line-height:1.6;white-space:pre-wrap}.gd-code-block{background:#1e293b;border:1px solid #334155;border-radius:8px;padding:16px;font-family:JetBrains Mono,Fira Code,monospace;font-size:13px;color:#f1f5f9;overflow-x:auto;white-space:pre-wrap}.gd-code-lang{display:inline-block;background:#3b82f6;color:#fff;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;margin-bottom:8px}.gd-file-link{display:inline-flex;align-items:center;gap:6px;color:#2563eb;text-decoration:none;font-size:14px;font-weight:500}.gd-file-link:hover{color:#1d4ed8;text-decoration:underline}.gd-grade-form{display:flex;align-items:end;gap:16px;padding-top:16px;border-top:1px solid #e5e7eb;flex-wrap:wrap}.gd-grade-group{display:flex;flex-direction:column;gap:6px}.gd-grade-group label{font-size:12px;color:#475569;font-weight:600}.gd-grade-group input,.gd-grade-group textarea{background:#fff;border:1px solid #d1d5db;border-radius:8px;padding:10px 12px;color:#1e293b;font-size:14px;font-family:inherit;transition:border-color .2s}.gd-grade-group input:focus,.gd-grade-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #3b82f61a}.gd-grade-group input[type=number]{width:90px}.gd-grade-group textarea{width:320px;min-height:42px;resize:vertical}.gd-grade-btn{padding:11px 20px;border-radius:8px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;background:#10b981;color:#fff}.gd-grade-btn:hover{background:#059669;transform:translateY(-1px);box-shadow:0 4px 6px -1px #10b98166}.gd-grade-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.gd-graded-info{display:flex;align-items:center;gap:12px;padding-top:16px;border-top:1px solid #d1fae5;font-size:14px;color:#059669;font-weight:600}.gd-loading{text-align:center;padding:60px 20px;color:#64748b;font-size:16px}.gd-loading .gd-spinner{display:inline-block;width:36px;height:36px;border:4px solid #e2e8f0;border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.gd-empty{text-align:center;padding:60px 20px;color:#94a3b8}.gd-empty-icon{font-size:48px;display:block;margin-bottom:12px}.gd-empty p{font-size:16px;margin:4px 0}.gd-tabs{display:flex;gap:8px;margin-bottom:24px;background:#f1f5f9;padding:6px;border-radius:12px;border:1px solid #e2e8f0}.gd-tab{padding:8px 16px;border-radius:8px;border:none;background:transparent;color:#64748b;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.gd-tab:hover{color:#1e293b;background:#e2e8f0}.gd-tab.active{background:#fff;color:var(--accent);box-shadow:0 1px 3px #0000001a}.gd-tab .gd-tab-count{background:#e2e8f0;color:#475569;padding:2px 8px;border-radius:10px;font-size:11px;margin-left:8px}.gd-tab.active .gd-tab-count{background:#eff6ff;color:var(--accent)}@media(max-width:768px){.gd-page{padding:16px}.gd-header{flex-direction:column;align-items:flex-start;gap:12px}.gd-stats{grid-template-columns:repeat(2,1fr)}.gd-grade-form{flex-direction:column;align-items:stretch}.gd-grade-group textarea{width:100%}.gd-tabs{overflow-x:auto;padding-bottom:10px}}.erl-root{min-height:100vh;background:#f0f4f8;padding:32px 32px 60px;font-family:var(--font-body);color:#1e293b}.erl-back{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:#64748b;font-size:.82rem;font-weight:600;cursor:pointer;padding:6px 0;margin-bottom:12px;transition:all .2s ease}.erl-back:hover{color:var(--accent);transform:translate(-2px)}.erl-back svg{width:15px;height:15px}.erl-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:32px}.erl-header-left{display:flex;flex-direction:column;gap:4px}.erl-eyebrow{display:flex;align-items:center;gap:6px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent)}.erl-heading{font-family:var(--font-display);font-size:28px;font-weight:800;color:#0f172a;margin:0;letter-spacing:-.02em}.erl-subheading{font-size:14px;color:#64748b;margin:0}.erl-header-actions{display:flex;gap:12px;align-items:center}.erl-btn-primary{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:10px;border:none;font-size:14px;font-weight:600;cursor:pointer;background:var(--accent);color:#fff;transition:all .2s ease}.erl-btn-primary:hover:not(:disabled){background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.erl-btn-primary:disabled{opacity:.6;cursor:not-allowed}.erl-btn-outline{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:10px;border:1px solid #d1d5db;font-size:14px;font-weight:600;cursor:pointer;background:#fff;color:#374151;transition:all .2s ease}.erl-btn-outline:hover{background:#f9fafb;border-color:#9ca3af}.erl-summary-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:20px;margin-bottom:32px}.erl-summary-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:24px;display:flex;flex-direction:column;gap:12px;box-shadow:0 1px 3px #0000000d;transition:all .2s ease}.erl-summary-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a}.erl-sc-purple{border-top:4px solid #8b5cf6}.erl-sc-green{border-top:4px solid #10b981}.erl-sc-blue{border-top:4px solid #3b82f6}.erl-sc-amber{border-top:4px solid #f59e0b}.erl-summary-top{display:flex;align-items:center;justify-content:space-between}.erl-summary-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#64748b}.erl-summary-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center}.erl-sc-purple .erl-summary-icon{background:#f5f3ff;color:#8b5cf6}.erl-sc-green .erl-summary-icon{background:#f0fdf4;color:#10b981}.erl-sc-blue .erl-summary-icon{background:#eff6ff;color:#3b82f6}.erl-sc-amber .erl-summary-icon{background:#fffbeb;color:#f59e0b}.erl-summary-icon svg{width:20px;height:20px}.erl-summary-value{font-size:24px;font-weight:800;color:#0f172a}.erl-table-container{background:#fff;border:1px solid #e2e8f0;border-radius:16px;overflow:hidden;box-shadow:0 1px 3px #0000000d}.erl-table-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e2e8f0}.erl-table-title{font-size:16px;font-weight:700;color:#1e293b}.erl-table-badge{font-size:11px;font-weight:700;background:#eff6ff;color:#3b82f6;padding:4px 12px;border-radius:20px}.erl-table{width:100%;border-collapse:collapse}.erl-table thead th{padding:14px 20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#64748b;text-align:left;background:#f8fafc;border-bottom:1px solid #e2e8f0;white-space:nowrap}.erl-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background .15s}.erl-table tbody tr:hover{background:#f8fafc}.erl-table tbody td{padding:16px 20px;font-size:14px;color:#334155;vertical-align:middle}.erl-rank{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;font-size:12px;font-weight:700}.erl-rank-1{background:#fef3c7;color:#b45309;border:1px solid #fde68a}.erl-rank-2{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.erl-rank-3{background:#ffedd5;color:#9a3412;border:1px solid #fed7aa}.erl-rank-default{background:#f8fafc;color:#64748b}.erl-candidate-id{font-weight:700;color:#0f172a;font-family:inherit}.erl-score-cell{display:flex;align-items:center;gap:12px}.erl-score-num{font-weight:700;color:#1e293b;min-width:45px}.erl-score-bar-bg{flex:1;height:6px;border-radius:3px;background:#e2e8f0;max-width:100px;overflow:hidden}.erl-score-bar-fill{height:100%}.erl-bar-green{background:#10b981}.erl-bar-amber{background:#f59e0b}.erl-bar-red{background:#ef4444}.erl-status-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:700}.erl-status-pass{background:#dcfce7;color:#15803d}.erl-status-fail{background:#fee2e2;color:#b91c1c}.erl-status-dot{width:6px;height:6px;border-radius:50%}.erl-status-pass .erl-status-dot{background:#22c55e}.erl-status-fail .erl-status-dot{background:#ef4444}.erl-pct{font-weight:700}.erl-pct-high{color:#16a34a}.erl-pct-mid{color:#d97706}.erl-pct-low{color:#dc2626}.erl-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:80px 20px;color:#64748b}.erl-empty-title{font-size:18px;font-weight:700;color:#334155}.erl-empty-desc{font-size:14px;color:#64748b;max-width:380px;line-height:1.6}.erl-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:100px 20px;color:#64748b}.erl-spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:var(--accent);border-radius:50%;animation:erl-spin .8s linear infinite}@keyframes erl-spin{to{transform:rotate(360deg)}}.erl-actions-cell{text-align:right!important}.erl-btn-view{display:inline-flex;align-items:center;gap:8px;background:#eff6ff;border:1px solid #bfdbfe;color:#2563eb;padding:8px 14px;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;transition:all .2s ease}.erl-btn-view:hover{background:#dbeafe;border-color:#3b82f6;transform:translateY(-1px)}@media(max-width:900px){.erl-root{padding:24px 16px 40px}.erl-header{flex-direction:column;align-items:stretch}.erl-summary-bar{grid-template-columns:repeat(2,1fr)}.erl-table-container{overflow-x:auto}}.csp-root{min-height:100vh;background-color:#f8fafc;padding-bottom:2rem;font-family:Inter,system-ui,-apple-system,sans-serif}.csp-header{display:flex;justify-content:space-between;align-items:center;background-color:#fff;padding:1.5rem 2rem;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000d;position:sticky;top:0;z-index:50}.csp-header-left{display:flex;gap:1rem;align-items:flex-start}.csp-back-btn{appearance:none;background:#f1f5f9;border:none;width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#475569;transition:all .2s cubic-bezier(.4,0,.2,1)}.csp-back-btn:hover{background:#e2e8f0;color:#1e293b;transform:translate(-2px)}.csp-eyebrow{font-size:.7rem;text-transform:uppercase;font-weight:700;color:#3b82f6;letter-spacing:.05em;margin-bottom:.25rem}.csp-title{font-size:1.5rem;font-weight:800;color:#1e293b;margin:0;line-height:1.2}.csp-subtitle{font-size:.82rem;color:#64748b;margin:.25rem 0 0}.csp-score-box{background:#eff6ff;border:1px solid #bfdbfe;padding:.75rem 1.25rem;border-radius:16px;display:flex;flex-direction:column;align-items:center;min-width:100px}.csp-score-label{font-size:.65rem;color:#3b82f6;text-transform:uppercase;font-weight:700;letter-spacing:.05em}.csp-score-value{font-size:1.75rem;font-weight:900;color:#1e3a8a}.csp-content{max-width:900px;margin:2rem auto;padding:0 1.5rem;display:flex;flex-direction:column;gap:1.5rem}.csp-answer-card{background:#fff;border-radius:20px;border:1px solid #e2e8f0;box-shadow:0 4px 6px -1px #0000001a;display:flex;overflow:hidden;transition:transform .2s ease}.csp-answer-card:hover{transform:translateY(-2px)}.csp-answer-num{background:#f8fafc;width:60px;display:flex;align-items:center;justify-content:center;font-weight:800;color:#94a3b8;font-size:1.1rem;border-right:1px solid #f1f5f9}.csp-q-body{flex:1;padding:1.5rem}.csp-q-text{font-size:1.1rem;font-weight:600;color:#1e293b;line-height:1.5;margin-bottom:1rem}.csp-q-meta{display:flex;gap:.5rem;margin-bottom:1.5rem}.csp-type-badge{font-size:.68rem;font-weight:700;background:#f1f5f9;color:#64748b;padding:.25rem .65rem;border-radius:100px}.csp-marks-badge{font-size:.68rem;font-weight:700;background:#f0f9ff;color:#0369a1;padding:.25rem .65rem;border-radius:100px}.csp-student-response{background:#fafafa;border:1px solid #f1f5f9;border-radius:12px;padding:1rem;margin-bottom:1rem}.csp-student-response label{display:block;font-size:.72rem;font-weight:700;color:#94a3b8;text-transform:uppercase;margin-bottom:.5rem}.csp-text-response{color:#334155;white-space:pre-wrap;line-height:1.6}.csp-no-ans{color:#94a3b8;font-style:italic}.csp-code-wrap{background:#0f172a;border-radius:8px;overflow:hidden}.csp-code-header{background:#1e293b;padding:.5rem 1rem;color:#94a3b8;font-size:.72rem;font-family:JetBrains Mono,Fira Code,monospace}.csp-code-wrap pre{padding:1rem;margin:0;color:#e2e8f0;font-family:JetBrains Mono,Fira Code,monospace;font-size:.85rem;overflow-x:auto}.csp-file-link{display:inline-flex;align-items:center;background:#3b82f6;color:#fff;padding:.6rem 1rem;border-radius:8px;text-decoration:none;font-weight:600;font-size:.82rem;transition:background .2s ease}.csp-file-link:hover{background:#2563eb}.csp-remarks{background:#fffbeb;border:1px solid #fde68a;padding:.75rem 1rem;border-radius:12px;margin-bottom:1rem}.csp-remarks label{display:block;font-size:.7rem;font-weight:700;color:#d97706;text-transform:uppercase;margin-bottom:.25rem}.csp-remarks p{margin:0;color:#92400e;font-size:.88rem;line-height:1.5}.csp-grad-info{font-size:.7rem;color:#94a3b8;font-style:italic;text-align:right}.csp-loading{height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:#64748b}.csp-spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:csp-spin .8s linear infinite}@keyframes csp-spin{to{transform:rotate(360deg)}}.csp-error{text-align:center;margin-top:100px}@font-face{font-display:block;font-family:KaTeX_AMS;font-style:normal;font-weight:400;src:url(/assets/KaTeX_AMS-Regular-BQhdFMY1.woff2) format("woff2"),url(/assets/KaTeX_AMS-Regular-DMm9YOAa.woff) format("woff"),url(/assets/KaTeX_AMS-Regular-DRggAlZN.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Caligraphic;font-style:normal;font-weight:700;src:url(/assets/KaTeX_Caligraphic-Bold-Dq_IR9rO.woff2) format("woff2"),url(/assets/KaTeX_Caligraphic-Bold-BEiXGLvX.woff) format("woff"),url(/assets/KaTeX_Caligraphic-Bold-ATXxdsX0.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Caligraphic;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Caligraphic-Regular-Di6jR-x-.woff2) format("woff2"),url(/assets/KaTeX_Caligraphic-Regular-CTRA-rTL.woff) format("woff"),url(/assets/KaTeX_Caligraphic-Regular-wX97UBjC.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Fraktur;font-style:normal;font-weight:700;src:url(/assets/KaTeX_Fraktur-Bold-CL6g_b3V.woff2) format("woff2"),url(/assets/KaTeX_Fraktur-Bold-BsDP51OF.woff) format("woff"),url(/assets/KaTeX_Fraktur-Bold-BdnERNNW.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Fraktur;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Fraktur-Regular-CTYiF6lA.woff2) format("woff2"),url(/assets/KaTeX_Fraktur-Regular-Dxdc4cR9.woff) format("woff"),url(/assets/KaTeX_Fraktur-Regular-CB_wures.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Main;font-style:normal;font-weight:700;src:url(/assets/KaTeX_Main-Bold-Cx986IdX.woff2) format("woff2"),url(/assets/KaTeX_Main-Bold-Jm3AIy58.woff) format("woff"),url(/assets/KaTeX_Main-Bold-waoOVXN0.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Main;font-style:italic;font-weight:700;src:url(/assets/KaTeX_Main-BoldItalic-DxDJ3AOS.woff2) format("woff2"),url(/assets/KaTeX_Main-BoldItalic-SpSLRI95.woff) format("woff"),url(/assets/KaTeX_Main-BoldItalic-DzxPMmG6.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Main;font-style:italic;font-weight:400;src:url(/assets/KaTeX_Main-Italic-NWA7e6Wa.woff2) format("woff2"),url(/assets/KaTeX_Main-Italic-BMLOBm91.woff) format("woff"),url(/assets/KaTeX_Main-Italic-3WenGoN9.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Main;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Main-Regular-B22Nviop.woff2) format("woff2"),url(/assets/KaTeX_Main-Regular-Dr94JaBh.woff) format("woff"),url(/assets/KaTeX_Main-Regular-ypZvNtVU.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Math;font-style:italic;font-weight:700;src:url(/assets/KaTeX_Math-BoldItalic-CZnvNsCZ.woff2) format("woff2"),url(/assets/KaTeX_Math-BoldItalic-iY-2wyZ7.woff) format("woff"),url(/assets/KaTeX_Math-BoldItalic-B3XSjfu4.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Math;font-style:italic;font-weight:400;src:url(/assets/KaTeX_Math-Italic-t53AETM-.woff2) format("woff2"),url(/assets/KaTeX_Math-Italic-DA0__PXp.woff) format("woff"),url(/assets/KaTeX_Math-Italic-flOr_0UB.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_SansSerif;font-style:normal;font-weight:700;src:url(/assets/KaTeX_SansSerif-Bold-D1sUS0GD.woff2) format("woff2"),url(/assets/KaTeX_SansSerif-Bold-DbIhKOiC.woff) format("woff"),url(/assets/KaTeX_SansSerif-Bold-CFMepnvq.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_SansSerif;font-style:italic;font-weight:400;src:url(/assets/KaTeX_SansSerif-Italic-C3H0VqGB.woff2) format("woff2"),url(/assets/KaTeX_SansSerif-Italic-DN2j7dab.woff) format("woff"),url(/assets/KaTeX_SansSerif-Italic-YYjJ1zSn.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_SansSerif;font-style:normal;font-weight:400;src:url(/assets/KaTeX_SansSerif-Regular-DDBCnlJ7.woff2) format("woff2"),url(/assets/KaTeX_SansSerif-Regular-CS6fqUqJ.woff) format("woff"),url(/assets/KaTeX_SansSerif-Regular-BNo7hRIc.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Script;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Script-Regular-D3wIWfF6.woff2) format("woff2"),url(/assets/KaTeX_Script-Regular-D5yQViql.woff) format("woff"),url(/assets/KaTeX_Script-Regular-C5JkGWo-.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Size1;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Size1-Regular-mCD8mA8B.woff2) format("woff2"),url(/assets/KaTeX_Size1-Regular-C195tn64.woff) format("woff"),url(/assets/KaTeX_Size1-Regular-Dbsnue_I.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Size2;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Size2-Regular-Dy4dx90m.woff2) format("woff2"),url(/assets/KaTeX_Size2-Regular-oD1tc_U0.woff) format("woff"),url(/assets/KaTeX_Size2-Regular-B7gKUWhC.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Size3;font-style:normal;font-weight:400;src:url(data:font/woff2;base64,d09GMgABAAAAAA4oAA4AAAAAHbQAAA3TAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAABmAAgRQIDgmcDBEICo1oijYBNgIkA14LMgAEIAWJAAeBHAyBHBvbGiMRdnO0IkRRkiYDgr9KsJ1NUAf2kILNxgUmgqIgq1P89vcbIcmsQbRps3vCcXdYOKSWEPEKgZgQkprQQsxIXUgq0DqpGKmIvrgkeVGtEQD9DzAO29fM9jYhxZEsL2FeURH2JN4MIcTdO049NCVdxQ/w9NrSYFEBKTDKpLKfNkCGDc1RwjZLQcm3vqJ2UW9Xfa3tgAHz6ivp6vgC2yD4/6352ndnN0X0TL7seypkjZlMsjmZnf0Mm5Q+JykRWQBKCVCVPbARPXWyQtb5VgLB6Biq7/Uixcj2WGqdI8tGSgkuRG+t910GKP2D7AQH0DB9FMDW/obJZ8giFI3Wg8Cvevz0M+5m0rTh7XDBlvo9Y4vm13EXmfttwI4mBo1EG15fxJhUiCLbiiyCf/ZA6MFAhg3pGIZGdGIVjtPn6UcMk9A/UUr9PhoNsCENw1APAq0gpH73e+M+0ueyHbabc3vkbcdtzcf/fiy+NxQEjf9ud/ELBHAXJ0nk4z+MXH2Ev/kWyV4k7SkvpPc9Qr38F6RPWnM9cN6DJ0AdD1BhtgABtmoRoFCvPsBAumNm6soZG2Gk5GyVTo2sJncSyp0jQTYoR6WDvTwaaEcHsxHfvuWhHA3a6bN7twRKtcGok6NsCi7jYRrM2jExsUFMxMQYuJbMhuWNOumEJy9hi29Dmg5zMp/A5+hhPG19j1vBrq8JTLr8ki5VLPmG/PynJHVul440bxg5xuymHUFPBshC+nA9I1FmwbRBTNHAcik3Oae0cxKoI3MOriM42UrPe51nsaGxJ+WfXubAsP84aabUlQSJ1IiE0iPETLUU4CATgfXSCSpuRFRmCGbO+wSpAnzaeaCYW1VNEysRtuXCEL1kUFUbbtMv3Tilt/1c11jt3Q5bbMa84cpWipp8Elw3MZhOHsOlwwVUQM3lAR35JiFQbaYCRnMF2lxAWoOg2gyoIV4PouX8HytNIfLhqpJtXB4vjiViUI8IJ7bkC4ikkQvKksnOTKICwnqWSZ9YS5f0WCxmpgjbIq7EJcM4aI2nmhLNY2JIUgOjXZFWBHb+x5oh6cwb0Tv1ackHdKi0I9OO2wE9aogIOn540CCCziyhN+IaejtgAONKznHlHyutPrHGwCx9S6B8kfS4Mfi4Eyv7OU730bT1SCBjt834cXsf43zVjPUqqJjgrjeGnBxSG4aYAKFuVbeCfkDIjAqMb6yLNIbCuvXhMH2/+k2vkNpkORhR59N1CkzoOENvneIosjYmuTxlhUzaGEJQ/iWqx4dmwpmKjrwTiTGTCVozNAYqk/zXOndWxuWSmJkQpJw3pK5KX6QrLt5LATMqpmPAQhkhK6PUjzHUn7E0gHE0kPE0iKkolgkUx9SZmVAdDgpffdyJKg3k7VmzYGCwVXGz/tXmkOIp+vcWs+EMuhhvN0h9uhfzWJziBQmCREGSIFmQIkgVpAnSBRmC//6hkLZwaVhwxlrJSOdqlFtOYxlau9F2QN5Y98xmIAsiM1HVp2VFX+DHHGg6Ecjh3vmqtidX3qHI2qycTk/iwxSt5UzTmEP92ZBnEWTk4Mx8Mpl78ZDokxg/KWb+Q0QkvdKVmq3TMW+RXEgrsziSAfNXFMhDc60N5N9jQzjfO0kBKpUZl0ZmwJ41j/B9Hz6wmRaJB84niNmQrzp9eSlQCDDzazGDdVi3P36VZQ+Jy4f9UBNp+3zTjqI4abaFAm+GShVaXlsGdF3FYzZcDI6cori4kMxUECl9IjJZpzkvitAoxKue+90pDMvcKRxLl53TmOKCmV/xRolNKSqqUxc6LStOETmFOiLZZptlZepcKiAzteG8PEdpnQpbOMNcMsR4RR2Bs0cKFEvSmIjAFcnarqwUL4lDhHmnVkwu1IwshbiCcgvOheZuYyOteufZZwlcTlLgnZ3o/WcYdzZHW/WGaqaVfmTZ1aWCceJjkbZqsfbkOtcFlUZM/jy+hXHDbaUobWqqXaeWobbLO99yG5N3U4wxco0rQGGcOLASFMXeJoham8M+/x6O2WywK2l4HGbq1CoUyC/IZikQhdq3SiuNrvAEj0AVu9x2x3lp/xWzahaxidezFVtdcb5uEnzyl0ZmYiuKI0exvCd4Xc9CV1KB0db00z92wDPde0kukbvZIWN6jUWFTmPIC/Y4UPCm8UfDTFZpZNon1qLFTkBhxzB+FjQRA2Q/YRJT8pQigslMaUpFyAG8TMlXigiqmAZX4xgijKjRlGpLE0GdplRfCaJo0JQaSxNBk6ZmMzcya0FmrcisDdn0Q3HI2sWSppYigmlM1XT/kLQZSNpMJG0WkjYbSZuDpM1F0uYhFc1HxU4m1QJjDK6iL0S5uSj5rgXc3RejEigtcRBtqYPQsiTskmO5vosV+q4VGIKbOkDg0jtRrq+Em1YloaTFar3EGr1EUC8R0kus1Uus00usL97ABr2BjXoDm/QGNhuWtMVBKOwg/i78lT7hBsAvDmwHc/ao3vmUbBmhjeYySZNWvGkfZAgISDSaDo1SVpzGDsAEkF8B+gEapViUoZgUWXcRIGFZNm6gWbAKk0bp0k1MHG9fLYtV4iS2SmLEQFARzRcnf9PUS0LVn05/J9MiRRBU3v2IrvW974v4N00L7ZMk0wXP1409CHo/an8zTRHD3eSJ6m8D4YMkZNl3M79sqeuAsr/m3f+8/yl7A50aiAEJgeBeMWzu7ui9UfUBCe2TIqZIoOd/3/udRBOQidQZUERzb2/VwZN1H/Sju82ew2H2Wfr6qvfVf3hqwDvAIpkQVFy4B9Pe9e4/XvPeceu7h3dvO56iJPf0+A6cqA2ip18ER+iFgggiuOkvj24bby0N9j2UHIkgqIt+sVgfodC4YghLSMjSZbH0VR/6dMDrYJeKHilKTemt6v6kvzvn3/RrdWtr0GoN/xL+Sex/cPYLUpepx9cz/D46UPU5KXgAQa+NDps1v6J3xP1i2HtaDB0M9aX2deA7SYff//+gUCovMmIK/qfsFcOk+4Y5ZN97XlG6zebqtMbKgeRFi51vnxTQYBUik2rS/Cn6PC8ADR8FGxsRPB82dzfND90gIcshOcYUkfjherBz53odpm6TP8txlwOZ71xmfHHOvq053qFF/MRlS3jP0ELudrf2OeN8DHvp6ZceLe8qKYvWz/7yp0u4dKPfli3CYq0O13Ih71mylJ80tOi10On8wi+F4+LWgDPeJ30msSQt9/vkmHq9/Lvo2b461mP801v3W4xTcs6CbvF9UDdrSt+A8OUbpSh55qAUFXWznBBfdeJ8a4d7ugT5tvxUza3h9m4H7ptTqiG4z0g5dc0X29OcGlhpGFMpQo9ytTS+NViZpNdvU4kWx+LKxNY10kQ1yqGXrhe4/1nvP7E+nd5A92TtaRplbHSqoIdOqtRWti+fkB5/n1+/VvCmz12pG1kpQWsfi1ftlBobm0bpngs16CHkbIwdLnParxtTV3QYRlfJ0KFskH7pdN/YDn+yRuSd7sNH3aO0DYPggk6uWuXrfOc+fa3VTxFVvKaNxHsiHmsXyCLIE5yuOeN3/Jdf8HBL/5M6shjyhxHx9BjB1O0+4NLOnjLLSxwO7ukN4jMbOIcD879KLSi6Pk61Oqm2377n8079PXEEQ7cy7OKEC9nbpet118fxweTafpt69x/Bt8UqGzNQt7aelpc44dn5cqhwf71+qKp/Zf/+a0zcizOUWpl/iBcSXip0pplkatCchoH5c5aUM8I7/dWxAej8WicPL1URFZ9BDJelUwEwTkGqUhgSlydVes95YdXvhh9Gfz/aeFWvgVb4tuLbcv4+wLdutVZv/cUonwBD/6eDlE0aSiKK/uoH3+J1wDE/jMVqY2ysGufN84oIXB0sPzy8ollX/LegY74DgJXJR57sn+VGza0x3DnuIgABFM15LmajjjsNlYj+JEZGbuRYcAMOWxFkPN2w6Wd46xo4gVWQR/X4lyI/R6K/YK0110GzudPRW7Y+UOBGTfNNzHeYT0fiH0taunBpq9HEW8OKSaBGj21L0MqenEmNRWBAWDWAk4CpNoEZJ2tTaPFgbQYj8HxtFilErs3BTRwT8uO1NXQaWfIotchmPkAF5mMBAliEmZiOGVgCG9LgRzpscMAOOwowlT3JhusdazXGSC/hxR3UlmWVwWHpOIKheqONvjyhSiTHIkVUco5bnji8m//zL7PKaT1Vl5I6UE609f+gkr6MZKVyKc7zJRmCahLsdlyA5fdQkRSan9LgnnLEyGSkaKJCJog0wAgvepWBt80+1yKln1bMVtCljfNWDueKLsWwaEbBSfSPTEmVRsUcYYMnEjcjeyCZzBXK9E9BYBXLKjOSpUDR+nEV3TFSUdQaz+ot98QxgXwx0GQ+EEUAKB2qZPkQQ0GqFD8UPFMqyaCHM24BZmSGic9EYMagKizOw9Hz50DMrDLrqqLkTAhplMictiCAx5S3BIUQdeJeLnBy2CNtMfz6cV4u8XKoFZQesbf9YZiIERiHjaNodDW6LgcirX/mPnJIkBGDUpTBhSa0EIr38D5hCIszhCM8URGBqImoWjpvpt1ebu/v3Gl3qJfMnNM+9V+kiRFyROTPHQWOcs1dNW94/ukKMPZBvDi55i5CttdeJz84DLngLqjcdwEZ87bFFR8CIG35OAkDVN6VRDZ7aq67NteYqZ2lpT8oYB2CytoBd6VuAx4WgiAsnuj3WohG+LugzXiQRDeM3XYXlULv4dp5VFYC) format("woff2"),url(/assets/KaTeX_Size3-Regular-CTq5MqoE.woff) format("woff"),url(/assets/KaTeX_Size3-Regular-DgpXs0kz.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Size4;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Size4-Regular-Dl5lxZxV.woff2) format("woff2"),url(/assets/KaTeX_Size4-Regular-BF-4gkZK.woff) format("woff"),url(/assets/KaTeX_Size4-Regular-DWFBv043.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Typewriter;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Typewriter-Regular-CO6r4hn1.woff2) format("woff2"),url(/assets/KaTeX_Typewriter-Regular-C0xS9mPB.woff) format("woff"),url(/assets/KaTeX_Typewriter-Regular-D3Ib7_Hf.ttf) format("truetype")}.katex{font: 1.21em KaTeX_Main,Times New Roman,serif;line-height:1.2;position:relative;text-indent:0;text-rendering:auto}.katex *{-ms-high-contrast-adjust:none!important;border-color:currentColor}.katex .katex-version:after{content:"0.16.44"}.katex .katex-mathml{clip:rect(1px,1px,1px,1px);border:0;height:1px;overflow:hidden;padding:0;position:absolute;width:1px}.katex .katex-html>.newline{display:block}.katex .base{position:relative;white-space:nowrap;width:-webkit-min-content;width:-moz-min-content;width:min-content}.katex .base,.katex .strut{display:inline-block}.katex .textbf{font-weight:700}.katex .textit{font-style:italic}.katex .textrm{font-family:KaTeX_Main}.katex .textsf{font-family:KaTeX_SansSerif}.katex .texttt{font-family:KaTeX_Typewriter}.katex .mathnormal{font-family:KaTeX_Math;font-style:italic}.katex .mathit{font-family:KaTeX_Main;font-style:italic}.katex .mathrm{font-style:normal}.katex .mathbf{font-family:KaTeX_Main;font-weight:700}.katex .boldsymbol{font-family:KaTeX_Math;font-style:italic;font-weight:700}.katex .amsrm,.katex .mathbb,.katex .textbb{font-family:KaTeX_AMS}.katex .mathcal{font-family:KaTeX_Caligraphic}.katex .mathfrak,.katex .textfrak{font-family:KaTeX_Fraktur}.katex .mathboldfrak,.katex .textboldfrak{font-family:KaTeX_Fraktur;font-weight:700}.katex .mathtt{font-family:KaTeX_Typewriter}.katex .mathscr,.katex .textscr{font-family:KaTeX_Script}.katex .mathsf,.katex .textsf{font-family:KaTeX_SansSerif}.katex .mathboldsf,.katex .textboldsf{font-family:KaTeX_SansSerif;font-weight:700}.katex .mathitsf,.katex .mathsfit,.katex .textitsf{font-family:KaTeX_SansSerif;font-style:italic}.katex .mainrm{font-family:KaTeX_Main;font-style:normal}.katex .vlist-t{border-collapse:collapse;display:inline-table;table-layout:fixed}.katex .vlist-r{display:table-row}.katex .vlist{display:table-cell;position:relative;vertical-align:bottom}.katex .vlist>span{display:block;height:0;position:relative}.katex .vlist>span>span{display:inline-block}.katex .vlist>span>.pstrut{overflow:hidden;width:0}.katex .vlist-t2{margin-right:-2px}.katex .vlist-s{display:table-cell;font-size:1px;min-width:2px;vertical-align:bottom;width:2px}.katex .vbox{align-items:baseline;display:inline-flex;flex-direction:column}.katex .hbox{width:100%}.katex .hbox,.katex .thinbox{display:inline-flex;flex-direction:row}.katex .thinbox{max-width:0;width:0}.katex .msupsub{text-align:left}.katex .mfrac>span>span{text-align:center}.katex .mfrac .frac-line{border-bottom-style:solid;display:inline-block;width:100%}.katex .hdashline,.katex .hline,.katex .mfrac .frac-line,.katex .overline .overline-line,.katex .rule,.katex .underline .underline-line{min-height:1px}.katex .mspace{display:inline-block}.katex .smash{display:inline;line-height:0}.katex .clap,.katex .llap,.katex .rlap{position:relative;width:0}.katex .clap>.inner,.katex .llap>.inner,.katex .rlap>.inner{position:absolute}.katex .clap>.fix,.katex .llap>.fix,.katex .rlap>.fix{display:inline-block}.katex .llap>.inner{right:0}.katex .clap>.inner,.katex .rlap>.inner{left:0}.katex .clap>.inner>span{margin-left:-50%;margin-right:50%}.katex .rule{border:0 solid;display:inline-block;position:relative}.katex .hline,.katex .overline .overline-line,.katex .underline .underline-line{border-bottom-style:solid;display:inline-block;width:100%}.katex .hdashline{border-bottom-style:dashed;display:inline-block;width:100%}.katex .sqrt>.root{margin-left:.2777777778em;margin-right:-.5555555556em}.katex .fontsize-ensurer.reset-size1.size1,.katex .sizing.reset-size1.size1{font-size:1em}.katex .fontsize-ensurer.reset-size1.size2,.katex .sizing.reset-size1.size2{font-size:1.2em}.katex .fontsize-ensurer.reset-size1.size3,.katex .sizing.reset-size1.size3{font-size:1.4em}.katex .fontsize-ensurer.reset-size1.size4,.katex .sizing.reset-size1.size4{font-size:1.6em}.katex .fontsize-ensurer.reset-size1.size5,.katex .sizing.reset-size1.size5{font-size:1.8em}.katex .fontsize-ensurer.reset-size1.size6,.katex .sizing.reset-size1.size6{font-size:2em}.katex .fontsize-ensurer.reset-size1.size7,.katex .sizing.reset-size1.size7{font-size:2.4em}.katex .fontsize-ensurer.reset-size1.size8,.katex .sizing.reset-size1.size8{font-size:2.88em}.katex .fontsize-ensurer.reset-size1.size9,.katex .sizing.reset-size1.size9{font-size:3.456em}.katex .fontsize-ensurer.reset-size1.size10,.katex .sizing.reset-size1.size10{font-size:4.148em}.katex .fontsize-ensurer.reset-size1.size11,.katex .sizing.reset-size1.size11{font-size:4.976em}.katex .fontsize-ensurer.reset-size2.size1,.katex .sizing.reset-size2.size1{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size2.size2,.katex .sizing.reset-size2.size2{font-size:1em}.katex .fontsize-ensurer.reset-size2.size3,.katex .sizing.reset-size2.size3{font-size:1.1666666667em}.katex .fontsize-ensurer.reset-size2.size4,.katex .sizing.reset-size2.size4{font-size:1.3333333333em}.katex .fontsize-ensurer.reset-size2.size5,.katex .sizing.reset-size2.size5{font-size:1.5em}.katex .fontsize-ensurer.reset-size2.size6,.katex .sizing.reset-size2.size6{font-size:1.6666666667em}.katex .fontsize-ensurer.reset-size2.size7,.katex .sizing.reset-size2.size7{font-size:2em}.katex .fontsize-ensurer.reset-size2.size8,.katex .sizing.reset-size2.size8{font-size:2.4em}.katex .fontsize-ensurer.reset-size2.size9,.katex .sizing.reset-size2.size9{font-size:2.88em}.katex .fontsize-ensurer.reset-size2.size10,.katex .sizing.reset-size2.size10{font-size:3.4566666667em}.katex .fontsize-ensurer.reset-size2.size11,.katex .sizing.reset-size2.size11{font-size:4.1466666667em}.katex .fontsize-ensurer.reset-size3.size1,.katex .sizing.reset-size3.size1{font-size:.7142857143em}.katex .fontsize-ensurer.reset-size3.size2,.katex .sizing.reset-size3.size2{font-size:.8571428571em}.katex .fontsize-ensurer.reset-size3.size3,.katex .sizing.reset-size3.size3{font-size:1em}.katex .fontsize-ensurer.reset-size3.size4,.katex .sizing.reset-size3.size4{font-size:1.1428571429em}.katex .fontsize-ensurer.reset-size3.size5,.katex .sizing.reset-size3.size5{font-size:1.2857142857em}.katex .fontsize-ensurer.reset-size3.size6,.katex .sizing.reset-size3.size6{font-size:1.4285714286em}.katex .fontsize-ensurer.reset-size3.size7,.katex .sizing.reset-size3.size7{font-size:1.7142857143em}.katex .fontsize-ensurer.reset-size3.size8,.katex .sizing.reset-size3.size8{font-size:2.0571428571em}.katex .fontsize-ensurer.reset-size3.size9,.katex .sizing.reset-size3.size9{font-size:2.4685714286em}.katex .fontsize-ensurer.reset-size3.size10,.katex .sizing.reset-size3.size10{font-size:2.9628571429em}.katex .fontsize-ensurer.reset-size3.size11,.katex .sizing.reset-size3.size11{font-size:3.5542857143em}.katex .fontsize-ensurer.reset-size4.size1,.katex .sizing.reset-size4.size1{font-size:.625em}.katex .fontsize-ensurer.reset-size4.size2,.katex .sizing.reset-size4.size2{font-size:.75em}.katex .fontsize-ensurer.reset-size4.size3,.katex .sizing.reset-size4.size3{font-size:.875em}.katex .fontsize-ensurer.reset-size4.size4,.katex .sizing.reset-size4.size4{font-size:1em}.katex .fontsize-ensurer.reset-size4.size5,.katex .sizing.reset-size4.size5{font-size:1.125em}.katex .fontsize-ensurer.reset-size4.size6,.katex .sizing.reset-size4.size6{font-size:1.25em}.katex .fontsize-ensurer.reset-size4.size7,.katex .sizing.reset-size4.size7{font-size:1.5em}.katex .fontsize-ensurer.reset-size4.size8,.katex .sizing.reset-size4.size8{font-size:1.8em}.katex .fontsize-ensurer.reset-size4.size9,.katex .sizing.reset-size4.size9{font-size:2.16em}.katex .fontsize-ensurer.reset-size4.size10,.katex .sizing.reset-size4.size10{font-size:2.5925em}.katex .fontsize-ensurer.reset-size4.size11,.katex .sizing.reset-size4.size11{font-size:3.11em}.katex .fontsize-ensurer.reset-size5.size1,.katex .sizing.reset-size5.size1{font-size:.5555555556em}.katex .fontsize-ensurer.reset-size5.size2,.katex .sizing.reset-size5.size2{font-size:.6666666667em}.katex .fontsize-ensurer.reset-size5.size3,.katex .sizing.reset-size5.size3{font-size:.7777777778em}.katex .fontsize-ensurer.reset-size5.size4,.katex .sizing.reset-size5.size4{font-size:.8888888889em}.katex .fontsize-ensurer.reset-size5.size5,.katex .sizing.reset-size5.size5{font-size:1em}.katex .fontsize-ensurer.reset-size5.size6,.katex .sizing.reset-size5.size6{font-size:1.1111111111em}.katex .fontsize-ensurer.reset-size5.size7,.katex .sizing.reset-size5.size7{font-size:1.3333333333em}.katex .fontsize-ensurer.reset-size5.size8,.katex .sizing.reset-size5.size8{font-size:1.6em}.katex .fontsize-ensurer.reset-size5.size9,.katex .sizing.reset-size5.size9{font-size:1.92em}.katex .fontsize-ensurer.reset-size5.size10,.katex .sizing.reset-size5.size10{font-size:2.3044444444em}.katex .fontsize-ensurer.reset-size5.size11,.katex .sizing.reset-size5.size11{font-size:2.7644444444em}.katex .fontsize-ensurer.reset-size6.size1,.katex .sizing.reset-size6.size1{font-size:.5em}.katex .fontsize-ensurer.reset-size6.size2,.katex .sizing.reset-size6.size2{font-size:.6em}.katex .fontsize-ensurer.reset-size6.size3,.katex .sizing.reset-size6.size3{font-size:.7em}.katex .fontsize-ensurer.reset-size6.size4,.katex .sizing.reset-size6.size4{font-size:.8em}.katex .fontsize-ensurer.reset-size6.size5,.katex .sizing.reset-size6.size5{font-size:.9em}.katex .fontsize-ensurer.reset-size6.size6,.katex .sizing.reset-size6.size6{font-size:1em}.katex .fontsize-ensurer.reset-size6.size7,.katex .sizing.reset-size6.size7{font-size:1.2em}.katex .fontsize-ensurer.reset-size6.size8,.katex .sizing.reset-size6.size8{font-size:1.44em}.katex .fontsize-ensurer.reset-size6.size9,.katex .sizing.reset-size6.size9{font-size:1.728em}.katex .fontsize-ensurer.reset-size6.size10,.katex .sizing.reset-size6.size10{font-size:2.074em}.katex .fontsize-ensurer.reset-size6.size11,.katex .sizing.reset-size6.size11{font-size:2.488em}.katex .fontsize-ensurer.reset-size7.size1,.katex .sizing.reset-size7.size1{font-size:.4166666667em}.katex .fontsize-ensurer.reset-size7.size2,.katex .sizing.reset-size7.size2{font-size:.5em}.katex .fontsize-ensurer.reset-size7.size3,.katex .sizing.reset-size7.size3{font-size:.5833333333em}.katex .fontsize-ensurer.reset-size7.size4,.katex .sizing.reset-size7.size4{font-size:.6666666667em}.katex .fontsize-ensurer.reset-size7.size5,.katex .sizing.reset-size7.size5{font-size:.75em}.katex .fontsize-ensurer.reset-size7.size6,.katex .sizing.reset-size7.size6{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size7.size7,.katex .sizing.reset-size7.size7{font-size:1em}.katex .fontsize-ensurer.reset-size7.size8,.katex .sizing.reset-size7.size8{font-size:1.2em}.katex .fontsize-ensurer.reset-size7.size9,.katex .sizing.reset-size7.size9{font-size:1.44em}.katex .fontsize-ensurer.reset-size7.size10,.katex .sizing.reset-size7.size10{font-size:1.7283333333em}.katex .fontsize-ensurer.reset-size7.size11,.katex .sizing.reset-size7.size11{font-size:2.0733333333em}.katex .fontsize-ensurer.reset-size8.size1,.katex .sizing.reset-size8.size1{font-size:.3472222222em}.katex .fontsize-ensurer.reset-size8.size2,.katex .sizing.reset-size8.size2{font-size:.4166666667em}.katex .fontsize-ensurer.reset-size8.size3,.katex .sizing.reset-size8.size3{font-size:.4861111111em}.katex .fontsize-ensurer.reset-size8.size4,.katex .sizing.reset-size8.size4{font-size:.5555555556em}.katex .fontsize-ensurer.reset-size8.size5,.katex .sizing.reset-size8.size5{font-size:.625em}.katex .fontsize-ensurer.reset-size8.size6,.katex .sizing.reset-size8.size6{font-size:.6944444444em}.katex .fontsize-ensurer.reset-size8.size7,.katex .sizing.reset-size8.size7{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size8.size8,.katex .sizing.reset-size8.size8{font-size:1em}.katex .fontsize-ensurer.reset-size8.size9,.katex .sizing.reset-size8.size9{font-size:1.2em}.katex .fontsize-ensurer.reset-size8.size10,.katex .sizing.reset-size8.size10{font-size:1.4402777778em}.katex .fontsize-ensurer.reset-size8.size11,.katex .sizing.reset-size8.size11{font-size:1.7277777778em}.katex .fontsize-ensurer.reset-size9.size1,.katex .sizing.reset-size9.size1{font-size:.2893518519em}.katex .fontsize-ensurer.reset-size9.size2,.katex .sizing.reset-size9.size2{font-size:.3472222222em}.katex .fontsize-ensurer.reset-size9.size3,.katex .sizing.reset-size9.size3{font-size:.4050925926em}.katex .fontsize-ensurer.reset-size9.size4,.katex .sizing.reset-size9.size4{font-size:.462962963em}.katex .fontsize-ensurer.reset-size9.size5,.katex .sizing.reset-size9.size5{font-size:.5208333333em}.katex .fontsize-ensurer.reset-size9.size6,.katex .sizing.reset-size9.size6{font-size:.5787037037em}.katex .fontsize-ensurer.reset-size9.size7,.katex .sizing.reset-size9.size7{font-size:.6944444444em}.katex .fontsize-ensurer.reset-size9.size8,.katex .sizing.reset-size9.size8{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size9.size9,.katex .sizing.reset-size9.size9{font-size:1em}.katex .fontsize-ensurer.reset-size9.size10,.katex .sizing.reset-size9.size10{font-size:1.2002314815em}.katex .fontsize-ensurer.reset-size9.size11,.katex .sizing.reset-size9.size11{font-size:1.4398148148em}.katex .fontsize-ensurer.reset-size10.size1,.katex .sizing.reset-size10.size1{font-size:.2410800386em}.katex .fontsize-ensurer.reset-size10.size2,.katex .sizing.reset-size10.size2{font-size:.2892960463em}.katex .fontsize-ensurer.reset-size10.size3,.katex .sizing.reset-size10.size3{font-size:.337512054em}.katex .fontsize-ensurer.reset-size10.size4,.katex .sizing.reset-size10.size4{font-size:.3857280617em}.katex .fontsize-ensurer.reset-size10.size5,.katex .sizing.reset-size10.size5{font-size:.4339440694em}.katex .fontsize-ensurer.reset-size10.size6,.katex .sizing.reset-size10.size6{font-size:.4821600771em}.katex .fontsize-ensurer.reset-size10.size7,.katex .sizing.reset-size10.size7{font-size:.5785920926em}.katex .fontsize-ensurer.reset-size10.size8,.katex .sizing.reset-size10.size8{font-size:.6943105111em}.katex .fontsize-ensurer.reset-size10.size9,.katex .sizing.reset-size10.size9{font-size:.8331726133em}.katex .fontsize-ensurer.reset-size10.size10,.katex .sizing.reset-size10.size10{font-size:1em}.katex .fontsize-ensurer.reset-size10.size11,.katex .sizing.reset-size10.size11{font-size:1.1996142719em}.katex .fontsize-ensurer.reset-size11.size1,.katex .sizing.reset-size11.size1{font-size:.2009646302em}.katex .fontsize-ensurer.reset-size11.size2,.katex .sizing.reset-size11.size2{font-size:.2411575563em}.katex .fontsize-ensurer.reset-size11.size3,.katex .sizing.reset-size11.size3{font-size:.2813504823em}.katex .fontsize-ensurer.reset-size11.size4,.katex .sizing.reset-size11.size4{font-size:.3215434084em}.katex .fontsize-ensurer.reset-size11.size5,.katex .sizing.reset-size11.size5{font-size:.3617363344em}.katex .fontsize-ensurer.reset-size11.size6,.katex .sizing.reset-size11.size6{font-size:.4019292605em}.katex .fontsize-ensurer.reset-size11.size7,.katex .sizing.reset-size11.size7{font-size:.4823151125em}.katex .fontsize-ensurer.reset-size11.size8,.katex .sizing.reset-size11.size8{font-size:.578778135em}.katex .fontsize-ensurer.reset-size11.size9,.katex .sizing.reset-size11.size9{font-size:.6945337621em}.katex .fontsize-ensurer.reset-size11.size10,.katex .sizing.reset-size11.size10{font-size:.8336012862em}.katex .fontsize-ensurer.reset-size11.size11,.katex .sizing.reset-size11.size11{font-size:1em}.katex .delimsizing.size1{font-family:KaTeX_Size1}.katex .delimsizing.size2{font-family:KaTeX_Size2}.katex .delimsizing.size3{font-family:KaTeX_Size3}.katex .delimsizing.size4{font-family:KaTeX_Size4}.katex .delimsizing.mult .delim-size1>span{font-family:KaTeX_Size1}.katex .delimsizing.mult .delim-size4>span{font-family:KaTeX_Size4}.katex .nulldelimiter{display:inline-block;width:.12em}.katex .delimcenter,.katex .op-symbol{position:relative}.katex .op-symbol.small-op{font-family:KaTeX_Size1}.katex .op-symbol.large-op{font-family:KaTeX_Size2}.katex .accent>.vlist-t,.katex .op-limits>.vlist-t{text-align:center}.katex .accent .accent-body{position:relative}.katex .accent .accent-body:not(.accent-full){width:0}.katex .overlay{display:block}.katex .mtable .vertical-separator{display:inline-block;min-width:1px}.katex .mtable .arraycolsep{display:inline-block}.katex .mtable .col-align-c>.vlist-t{text-align:center}.katex .mtable .col-align-l>.vlist-t{text-align:left}.katex .mtable .col-align-r>.vlist-t{text-align:right}.katex .svg-align{text-align:left}.katex svg{fill:currentColor;stroke:currentColor;display:block;height:inherit;position:absolute;width:100%}.katex svg path{stroke:none}.katex svg{fill-rule:nonzero;fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1}.katex img{border-style:none;max-height:none;max-width:none;min-height:0;min-width:0}.katex .stretchy{display:block;overflow:hidden;position:relative;width:100%}.katex .stretchy:after,.katex .stretchy:before{content:""}.katex .hide-tail{overflow:hidden;position:relative;width:100%}.katex .halfarrow-left{left:0;overflow:hidden;position:absolute;width:50.2%}.katex .halfarrow-right{overflow:hidden;position:absolute;right:0;width:50.2%}.katex .brace-left{left:0;overflow:hidden;position:absolute;width:25.1%}.katex .brace-center{left:25%;overflow:hidden;position:absolute;width:50%}.katex .brace-right{overflow:hidden;position:absolute;right:0;width:25.1%}.katex .x-arrow-pad{padding:0 .5em}.katex .cd-arrow-pad{padding:0 .55556em 0 .27778em}.katex .mover,.katex .munder,.katex .x-arrow{text-align:center}.katex .boxpad{padding:0 .3em}.katex .fbox,.katex .fcolorbox{border:.04em solid;box-sizing:border-box}.katex .cancel-pad{padding:0 .2em}.katex .cancel-lap{margin-left:-.2em;margin-right:-.2em}.katex .sout{border-bottom-style:solid;border-bottom-width:.08em}.katex .angl{border-right:.049em solid;border-top:.049em solid;box-sizing:border-box;margin-right:.03889em}.katex .anglpad{padding:0 .03889em}.katex .eqn-num:before{content:"(" counter(katexEqnNo) ")";counter-increment:katexEqnNo}.katex .mml-eqn-num:before{content:"(" counter(mmlEqnNo) ")";counter-increment:mmlEqnNo}.katex .mtr-glue{width:50%}.katex .cd-vert-arrow{display:inline-block;position:relative}.katex .cd-label-left{display:inline-block;position:absolute;right:calc(50% + .3em);text-align:left}.katex .cd-label-right{display:inline-block;left:calc(50% + .3em);position:absolute;text-align:right}.katex-display{display:block;margin:1em 0;text-align:center}.katex-display>.katex{display:block;text-align:center;white-space:nowrap}.katex-display>.katex>.katex-html{display:block;position:relative}.katex-display>.katex>.katex-html>.tag{position:absolute;right:0}.katex-display.leqno>.katex>.katex-html>.tag{left:0;right:auto}.katex-display.fleqn>.katex{padding-left:2em;text-align:left}body{counter-reset:katexEqnNo mmlEqnNo}.qr-container{--qr-surface: #ffffff;--qr-surface-2: #f8fafc;--qr-border: #e9eef4;--qr-text-1: #0f172a;--qr-text-2: #64748b;--qr-text-3: #94a3b8;--qr-indigo: #6366f1;--qr-indigo-soft: rgba(99, 102, 241, .08);--qr-indigo-border: rgba(99, 102, 241, .2);--qr-green: #22c55e;--qr-green-soft: rgba(34, 197, 94, .09);--qr-green-border: rgba(34, 197, 94, .2);--qr-amber: #f59e0b;--qr-amber-soft: rgba(245, 158, 11, .09);--qr-red: #ef4444;--qr-red-soft: rgba(239, 68, 68, .08);--qr-radius-sm: 8px;--qr-radius-md: 12px}.qr-container{background:transparent;border:none;border-radius:0;padding:0;margin-bottom:0;-webkit-backdrop-filter:none;backdrop-filter:none}.qr-container:hover{border-color:transparent;box-shadow:none}.qr-header{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}.qr-number{background:var(--qr-indigo-soft);color:var(--qr-indigo);font-weight:600;font-size:12px;padding:3px 10px;border-radius:6px;border:.5px solid var(--qr-indigo-border);min-width:auto;text-align:center;background:var(--qr-indigo);color:#fff}.qr-type-badge{font-size:10px;padding:2px 9px;border-radius:99px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;background:var(--qr-indigo-soft);color:var(--qr-indigo);border:.5px solid var(--qr-indigo-border)}.qr-type-badge[data-type=CODING]{background:#22c55e17;color:#15803d;border-color:#22c55e33}.qr-type-badge[data-type=SUBJECTIVE]{background:#f59e0b17;color:#b45309;border-color:#f59e0b33}.qr-type-badge[data-type=FILE_UPLOAD]{background:#ec489917;color:#be185d;border-color:#ec489933}.qr-type-badge[data-type=FILL_BLANK]{background:#0ea5e917;color:#0369a1;border-color:#0ea5e933}.qr-type-badge[data-type=MATCH_FOLLOWING]{background:#ea580c17;color:#c2410c;border-color:#ea580c33}.qr-type-badge[data-type=DRAG_DROP]{background:#8b5cf617;color:#7c3aed;border-color:#8b5cf633}.qr-type-badge[data-type=SHORT_ANSWER]{background:#06b6d417;color:#0e7490;border-color:#06b6d433}.qr-type-badge[data-type=MCQ_MULTIPLE]{background:var(--qr-indigo-soft);color:var(--qr-indigo);border-color:var(--qr-indigo-border)}.qr-marks{margin-left:auto;font-size:12px;color:var(--qr-text-2);background:var(--qr-surface-2);padding:3px 10px;border-radius:6px;border:.5px solid var(--qr-border)}.qr-required{color:var(--qr-red);font-size:16px;font-weight:700;line-height:1}.qr-section-tag{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;margin-bottom:10px;background:var(--qr-indigo-soft);border:.5px solid var(--qr-indigo-border);border-radius:6px;font-size:11px;color:var(--qr-indigo);font-weight:500}.qr-text{font-size:16px;line-height:1.65;color:var(--qr-text-1);margin-bottom:20px;padding-bottom:16px;border-bottom:.5px solid var(--qr-border);font-weight:500}.qr-text p{margin:0 0 8px;color:var(--qr-text-1)}.qr-text img{max-width:100%;border-radius:var(--qr-radius-sm)}.qr-text code{background:var(--qr-surface-2);border:.5px solid var(--qr-border);border-radius:4px;padding:1px 5px;font-size:13px;color:var(--qr-indigo)}.qr-text pre{background:var(--qr-surface-2);border:.5px solid var(--qr-border);border-radius:var(--qr-radius-sm);padding:12px 14px;overflow-x:auto;font-size:13px;color:var(--qr-text-1)}.qr-answer-area{width:100%}.qr-unsupported{padding:16px;text-align:center;color:var(--qr-red);background:var(--qr-red-soft);border-radius:var(--qr-radius-md);font-size:13px}.mcq-premium{display:flex;flex-direction:column;gap:8px}.mcq-hint-bar{display:flex;align-items:center;gap:8px;padding:7px 12px;background:var(--qr-indigo-soft);border:.5px solid var(--qr-indigo-border);border-radius:8px;font-size:12px;color:var(--qr-text-2);margin-bottom:2px}.mcq-selected-count{margin-left:auto;padding:1px 9px;background:var(--qr-indigo-soft);border-radius:99px;color:var(--qr-indigo);font-weight:500;font-size:11px;border:.5px solid var(--qr-indigo-border)}.mcq-options-grid{display:flex;flex-direction:column;gap:9px}.mcq-opt-card{display:flex;align-items:center;gap:12px;padding:13px 15px;background:var(--qr-surface-2);border:.5px solid var(--qr-border);border-radius:var(--qr-radius-md);cursor:pointer;transition:all .15s ease;position:relative;overflow:hidden;outline:none;text-align:left;width:100%}.mcq-opt-card:hover:not(.mcq-opt-disabled){background:var(--qr-indigo-soft);border-color:var(--qr-indigo-border);transform:none}.mcq-opt-card:focus-visible{border-color:var(--qr-indigo);box-shadow:0 0 0 3px var(--qr-indigo-soft)}.mcq-opt-card.mcq-opt-selected{background:var(--qr-indigo-soft)!important;border-color:var(--qr-indigo)!important;border-width:1px!important}.mcq-opt-card.mcq-opt-disabled{opacity:.6;cursor:not-allowed}@keyframes mcqPulse{0%{transform:scale(1)}50%{transform:scale(1.01)}to{transform:scale(1)}}.mcq-opt-card.mcq-opt-animate{animation:mcqPulse .3s ease-out}.mcq-opt-indicator{flex-shrink:0}.mcq-radio{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--qr-border);display:flex;align-items:center;justify-content:center;transition:all .15s ease;background:var(--qr-surface)}.mcq-radio.mcq-radio-checked{border-color:var(--qr-indigo)}.mcq-radio-inner{width:9px;height:9px;border-radius:50%;background:var(--qr-indigo);animation:mcqFadeIn .15s ease}.mcq-checkbox{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--qr-border);display:flex;align-items:center;justify-content:center;transition:all .15s ease;background:var(--qr-surface)}.mcq-checkbox.mcq-checkbox-checked{border-color:var(--qr-indigo);background:var(--qr-indigo);color:#fff}@keyframes mcqFadeIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.mcq-opt-letter{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:7px;background:var(--qr-surface);border:.5px solid var(--qr-border);font-weight:600;font-size:12px;color:var(--qr-text-2);flex-shrink:0;transition:all .15s ease}.mcq-opt-selected .mcq-opt-letter{background:var(--qr-indigo);border-color:var(--qr-indigo);color:#fff}.mcq-opt-text{color:var(--qr-text-1);font-size:14px;line-height:1.5;flex:1}.mcq-opt-selected .mcq-opt-text{color:var(--qr-indigo);font-weight:500}.mcq-opt-check-badge{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:var(--qr-indigo-soft);display:flex;align-items:center;justify-content:center;color:var(--qr-indigo);animation:mcqFadeIn .15s ease}.subj-premium{border:.5px solid var(--qr-border);border-radius:var(--qr-radius-md);overflow:hidden;transition:border-color .2s ease,box-shadow .2s ease;background:var(--qr-surface)}.subj-premium.subj-focused{border-color:var(--qr-indigo);border-width:1px;box-shadow:0 0 0 3px var(--qr-indigo-soft)}.subj-toolbar{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--qr-surface-2);border-bottom:.5px solid var(--qr-border)}.subj-toolbar-group{display:flex;gap:3px}.subj-tb-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:5px;color:var(--qr-text-2);cursor:pointer;font-size:13px;transition:all .13s ease}.subj-tb-btn:hover:not(:disabled){background:var(--qr-indigo-soft);color:var(--qr-indigo)}.subj-tb-btn:disabled{opacity:.35;cursor:not-allowed}.subj-toolbar-sep{width:.5px;height:18px;background:var(--qr-border)}.subj-status-pills{margin-left:auto;display:flex;gap:6px}.subj-pill{font-size:10.5px;padding:2px 8px;background:var(--qr-surface-2);border:.5px solid var(--qr-border);border-radius:99px;color:var(--qr-text-3);font-weight:400}.subj-editor{width:100%;min-height:200px;padding:16px;background:var(--qr-surface);border:none;color:var(--qr-text-1);font-family:DM Sans,system-ui,sans-serif;font-size:14px;line-height:1.65;resize:vertical;outline:none}.subj-editor::placeholder{color:var(--qr-text-3)}.subj-bottom-bar{display:flex;align-items:center;justify-content:space-between;padding:7px 12px;background:var(--qr-surface-2);border-top:.5px solid var(--qr-border)}.subj-autosave-indicator{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--qr-text-3)}.subj-save-dot{width:5px;height:5px;border-radius:50%;background:var(--qr-green);animation:subj-pulse 2s infinite}@keyframes subj-pulse{0%,to{opacity:1}50%{opacity:.3}}.subj-hint{font-size:11px;color:var(--qr-text-3);font-style:italic}.sa-premium{transition:all .2s ease}.sa-input-wrap{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--qr-surface-2);border:.5px solid var(--qr-border);border-radius:var(--qr-radius-md);transition:all .2s ease}.sa-premium.sa-focused .sa-input-wrap{border-color:var(--qr-indigo);border-width:1px;background:var(--qr-surface);box-shadow:0 0 0 3px var(--qr-indigo-soft)}.sa-icon{flex-shrink:0;color:var(--qr-text-3);transition:color .2s}.sa-premium.sa-focused .sa-icon{color:var(--qr-indigo)}.sa-input{flex:1;background:none;border:none;color:var(--qr-text-1);font-size:14px;outline:none;font-family:DM Sans,system-ui,sans-serif}.sa-input::placeholder{color:var(--qr-text-3)}.sa-clear{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border:none;background:var(--qr-surface-2);border-radius:5px;color:var(--qr-text-3);cursor:pointer;transition:all .13s ease}.sa-clear:hover{background:var(--qr-red-soft);color:var(--qr-red)}.sa-progress-wrap{display:flex;align-items:center;gap:8px;margin-top:7px}.sa-progress-track{flex:1;height:3px;background:var(--qr-border);border-radius:2px;overflow:hidden}.sa-progress-fill{height:100%;background:linear-gradient(90deg,var(--qr-indigo),#8b5cf6);border-radius:2px;transition:width .3s ease}.sa-progress-fill.sa-fill-warn{background:linear-gradient(90deg,var(--qr-amber),var(--qr-red))}.sa-char-count{font-size:11px;color:var(--qr-text-3);min-width:60px;text-align:right}.sa-char-count.sa-count-warn{color:var(--qr-amber)}.code-premium{border:.5px solid var(--qr-border);border-radius:var(--qr-radius-md);overflow:hidden;background:#f8fafc}.code-toolbar{display:flex;align-items:center;justify-content:space-between;padding:9px 14px;background:var(--qr-surface-2);border-bottom:.5px solid var(--qr-border)}.code-lang-switcher{display:flex;gap:4px}.code-lang-tab{display:flex;align-items:center;gap:5px;padding:5px 12px;border:.5px solid var(--qr-border);background:var(--qr-surface);border-radius:7px;color:var(--qr-text-2);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s ease}.code-lang-tab:hover:not(:disabled){background:var(--qr-indigo-soft);border-color:var(--qr-indigo-border);color:var(--qr-indigo)}.code-lang-tab.code-lang-active{background:var(--qr-indigo-soft);border-color:var(--qr-indigo);color:var(--qr-indigo);font-weight:600}.code-lang-icon{font-size:14px}.code-toolbar-actions{display:flex;align-items:center;gap:10px}.code-tb-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;border:.5px solid var(--qr-border);background:var(--qr-surface);border-radius:6px;color:var(--qr-text-2);font-size:12px;cursor:pointer;transition:all .13s ease}.code-tb-btn:hover:not(:disabled){border-color:#ef44444d;color:var(--qr-red);background:var(--qr-red-soft)}.code-line-count{font-size:11px;color:var(--qr-text-3)}.code-tab-bar{display:flex;background:var(--qr-surface-2);border-bottom:.5px solid var(--qr-border)}.code-tab{display:flex;align-items:center;gap:5px;padding:8px 16px;border:none;background:none;color:var(--qr-text-3);font-size:12px;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s ease}.code-tab:hover{color:var(--qr-text-2)}.code-tab.code-tab-active{color:var(--qr-text-1);border-bottom-color:var(--qr-indigo);font-weight:500}.code-editor-wrap{display:flex;min-height:280px;max-height:500px}.code-line-numbers{display:flex;flex-direction:column;padding:14px 10px;background:#f1f5f9;min-width:44px;text-align:right;-webkit-user-select:none;user-select:none;overflow:hidden;border-right:.5px solid var(--qr-border)}.code-line-numbers span{font-family:Fira Code,JetBrains Mono,monospace;font-size:12px;line-height:1.5;color:var(--qr-text-3);height:1.5em}.code-editor-area{flex:1;padding:14px;background:#fafbfc;border:none;color:var(--qr-text-1);font-family:Fira Code,JetBrains Mono,monospace;font-size:13px;line-height:1.5;tab-size:4;resize:none;outline:none;overflow:auto}.code-editor-area::placeholder{color:var(--qr-text-3)}.code-testcases{padding:14px;display:flex;flex-direction:column;gap:10px;max-height:360px;overflow-y:auto}.code-tc-card{border:.5px solid var(--qr-border);border-radius:10px;overflow:hidden;background:var(--qr-surface)}.code-tc-header{padding:9px 13px;background:var(--qr-surface-2);border-bottom:.5px solid var(--qr-border)}.code-tc-badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--qr-indigo);font-weight:600}.code-tc-body{padding:12px;display:flex;flex-direction:column;gap:10px}.code-tc-section{display:flex;flex-direction:column;gap:4px}.code-tc-label{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--qr-text-3);font-weight:600}.code-tc-pre{margin:0;padding:9px 12px;background:var(--qr-surface-2);border:.5px solid var(--qr-border);border-radius:7px;font-family:Fira Code,monospace;font-size:12px;color:var(--qr-text-1);white-space:pre-wrap;overflow-x:auto}.code-tc-explanation{margin:0;font-size:13px;color:var(--qr-text-2);line-height:1.5}.fu-premium{display:flex;flex-direction:column;gap:10px}.fu-hidden-input{display:none!important}.fu-dropzone{padding:36px 24px;border:1.5px dashed var(--qr-border);border-radius:var(--qr-radius-md);background:var(--qr-surface-2);cursor:pointer;transition:all .2s ease;text-align:center}.fu-dropzone:hover,.fu-dropzone.fu-dragover{border-color:var(--qr-indigo);background:var(--qr-indigo-soft);transform:translateY(-1px)}.fu-dropzone.fu-disabled{opacity:.5;cursor:not-allowed}.fu-drop-content{display:flex;flex-direction:column;align-items:center;gap:10px}.fu-drop-icon{color:var(--qr-text-3);transition:all .2s ease}.fu-drop-icon.fu-icon-active{color:var(--qr-indigo);transform:translateY(-4px) scale(1.1)}.fu-drop-title{margin:0;font-size:15px;color:var(--qr-text-1);font-weight:500}.fu-drop-subtitle{margin:0;font-size:13px;color:var(--qr-text-2)}.fu-drop-meta{display:flex;gap:14px;margin-top:6px}.fu-meta-item{display:flex;align-items:center;gap:4px;font-size:11.5px;color:var(--qr-text-3)}.fu-file-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--qr-surface);border:.5px solid var(--qr-border);border-radius:var(--qr-radius-md)}.fu-file-icon{font-size:28px;flex-shrink:0}.fu-file-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.fu-file-name{font-size:13px;font-weight:500;color:var(--qr-text-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fu-file-size{font-size:11.5px;color:var(--qr-text-3)}.fu-progress-wrap{display:flex;align-items:center;gap:8px;margin-top:3px}.fu-progress-track{flex:1;height:3px;background:var(--qr-border);border-radius:2px;overflow:hidden}.fu-progress-fill{height:100%;background:linear-gradient(90deg,var(--qr-indigo),#8b5cf6);border-radius:2px;transition:width .3s ease}.fu-progress-text{font-size:11px;color:var(--qr-text-3);min-width:32px;text-align:right}.fu-upload-complete{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;color:#15803d;font-weight:500;margin-top:2px}.fu-remove-btn{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:.5px solid var(--qr-border);background:var(--qr-surface);border-radius:7px;color:var(--qr-text-3);cursor:pointer;transition:all .13s ease}.fu-remove-btn:hover{background:var(--qr-red-soft);border-color:#ef444440;color:var(--qr-red)}.fu-view-link{display:inline-flex;align-items:center;gap:5px;color:var(--qr-indigo);text-decoration:none;font-size:13px;padding:6px 12px;border-radius:7px;transition:background .15s}.fu-view-link:hover{background:var(--qr-indigo-soft);text-decoration:underline}.fu-error{display:flex;align-items:center;gap:7px;padding:9px 13px;background:var(--qr-red-soft);border:.5px solid rgba(239,68,68,.25);border-radius:9px;color:var(--qr-red);font-size:13px}.fb-premium{display:flex;flex-direction:column;gap:14px}.fb-progress-header{display:flex;align-items:center;gap:14px;padding:9px 13px;background:var(--qr-indigo-soft);border:.5px solid var(--qr-indigo-border);border-radius:9px}.fb-progress-info{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--qr-text-2);flex-shrink:0}.fb-progress-bar-wrapper{flex:1;display:flex;align-items:center;gap:8px}.fb-progress-track{flex:1;height:3px;background:#6366f126;border-radius:2px;overflow:hidden}.fb-progress-fill{height:100%;background:var(--qr-indigo);border-radius:2px;transition:width .35s ease}.fb-progress-text{font-size:11px;color:var(--qr-indigo);font-weight:600}.fb-blanks-list{display:flex;flex-direction:column;gap:8px}.fb-blank-card{display:flex;align-items:center;gap:12px;padding:11px 14px;background:var(--qr-surface-2);border:.5px solid var(--qr-border);border-radius:var(--qr-radius-md);transition:all .15s ease}.fb-blank-card.fb-blank-focused{border-color:var(--qr-indigo);border-width:1px;box-shadow:0 0 0 3px var(--qr-indigo-soft);background:var(--qr-surface)}.fb-blank-card.fb-blank-filled{border-color:var(--qr-green-border);background:var(--qr-green-soft)}.fb-blank-number{flex-shrink:0}.fb-num-circle{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--qr-surface);border:.5px solid var(--qr-border);font-size:11.5px;font-weight:600;color:var(--qr-text-2);transition:all .15s ease}.fb-blank-filled .fb-num-circle{background:var(--qr-green-soft);border-color:var(--qr-green-border);color:#15803d}.fb-blank-input-wrap{flex:1;display:flex;align-items:center;gap:6px}.fb-blank-input{flex:1;padding:9px 12px;background:var(--qr-surface);border:.5px solid var(--qr-border);border-radius:7px;color:var(--qr-text-1);font-size:13.5px;outline:none;transition:border-color .15s;font-family:DM Sans,system-ui,sans-serif}.fb-blank-input:focus{border-color:var(--qr-indigo);border-width:1px}.fb-blank-input::placeholder{color:var(--qr-text-3)}.fb-blank-input:disabled{background:var(--qr-surface-2);color:var(--qr-text-2);cursor:not-allowed}.fb-clear-btn{flex-shrink:0;width:22px;height:22px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:4px;color:var(--qr-text-3);cursor:pointer;transition:all .13s}.fb-clear-btn:hover{background:var(--qr-red-soft);color:var(--qr-red)}.mf-premium{display:flex;flex-direction:column;gap:14px}.mf-instructions{display:flex;align-items:center;gap:7px;padding:9px 13px;background:var(--qr-indigo-soft);border:.5px solid var(--qr-indigo-border);border-radius:9px;font-size:12.5px;color:var(--qr-text-2)}.mf-progress-pill{margin-left:auto;padding:2px 10px;background:var(--qr-surface);border:.5px solid var(--qr-indigo-border);border-radius:99px;color:var(--qr-indigo);font-weight:500;font-size:11px}.mf-progress-track{height:3px;background:var(--qr-border);border-radius:2px;overflow:hidden}.mf-progress-fill{height:100%;background:var(--qr-indigo);border-radius:2px;transition:width .35s ease}.mf-columns{display:grid;grid-template-columns:1fr 32px 1fr;gap:0;align-items:start}.mf-column{display:flex;flex-direction:column;gap:7px}.mf-col-header{padding:7px 12px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--qr-indigo);border-bottom:.5px solid var(--qr-indigo-border);margin-bottom:2px}.mf-connector{display:flex;align-items:center;justify-content:center;opacity:.35;padding-top:36px}.mf-item{padding:11px 14px;background:var(--qr-surface-2);border:.5px solid var(--qr-border);border-radius:var(--qr-radius-sm);cursor:pointer;transition:all .15s ease;display:flex;flex-direction:column;gap:6px}.mf-item:hover{background:var(--qr-indigo-soft);border-color:var(--qr-indigo-border)}.mf-item.mf-item-selected{border-color:var(--qr-indigo);border-width:1px;background:var(--qr-indigo-soft);box-shadow:0 0 0 2px var(--qr-indigo-soft)}.mf-item.mf-item-matched{border-color:var(--qr-green-border);background:var(--qr-green-soft)}.mf-item.mf-item-used{border-color:var(--qr-green-border);background:var(--qr-green-soft);opacity:.8}.mf-item.mf-item-available{border-color:var(--qr-indigo-border);animation:mf-pulse 1.5s infinite}@keyframes mf-pulse{0%,to{box-shadow:0 0 0 0 var(--qr-indigo-soft)}50%{box-shadow:0 0 0 4px var(--qr-indigo-soft)}}.mf-item-text{color:var(--qr-text-1);font-size:13.5px}.mf-match-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;background:var(--qr-green-soft);border:.5px solid var(--qr-green-border);border-radius:6px;font-size:11.5px;color:#15803d}.mf-unmatch-btn{border:none;background:none;color:var(--qr-text-3);cursor:pointer;font-size:14px;padding:0 2px;line-height:1}.mf-unmatch-btn:hover{color:var(--qr-red)}.mf-used-check{margin-left:auto;color:var(--qr-green)}.dd-premium{display:flex;flex-direction:column;gap:14px}.dd-instructions{display:flex;align-items:center;gap:7px;padding:9px 13px;background:#8b5cf60f;border:.5px solid rgba(139,92,246,.18);border-radius:9px;font-size:12.5px;color:var(--qr-text-2)}.dd-progress-pill{margin-left:auto;padding:2px 10px;background:#8b5cf614;border:.5px solid rgba(139,92,246,.2);border-radius:99px;color:#7c3aed;font-weight:500;font-size:11px}.dd-progress-track{height:3px;background:var(--qr-border);border-radius:2px;overflow:hidden}.dd-progress-fill{height:100%;background:linear-gradient(90deg,#8b5cf6,#a78bfa);border-radius:2px;transition:width .35s ease}.dd-items-tray{padding:13px;background:var(--qr-surface-2);border:.5px solid var(--qr-border);border-radius:var(--qr-radius-md)}.dd-tray-label{display:flex;align-items:center;gap:5px;font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--qr-text-3);font-weight:600;margin-bottom:10px}.dd-items-row{display:flex;flex-wrap:wrap;gap:7px}.dd-item-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--qr-surface);border:.5px solid rgba(139,92,246,.2);border-radius:8px;color:var(--qr-text-1);font-size:13px;cursor:grab;-webkit-user-select:none;user-select:none;transition:all .15s ease}.dd-item-chip:hover{background:#8b5cf60f;border-color:#8b5cf64d;transform:translateY(-1px)}.dd-item-chip.dd-chip-dragging{opacity:.4;transform:scale(.97)}.dd-item-chip.dd-chip-selected{border-color:#8b5cf6;border-width:1px;background:#8b5cf614}.dd-grip{color:var(--qr-text-3)}.dd-zones-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px}.dd-zone{border:1.5px dashed var(--qr-border);border-radius:var(--qr-radius-md);overflow:hidden;transition:all .2s ease;min-height:100px;display:flex;flex-direction:column;background:var(--qr-surface)}.dd-zone.dd-zone-dragover{border-color:#8b5cf6;background:#8b5cf60a}.dd-zone.dd-zone-clickable{cursor:pointer;border-color:#8b5cf64d}.dd-zone-header{display:flex;align-items:center;justify-content:space-between;padding:8px 13px;background:var(--qr-surface-2);border-bottom:.5px solid var(--qr-border)}.dd-zone-label{font-size:12.5px;font-weight:600;color:#7c3aed}.dd-zone-count{font-size:11px;color:var(--qr-text-3)}.dd-zone-body{flex:1;padding:10px;display:flex;flex-direction:column;gap:5px}.dd-zone-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--qr-text-3);font-size:12px;padding:16px}.dd-zone-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#8b5cf60f;border:.5px solid rgba(139,92,246,.15);border-radius:7px;color:var(--qr-text-1);font-size:13px;animation:dd-fadeIn .2s ease}@keyframes dd-fadeIn{0%{opacity:0;transform:translateY(-3px)}to{opacity:1;transform:translateY(0)}}.dd-zone-remove{border:none;background:transparent;border-radius:4px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:var(--qr-text-3);cursor:pointer;transition:all .13s}.dd-zone-remove:hover{background:var(--qr-red-soft);color:var(--qr-red)}.qr-question-image-wrap{position:relative;margin-bottom:20px;border-radius:var(--qr-radius-md);overflow:hidden;border:1px solid var(--qr-border);background:var(--qr-surface-2);animation:qrImageFadeIn .4s ease}@keyframes qrImageFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.qr-question-image{display:block;width:100%;max-height:400px;object-fit:contain;padding:10px;cursor:zoom-in;transition:transform .2s ease}.qr-question-image:hover{transform:scale(1.01)}.qr-image-zoom-hint{display:flex;align-items:center;gap:5px;padding:5px 12px;background:var(--qr-surface-2);border:none;border-top:.5px solid var(--qr-border);color:var(--qr-text-3);font-size:11px;cursor:pointer;width:100%;justify-content:center;transition:all .15s}.qr-image-zoom-hint:hover{background:var(--qr-indigo-soft);color:var(--qr-indigo)}.qr-lightbox-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:qrLightboxIn .25s ease;padding:24px}@keyframes qrLightboxIn{0%{opacity:0}to{opacity:1}}.qr-lightbox-content{position:relative;max-width:90vw;max-height:90vh;animation:qrLightboxZoom .3s ease}@keyframes qrLightboxZoom{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.qr-lightbox-img{display:block;max-width:90vw;max-height:85vh;object-fit:contain;border-radius:12px;box-shadow:0 20px 60px #00000080}.qr-lightbox-close{position:absolute;top:-12px;right:-12px;width:36px;height:36px;border-radius:50%;border:none;background:#ffffff26;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;box-shadow:0 4px 12px #0000004d}.qr-lightbox-close:hover{background:#ef4444cc;transform:scale(1.1)}.numerical-premium{padding:4px 0}.numerical-input-wrap{display:flex;align-items:center;gap:10px;background:#f8fafc;border:2px solid #e2e8f0;border-radius:10px;padding:10px 14px;transition:all .25s ease}.numerical-focused .numerical-input-wrap{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f;background:#fff}.numerical-icon{color:#94a3b8;flex-shrink:0}.numerical-input{flex:1;border:none;background:transparent;font-size:16px;font-weight:500;color:#1e293b;outline:none;font-family:JetBrains Mono,Fira Code,monospace;letter-spacing:.5px}.numerical-input::placeholder{color:#94a3b8;font-weight:400;font-family:inherit}.numerical-unit{background:#e0e7ff;color:#4338ca;padding:4px 10px;border-radius:6px;font-size:13px;font-weight:600;flex-shrink:0}.numerical-clear{background:none;border:none;color:#94a3b8;cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;transition:all .2s}.numerical-clear:hover{color:#ef4444;background:#fef2f2}.numerical-hint{display:flex;align-items:center;gap:6px;margin-top:8px;font-size:12px;color:#64748b}.equation-premium{padding:4px 0}.eq-toolbar{display:flex;flex-wrap:wrap;gap:4px;align-items:center;margin-bottom:10px;padding:8px 10px;background:#f1f5f9;border-radius:8px;border:1px solid #e2e8f0}.eq-toolbar-label{font-size:11px;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-right:4px}.eq-sym-btn{background:#fff;border:1px solid #cbd5e1;border-radius:6px;padding:4px 8px;font-size:13px;cursor:pointer;color:#334155;font-weight:500;transition:all .15s;min-width:32px;text-align:center}.eq-sym-btn:hover:not(:disabled){background:#6366f1;color:#fff;border-color:#6366f1;transform:translateY(-1px)}.eq-sym-btn:disabled{opacity:.5;cursor:not-allowed}.eq-input-wrap{margin-bottom:10px}.eq-textarea{width:100%;border:2px solid #e2e8f0;border-radius:10px;padding:12px 14px;font-family:JetBrains Mono,Fira Code,monospace;font-size:14px;color:#1e293b;background:#f8fafc;resize:vertical;outline:none;transition:all .25s ease;box-sizing:border-box}.equation-focused .eq-textarea{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f;background:#fff}.eq-textarea::placeholder{color:#94a3b8}.eq-preview{background:#fefce8;border:1px solid #fde68a;border-radius:10px;padding:12px 16px;min-height:50px;position:relative}.eq-preview-error{background:#fef2f2;border-color:#fca5a5}.eq-preview-label{position:absolute;top:-8px;left:12px;background:#fefce8;padding:0 6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#a16207}.eq-preview-error .eq-preview-label{background:#fef2f2;color:#dc2626}.eq-preview-content{text-align:center;padding:8px 0;overflow-x:auto}.eq-placeholder{color:#94a3b8;font-size:14px;font-style:italic}.eq-error{color:#dc2626;font-size:13px}.eq-hint{display:flex;align-items:center;gap:6px;margin-top:8px;font-size:12px;color:#64748b}.io-stack{position:fixed;top:66px;right:14px;z-index:9998;display:flex;flex-direction:column;gap:8px;width:360px;pointer-events:none}.io-stack>*{pointer-events:auto}.io-toast{display:flex;align-items:flex-start;gap:10px;padding:11px 12px 11px 0;border-radius:10px;border:.5px solid var(--border);border-left:3px solid var(--accent);background:var(--bg);position:relative;overflow:hidden}.io-toast--enter{animation:io-slide-in .28s cubic-bezier(.34,1.2,.64,1) both}.io-toast--exit{animation:io-slide-out .25s ease forwards}@keyframes io-slide-in{0%{opacity:0;transform:translate(20px) scale(.97)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes io-slide-out{0%{opacity:1;transform:translate(0) scale(1);max-height:200px;margin-bottom:0}to{opacity:0;transform:translate(14px) scale(.96);max-height:0;margin-bottom:-8px;padding-top:0;padding-bottom:0}}.io-accent-bar{width:0;flex-shrink:0}.io-icon-circle{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;color:var(--accent)}.io-toast--low .io-icon-circle{background:#dcfce7}.io-toast--medium .io-icon-circle{background:#fef3c7}.io-toast--high .io-icon-circle{background:#ffedd5}.io-toast--critical .io-icon-circle{background:#fee2e2}.io-body{flex:1;min-width:0;padding-top:1px}.io-header-row{display:flex;align-items:center;gap:6px;margin-bottom:3px;flex-wrap:wrap}.io-severity-label{font-size:12px;font-weight:500;color:var(--text)}.io-type-tag{font-size:10px;font-weight:500;padding:1px 7px;border-radius:99px;background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--text);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.io-time{font-size:10.5px;color:#94a3b8;margin-left:auto;white-space:nowrap}.io-message{font-size:12px;color:var(--sub);line-height:1.5;margin:0}.io-tab-counter{margin-top:9px;display:flex;flex-direction:column;gap:5px}.io-pips{display:flex;gap:4px}.io-pip{height:5px;flex:1;border-radius:3px;background:#e2e8f0;transition:background .2s ease}.io-pip--filled{background:#f59e0b}.io-pip--danger{background:#ef4444}.io-pip-label{font-size:10.5px;color:var(--sub);font-weight:400}.io-dismiss{width:22px;height:22px;border-radius:50%;border:none;background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#94a3b8;transition:all .15s ease;flex-shrink:0;margin-top:2px;margin-right:2px}.io-dismiss:hover{background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--text)}.io-progress-bar{position:absolute;bottom:0;left:0;right:0;height:2px;background:transparent;overflow:hidden}.io-progress-fill{height:100%;width:100%;background:var(--accent);opacity:.45;animation:io-progress var(--duration, 8s) linear forwards;border-radius:0 2px 0 0}@keyframes io-progress{0%{width:100%}to{width:0%}}.io-badge{position:fixed;bottom:64px;left:14px;z-index:9997;display:flex;align-items:center;gap:6px;padding:6px 12px;background:#fff;border:.5px solid #e2e8f0;border-radius:99px;color:#64748b;font-size:12px;font-weight:400;cursor:pointer;transition:all .18s ease;box-shadow:0 1px 4px #0f172a0f}.io-badge:hover,.io-badge--active{background:#f8fafc;border-color:#cbd5e1;color:#1e293b;box-shadow:0 2px 8px #0f172a1a}.io-badge--critical{border-color:#fca5a5;color:#b91c1c;background:#fef2f2}.io-badge--critical:hover,.io-badge--critical.io-badge--active{border-color:#f87171;background:#fee2e2}.io-badge-pulse{width:6px;height:6px;border-radius:50%;background:#ef4444;animation:io-pulse 1.5s infinite;flex-shrink:0}@keyframes io-pulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 5px #ef444400}}.io-history-panel{position:fixed;bottom:108px;left:14px;z-index:9997;width:320px;max-height:360px;background:#fff;border:.5px solid #e2e8f0;border-radius:14px;box-shadow:0 8px 32px #0f172a1a,0 2px 8px #0f172a0f;display:flex;flex-direction:column;overflow:hidden;animation:io-panel-in .22s cubic-bezier(.34,1.2,.64,1)}@keyframes io-panel-in{0%{opacity:0;transform:translateY(10px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.io-history-header{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:.5px solid #f1f5f9;flex-shrink:0}.io-history-title{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:500;color:#1e293b;flex:1}.io-history-title svg{color:#94a3b8;flex-shrink:0}.io-history-count{font-size:10.5px;font-weight:500;padding:2px 8px;background:#f1f5f9;border-radius:99px;color:#64748b}.io-history-close{width:24px;height:24px;border-radius:50%;border:none;background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#94a3b8;transition:all .15s}.io-history-close:hover{background:#f1f5f9;color:#475569}.io-history-list{flex:1;overflow-y:auto;padding:4px 0}.io-history-list::-webkit-scrollbar{width:3px}.io-history-list::-webkit-scrollbar-track{background:transparent}.io-history-list::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:99px}.io-history-item{display:flex;align-items:flex-start;gap:10px;padding:9px 14px;border-bottom:.5px solid #f8fafc;transition:background .12s}.io-history-item:hover{background:#f8fafc}.io-history-item:last-child{border-bottom:none}.io-history-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:4px}.io-history-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.io-history-type{font-size:10.5px;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.io-history-msg{font-size:11.5px;color:#64748b;line-height:1.4}.io-history-time{font-size:10px;color:#94a3b8;flex-shrink:0;white-space:nowrap;margin-top:2px}.io-history-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:28px 16px;color:#94a3b8;font-size:12px}.io-history-empty svg{opacity:.5}@media(max-width:480px){.io-stack{right:8px;left:8px;width:auto}.io-history-panel{left:8px;right:8px;width:auto}}:root{--font-body: "DM Sans", system-ui, sans-serif;--font-display: "Syne", sans-serif;--blue: #3b82f6;--blue-soft: rgba(59, 130, 246, .08);--blue-border: rgba(59, 130, 246, .2);--indigo: #6366f1;--indigo-soft: rgba(99, 102, 241, .08);--indigo-border: rgba(99, 102, 241, .2);--green: #22c55e;--green-soft: rgba(34, 197, 94, .09);--green-border: rgba(34, 197, 94, .2);--amber: #f59e0b;--amber-soft: rgba(245, 158, 11, .09);--amber-border: rgba(245, 158, 11, .2);--red: #ef4444;--red-soft: rgba(239, 68, 68, .08);--red-border: rgba(239, 68, 68, .2);--surface: #ffffff;--surface-2: #f8fafc;--border: #e9eef4;--bg: #eef2f7;--text-1: #0f172a;--text-2: #64748b;--text-3: #94a3b8;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--shadow-sm: 0 1px 3px rgba(15, 23, 42, .05), 0 1px 6px rgba(15, 23, 42, .03);--shadow-md: 0 4px 16px rgba(15, 23, 42, .07), 0 1px 4px rgba(15, 23, 42, .04)}.cep-fullscreen-state{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;font-family:var(--font-body);font-size:15px;color:var(--text-2);background:var(--bg)}.cep-error-state{color:var(--red)}.cep-spinner{width:30px;height:30px;border:2.5px solid var(--border);border-top-color:var(--indigo);border-radius:50%;animation:cep-spin .65s linear infinite}@keyframes cep-spin{to{transform:rotate(360deg)}}.cep-root{font-family:var(--font-body);background:var(--bg);min-height:100vh;display:flex;flex-direction:column;color:var(--text-1)}.cep-topbar{display:flex;justify-content:space-between;align-items:center;padding:0 22px;height:56px;background:var(--surface);border-bottom:.5px solid var(--border);position:sticky;top:0;z-index:50;gap:16px}.cep-topbar-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.cep-exam-badge{width:30px;height:30px;border-radius:8px;background:var(--indigo-soft);border:.5px solid var(--indigo-border);display:flex;align-items:center;justify-content:center;color:var(--indigo);flex-shrink:0}.cep-exam-title{font-family:var(--font-display);font-size:14.5px;font-weight:700;color:var(--text-1);letter-spacing:-.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cep-topbar-center{display:flex;align-items:center;justify-content:center;flex-shrink:0}.cep-timer{display:flex;align-items:center;gap:7px;padding:6px 16px;background:var(--surface-2);border:.5px solid var(--border);border-radius:999px;color:var(--text-2);font-size:12.5px;transition:all .3s ease}.cep-timer-value{font-family:var(--font-display);font-size:17px;font-weight:700;color:var(--text-1);letter-spacing:-.3px;min-width:52px;text-align:center}.cep-timer-low{background:var(--red-soft);border-color:var(--red-border);color:var(--red)}.cep-timer-low .cep-timer-value{color:var(--red);animation:cep-blink 1s infinite}@keyframes cep-blink{0%,to{opacity:1}50%{opacity:.5}}.cep-timer-warn-dot{width:7px;height:7px;border-radius:50%;background:var(--red);animation:cep-pulse 1.2s infinite}@keyframes cep-pulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 5px #ef444400}}.cep-topbar-right{flex-shrink:0;display:flex;align-items:center;gap:8px}.cep-proctor-badge{display:flex;align-items:center;gap:7px;padding:5px 13px;background:var(--red-soft);border:.5px solid var(--red-border);border-radius:999px;font-size:12px;font-weight:500;color:#b91c1c;white-space:nowrap}.cep-proctor-dot{width:6px;height:6px;border-radius:50%;background:var(--red);animation:cep-pulse 1.5s infinite}.cep-rec-badge{display:flex;align-items:center;gap:6px;padding:5px 12px;background:#ef44441f;border:1px solid rgba(239,68,68,.3);border-radius:999px;font-size:11px;font-weight:700;color:#dc2626;letter-spacing:.08em;white-space:nowrap;animation:cep-rec-glow 2s ease-in-out infinite}.cep-rec-dot{width:7px;height:7px;border-radius:50%;background:#dc2626;animation:cep-rec-blink 1s ease-in-out infinite}@keyframes cep-rec-blink{0%,to{opacity:1}50%{opacity:.3}}@keyframes cep-rec-glow{0%,to{box-shadow:0 0 #ef444400}50%{box-shadow:0 0 8px 2px #ef444426}}.cep-timer-bar{height:2.5px;background:var(--border);position:sticky;top:56px;z-index:49}.cep-timer-fill{height:100%;background:linear-gradient(to right,var(--indigo),var(--blue));transition:width 1s linear;border-radius:0 2px 2px 0}.cep-fill-low{background:linear-gradient(to right,var(--red),#f97316)}.cep-body{display:grid;grid-template-columns:1fr 288px;gap:16px;padding:16px 18px;flex:1;align-items:start}.cep-question-panel{display:flex;flex-direction:column;gap:14px}.cep-question-card{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:26px 28px;box-shadow:var(--shadow-sm);animation:cep-fade .22s ease both}@keyframes cep-fade{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}.cep-question-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.cep-qnum{display:flex;flex-direction:column;gap:1px}.cep-qnum-label{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3)}.cep-qnum-val{font-family:var(--font-display);font-size:22px;font-weight:800;color:var(--text-1);letter-spacing:-.5px;line-height:1}.cep-qnum-total{font-size:14px;font-weight:600;color:var(--text-3)}.cep-marked-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:999px;background:var(--amber-soft);border:.5px solid var(--amber-border);color:#b45309;font-size:11.5px;font-weight:500}.cep-question-text{font-size:16.5px;font-weight:500;color:var(--text-1);line-height:1.65;margin-bottom:22px}.cep-options{display:flex;flex-direction:column;gap:9px}.cep-option{display:flex;align-items:center;gap:12px;padding:13px 15px;border-radius:var(--radius-md);border:.5px solid var(--border);background:var(--surface-2);cursor:pointer;text-align:left;transition:all .16s ease;font-family:var(--font-body);font-size:14px;color:var(--text-1);position:relative}.cep-option:hover{border-color:var(--indigo-border);background:var(--indigo-soft)}.cep-option-selected{border-color:var(--indigo)!important;border-width:1px!important;background:var(--indigo-soft)!important;color:var(--indigo)!important;font-weight:500}.cep-option-letter{width:28px;height:28px;border-radius:7px;background:var(--surface);border:.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--text-2);flex-shrink:0;transition:all .16s ease}.cep-option-selected .cep-option-letter{background:var(--indigo);border-color:var(--indigo);color:#fff}.cep-option-text{flex:1}.cep-option-check{color:var(--indigo);flex-shrink:0}.cep-text-answer{width:100%;min-height:140px;padding:14px 16px;border-radius:var(--radius-md);border:.5px solid var(--border);background:var(--surface-2);font-family:var(--font-body);font-size:14px;color:var(--text-1);resize:vertical;outline:none;transition:all .16s ease;line-height:1.6}.cep-text-answer:focus{border-color:var(--indigo);border-width:1px;background:var(--surface);box-shadow:0 0 0 3px var(--indigo-soft)}.cep-text-answer::placeholder{color:var(--text-3)}.cep-proctor-panel{display:flex;flex-direction:column;gap:10px;position:sticky;top:74px}.cep-camera-box{width:100%;aspect-ratio:4/3;background:#0f172a;border-radius:var(--radius-lg);overflow:hidden;position:relative;border:.5px solid rgba(255,255,255,.07);box-shadow:var(--shadow-sm);transition:border-color .3s ease,box-shadow .3s ease}.cep-camera-box video{width:100%;height:100%;object-fit:cover}.cep-face-warning{border-color:var(--red)!important;box-shadow:0 0 0 3px var(--red-soft),0 0 18px #ef444440!important}.cep-cam-overlay{position:absolute;bottom:8px;left:8px}.cep-cam-indicator{display:inline-flex;align-items:center;gap:6px;background:#00000085;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:400}.cep-cam-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:cep-pulse 1.8s infinite}.cep-face-alert{position:absolute;top:8px;left:8px;right:8px;display:flex;align-items:center;gap:6px;background:#ef4444d9;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff;padding:6px 10px;border-radius:8px;font-size:11.5px;font-weight:500}.cep-stats-row{display:flex;align-items:center;background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-md);padding:11px 12px;box-shadow:var(--shadow-sm)}.cep-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px}.cep-stat-val{font-family:var(--font-display);font-size:18px;font-weight:800;letter-spacing:-.4px;line-height:1}.cep-stat-green{color:var(--green)}.cep-stat-amber{color:var(--amber)}.cep-stat-gray{color:var(--text-3)}.cep-stat-label{font-size:10px;color:var(--text-3);font-weight:500}.cep-stat-divider{width:.5px;height:28px;background:var(--border)}.cep-nav-wrap{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-md);padding:13px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:10px;max-height:280px;overflow:hidden}.cep-nav-header{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);flex-shrink:0}.cep-navigator{display:grid;grid-template-columns:repeat(auto-fill,minmax(30px,1fr));gap:5px;overflow-y:auto}.cep-navigator::-webkit-scrollbar{width:3px}.cep-navigator::-webkit-scrollbar-track{background:transparent}.cep-navigator::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}.cep-nav-btn{height:30px;border-radius:6px;border:.5px solid var(--border);background:var(--surface-2);font-family:var(--font-body);font-size:11.5px;font-weight:400;color:var(--text-2);cursor:pointer;transition:all .13s ease;display:flex;align-items:center;justify-content:center}.cep-nav-btn:hover{border-color:#cbd5e1;background:var(--surface)}.cep-nav-current{border-color:var(--indigo)!important;border-width:1px!important;background:var(--indigo-soft)!important;color:var(--indigo)!important;font-weight:600}.cep-nav-answered{background:var(--green-soft)!important;border-color:var(--green-border)!important;color:#15803d!important}.cep-nav-marked{background:var(--amber-soft)!important;border-color:var(--amber-border)!important;color:#b45309!important}.cep-legend{display:flex;gap:10px;flex-wrap:wrap;flex-shrink:0}.cep-leg-item{display:flex;align-items:center;gap:5px;font-size:10.5px;color:var(--text-3)}.cep-leg-dot{width:8px;height:8px;border-radius:3px;flex-shrink:0}.cep-leg-answered{background:var(--green)}.cep-leg-marked{background:var(--amber)}.cep-leg-current{background:var(--indigo)}.cep-sections-nav{display:flex;flex-direction:column;gap:10px;overflow-y:auto}.cep-section-group{display:flex;flex-direction:column;gap:6px}.cep-section-label{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--indigo);padding:3px 9px;background:var(--indigo-soft);border-radius:6px;border:.5px solid var(--indigo-border)}.cep-proctor-status{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-md);padding:11px 13px;display:flex;flex-direction:column;gap:8px;box-shadow:var(--shadow-sm)}.cep-ps-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-2)}.cep-ps-row svg{color:var(--text-3);flex-shrink:0}.cep-ps-row span:nth-child(2){flex:1}.cep-ps-status{font-size:10.5px;font-weight:600;padding:2px 8px;border-radius:999px}.cep-ps-ok{background:var(--green-soft);color:#15803d;border:.5px solid var(--green-border)}.cep-footer{display:flex;align-items:center;gap:12px;padding:11px 18px;background:var(--surface);border-top:.5px solid var(--border);position:sticky;bottom:0;z-index:40}.cep-footer-left{flex:1}.cep-footer-center{display:flex;align-items:center;gap:10px}.cep-footer-right{flex:1;display:flex;justify-content:flex-end}.cep-footer-qcount{font-family:var(--font-display);font-size:13.5px;font-weight:700;color:var(--text-2);min-width:52px;text-align:center;letter-spacing:-.2px}.cep-btn-mark{display:inline-flex;align-items:center;gap:7px;padding:7px 14px;border-radius:var(--radius-sm);border:.5px solid var(--border);background:var(--surface);font-family:var(--font-body);font-size:12.5px;font-weight:400;color:var(--text-2);cursor:pointer;transition:all .16s ease}.cep-btn-mark:hover{background:var(--amber-soft);border-color:var(--amber-border);color:#b45309}.cep-btn-marked{background:var(--amber-soft)!important;border-color:var(--amber-border)!important;color:#b45309!important}.cep-btn-nav{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border-radius:var(--radius-sm);border:.5px solid var(--border);background:var(--surface);font-family:var(--font-body);font-size:13px;font-weight:400;color:var(--text-1);cursor:pointer;transition:all .16s ease}.cep-btn-nav:hover:not(:disabled){background:var(--surface-2);border-color:#cbd5e1}.cep-btn-nav:disabled{opacity:.32;cursor:not-allowed}.cep-btn-end{display:inline-flex;align-items:center;gap:7px;padding:8px 18px;border-radius:var(--radius-sm);border:none;background:var(--text-1);color:#fff;font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;transition:all .16s ease}.cep-btn-end:hover{background:#1e293b;transform:translateY(-1px);box-shadow:0 4px 12px #0f172a2e}.cep-btn-end:active{transform:none}.cep-modal-overlay{position:fixed;inset:0;background:#0f172a73;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:cep-overlay-in .2s ease}@keyframes cep-overlay-in{0%{opacity:0}to{opacity:1}}.cep-modal{background:var(--surface);border-radius:var(--radius-lg);padding:30px 26px;width:380px;max-width:92vw;display:flex;flex-direction:column;align-items:center;gap:14px;box-shadow:0 20px 50px #0f172a2e;animation:cep-modal-in .26s cubic-bezier(.34,1.56,.64,1)}@keyframes cep-modal-in{0%{opacity:0;transform:scale(.92) translateY(10px)}to{opacity:1;transform:none}}.cep-modal-icon{width:56px;height:56px;border-radius:14px;background:var(--indigo-soft);border:.5px solid var(--indigo-border);display:flex;align-items:center;justify-content:center;color:var(--indigo)}.cep-modal-title{font-family:var(--font-display);font-size:19px;font-weight:800;color:var(--text-1);letter-spacing:-.3px;text-align:center}.cep-modal-body{font-size:13.5px;color:var(--text-2);text-align:center;line-height:1.65}.cep-modal-body strong{color:var(--text-1);font-weight:600}.cep-modal-actions{display:flex;gap:10px;width:100%;margin-top:4px}.cep-btn-cancel{flex:1;padding:10px;border-radius:var(--radius-sm);border:.5px solid var(--border);background:var(--surface);font-family:var(--font-body);font-size:13px;font-weight:400;color:var(--text-2);cursor:pointer;transition:all .16s ease}.cep-btn-cancel:hover{background:var(--surface-2);color:var(--text-1)}.cep-btn-confirm{flex:1;padding:10px;border-radius:var(--radius-sm);border:none;background:var(--text-1);color:#fff;font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;transition:all .16s ease}.cep-btn-confirm:hover{background:#1e293b;box-shadow:0 4px 12px #0f172a2e}.cep-state-terminated{background:#0f0505}.cep-terminated-icon{width:72px;height:72px;border-radius:18px;background:#ef44441a;border:.5px solid rgba(239,68,68,.2);display:flex;align-items:center;justify-content:center}.cep-terminated-title{font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:#fca5a5;margin:0}.cep-terminated-body{color:#94a3b8;max-width:380px;text-align:center;line-height:1.65;font-size:14px;margin:0}.cep-terminated-sub{color:#475569;font-size:12px;margin:0}.cep-fs-overlay{background:#000000e0!important;z-index:9999!important}.cep-fs-modal{border:.5px solid rgba(239,68,68,.4)!important;text-align:center}.cep-fs-icon{width:60px;height:60px;border-radius:14px;background:#ef44441a;border:.5px solid rgba(239,68,68,.25);display:flex;align-items:center;justify-content:center;color:#ef4444}.cep-fs-title{color:#ef4444!important}.cep-btn-fs{width:100%;background:#ef4444!important;box-shadow:none!important}.cep-btn-fs:hover{background:#dc2626!important;box-shadow:0 4px 12px #ef444440!important}@media(max-width:900px){.cep-body{grid-template-columns:1fr}.cep-proctor-panel{position:static;display:grid;grid-template-columns:1fr 1fr;gap:10px}.cep-camera-box{grid-column:span 2}}@media(max-width:560px){.cep-topbar{padding:0 14px}.cep-exam-title{display:none}.cep-footer{padding:10px 14px}.cep-btn-mark span{display:none}.cep-proctor-panel{grid-template-columns:1fr}.cep-camera-box{grid-column:1}}.system-check-container{padding:40px;max-width:1100px;margin:auto;font-family:Segoe UI,sans-serif}.system-check-header{text-align:center;margin-bottom:30px}.system-check-header h2{font-size:28px;margin-bottom:8px}.system-check-header p{color:#666}.system-check-banner{background:#1f8f7a;border-radius:10px;padding:30px;color:#fff;margin-bottom:40px}.banner-text h3{margin-bottom:15px}.banner-text ul{list-style:none;padding:0}.banner-text li{margin-bottom:8px}.system-check-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.step-card{background:#fff;border-radius:12px;padding:25px;text-align:center;box-shadow:0 6px 18px #00000014}.step-number{display:inline-block;background:#f4b400;color:#000;width:36px;height:36px;line-height:36px;border-radius:50%;font-weight:700;margin-bottom:10px}.system-check-action{text-align:center;margin-top:40px}.proceed-btn{background:#f4b400;border:none;padding:14px 36px;font-size:16px;border-radius:8px;cursor:pointer;font-weight:600}.proceed-btn:hover{background:#e0a800}.device-check-container{padding:40px;max-width:1000px;margin:auto;font-family:Segoe UI,sans-serif;text-align:center}.camera-preview{width:320px;height:240px;margin:20px auto 30px;background:#000;border-radius:10px;overflow:hidden}.camera-preview video{width:100%;height:100%;object-fit:cover}.check-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:20px}.check-card{background:#fff;padding:20px;border-radius:12px;box-shadow:0 6px 16px #00000014}.check-card h4{margin-bottom:10px}.success{color:#1e8e3e;font-weight:600}.error{color:#d93025;font-weight:600}.device-check-action{margin-top:40px}.continue-btn{padding:14px 36px;font-size:16px;border-radius:8px;border:none;background:#f4b400;font-weight:700;cursor:pointer}.continue-btn:disabled{background:#ccc;cursor:not-allowed}.seb-gateway{min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);display:flex;align-items:center;justify-content:center;padding:40px 20px;font-family:Inter,system-ui,-apple-system,sans-serif}.seb-gateway-card{background:#1e293b;border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:48px 40px;max-width:640px;width:100%;text-align:center;box-shadow:0 25px 50px #0006}.seb-gateway-icon{width:100px;height:100px;margin:0 auto 24px;background:#2563eb1f;border-radius:50%;display:flex;align-items:center;justify-content:center}.seb-gateway-title{font-size:26px;font-weight:800;color:#f1f5f9;margin:0 0 12px;letter-spacing:-.02em}.seb-gateway-subtitle{font-size:15px;color:#94a3b8;line-height:1.6;max-width:480px;margin:0 auto 36px}.seb-gateway-steps{text-align:left;display:flex;flex-direction:column;gap:20px;margin-bottom:36px}.seb-step{display:flex;gap:16px;align-items:flex-start}.seb-step-num{width:36px;height:36px;min-width:36px;border-radius:50%;background:#2563eb26;color:#60a5fa;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;margin-top:2px}.seb-step-content h3{margin:0 0 4px;font-size:15px;font-weight:700;color:#e2e8f0}.seb-step-content p{margin:0;font-size:13px;color:#94a3b8;line-height:1.5}.seb-download-link{display:inline-flex;align-items:center;gap:6px;margin-top:8px;font-size:13px;font-weight:600;color:#60a5fa;text-decoration:none;transition:color .2s}.seb-download-link:hover{color:#93bbfd}.seb-gateway-actions{display:flex;flex-direction:column;gap:12px;margin-bottom:28px}.seb-launch-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:16px 28px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff!important;border:none;border-radius:12px;font-size:15px;font-weight:700;text-decoration:none;cursor:pointer;transition:all .25s;box-shadow:0 4px 16px #2563eb59}.seb-launch-btn:hover{transform:translateY(-2px);box-shadow:0 6px 24px #2563eb80}.seb-retry-btn{padding:12px 24px;background:transparent;border:1px solid rgba(255,255,255,.12);color:#94a3b8;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.seb-retry-btn:hover{background:#ffffff0d;border-color:#fff3;color:#e2e8f0}.seb-retry-btn:disabled{opacity:.5;cursor:not-allowed}.seb-gateway-info{display:flex;align-items:flex-start;gap:10px;background:#2563eb14;border:1px solid rgba(37,99,235,.15);border-radius:10px;padding:14px 16px;text-align:left}.seb-gateway-info svg{min-width:16px;margin-top:2px;color:#60a5fa}.seb-gateway-info span{font-size:12px;color:#94a3b8;line-height:1.5}@media(max-width:640px){.seb-gateway-card{padding:32px 24px}.seb-gateway-title{font-size:22px}}.waiting-room-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#f0f4f8;color:#1e293b;font-family:DM Sans,-apple-system,system-ui,sans-serif;padding:20px;position:relative;overflow:hidden}.waiting-room-container:before{content:"";position:absolute;inset:0;background-image:radial-gradient(#cbd5e1 .5px,transparent .5px);background-size:24px 24px;opacity:.4;pointer-events:none;z-index:0}.wr-ambient-glow{position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(59,130,246,.08) 0%,transparent 70%);border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);filter:blur(60px);z-index:0;pointer-events:none}.waiting-box{background:#fff;border:1px solid #e2e8f0;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;border-radius:20px;padding:48px;text-align:center;max-width:480px;width:100%;z-index:1;position:relative;animation:wr-box-enter .5s cubic-bezier(.16,1,.3,1) forwards}@keyframes wr-box-enter{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.waiting-box h2{font-size:26px;font-weight:700;margin-bottom:12px;color:#0f172a}.waiting-box p.muted{font-size:15px;color:#64748b;line-height:1.6;margin-bottom:24px}.wr-snapshot-wrap{position:relative;width:100%;border-radius:16px;overflow:hidden;margin-top:24px;border:1px solid #e2e8f0;background:#000;box-shadow:0 4px 6px -1px #0000001a}.snapshot-preview{display:block;width:100%;height:280px;object-fit:cover;transform:scaleX(-1)}.wr-scanning-line{position:absolute;top:0;left:0;width:100%;height:3px;background:#3b82f6;box-shadow:0 0 15px 3px #3b82f699;animation:wr-scan 2.5s ease-in-out infinite alternate;z-index:2}@keyframes wr-scan{0%{top:0}to{top:calc(100% - 3px)}}.wr-radar-container{position:relative;width:100px;height:100px;margin:0 auto 32px;display:flex;align-items:center;justify-content:center}.wr-radar-core{width:24px;height:24px;background:#3b82f6;border-radius:50%;box-shadow:0 0 20px #3b82f680;position:relative;z-index:2}.wr-radar-wave{position:absolute;width:100%;height:100%;border-radius:50%;border:2px solid #3b82f6;opacity:0;animation:wr-ripple 2s cubic-bezier(.16,1,.3,1) infinite}.wr-radar-wave:nth-child(2){animation-delay:.6s}.wr-radar-wave:nth-child(3){animation-delay:1.2s}@keyframes wr-ripple{0%{transform:scale(.3);opacity:.8}to{transform:scale(1.6);opacity:0}}.wr-status-icon-wrap{width:84px;height:84px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 28px;animation:wr-pop .5s cubic-bezier(.175,.885,.32,1.275) forwards}@keyframes wr-pop{0%{transform:scale(0)}to{transform:scale(1)}}.wr-status-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.wr-status-success svg{width:44px;height:44px}.wr-status-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.wr-status-error svg{width:44px;height:44px}.wr-btn-return{display:inline-flex;align-items:center;justify-content:center;gap:10px;margin-top:10px;background:#1e293b;color:#fff;font-weight:600;padding:14px 24px;border-radius:10px;border:none;cursor:pointer;transition:all .2s;width:100%;font-family:inherit}.wr-btn-return:hover{background:#334155;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.ss-sidebar{font-family:DM Sans,sans-serif;width:260px;height:100vh;background:#080c14;display:flex;flex-direction:column;position:relative;overflow:hidden;border-right:1px solid rgba(255,255,255,.04);transition:width .3s cubic-bezier(.4,0,.2,1)}.ss-sidebar.collapsed{width:72px}.ss-sidebar:before{content:"";position:absolute;top:-80px;left:-80px;width:240px;height:240px;background:radial-gradient(circle,rgba(99,102,241,.12) 0%,transparent 70%);pointer-events:none}.ss-sidebar:after{content:"";position:absolute;bottom:0;right:-60px;width:180px;height:180px;background:radial-gradient(circle,rgba(16,185,129,.07) 0%,transparent 70%);pointer-events:none}.ss-collapse-btn{position:absolute;top:22px;right:-12px;width:24px;height:24px;background:#1e293b;border:1px solid rgba(255,255,255,.08);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .2s ease;color:#64748b}.ss-collapse-btn:hover{background:#334155;color:#fff;transform:scale(1.1)}.ss-collapse-btn svg{width:12px;height:12px;transition:transform .3s ease}.ss-sidebar.collapsed .ss-collapse-btn svg{transform:rotate(180deg)}.ss-header{padding:24px 20px 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid rgba(255,255,255,.05);min-height:80px;overflow:hidden}.ss-sidebar.collapsed .ss-header{padding:20px 0;justify-content:center}.ss-logo-wrap{flex-shrink:0;cursor:pointer}.ss-logo{width:50%;height:50%;object-fit:contain;border-radius:8px;display:block}.ss-brand{overflow:hidden;white-space:nowrap;transition:opacity .2s ease,max-width .3s ease;opacity:1;max-width:200px}.ss-sidebar.collapsed .ss-brand{opacity:0;max-width:0}.ss-brand-name{font-family:Syne,sans-serif;font-size:15px;font-weight:700;color:#fff;letter-spacing:-.3px;line-height:1}.ss-brand-sub{font-size:20.5px;color:#21262d;font-weight:400;letter-spacing:.04em;margin-top:2px;text-transform:uppercase}.ss-clock-wrap{padding:12px 12px 0}.ss-sidebar.collapsed .ss-clock-wrap{display:none}.ss-clock{padding:10px 14px;background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:10px;display:flex;align-items:center;justify-content:space-between}.ss-clock-time{font-family:Syne,sans-serif;font-size:24px;font-weight:600;color:#080c14;letter-spacing:-.5px}.ss-clock-day{color:#94a3b8;font-size:11px;font-weight:500;text-align:right}.ss-clock-date{font-size:10.5px;color:#475569;text-align:right}.ss-status-row{display:flex;align-items:center;gap:7px;padding:10px 20px 4px;font-size:11px;color:#475569}.ss-sidebar.collapsed .ss-status-row{display:none}.ss-status-dot{width:6px;height:6px;border-radius:50%;background:#10b981;box-shadow:0 0 6px #10b98199;flex-shrink:0;animation:pulse-dot 2s infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.ss-section-label{font-size:9.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#334155;padding:14px 20px 6px;transition:opacity .2s ease}.ss-sidebar.collapsed .ss-section-label{opacity:0;height:0;padding:0;overflow:hidden}.ss-nav{display:flex;flex-direction:column;gap:2px;padding:8px 12px;flex-grow:1}.ss-sidebar.collapsed .ss-nav{padding:8px 10px}.ss-nav a{text-decoration:none;padding:10px 12px;border-radius:8px;font-size:13.5px;font-weight:500;display:flex;align-items:center;gap:11px;transition:all .18s ease;position:relative;overflow:visible}.ss-sidebar.collapsed .ss-nav a{justify-content:center;padding:10px 0}.ss-nav a:before{content:"";position:absolute;inset:0;border-radius:8px;background:#6366f11a;opacity:0;transition:opacity .18s ease}.ss-nav a:hover{color:#070708}.ss-nav a:hover:before{opacity:1}.ss-nav a.active{color:#000;background:linear-gradient(135deg,#6366f133,#8b5cf626);border:1px solid rgba(99,102,241,.25)}.ss-nav a.active:before{display:none}.ss-nav a.active:after{content:"";position:absolute;left:0;top:25%;height:50%;width:3px;background:linear-gradient(to bottom,#818cf8,#6366f1);border-radius:0 2px 2px 0}.ss-nav-icon{width:18px;height:18px;flex-shrink:0}.ss-nav-label{flex:1;white-space:nowrap;overflow:hidden;transition:opacity .2s ease,max-width .3s ease;opacity:1;max-width:200px}.ss-sidebar.collapsed .ss-nav-label{opacity:0;max-width:0}.ss-nav-badge{font-size:10px;font-weight:600;background:#6366f133;color:#818cf8;border-radius:20px;padding:2px 7px;border:1px solid rgba(99,102,241,.2);flex-shrink:0;transition:opacity .2s ease}.ss-sidebar.collapsed .ss-nav-badge{opacity:0;display:none}.ss-tooltip{position:absolute;left:calc(100% + 12px);top:50%;transform:translateY(-50%);background:#1e293b;color:#e2e8f0;font-size:12px;font-weight:500;padding:5px 10px;border-radius:6px;white-space:nowrap;pointer-events:none;opacity:0;display:none;border:1px solid rgba(255,255,255,.08);box-shadow:0 4px 12px #0006;z-index:100}.ss-sidebar.collapsed .ss-nav a:hover .ss-tooltip{opacity:1;display:block}.ss-footer{padding:12px 12px 16px;border-top:1px solid rgba(255,255,255,.05)}.ss-sidebar.collapsed .ss-footer{padding:12px 10px}.ss-user-card{display:flex;align-items:center;gap:10px;padding:10px;border-radius:8px;background:#ffffff08;border:1px solid rgba(255,255,255,.05);margin-bottom:8px;cursor:pointer;transition:background .18s ease}.ss-sidebar.collapsed .ss-user-card{display:none}.ss-user-card:hover{background:#ffffff0d}.ss-avatar{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;font-family:Syne,sans-serif;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}.ss-user-info{flex:1;overflow:hidden}.ss-user-name{font-size:12.5px;font-weight:600;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ss-user-role{font-size:10.5px;color:#475569;margin-top:1px}.ss-user-chevron{width:14px;height:14px;color:#334155;flex-shrink:0}.ss-logout-btn{width:100%;padding:9px 12px;border:1px solid rgba(239,68,68,.15);border-radius:8px;background:transparent;color:#ef4444;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .18s ease;display:flex;align-items:center;gap:9px;position:relative;overflow:hidden}.ss-sidebar.collapsed .ss-logout-btn{justify-content:center;padding:10px 0}.ss-logout-btn:before{content:"";position:absolute;inset:0;background:#ef444414;opacity:0;transition:opacity .18s ease}.ss-logout-btn:hover{border-color:#ef444459;color:#fca5a5}.ss-logout-btn:hover:before{opacity:1}.ss-logout-icon{width:15px;height:15px;flex-shrink:0}.ss-logout-label{transition:opacity .2s ease,max-width .3s ease;opacity:1;max-width:200px;overflow:hidden;white-space:nowrap}.ss-sidebar.collapsed .ss-logout-label{opacity:0;max-width:0}.student-sidebar .sidebar-header{display:flex;justify-content:center;align-items:center;padding:20px 12px;border-bottom:1px solid #e5e7eb}.student-layout{display:flex;height:100vh;background-color:#f8fafc;overflow:hidden;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont;color:#0f172a}.student-layout>*:first-child{width:260px;background:#fff;border-right:1px solid #e5e7eb;flex-shrink:0;display:flex;flex-direction:column}.student-right{flex:1;display:flex;flex-direction:column;overflow:hidden}.student-right>*:first-child{height:64px;background:#fff;border-bottom:1px solid #e5e7eb;flex-shrink:0;display:flex;align-items:center}.student-main{flex:1;overflow-y:auto;padding:24px}.student-main::-webkit-scrollbar{width:6px}.student-main::-webkit-scrollbar-thumb{background-color:#cbd5f5;border-radius:4px}button{font-family:inherit}a{text-decoration:none;color:inherit}.student-main h2{font-size:18px;font-weight:600;color:#0f172a;margin-top:32px;margin-bottom:12px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.muted{font-size:14px;color:#64748b}.quick-exams{list-style:none;padding:0;margin:12px 0 0;display:flex;flex-direction:column;gap:10px}.quick-exams li{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:14px 16px;display:flex;align-items:center;justify-content:space-between;transition:all .2s ease}.quick-exams li:hover{background:#f8fafc}.quick-exams span{font-size:14px;font-weight:500;color:#0f172a}.quick-exams a{font-size:13px;font-weight:500;color:#2563eb;text-decoration:none;padding:6px 12px;border-radius:8px;background:#eff6ff;transition:background .2s ease}.quick-exams a:hover{background:#dbeafe}.student-main h1{font-size:22px;font-weight:600;color:#0f172a;margin-bottom:4px}.subtitle{font-size:14px;color:#64748b;margin-bottom:24px}.exam-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:1px solid #e5e7eb}.exam-tabs button{padding:8px 14px;border:none;background:transparent;font-size:14px;font-weight:500;color:#64748b;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s ease}.exam-tabs button:hover{color:#0f172a}.exam-tabs button.active{color:#2563eb;border-bottom-color:#2563eb;font-weight:600}.exam-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.exam-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:18px;display:flex;flex-direction:column;gap:12px;position:relative;transition:all .2s ease}.exam-card:hover{box-shadow:0 10px 28px #0f172a0f;transform:translateY(-2px)}.exam-badge{position:absolute;top:14px;right:14px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px}.exam-badge.active{background:#dcfce7;color:#166534}.exam-badge.completed{background:#e0e7ff;color:#3730a3}.exam-badge.expired{background:#fee2e2;color:#991b1b}.exam-badge.upcoming{background:#fef3c7;color:#92400e}.exam-card h3{font-size:16px;font-weight:600;color:#0f172a;margin-right:60px}.exam-desc{font-size:13px;color:#64748b;line-height:1.4}.exam-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:13px;color:#475569}.exam-progress{height:6px;background:#f1f5f9;border-radius:999px;overflow:hidden}.progress-bar{height:100%;background:#2563eb;border-radius:999px}.progress-text{font-size:12px;color:#64748b}.exam-card button{margin-top:auto;padding:10px;border-radius:10px;border:none;font-size:14px;font-weight:500;cursor:pointer;background:#2563eb;color:#fff;transition:background .2s ease}.exam-card button:hover{background:#1d4ed8}.exam-card button:disabled{background:#e5e7eb;color:#94a3b8;cursor:not-allowed}.student-topbar{height:64px;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;padding:0 24px}.topbar-left h3{font-size:16px;font-weight:600;color:#0f172a}.topbar-right{display:flex;align-items:center}.user-info{display:flex;align-items:center;gap:12px}.avatar{width:36px;height:36px;border-radius:50%;background:#2563eb;color:#fff;font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center}.user-info .name{font-size:14px;font-weight:500;color:#0f172a;line-height:1.2}.user-info .email{font-size:12px;color:#64748b}.dashboard-container{padding:28px;background:#f3f5f9;min-height:100vh;font-family:Inter,sans-serif}.dashboard-header{margin-bottom:20px}.dashboard-header h1{font-size:22px;font-weight:600;color:#1e293b;margin-bottom:4px}.dashboard-header p{font-size:13px;color:#64748b}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px;margin-bottom:20px}.stat-card{position:relative;background:#fff;padding:18px 20px;border-radius:14px;border:1px solid #e5e7eb;box-shadow:0 6px 16px #0000000a;transition:all .25s ease;overflow:hidden}.stat-card:hover{transform:translateY(-3px);box-shadow:0 10px 24px #00000014}.stat-card:before{content:"";position:absolute;top:0;left:0;height:4px;width:100%;background:linear-gradient(90deg,#3b82f6,#8b5cf6,#ec4899)}.stat-title{font-size:12px;font-weight:600;color:#64748b;margin-bottom:8px;text-transform:uppercase;letter-spacing:.6px}.stat-value{font-size:22px;font-weight:700;color:#111827}.stat-suffix{font-size:13px;margin-left:3px;color:#6b7280}.kpi-tag{display:inline-block;margin-top:10px;padding:4px 8px;font-size:11px;background:#eef2ff;color:#4f46e5;border-radius:6px;font-weight:500}.performance-section{margin-top:10px;background:#fff;padding:18px;border-radius:14px;border:1px solid #e5e7eb;box-shadow:0 6px 16px #0000000a}.performance-section h2{font-size:16px;font-weight:600;margin-bottom:10px;color:#1e293b}.performance-box p{font-size:13px;margin-bottom:6px;color:#475569}.success{color:#16a34a;font-weight:500}.warning{color:#d97706;font-weight:500}.muted{color:#6b7280}.loader{padding:40px;text-align:center;font-size:14px}.error{padding:14px;background:#fee2e2;color:#b91c1c;border-radius:8px}.results-page{padding:32px;background-color:#f4f7fb;min-height:100vh;font-family:Inter,system-ui,-apple-system,sans-serif}.results-header-block{margin-bottom:32px;padding-bottom:16px;border-bottom:2px solid #e2e8f0}.results-header-block h1{font-size:28px;font-weight:700;color:#1e293b;margin-bottom:8px;letter-spacing:-.5px}.results-header-block p{font-size:15px;color:#64748b;margin-top:4px}.results-loading{padding:60px;text-align:center;color:#3b82f6;font-weight:500;font-size:1.1rem}.results-empty{background:#fff;padding:48px 32px;border-radius:16px;text-align:center;color:#64748b;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;border:1px solid #e2e8f0;font-size:16px}.results-card{background:#fff;border-radius:16px;box-shadow:0 10px 25px -5px #0000000d,0 8px 10px -6px #00000003;overflow:hidden;border:1px solid #e2e8f0}.results-table-head{display:grid;grid-template-columns:2fr 1.2fr 1.2fr 1fr;padding:18px 24px;background:#f8fafc;font-size:14px;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0}.results-row{display:grid;grid-template-columns:2fr 1.2fr 1.2fr 1fr;padding:20px 24px;align-items:center;border-bottom:1px solid #f1f5f9;transition:all .2s ease}.results-row:last-child{border-bottom:none}.results-row:hover{background:#f5f8ff;transform:translateY(-1px)}.exam-title{font-weight:600;color:#1e293b;font-size:16px}.score{font-weight:600;color:#334155;display:flex;align-items:center}.badge{margin-left:12px;padding:4px 10px;font-size:12px;border-radius:6px;font-weight:700;letter-spacing:.5px}.badge.pass{background:#d1fae5;color:#059669;border:1px solid #a7f3d0}.badge.fail{background:#fee2e2;color:#dc2626;border:1px solid #fecaca}.date{color:#64748b;font-size:14px;font-weight:500}.view-btn{background:#eff6ff;border:1px solid #bfdbfe;color:#2563eb;font-weight:600;cursor:pointer;text-align:center;padding:8px 16px;border-radius:8px;transition:all .2s;font-size:14px}.view-btn:hover{background:#3b82f6;color:#fff;border-color:#3b82f6;box-shadow:0 4px 6px -1px #3b82f64d}.ser-page{min-height:100vh;background:#f4f7fb;padding:40px 20px;font-family:Inter,system-ui,-apple-system,sans-serif;display:flex;justify-content:center;align-items:flex-start}.ser-container{width:100%;max-width:880px;display:flex;flex-direction:column;gap:24px}.ser-loading{display:flex;flex-direction:column;align-items:center;gap:16px;padding:80px 0;color:#3b82f6;font-size:1.1rem;font-weight:500}.ser-spinner{width:40px;height:40px;border:3px solid rgba(59,130,246,.15);border-top-color:#3b82f6;border-radius:50%;animation:ser-spin .8s linear infinite}@keyframes ser-spin{to{transform:rotate(360deg)}}.ser-error-card{text-align:center;padding:60px 40px;background:#fff;border:1px solid #e2e8f0;border-radius:20px;color:#64748b;max-width:500px;margin:0 auto;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008}.ser-error-card svg{color:#ef4444;margin-bottom:16px}.ser-error-card h3{font-size:1.2rem;color:#1e293b;margin:0 0 8px;font-weight:700}.ser-error-card p{margin:0 0 24px;color:#64748b}.ser-hero{display:flex;align-items:center;justify-content:space-between;padding:36px 40px;border-radius:20px;background:#fff;border:1px solid #e2e8f0;box-shadow:0 10px 25px -5px #0000000d,0 8px 10px -6px #00000003;position:relative;overflow:hidden}.ser-hero:before{content:"";position:absolute;inset:0;opacity:.15;pointer-events:none}.ser-hero-pass:before{background:linear-gradient(135deg,rgba(16,185,129,.3),rgba(6,182,212,.1),transparent)}.ser-hero-fail:before{background:linear-gradient(135deg,rgba(239,68,68,.3),rgba(251,146,60,.1),transparent)}.ser-hero-left{display:flex;align-items:flex-start;gap:20px;z-index:1}.ser-hero-icon{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ser-hero-pass .ser-hero-icon{background:#d1fae5;color:#059669}.ser-hero-fail .ser-hero-icon{background:#fee2e2;color:#dc2626}.ser-hero-title{font-size:1.5rem;font-weight:700;margin:0 0 4px;color:#1e293b;letter-spacing:-.5px}.ser-hero-subtitle{margin:0 0 12px;font-size:.95rem;color:#64748b}.ser-status-badge{display:inline-block;padding:6px 16px;border-radius:20px;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px}.ser-badge-pass{background:#d1fae5;color:#059669;border:1px solid #a7f3d0}.ser-badge-fail{background:#fee2e2;color:#dc2626;border:1px solid #fecaca}.ser-score-ring-wrap{position:relative;width:120px;height:120px;flex-shrink:0;z-index:1}.ser-score-ring{width:120px;height:120px;transform:rotate(-90deg)}.ser-ring-bg{fill:none;stroke:#e2e8f0;stroke-width:8}.ser-ring-fill{fill:none;stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset 1s cubic-bezier(.4,0,.2,1)}.ser-ring-pass{stroke:#10b981}.ser-ring-fail{stroke:#ef4444}.ser-score-val{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.ser-score-pct{font-size:1.5rem;font-weight:800;color:#1e293b}.ser-score-label{font-size:.72rem;color:#64748b;text-transform:uppercase;letter-spacing:1px;font-weight:700}.ser-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.ser-stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:24px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;transition:all .25s ease;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008}.ser-stat-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #00000014,0 4px 6px -2px #0000000a}.ser-stat-wide{grid-column:span 4;flex-direction:row;justify-content:center;gap:16px;padding:20px 24px}.ser-stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.ser-stat-blue{background:#eff6ff;color:#3b82f6}.ser-stat-indigo{background:#eef2ff;color:#6366f1}.ser-stat-green{background:#f0fdf4;color:#22c55e}.ser-stat-red{background:#fef2f2;color:#ef4444}.ser-stat-purple{background:#f3e8ff;color:#a855f7}.ser-stat-value{font-size:1.5rem;font-weight:800;color:#1e293b}.ser-stat-name{font-size:.85rem;color:#64748b;font-weight:600}.ser-tab-bar{display:flex;gap:8px;padding:6px;background:#fff;border-radius:12px;border:1px solid #e2e8f0;box-shadow:0 2px 4px #00000005}.ser-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 20px;border:none;background:transparent;border-radius:8px;color:#64748b;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease}.ser-tab:hover{background:#f8fafc;color:#1e293b}.ser-tab.ser-tab-active{background:#eff6ff;color:#2563eb;font-weight:700}.ser-type-breakdown{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:24px;box-shadow:0 4px 6px -1px #0000000d}.ser-section-title{margin:0 0 20px;font-size:1.1rem;font-weight:700;color:#1e293b}.ser-type-cards{display:flex;flex-direction:column;gap:12px}.ser-type-card{display:grid;grid-template-columns:1fr auto auto 60px;align-items:center;gap:16px;padding:16px 20px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;transition:all .2s ease}.ser-type-card:hover{background:#f1f5f9}.ser-type-header{display:flex;align-items:center;gap:12px}.ser-type-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.ser-type-name{font-size:.95rem;color:#1e293b;font-weight:600;text-transform:capitalize}.ser-type-count{font-size:.75rem;color:#64748b;padding:4px 10px;background:#e2e8f0;border-radius:6px;font-weight:600}.ser-type-score{text-align:right}.ser-type-scored{font-weight:800;font-size:1.1rem;color:#1e293b}.ser-type-divider{color:#94a3b8;margin:0 4px}.ser-type-total{font-size:.95rem;color:#64748b;font-weight:500}.ser-type-bar-track{height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden;min-width:120px}.ser-type-bar-fill{height:100%;border-radius:4px;transition:width .6s ease}.ser-type-pct{font-size:.9rem;font-weight:700;color:#475569;text-align:right}.ser-q-details{display:flex;flex-direction:column;gap:20px}.ser-q-section{background:#fff;border:1px solid #e2e8f0;border-radius:16px;overflow:hidden;box-shadow:0 4px 6px -1px #0000000d}.ser-q-section-header{display:flex;align-items:center;gap:10px;padding:16px 24px;background:#f8fafc;border-bottom:1px solid #e2e8f0;font-size:.95rem;font-weight:700;color:#1e293b}.ser-q-section-count{margin-left:auto;font-size:.8rem;color:#64748b;font-weight:500}.ser-q-row{border-bottom:1px solid #f1f5f9;transition:background .2s ease}.ser-q-row:last-child{border-bottom:none}.ser-q-row:hover{background:#f8fafc}.ser-q-row-main{display:flex;align-items:center;gap:14px;padding:16px 24px;cursor:pointer;-webkit-user-select:none;user-select:none}.ser-q-num{width:32px;height:32px;border-radius:8px;background:#f1f5f9;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:#475569;flex-shrink:0}.ser-q-type-badge{font-size:.72rem;padding:4px 10px;border-radius:6px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0}.ser-q-text-preview{flex:1;font-size:.9rem;color:#334155;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.ser-q-marks{font-size:.9rem;font-weight:700;color:#1e293b;flex-shrink:0}.ser-q-badge{font-size:.75rem;padding:4px 12px;border-radius:12px;font-weight:700;flex-shrink:0}.ser-badge-correct{background:#d1fae5;color:#059669}.ser-badge-partial{background:#fef3c7;color:#d97706}.ser-badge-wrong{background:#fee2e2;color:#dc2626}.ser-badge-pending{background:#e2e8f0;color:#475569}.ser-q-chevron{flex-shrink:0;color:#94a3b8;transition:transform .2s ease}.ser-q-expanded .ser-q-chevron{transform:rotate(180deg)}.ser-q-detail-panel{padding:20px 24px 24px 70px;border-top:1px solid #f1f5f9;background:#fafaf9;animation:ser-fadeIn .25s ease}@keyframes ser-fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.ser-q-detail-text{font-size:.95rem;color:#334155;line-height:1.6;margin-bottom:16px}.ser-q-remarks{display:flex;align-items:flex-start;gap:8px;padding:12px 16px;background:#eff6ff;border-radius:8px;font-size:.85rem;color:#1e40af;margin-bottom:16px;font-weight:500}.ser-q-detail-meta{display:flex;gap:10px}.ser-q-meta-tag{font-size:.75rem;padding:4px 12px;background:#e2e8f0;border-radius:6px;color:#475569;font-weight:600}.ser-footer{display:flex;justify-content:center;padding:16px 0}.ser-back-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;color:#475569;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 6px -1px #0000000d}.ser-back-btn:hover{background:#eff6ff;border-color:#3b82f6;color:#2563eb;box-shadow:0 6px 10px -2px #3b82f633;transform:translateY(-1px)}@media(max-width:768px){.ser-page{padding:20px 12px}.ser-hero{flex-direction:column;gap:24px;padding:28px 24px;text-align:center}.ser-hero-left{flex-direction:column;align-items:center}.ser-stats-grid{grid-template-columns:repeat(2,1fr)}.ser-stat-wide{grid-column:span 2}.ser-type-card{grid-template-columns:1fr auto;gap:8px}.ser-type-bar-track{display:none}.ser-q-row-main{flex-wrap:wrap;gap:8px}.ser-q-text-preview{width:100%;order:10}}.page-bg{min-height:100vh;background:linear-gradient(180deg,#f4f6fb,#eef2f7);padding:30px 0}.page-bg-content{width:100%}.entry-container{min-height:calc(100vh - 60px);display:flex;align-items:center;justify-content:center}.entry-card{width:100%;max-width:420px;background:#fff;padding:32px;border-radius:16px;box-shadow:0 10px 28px #1e293b1f}.entry-card h2{margin:0;font-size:22px}.subtitle{margin-top:6px;margin-bottom:20px;color:#6b7280;font-size:14px}.form-group{display:flex;flex-direction:column;margin-bottom:18px}.form-group label{font-size:13px;margin-bottom:6px;color:#374151}.form-group input{padding:12px;border-radius:10px;border:1px solid #d1d5db;font-size:14px}.form-group input:focus{outline:none;border-color:#2563eb}.btn-primary{width:100%;background:#2563eb;color:#fff;border:none;padding:12px;border-radius:10px;font-size:14px;font-weight:500;cursor:pointer}.btn-primary:hover{background:#1e40af}.approval-queue-container{background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:12px;padding:20px;margin-bottom:24px}.approval-queue-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.approval-queue-title{font-size:1.2rem;font-weight:600;display:flex;align-items:center;gap:8px;margin:0}.approval-badge{background:#ef4444;color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700}.approval-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.approval-card{background:#0f172a80;border:1px solid #475569;border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:12px}.approval-snapshot{width:100%;aspect-ratio:4/3;object-fit:contain;background:#000;border-radius:6px;border:1px solid #334155}.approval-info{display:flex;flex-direction:column;gap:4px}.approval-name{font-weight:600;font-size:.95rem}.approval-id{font-size:.8rem;color:#94a3b8;font-family:monospace}.approval-actions{display:flex;gap:8px;margin-top:auto}.btn-approve{flex:1;background:#22c55e;color:#fff;border:none;padding:8px;border-radius:6px;font-weight:600;cursor:pointer;transition:opacity .2s}.btn-approve:hover{opacity:.9}.btn-reject{flex:1;background:#ef4444;color:#fff;border:none;padding:8px;border-radius:6px;font-weight:600;cursor:pointer;transition:opacity .2s}.btn-reject:hover{opacity:.9}:root{--font-body: "Inter", system-ui, sans-serif;--bg: #f1f5f9;--surface-1: #ffffff;--surface-2: #f8fafc;--surface-3: #f1f5f9;--border: #e2e8f0;--border-mid: #cbd5e1;--blue: #3b82f6;--blue-soft: #eff6ff;--blue-border: #bfdbfe;--blue-text: #1d4ed8;--green: #22c55e;--green-soft: #f0fdf4;--green-border: #bbf7d0;--green-text: #15803d;--amber: #f59e0b;--amber-soft: #fffbeb;--amber-border: #fde68a;--amber-text: #92400e;--red: #ef4444;--red-soft: #fef2f2;--red-border: #fecaca;--red-text: #b91c1c;--text-1: #0f172a;--text-2: #64748b;--text-3: #94a3b8;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .06);--transition: .18s ease}.pd-root{font-family:var(--font-body);display:flex;flex-direction:column;gap:22px;min-height:100%;background:var(--bg);color:var(--text-1);animation:pd-in .3s ease both}@keyframes pd-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.pd-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.pd-page-eyebrow{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:600;letter-spacing:.08em;color:var(--blue);margin-bottom:4px}.pd-page-title{font-size:28px;font-weight:700;color:var(--text-1);letter-spacing:-.5px;margin:0 0 4px;line-height:1.1}.pd-page-sub{font-size:13.5px;color:var(--text-2);margin:0}.pd-clear-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-1);color:var(--text-2);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition);white-space:nowrap;flex-shrink:0}.pd-clear-btn:hover{border-color:var(--border-mid);color:var(--text-1)}.pd-live-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 2px #22c55e40;flex-shrink:0;animation:pd-pulse 2s infinite}@keyframes pd-pulse{0%,to{box-shadow:0 0 #22c55e66}50%{box-shadow:0 0 0 5px #22c55e00}}.pd-stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.pd-stat-card{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 22px 18px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:transform var(--transition),box-shadow var(--transition)}.pd-stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.pd-sc-blue:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--blue);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.pd-sc-green:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--green);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.pd-sc-amber:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--amber);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.pd-sc-red:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--red);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.pd-stat-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:12px}.pd-stat-label{font-size:13px;font-weight:600;color:var(--text-1);letter-spacing:-.1px}.pd-stat-icon{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pd-stat-icon svg{width:17px;height:17px}.pd-si-blue{background:var(--blue-soft);color:var(--blue);border:1px solid var(--blue-border)}.pd-si-green{background:var(--green-soft);color:var(--green);border:1px solid var(--green-border)}.pd-si-amber{background:var(--amber-soft);color:var(--amber);border:1px solid var(--amber-border)}.pd-si-red{background:var(--red-soft);color:var(--red);border:1px solid var(--red-border)}.pd-stat-value{font-size:32px;font-weight:700;color:var(--text-1);letter-spacing:-1px;line-height:1;margin-bottom:4px}.pd-sv-red{color:var(--red)}.pd-stat-sub{font-size:12px;color:var(--text-2)}.pd-grid{display:grid;grid-template-columns:280px 1fr 280px;gap:16px;min-height:0;flex:1}.pd-card{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;overflow:hidden}.pd-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:18px 20px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.pd-card-title-wrap{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.pd-card-title{font-size:15px;font-weight:700;color:var(--text-1);letter-spacing:-.2px;margin:0}.pd-card-sub{font-size:12px;color:var(--text-2);margin-top:1px}.pd-badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:999px;font-size:11px;font-weight:600}.pd-badge-blue{background:var(--blue-soft);color:var(--blue-text);border:1px solid var(--blue-border)}.pd-badge-amber{background:var(--amber-soft);color:var(--amber-text);border:1px solid var(--amber-border)}.pd-exam-tag{display:flex;align-items:center;gap:5px;padding:4px 10px;background:var(--surface-3);border:1px solid var(--border);border-radius:999px;font-size:11.5px;font-weight:500;color:var(--text-2);white-space:nowrap;flex-shrink:0}.pd-filter-chip{display:flex;align-items:center;gap:4px;padding:3px 9px;background:var(--surface-3);border:1px solid var(--border);border-radius:999px;font-family:var(--font-body);font-size:11px;font-weight:500;color:var(--text-2);cursor:pointer;transition:all var(--transition)}.pd-filter-chip:hover{border-color:var(--border-mid);color:var(--text-1)}.pd-empty{display:flex;flex-direction:column;align-items:center;gap:6px;padding:30px 16px;color:var(--text-2);font-size:13px;font-weight:500;text-align:center}.pd-empty p{font-size:12px;color:var(--text-3);margin:0}.pd-empty-icon{width:44px;height:44px;border-radius:12px;background:var(--surface-3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-3);margin-bottom:4px}.pd-empty-lg{padding:60px 24px}.pd-empty-lg .pd-empty-icon{width:56px;height:56px;border-radius:14px}.pd-candidates-card{max-height:600px}.pd-candidate-list{flex:1;overflow-y:auto;padding:10px 14px;display:flex;flex-direction:column;gap:4px}.pd-candidate-list::-webkit-scrollbar{width:4px}.pd-candidate-list::-webkit-scrollbar-thumb{background:var(--border-mid);border-radius:4px}.pd-candidate-row{display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;transition:all var(--transition);animation:pd-slide-in .22s ease both}@keyframes pd-slide-in{0%{opacity:0;transform:translate(-6px)}to{opacity:1;transform:none}}.pd-candidate-row:hover{background:var(--surface-3);border-color:var(--border)}.pd-cr-selected{background:var(--blue-soft)!important;border-color:var(--blue-border)!important}.pd-cr-avatar{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.pd-av-high{background:var(--red-soft);border:1px solid var(--red-border);color:var(--red-text)}.pd-av-medium{background:var(--amber-soft);border:1px solid var(--amber-border);color:var(--amber-text)}.pd-av-low{background:var(--green-soft);border:1px solid var(--green-border);color:var(--green-text)}.pd-cr-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px}.pd-cr-id{font-size:12px;font-weight:600;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pd-cr-bar-wrap{display:flex;align-items:center;gap:6px}.pd-cr-bar{flex:1;height:4px;background:var(--border);border-radius:999px;overflow:hidden}.pd-cr-fill{height:100%;border-radius:999px;transition:width .5s ease}.pd-fill-high{background:var(--red)}.pd-fill-medium{background:var(--amber)}.pd-fill-low{background:var(--green)}.pd-cr-count{font-size:10.5px;color:var(--text-3);font-weight:500;white-space:nowrap}.pd-risk-pill{display:inline-flex;align-items:center;padding:3px 9px;border-radius:999px;font-size:10.5px;font-weight:600;letter-spacing:.03em;text-transform:capitalize;white-space:nowrap;flex-shrink:0}.pd-rp-high{background:var(--red-soft);color:var(--red-text);border:1px solid var(--red-border)}.pd-rp-medium{background:var(--amber-soft);color:var(--amber-text);border:1px solid var(--amber-border)}.pd-rp-low{background:var(--green-soft);color:var(--green-text);border:1px solid var(--green-border)}.pd-feed-card{overflow:hidden}.pd-live-indicator{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--green-text);letter-spacing:.06em;text-transform:uppercase;margin-bottom:3px}.pd-filter-banner{display:flex;align-items:center;gap:7px;padding:8px 20px;background:var(--blue-soft);border-bottom:1px solid var(--blue-border);font-size:12px;font-weight:500;color:var(--blue-text);flex-shrink:0}.pd-feed{flex:1;overflow-y:auto;padding:10px 16px;display:flex;flex-direction:column;gap:6px}.pd-feed::-webkit-scrollbar{width:4px}.pd-feed::-webkit-scrollbar-thumb{background:var(--border-mid);border-radius:4px}.pd-event-row{display:flex;align-items:flex-start;gap:11px;padding:12px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);transition:all var(--transition);animation:pd-event-in .25s ease both;position:relative;overflow:hidden}@keyframes pd-event-in{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:none}}.pd-event-row:hover{border-color:var(--border-mid);box-shadow:var(--shadow-sm)}.pd-er-stripe{position:absolute;left:0;top:0;bottom:0;width:3px}.pd-stripe-high{background:var(--red)}.pd-stripe-medium{background:var(--amber)}.pd-stripe-low{background:var(--green)}.pd-er-avatar{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0;margin-left:6px}.pd-er-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px}.pd-er-meta{display:flex;align-items:center;gap:7px}.pd-er-id{font-size:11.5px;font-weight:600;color:var(--blue);cursor:pointer;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color var(--transition)}.pd-er-id:hover{color:var(--blue-text)}.pd-er-time{font-size:10.5px;color:var(--text-3);white-space:nowrap;flex-shrink:0}.pd-er-text{font-size:13px;color:var(--text-1);line-height:1.5;margin:0}.pd-right-col{display:flex;flex-direction:column;gap:16px}.pd-risk-rows{display:flex;flex-direction:column;gap:14px;padding:16px 20px}.pd-risk-row{display:flex;flex-direction:column;gap:5px}.pd-risk-row-top{display:flex;align-items:center;justify-content:space-between}.pd-risk-label{font-size:13px;font-weight:600}.pd-rl-high{color:var(--red-text)}.pd-rl-medium{color:var(--amber-text)}.pd-rl-low{color:var(--green-text)}.pd-risk-pct{font-size:13px;font-weight:700;color:var(--text-1)}.pd-risk-track{height:6px;background:var(--surface-3);border-radius:999px;overflow:hidden;border:1px solid var(--border)}.pd-risk-fill{height:100%;border-radius:999px;transition:width .6s ease}.pd-risk-count{font-size:11.5px;color:var(--text-2)}.pd-download-btn{display:flex;align-items:center;justify-content:center;gap:7px;width:calc(100% - 40px);margin:4px 20px 18px;padding:9px 16px;background:var(--surface-3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-2);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition)}.pd-download-btn:hover{background:var(--surface-1);border-color:var(--border-mid);color:var(--text-1);box-shadow:var(--shadow-sm)}.pd-evidence-card{flex:1}.pd-evidence-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:12px 14px}.pd-view-more-btn{display:block;width:calc(100% - 32px);margin:8px 16px;padding:10px 16px;background:linear-gradient(135deg,var(--blue-soft),#e8f0fe);border:1px dashed var(--blue-border);border-radius:var(--radius-md);color:var(--blue-text);font-size:12px;font-weight:600;cursor:pointer;transition:all var(--transition);text-align:center;letter-spacing:.02em}.pd-view-more-btn:hover{background:linear-gradient(135deg,#d0e3ff,#e0ecff);border-color:var(--blue-text);transform:translateY(-1px);box-shadow:0 2px 8px #3b82f626}.pd-view-more-btn.pd-view-less{background:var(--surface-2);border-color:var(--border);color:var(--text-3)}.pd-view-more-btn.pd-view-less:hover{background:var(--surface-3);border-color:var(--border-mid);color:var(--text-2)}.pd-ev-card{border-radius:var(--radius-sm);overflow:hidden;background:var(--surface-3);border:1px solid var(--border);cursor:pointer;transition:all var(--transition)}.pd-ev-card:hover{border-color:var(--border-mid);box-shadow:var(--shadow-sm);transform:scale(1.02)}.pd-ev-img-wrap{position:relative;overflow:hidden}.pd-ev-img-wrap img{width:100%;height:72px;object-fit:cover;display:block;transition:transform var(--transition)}.pd-ev-card:hover .pd-ev-img-wrap img{transform:scale(1.05)}.pd-ev-overlay{position:absolute;inset:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;transition:opacity var(--transition)}.pd-ev-card:hover .pd-ev-overlay{opacity:1}.pd-ev-info{padding:5px 8px;display:flex;justify-content:space-between;align-items:center;gap:4px;background:var(--surface-1)}.pd-ev-type{font-size:10px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.04em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pd-ev-time{font-size:10px;color:var(--text-3);white-space:nowrap;flex-shrink:0}@media(max-width:1200px){.pd-stat-row{grid-template-columns:repeat(2,1fr)}.pd-grid{grid-template-columns:240px 1fr 240px}}@media(max-width:900px){.pd-grid{grid-template-columns:1fr;grid-template-rows:auto 1fr auto}.pd-stat-row{grid-template-columns:repeat(2,1fr)}}.pd-lightbox-backdrop{position:fixed;inset:0;background:#0f172abf;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:pd-backdrop-in .2s ease both}@keyframes pd-backdrop-in{0%{opacity:0}to{opacity:1}}.pd-lightbox{background:#fff;border-radius:16px;box-shadow:0 24px 64px #00000038,0 4px 16px #0000001a;overflow:hidden;max-width:820px;width:100%;position:relative;animation:pd-lightbox-in .25s cubic-bezier(.34,1.56,.64,1) both;border:1px solid #e2e8f0}@keyframes pd-lightbox-in{0%{opacity:0;transform:scale(.88) translateY(16px)}to{opacity:1;transform:scale(1) translateY(0)}}.pd-lightbox-close{position:absolute;top:14px;right:14px;z-index:10;width:34px;height:34px;border-radius:50%;border:1px solid #e2e8f0;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#64748b;box-shadow:0 2px 8px #0000001a;transition:all .15s ease}.pd-lightbox-close:hover{background:#f1f5f9;color:#0f172a;transform:scale(1.08)}.pd-lightbox-img-wrap{width:100%;background:#0f172a;display:flex;align-items:center;justify-content:center;max-height:480px;overflow:hidden}.pd-lightbox-img-wrap img{width:100%;max-height:480px;object-fit:contain;display:block}.pd-lightbox-footer{padding:18px 24px 16px;border-top:1px solid #e2e8f0;display:flex;align-items:flex-end;justify-content:space-between;gap:16px;background:#f8fafc}.pd-lightbox-info{display:flex;flex-direction:column;gap:10px;flex:1}.pd-lightbox-row{display:flex;align-items:center;gap:8px}.pd-lightbox-row svg{color:#94a3b8;flex-shrink:0}.pd-lightbox-label{font-size:11.5px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.06em;min-width:110px;flex-shrink:0}.pd-lightbox-value{font-size:13.5px;font-weight:600;color:#0f172a}.pd-lightbox-mono{font-family:Courier New,monospace;font-size:12px;font-weight:500;background:#f1f5f9;border:1px solid #e2e8f0;padding:2px 8px;border-radius:4px;color:#3b82f6}.pd-lightbox-hint{font-size:11px;color:#94a3b8;white-space:nowrap;flex-shrink:0}.pd-live-feeds-section{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.pd-live-feeds-section>.pd-card-header{border-bottom:1px solid var(--border)}.pd-badge-green{background:var(--green-soft);color:var(--green-text);border:1px solid var(--green-border)}.pd-empty-feeds{padding:40px 24px}.pd-live-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;padding:16px}.pd-live-tile{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:all var(--transition);animation:pd-tile-in .3s ease both}@keyframes pd-tile-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:none}}.pd-live-tile:hover{border-color:var(--border-mid);box-shadow:var(--shadow-md);transform:translateY(-2px)}.pd-lt-high{border-color:var(--red-border)}.pd-lt-high:hover{border-color:var(--red)}.pd-lt-medium{border-color:var(--amber-border)}.pd-lt-medium:hover{border-color:var(--amber)}.pd-lt-low{border-color:var(--green-border)}.pd-lt-low:hover{border-color:var(--green)}.pd-lt-img-wrap{position:relative;aspect-ratio:4 / 3;background:#0f172a;overflow:hidden}.pd-lt-img-wrap img{width:100%;height:100%;object-fit:cover;display:block}.pd-lt-overlay{position:absolute;top:0;left:0;right:0;padding:8px 10px;display:flex;justify-content:flex-end;pointer-events:none}.pd-lt-overlay-focus{justify-content:flex-start}.pd-lt-live-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;background:#ef4444e6;color:#fff;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.08em;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.pd-live-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.pd-lt-streams{position:relative;width:100%;aspect-ratio:16/10;background:#000}.pd-lt-camera{width:100%;height:100%}.pd-lt-img-wrap img{width:100%;height:100%;object-fit:cover}.pd-lt-screen-mini{position:absolute;bottom:8px;right:8px;width:110px;aspect-ratio:16/9;border-radius:6px;overflow:hidden;border:2px solid rgba(255,255,255,.4);box-shadow:0 4px 12px #00000080;background:#111;z-index:10;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:zoom-in}.pd-lt-screen-mini:hover{width:180px;border-color:var(--blue)!important}.pd-mini-label{position:absolute;top:4px;left:4px;background:#000000b3;color:#fff;font-size:8px;font-weight:700;padding:1px 4px;border-radius:3px;text-transform:uppercase}.pd-stream-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#1e293b;color:#64748b;font-size:11px;font-weight:500}.pd-live-focus{width:90vw!important;max-width:1100px!important}.pd-focus-streams{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:#000;border-radius:8px;overflow:hidden;margin:4px}.pd-focus-main,.pd-focus-side{position:relative;aspect-ratio:4/3;background:#111}.pd-focus-main img,.pd-focus-side img{width:100%;height:100%;object-fit:contain}.pd-stream-placeholder-lg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#475569;font-style:italic;font-size:13px}.pd-lt-overlay-focus{padding:12px!important}.pd-lt-live-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:#fff;animation:pd-lt-blink 1.2s infinite}@keyframes pd-lt-blink{0%,to{opacity:1}50%{opacity:.3}}.pd-lt-info{padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:8px}.pd-lt-id{font-size:12px;font-weight:600;color:var(--text-1);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pd-lt-meta{display:flex;align-items:center;gap:6px;flex-shrink:0}.pd-lt-time{font-size:10.5px;color:var(--text-3);white-space:nowrap}.pd-live-focus .pd-lightbox-img-wrap{position:relative}.pd-live-focus .pd-lightbox-img-wrap img{max-height:60vh}.pd-terminate-btn{width:28px;height:28px;border-radius:6px;border:1px solid var(--red-border);background:var(--red-soft);color:var(--red);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;transition:all var(--transition);opacity:.7}.pd-candidate-row:hover .pd-terminate-btn{opacity:1}.pd-terminate-btn:hover{background:var(--red);color:#fff;border-color:var(--red);box-shadow:0 2px 8px #ef44444d;transform:scale(1.1)}.pd-video-btn{width:28px;height:28px;border-radius:6px;border:1px solid var(--blue-border);background:var(--blue-soft);color:var(--blue);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;transition:all var(--transition);opacity:.7}.pd-candidate-row:hover .pd-video-btn{opacity:1}.pd-video-btn:hover{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:0 2px 8px #3b82f64d;transform:scale(1.1)}.pd-terminated-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;background:#ef44441a;color:var(--red);font-size:9px;font-weight:700;letter-spacing:.05em;border:1px solid var(--red-border);flex-shrink:0}.pd-terminate-modal{background:var(--surface-1);border-radius:var(--radius-lg);width:440px;max-width:calc(100vw - 32px);box-shadow:0 25px 60px #00000040;animation:aqm-slideUp .25s ease;overflow:hidden}.pd-tm-header{display:flex;align-items:center;gap:12px;padding:20px 24px 14px;border-bottom:1px solid var(--red-border);background:var(--red-soft)}.pd-tm-icon{font-size:1.5rem}.pd-tm-title{font-size:1rem;font-weight:700;color:var(--red-text);margin:0}.pd-tm-desc{padding:0 24px;font-size:.85rem;color:var(--text-2);margin:10px 0 0;line-height:1.5}.pd-tm-candidate{font-size:.82rem;font-weight:600;color:var(--text-1);font-family:Fira Code,monospace;background:var(--surface-3);margin:6px 24px;padding:8px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);word-break:break-all}.pd-tm-field{padding:12px 24px}.pd-tm-label{display:block;font-size:.78rem;font-weight:600;color:var(--text-1);margin-bottom:6px}.pd-tm-textarea{width:100%;padding:10px 14px;font-size:.85rem;border:1.5px solid var(--border);border-radius:var(--radius-md);background:var(--surface-1);color:var(--text-1);font-family:var(--font-body);resize:vertical;box-sizing:border-box;transition:border-color var(--transition)}.pd-tm-textarea:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px #ef44441a}.pd-tm-actions{display:flex;justify-content:flex-end;gap:10px;padding:14px 24px;border-top:1px solid var(--border);background:var(--surface-2)}.pd-tm-cancel{padding:9px 20px;border-radius:var(--radius-md);border:1.5px solid var(--border);background:var(--surface-1);color:var(--text-2);font-size:.85rem;font-weight:500;cursor:pointer;font-family:var(--font-body);transition:all var(--transition)}.pd-tm-cancel:hover{background:var(--surface-3)}.pd-tm-confirm{padding:9px 22px;border-radius:var(--radius-md);border:none;background:var(--red);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;font-family:var(--font-body);transition:all var(--transition);box-shadow:0 2px 8px #ef444440}.pd-tm-confirm:hover{background:#dc2626;box-shadow:0 4px 12px #ef444459}.pd-tm-confirm:disabled,.pd-tm-cancel:disabled{opacity:.55;cursor:not-allowed}.pd-exam-filter{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 14px;font-family:var(--font-body);font-size:12.5px;font-weight:500;color:var(--text-1);cursor:pointer;outline:none;min-width:180px;transition:all var(--transition)}.pd-exam-filter:focus{border-color:var(--blue);box-shadow:0 0 0 3px #6366f11f}.pd-lt-exam-tag{font-size:10.5px;color:var(--blue);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pd-lt-exam-badge{position:absolute;bottom:6px;left:6px;background:#1e40afd9;color:#fff;font-size:9.5px;font-weight:600;padding:2px 8px;border-radius:4px;letter-spacing:.3px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.pd-live-placeholder{background:var(--surface-3);border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;aspect-ratio:4/3;color:var(--text-2);font-size:13px;font-weight:500;border:1px dashed var(--border-mid)}.pd-spinner-small{width:20px;height:20px;border:3px solid var(--border);border-top:3px solid var(--blue);border-radius:50%;animation:pd-spin .8s linear infinite}@keyframes pd-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.pd-live-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;padding:16px}.pd-live-item{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}.pd-live-header{padding:8px 12px;border-bottom:1px solid var(--border);background:var(--surface-2)}.pd-live-user{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:600;color:var(--text-1)}.pd-live-img{width:100%;aspect-ratio:4/3;object-fit:cover;background:#000;display:block}.pd-screen-mini{border-top:1px solid var(--border);background:#111;padding:4px}.pd-screen-mini img{width:100%;border-radius:4px;opacity:.8}:root{--font-body: "Inter", system-ui, sans-serif;--bg: #f1f5f9;--sidebar-bg: #ffffff;--topbar-bg: #ffffff;--content-bg: #f1f5f9;--surface-1: #ffffff;--surface-2: #f8fafc;--surface-3: #f1f5f9;--border: #e2e8f0;--border-mid: #cbd5e1;--blue: #3b82f6;--blue-soft: #eff6ff;--blue-border: #bfdbfe;--blue-text: #1d4ed8;--green: #22c55e;--green-soft: #f0fdf4;--green-border: #bbf7d0;--green-text: #15803d;--amber: #f59e0b;--amber-soft: #fffbeb;--amber-border: #fde68a;--amber-text: #b45309;--red: #ef4444;--red-soft: #fef2f2;--red-border: #fecaca;--red-text: #b91c1c;--text-1: #0f172a;--text-2: #64748b;--text-3: #94a3b8;--sidebar-width: 240px;--topbar-height: 60px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .06);--transition: .18s ease}*,*:before,*:after{box-sizing:border-box}.pl-shell{display:flex;height:100vh;background:var(--bg);color:var(--text-1);font-family:var(--font-body);overflow:hidden}.pl-sidebar{width:var(--sidebar-width);height:100vh;background:var(--sidebar-bg);display:flex;flex-direction:column;flex-shrink:0;border-right:1px solid var(--border);overflow:hidden;z-index:30}.pl-brand{display:flex;align-items:center;gap:11px;padding:20px 20px 16px;border-bottom:1px solid var(--border);cursor:pointer;min-height:72px}.pl-brand-icon{width:38px;height:38px;border-radius:8px;background:var(--blue);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 2px 8px #3b82f659}.pl-brand-icon svg{width:18px;height:18px}.pl-brand-text{display:flex;flex-direction:column}.pl-brand-name{font-size:15px;font-weight:700;color:var(--text-1);letter-spacing:-.3px;line-height:1.1}.pl-brand-sub{font-size:11px;color:var(--text-2);margin-top:2px}.pl-nav-section{padding:14px 12px 4px}.pl-nav-label{font-size:10.5px;font-weight:600;letter-spacing:.07em;color:var(--text-3);padding:0 8px 6px}.pl-nav{display:flex;flex-direction:column;gap:1px}.pl-nav-link{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--radius-sm);text-decoration:none;font-size:13.5px;font-weight:500;color:var(--text-2);transition:all var(--transition);cursor:pointer;-webkit-user-select:none;user-select:none}.pl-nav-link:hover{background:var(--surface-3);color:var(--text-1)}.pl-nav-link.active{background:var(--blue-soft);color:var(--blue);font-weight:600}.pl-nav-static{opacity:.55;cursor:default}.pl-nav-static:hover{background:transparent;color:var(--text-2)}.pl-nav-icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pl-nav-icon svg{width:16px;height:16px}.pl-nav-text{flex:1}.pl-live-chip{font-size:10px;font-weight:700;letter-spacing:.06em;background:var(--green);color:#fff;padding:2px 7px;border-radius:999px;line-height:1.6}.pl-sidebar-footer{padding:12px 14px 16px;border-top:1px solid var(--border)}.pl-proctor-card{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);background:var(--surface-3);border:1px solid var(--border)}.pl-proctor-avatar{width:32px;height:32px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}.pl-proctor-info{display:flex;flex-direction:column}.pl-proctor-name{font-size:12.5px;font-weight:600;color:var(--text-1)}.pl-proctor-role{font-size:11px;color:var(--text-2)}.pl-main{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--content-bg)}.pl-topbar{height:var(--topbar-height);background:var(--topbar-bg);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;flex-shrink:0;box-shadow:var(--shadow-sm)}.pl-topbar-left{display:flex;align-items:center;gap:8px}.pl-topbar-title{font-size:15px;font-weight:600;color:var(--text-1);letter-spacing:-.2px}.pl-topbar-right{display:flex;align-items:center;gap:10px}.pl-exam-switcher{display:flex;align-items:center;gap:7px;padding:6px 12px;background:var(--surface-3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-2);font-size:13px;transition:border-color var(--transition)}.pl-exam-switcher:hover{border-color:var(--border-mid)}.pl-exam-switcher select{background:transparent;border:none;color:var(--text-1);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;outline:none;appearance:none}.pl-clock-chip{display:flex;align-items:center;gap:8px;padding:6px 14px;background:var(--surface-3);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-weight:600;color:var(--text-1);white-space:nowrap}.pl-clock-sep{width:1px;height:14px;background:var(--border)}.pl-clock-date{font-weight:400;color:var(--text-2);font-size:12.5px}.pl-icon-btn{width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-1);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-2);transition:all var(--transition);position:relative}.pl-icon-btn:hover{background:var(--surface-3);color:var(--text-1);border-color:var(--border-mid)}.pl-notif-dot{position:absolute;top:7px;right:7px;width:6px;height:6px;border-radius:50%;background:var(--red);border:1.5px solid #fff}.pl-user-chip{display:flex;align-items:center;gap:9px;padding:5px 12px 5px 6px;background:var(--surface-3);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:default}.pl-user-avatar{width:28px;height:28px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}.pl-user-info{display:flex;flex-direction:column}.pl-user-name{font-size:12.5px;font-weight:600;color:var(--text-1);line-height:1.2}.pl-user-role{font-size:10.5px;color:var(--text-2)}.pl-topbar-logout{display:flex;align-items:center;gap:7px;padding:7px 14px;background:var(--text-1);border:none;border-radius:var(--radius-sm);color:#fff;font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer;transition:opacity var(--transition)}.pl-topbar-logout:hover{opacity:.85}.pl-content{flex:1;overflow-y:auto;padding:28px;background:var(--content-bg)}.pl-content::-webkit-scrollbar{width:5px}.pl-content::-webkit-scrollbar-thumb{background:var(--border-mid);border-radius:8px}@media(max-width:768px){.pl-sidebar{display:none}}
