@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg: #f1f5f9;--surface: #ffffff;--surface-hover: #f8fafc;--border: #e2e8f0;--border-light: #f1f5f9;--primary: #1e40af;--primary-light: #3b82f6;--primary-bg: #eff6ff;--primary-border: #bfdbfe;--text: #1e293b;--text-secondary: #475569;--text-muted: #94a3b8;--success: #059669;--success-bg: #ecfdf5;--warning: #d97706;--warning-bg: #fffbeb;--danger: #dc2626;--danger-bg: #fef2f2;--font: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--shadow-xs: 0 1px 2px rgba(0,0,0,.04);--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.07), 0 2px 4px -1px rgba(0,0,0,.04);--radius: 8px;--radius-lg: 12px;--transition: all .15s ease;--sidebar-width: 260px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}h1{font-size:1.5rem;font-weight:700;color:var(--text)}h2{font-size:1.15rem;font-weight:600;color:var(--text)}h3{font-size:1rem;font-weight:600;color:var(--text)}h4{font-size:.875rem;font-weight:600;color:var(--text)}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:50;overflow-y:auto}.sidebar-brand{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.75rem}.sidebar-brand-icon{width:36px;height:36px;background:var(--primary);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.sidebar-brand h1{font-size:1.1rem;letter-spacing:-.02em}.sidebar-brand h1 span{color:var(--primary-light)}.sidebar-nav{padding:.75rem;flex:1;display:flex;flex-direction:column;gap:2px}.sidebar-section-label{padding:.75rem .75rem .25rem;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border-radius:var(--radius);cursor:pointer;transition:var(--transition);font-size:.875rem;font-weight:500;color:var(--text-secondary);border:none;background:none;width:100%;text-align:left}.nav-item:hover{background:var(--bg);color:var(--text)}.nav-item.active{background:var(--primary-bg);color:var(--primary);font-weight:600}.nav-item .nav-icon{width:18px;height:18px;flex-shrink:0;opacity:.7}.nav-item.active .nav-icon{opacity:1}.sidebar-footer{padding:1rem 1.5rem;border-top:1px solid var(--border)}.sidebar-user{display:flex;align-items:center;gap:.75rem}.sidebar-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary-bg);color:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-weight:600;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:.7rem;color:var(--text-muted);text-transform:capitalize}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh}.page-header{background:var(--surface);border-bottom:1px solid var(--border);padding:1.25rem 2rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:30}.page-body{padding:1.5rem 2rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow-xs);transition:var(--transition)}.card:hover{box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-light)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow-xs)}.stat-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.5rem}.stat-value{font-size:2rem;font-weight:700;letter-spacing:-.02em}.stat-value.success{color:var(--success)}.stat-value.warning{color:var(--warning)}.stat-value.primary{color:var(--primary)}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .6rem;border-radius:9999px;font-size:.7rem;font-weight:600;letter-spacing:.02em}.badge-primary{background:var(--primary-bg);color:var(--primary);border:1px solid var(--primary-border)}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.code-badge{font-family:SF Mono,Monaco,Cascadia Code,monospace;background:var(--primary-bg);color:var(--primary);border:1px solid var(--primary-border);padding:.3rem .6rem;border-radius:var(--radius);font-size:.8rem;font-weight:600;letter-spacing:.05em}.input{width:100%;padding:.6rem .75rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font);font-size:.875rem;transition:var(--transition)}.input:focus{outline:none;border-color:var(--primary-light);box-shadow:0 0 0 3px #3b82f626}.input::placeholder{color:var(--text-muted)}textarea.input{resize:vertical;min-height:80px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.55rem 1rem;border-radius:var(--radius);font-family:var(--font);font-weight:500;font-size:.85rem;cursor:pointer;transition:var(--transition);border:1px solid transparent;white-space:nowrap}.btn-primary{background:var(--primary);color:#fff;box-shadow:var(--shadow-xs)}.btn-primary:hover{background:#1e3a8a;box-shadow:var(--shadow-sm)}.btn-secondary{background:var(--surface);color:var(--text-secondary);border-color:var(--border)}.btn-secondary:hover{background:var(--bg);color:var(--text)}.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:transparent}.btn-danger:hover{background:#fecaca}.btn-ghost{background:transparent;color:var(--text-muted);border:none;padding:.4rem}.btn-ghost:hover{color:var(--text);background:var(--bg)}.btn-sm{padding:.35rem .6rem;font-size:.75rem}.btn:disabled{opacity:.5;cursor:not-allowed}.list-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background:var(--bg);border-radius:var(--radius);gap:1rem;transition:var(--transition)}.list-item:hover{background:var(--surface-hover)}.list-item+.list-item{margin-top:.5rem}.modal-overlay{position:fixed;inset:0;background:#0f172a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .15s ease}.modal-content{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;animation:slideUp .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.modal-body{padding:1.5rem}.file-upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:1.5rem;text-align:center;cursor:pointer;transition:var(--transition);background:var(--bg)}.file-upload-zone:hover{border-color:var(--primary-light);background:var(--primary-bg)}.file-upload-zone.has-file{border-color:var(--success);background:var(--success-bg)}.empty-state{text-align:center;padding:3rem 2rem;color:var(--text-muted)}.empty-state-icon{font-size:2.5rem;margin-bottom:1rem;opacity:.4}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.text-muted{color:var(--text-muted)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-mono{font-family:SF Mono,Monaco,monospace}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.grid-2{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e3a8a,#1e40af,#3b82f6)}.login-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:0 25px 50px -12px #00000040;width:100%;max-width:400px;padding:2.5rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:slideUp .3s ease}.checkin-success{display:flex;flex-direction:column;align-items:center;padding:2rem 1rem;position:relative;overflow:hidden}.checkin-circle{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,#10b981,#34d399);display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;animation:circleIn .5s cubic-bezier(.34,1.56,.64,1) forwards;box-shadow:0 8px 30px #10b98159}.checkin-circle svg{width:50px;height:50px;stroke:#fff;stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:60;stroke-dashoffset:60;animation:drawCheck .4s ease .4s forwards}.checkin-title{font-size:1.4rem;font-weight:700;color:#10b981;margin-bottom:.25rem;opacity:0;transform:translateY(10px);animation:textUp .4s ease .6s forwards}.checkin-subtitle{font-size:.85rem;color:var(--text-muted);margin-bottom:.5rem;opacity:0;transform:translateY(10px);animation:textUp .4s ease .7s forwards}.checkin-info{background:var(--bg);border-radius:var(--radius);padding:.75rem 1.25rem;margin:.75rem 0;width:100%;max-width:280px;opacity:0;transform:translateY(10px);animation:textUp .4s ease .85s forwards}.checkin-info-row{display:flex;justify-content:space-between;padding:.25rem 0}.checkin-info-label{font-size:.75rem;color:var(--text-muted)}.checkin-info-value{font-size:.8rem;font-weight:600;color:var(--text)}.checkin-btn{opacity:0;animation:textUp .4s ease 1s forwards;margin-top:1rem}.confetti-container{position:absolute;inset:0;pointer-events:none;overflow:hidden}.confetti{position:absolute;width:8px;height:8px;border-radius:2px;top:40%;opacity:0;animation:confettiFall 1.2s ease forwards}@keyframes circleIn{0%{transform:scale(0);opacity:0}60%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}@keyframes drawCheck{to{stroke-dashoffset:0}}@keyframes textUp{to{opacity:1;transform:translateY(0)}}@keyframes confettiFall{0%{opacity:1;transform:translate(0) rotate(0) scale(1)}to{opacity:0;transform:translate(var(--dx),var(--dy)) rotate(var(--rot)) scale(.5)}}.checkin-fail .checkin-circle{background:linear-gradient(135deg,#ef4444,#f87171);box-shadow:0 8px 30px #ef444459}.checkin-fail .checkin-title{color:var(--danger)}.eye-toggle{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:6px;transition:var(--transition);font-size:1rem;flex-shrink:0}.eye-toggle:hover{background:var(--bg);color:var(--text)}.progress-bar{width:100%;height:6px;background:var(--border);border-radius:9999px;overflow:hidden}.progress-fill{height:100%;background:var(--primary);border-radius:9999px;transition:width .4s ease}.progress-fill.success{background:var(--success)}.progress-fill.warning{background:var(--warning)}.progress-fill.danger{background:var(--danger)}.class-detail-row{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}.detail-tag{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .5rem;background:var(--bg);border-radius:6px;font-size:.75rem;color:var(--text-secondary)}.mobile-menu-btn{display:none;width:36px;height:36px;align-items:center;justify-content:center;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius);color:var(--text);cursor:pointer;font-size:1.2rem}@media(max-width:768px){.mobile-menu-btn{display:flex}.sidebar{transform:translate(-100%);transition:transform .25s ease;z-index:100;box-shadow:none}.sidebar.open{transform:translate(0);box-shadow:8px 0 30px #00000026}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0000004d;z-index:90}.sidebar-overlay.open{display:block}.main-content{margin-left:0}.page-body{padding:1rem}.page-header{padding:.75rem 1rem;gap:.5rem}.page-header h2{font-size:1rem}.stat-grid{grid-template-columns:1fr 1fr;gap:.75rem}.stat-card{padding:1rem}.stat-value{font-size:1.5rem}.stat-label{font-size:.6rem}.grid-2{grid-template-columns:1fr}.card{padding:1rem}.btn{padding:.5rem .75rem;font-size:.8rem}.btn-sm{padding:.35rem .5rem;font-size:.7rem}.list-item{padding:.6rem;flex-wrap:wrap;gap:.5rem}.modal-content{max-width:95vw;margin:1rem}.modal-body,.modal-header{padding:1rem}.login-card{padding:1.5rem;margin:1rem}.file-upload-zone{padding:1rem}h1{font-size:1.25rem}h2{font-size:1rem}}@media(max-width:480px){.stat-grid{grid-template-columns:1fr 1fr;gap:.5rem}.stat-card{padding:.75rem}.stat-value{font-size:1.25rem}.page-body{padding:.75rem}}
