:root{font-family:system-ui,-apple-system,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#1f2933;background-color:#f3f6fb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background-color:inherit}a{color:inherit;text-decoration:none}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:600;font-family:inherit;background-color:#1f2933;color:#fff;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}button:hover{transform:translateY(-1px);box-shadow:0 8px 16px #1f29331f}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:#f3f4f6}.main-login-container{max-width:480px;margin:0;width:100%;padding:32px;background:#fff;border-radius:16px;box-shadow:0 16px 40px #1f29331f}.main-login-container h2{margin:0 0 24px;font-size:1.5rem;color:#111827}.inputs-field{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.inputs-field label{font-size:.9rem;font-weight:600;color:#4b5563}.inputs-field input{height:42px;padding:0 12px;border:1px solid #d1d5db;border-radius:8px;font-size:1rem}.inputs-field input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb33}.main-login-container button{width:100%}:root{--bg: #f2f5fb;--surface: #ffffff;--surface-soft: #f8fafc;--text: #10233f;--muted: #5b6b82;--border: #dbe3ef;--primary: #0e7490;--primary-strong: #0f5d73;--danger: #c53030}.app-shell{min-height:100vh;background:radial-gradient(circle at 12% 8%,rgba(14,116,144,.08) 0,transparent 35%),radial-gradient(circle at 85% 5%,rgba(16,35,63,.08) 0,transparent 30%),var(--bg)}.sidebar{padding:12px 24px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);background:linear-gradient(90deg,#0f172a,#132742 65%,#123453);color:#eef6ff;position:sticky;top:0;z-index:10}.sidebar h2{margin:0;letter-spacing:.08em;font-size:1.05rem}.sidebar-meta{display:flex;align-items:center;gap:12px;font-size:.9rem}.sidebar-user{font-weight:600}.sidebar-meta .role{text-transform:capitalize;background:#ffffff1f;border:1px solid rgba(255,255,255,.2);border-radius:999px;padding:3px 10px}.sidebar-meta button{background-color:var(--danger)}.sidebar-meta button:hover{background-color:#a92424}.content{padding:28px;max-width:1400px;width:100%;margin:0 auto}.page-header{margin-bottom:18px;display:flex;justify-content:space-between;align-items:center}.page-header h1{margin:0;color:var(--text);letter-spacing:.02em}.page-header button{background:var(--primary)}.page-header button:hover{background:var(--primary-strong)}.card{background:var(--surface);border-radius:14px;border:1px solid var(--border);padding:18px;box-shadow:0 14px 26px #10233f14;margin-bottom:16px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.form-grid input,.form-grid select{height:38px;padding:0 10px;border:1px solid #d1d8e5;border-radius:8px;background-color:var(--surface-soft)}.list{display:grid;gap:8px}.list-item{padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface-soft)}.toast-container{position:fixed;top:78px;right:16px;display:flex;flex-direction:column;gap:10px;z-index:1000}.toast{min-width:220px;padding:12px 14px;border-radius:10px;color:#f9fafb;background:#111827;box-shadow:0 10px 20px #0f172a40;cursor:pointer}.toast.success{background:#166534}.toast.error{background:#b91c1c}@media(max-width:900px){.sidebar{padding:10px 12px}.sidebar-meta{gap:8px;font-size:.8rem}.content{padding:14px}.page-header{align-items:flex-start;flex-direction:column;gap:10px}}.student-result-toolbar{display:flex;justify-content:flex-end;margin-bottom:12px}.student-result-toolbar button{height:38px;border:0;border-radius:8px;padding:0 14px;background-color:#1d4ed8;color:#fff;font-weight:600;cursor:pointer}.result-meta-card h3{margin-top:0}.result-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px 14px}.result-sheet-card{page-break-inside:avoid}.result-sheet-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:12px}.result-sheet-header h3{margin:0}.result-sheet-table-wrapper{overflow-x:auto}.result-sheet-table{width:100%;border-collapse:collapse;min-width:560px}.result-sheet-table th,.result-sheet-table td{border:1px solid #e5e7eb;padding:8px 10px;text-align:left}.result-sheet-table th{background-color:#f9fafb}@media print{.no-print,.sidebar,.page-header{display:none!important}.content{padding:0!important}.card{box-shadow:none!important;border:1px solid #d1d5db!important}}.class-frame{display:grid;grid-template-columns:minmax(260px,340px) 1fr;gap:20px;align-items:start;width:100%;min-width:0}.class-card{display:flex;background-color:#fff;padding:18px;flex-direction:column;align-items:stretch;border:1px solid #e5e7eb;border-radius:12px}.class-form-grid{display:flex;flex-direction:column;padding:6px 0 0;gap:15px}.class-form-grid input{height:38px;padding:0 10px;border:1px solid #d1d5db;border-radius:8px}.class-form-grid select{height:38px;padding:0 10px;border:1px solid #d1d5db;border-radius:8px;background-color:#fff}.class-form-grid button{height:40px;border:0;border-radius:8px;cursor:pointer;background-color:#0f766e;color:#fff;font-weight:600}.class-table-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:18px;min-width:0}.class-table-wrapper{max-width:100%;max-height:420px;overflow:auto}.class-table{width:100%;border-collapse:collapse;min-width:560px}.class-table th,.class-table td{text-align:left;padding:10px 8px;border-bottom:1px solid #e5e7eb;vertical-align:middle}.class-table tr{transition:background-color .15s ease}.class-table-row-selected{background-color:#f0fdfa}.class-table th{font-weight:600;color:#374151}.class-table tbody tr:hover{background-color:#f8fafc}.class-table-empty{text-align:center!important;color:#6b7280;padding:14px 8px}.class-students-card{margin-top:20px}.class-students-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.class-students-header button{height:36px;border:0;border-radius:8px;cursor:pointer;background-color:#0f766e;color:#fff;font-weight:600;padding:0 12px}.students-table{min-width:980px}.students-table input,.students-table select{width:100%;height:34px;border:1px solid #d1d5db;border-radius:6px;padding:0 8px;background-color:#fff}.student-actions{display:flex;gap:8px}.student-actions button{height:32px;border:0;border-radius:6px;cursor:pointer;background-color:#0f766e;color:#fff;padding:0 10px;font-size:12px;font-weight:600}.student-actions .danger-btn{background-color:#b91c1c}.incharge-update-group select{width:100%;min-width:180px;height:34px;padding:0 8px;border:1px solid #d1d5db;border-radius:6px;background-color:#fff}@media(max-width:900px){.class-frame{grid-template-columns:1fr}.class-students-header{flex-direction:column;align-items:stretch}}.main-admin{display:grid;grid-template-columns:minmax(320px,1fr) minmax(320px,1fr);gap:18px}.tab-card{border:1px solid #dbe3ef;border-radius:14px;background:linear-gradient(135deg,#0f766e,#0d9488);color:#fff;min-height:130px;display:flex;justify-content:center;align-items:center;font-size:1.1rem;font-weight:700;letter-spacing:.02em;box-shadow:0 14px 24px #0d948840}.teacher-tab-card{background-color:#fff;border:1px solid #dbe3ef;border-radius:14px;padding:18px;display:flex;flex-direction:column;box-shadow:0 10px 20px #0f172a14}.teacher-tab-card h3{margin:0 0 14px;font-size:1rem;color:#0f172a}.teacher-form-grid{display:flex;flex-direction:column;gap:10px}.teacher-form-grid input,.teacher-form-grid select{height:40px;padding:0 10px;border:1px solid #cfd8e6;border-radius:9px;width:100%;background:#f8fafc}.teacher-form-grid button{border-radius:9px;border:1px solid transparent;padding:.62em 1.2em;font-size:.95rem;font-weight:600;background-color:#0e7490;color:#fff;cursor:pointer}.teacher-form-grid button:hover{background-color:#0f5d73}.input-part{display:flex;gap:10px}@media(max-width:980px){.main-admin{grid-template-columns:1fr}.input-part{flex-direction:column}}
