:root{color-scheme:light}body{margin:0;display:block;min-width:0;line-height:1.5;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:#f6f7fb;color:#0f172a}a{color:inherit;text-decoration:none}a:hover{text-decoration:underline}button{font:inherit;border:1px solid transparent;border-radius:8px;background:transparent;cursor:pointer}button:focus{outline:2px solid #2563eb33;outline-offset:2px}:root{--bg:#f7f7fb;--card:#ffffff;--text:#0f172a;--muted:#6b7280;--primary:#2070e8;--primary-600:#305ae1;--link:#2563eb;--ring: 0 10px 30px rgba(2,8,23,.06);--border:#eef2f7;--topbar-bg: rgba(246,247,251,.75);--aside-bg: linear-gradient(180deg, rgba(220,226,233,1) 0%, rgba(175,200,230,1) 100%);--table-head:#f8fafc}:root[data-theme=dark]{--bg:#0b1220;--card:#111827;--text:#ffffff;--muted:#94a3b8;--primary:#60a5fa;--primary-600:#3b82f6;--link:#93c5fd;--ring: 0 10px 30px rgba(0,0,0,.5);--border:#1f2937;--topbar-bg: rgba(17,24,39,.6);--aside-bg: linear-gradient(180deg, rgba(30,41,59,1) 0%, rgba(17,24,39,1) 100%);--table-head:#0f172a}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:var(--bg)}.header{position:fixed;top:0;left:0;right:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:16px 32px;background:var(--card);border-bottom:1px solid var(--border);box-shadow:var(--ring)}.brand{font-weight:700;font-size:20px;color:var(--primary)}.meta{font-size:14px;color:var(--text);display:flex;align-items:center;gap:12px}.header .logout-btn{padding:6px 12px;border-radius:8px;background:var(--primary);color:#fff;border:none;font-weight:600;cursor:pointer;transition:background .2s ease}.header .logout-btn:hover{background:var(--primary-600)}.container{width:100%;max-width:none;margin:0 auto;padding:24px 20px}.link{color:var(--link);text-decoration:none}.link:hover{text-decoration:underline}.card{background:var(--card);border:1px solid var(--border);padding:18px;border-radius:14px;box-shadow:var(--ring);width:100%}.navbar{display:flex;justify-content:space-between;align-items:center;background:var(--card);border-bottom:1px solid var(--border);padding:10px 24px;box-shadow:var(--ring);position:sticky;top:0;z-index:20}.nav-left{display:flex;align-items:center;gap:8px}.nav-logo{font-size:20px}.nav-brand{font-size:16px;font-weight:700;color:var(--text)}.nav-center{display:flex;gap:24px}.nav-link{position:relative;font-weight:500;color:var(--muted);text-decoration:none;padding:8px 0}.nav-link:hover{color:var(--primary)}.nav-link.active{color:var(--primary);font-weight:600}.nav-link.active:after{content:"";position:absolute;bottom:-4px;left:0;right:0;height:2px;background:var(--primary);border-radius:2px}.nav-right{display:flex;align-items:center;gap:12px}.nav-profile{font-weight:600;color:var(--text)}.nav-bell{background:none;border:none;cursor:pointer;color:var(--muted)}.nav-bell:hover{color:var(--primary)}.logout-btn{padding:6px 14px;border-radius:8px;background:#2563eb;color:#fff;font-weight:600;border:none;cursor:pointer}.logout-btn:hover{background:#1d4ed8}.badge-new{margin-left:6px;font-size:10px;font-weight:700;padding:2px 6px;border-radius:999px;background:#dbeafe;color:#1d4ed8}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px;border-radius:10px;border:1px solid transparent;font-weight:600;cursor:pointer;transition:.15s ease-in-out}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-600)}.input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:var(--card);outline:none}.input:focus{border-color:#cbd5e1;box-shadow:0 0 0 3px #2563eb26}.table{width:100%;border-collapse:collapse}.th,.td{padding:10px;border-bottom:1px solid var(--border);text-align:left}.t-muted{color:var(--muted)}.h1{font-size:28px;margin:16px 0}.h2{font-size:20px;margin:16px 0}.center-screen{position:fixed;inset:0;display:flex;justify-content:center;align-items:center;background:var(--bg);z-index:0}.auth-card{width:380px}.center-dashboard{position:static;inset:auto;display:block;background:transparent;overflow:visible;padding-top:0}.alert{padding:12px 16px;border-radius:8px;margin-top:12px;margin-bottom:16px;font-weight:500}.alert-success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.page.admin-panel{max-width:1080px;width:100%;margin:0 auto;padding:16px}.page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:12px}.page-title .h1{margin:0}.breadcrumb{color:var(--muted);font-size:14px}.crumb-sep{margin:0 6px;color:var(--muted)}.page-actions{display:flex;align-items:center;justify-content:flex-end;gap:12px;flex-wrap:wrap}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:16px}.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.field{display:flex;flex-direction:column;gap:6px;min-width:220px}.label{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.select{appearance:auto}.card-section .section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.grid-range{grid-template-columns:repeat(2,minmax(0,1fr))}.actions-range{display:flex;align-items:flex-end;gap:8px}@media (min-width: 768px){.grid-range{grid-template-columns:repeat(3,minmax(0,1fr)) auto}}.grid.grid-range{column-gap:20px;row-gap:16px}.table-responsive{overflow:auto;border-radius:12px;border:1px solid var(--border)}.table-wrap{width:100%}.table-empty{padding:28px 20px;border-radius:12px;border:1px dashed var(--border);background:var(--card);text-align:center;font-weight:600;color:var(--muted)}.empty-icon{width:24px;height:24px;margin:0 auto 6px;opacity:.55;background:var(--table-head);border:1px solid var(--border);border-radius:6px}.mt-sm{margin-top:8px}.mb-sm{margin-bottom:8px}.link-primary{color:var(--link);text-decoration:none;font-weight:700}.link-primary:hover{text-decoration:underline}.btn-ghost{background:var(--card);border:1px solid var(--border);color:var(--text)}.btn-ghost:hover{background:var(--table-head)}@media (max-width: 720px){.table{border:0}.table thead{display:none}.table tbody tr{display:block;border:1px solid var(--border);border-radius:12px;margin-bottom:12px;background:var(--card);box-shadow:var(--ring);overflow:hidden}.table .td{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid #f1f5f1}.table .td:last-child{border-bottom:0}.table .td:before{content:attr(data-label);font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}}@media (min-width: 721px){.table thead th{position:sticky;top:0;background:var(--table-head);z-index:1}}.stats .stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.stat-card{background:var(--card, #fff);border:1px solid var(--border, #e6e8eb);border-radius:14px;padding:14px 16px;box-shadow:0 8px 24px #0208170d}.stat-card .stat-label{font-size:12px;color:var(--muted, #667085)}.stat-card .stat-value{font-size:22px;font-weight:700;margin-top:4px}.stat-info{border-color:#bfdbfe;background:#eff6ff}.stat-info .stat-label{color:#1d4ed8}.stat-success{border-color:#bbf7d0;background:#f0fdf4}.stat-warn{border-color:#fde68a;background:#fffbeb}.stat-danger{border-color:#fecaca;background:#fee2e2}.stat-success .stat-label{color:#065f46}.stat-warn .stat-label{color:#92400e}.stat-danger .stat-label{color:#991b1b}:root[data-theme=dark] .stat-success{background:#0a1f1a;border-color:#134e4a}:root[data-theme=dark] .stat-warn{background:#2a1e0a;border-color:#854d0e}:root[data-theme=dark] .stat-danger{background:#2a0e0e;border-color:#7f1d1d}:root[data-theme=dark] .stat-card .stat-value{color:var(--text)}:root[data-theme=dark] .stat-success .stat-label{color:#22c55e}:root[data-theme=dark] .stat-warn .stat-label{color:#f59e0b}:root[data-theme=dark] .stat-danger .stat-label{color:#ef4444}.field-inline{display:inline-flex;align-items:center;gap:8px}.field-inline .select{min-width:220px}.section-head .muted{color:var(--muted, #667085);font-size:13px;margin-top:4px}.table-sticky thead th{position:sticky;top:0;background:var(--table-head);z-index:1;box-shadow:inset 0 -1px 0 var(--border, #e6e8eb)}.table-empty{border:1px dashed var(--border, #e6e8eb);padding:28px;text-align:center;border-radius:12px;color:var(--muted, #667085)}.table-empty .empty-icon{width:42px;height:42px;border-radius:50%;margin:0 auto 10px;background:linear-gradient(180deg,#eef2ff,#f8fafc);border:1px solid var(--border, #e6e8eb)}@media (max-width: 820px){.stats .stats-grid{grid-template-columns:1fr 1fr}}@media (max-width: 560px){.stats .stats-grid{grid-template-columns:1fr}.field-inline .select{min-width:160px}}:root[data-theme=dark] .card,:root[data-theme=dark] .btn-ghost,:root[data-theme=dark] .table tbody tr,:root[data-theme=dark] .table thead th,:root[data-theme=dark] .table-empty,:root[data-theme=dark] .table-wrap,:root[data-theme=dark] .mu-user-table thead,:root[data-theme=dark] .mu-user-table tbody tr,:root[data-theme=dark] .mc-mode-btn,:root[data-theme=dark] .mc-mode-btn-active,:root[data-theme=dark] .mc-chip,:root[data-theme=dark] .mc-class-empty,:root[data-theme=dark] .mu-role-chip,:root[data-theme=dark] .mu-class-chip,:root[data-theme=dark] .mu-menu,:root[data-theme=dark] .mu-modal,:root[data-theme=dark] .mu-modal-select,:root[data-theme=dark] .mu-menu-trigger,:root[data-theme=dark] .ap-card,:root[data-theme=dark] .ap-link,:root[data-theme=dark] .pill,:root[data-theme=dark] .navbar,:root[data-theme=dark] .input,:root[data-theme=dark] .card p,:root[data-theme=dark] .card h2,:root[data-theme=dark] .card h3{background:var(--card)!important;color:var(--text)!important;border-color:var(--border)!important;box-shadow:var(--ring)}:root[data-theme=dark] .stat-success,:root[data-theme=dark] .stat-warn,:root[data-theme=dark] .stat-danger,:root[data-theme=dark] .mc-mode-btn-active,:root[data-theme=dark] .mc-chip-on,:root[data-theme=dark] .mu-role-chip-active,:root[data-theme=dark] .mu-class-chip-on{background:var(--card)!important}:root[data-theme=dark] .stat-info{background:#0a1b2a;border-color:#1e3a8a}:root[data-theme=dark] .stat-info .stat-label{color:#93c5fd}:root[data-theme=dark] .student-attendance-page{background:var(--bg)!important;color:var(--text)!important}:root[data-theme=dark] .student-attendance-page p{color:var(--muted)!important}.mc-wrap{max-width:980px;margin:0 auto;display:grid;gap:16px}.mc-card{padding:16px 16px 12px;border-radius:16px;box-shadow:0 4px 24px #0000000d}.mc-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.mc-eyebrow{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.mc-title{margin:2px 0 0;font-size:18px;font-weight:700}.mc-subline{font-size:13px;color:var(--muted);margin:6px 0 0;max-width:460px}.mc-mode-toggle{display:flex;flex-wrap:wrap;gap:10px}.mc-mode-btn{flex:1 1 200px;min-width:180px;border:1px solid var(--border);border-radius:12px;padding:10px 14px;background:var(--card);font-weight:600;color:var(--text);cursor:pointer;text-align:left;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.mc-mode-btn:hover{border-color:#2563eb;box-shadow:0 10px 24px #2563eb26;transform:translateY(-1px)}.mc-mode-btn-active{border-color:#2563eb;background:#eff6ff;color:#1d4ed8;box-shadow:0 14px 28px #2563eb2e}.mc-mode-btn-active:hover{border-color:#2563eb}.mc-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.mc-col-span-2{grid-column:1 / -1}.mc-actions{display:flex;gap:8px;justify-content:flex-end}.mc-assign{display:grid;gap:12px}.mc-chips{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px}.mc-chip{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:12px;cursor:pointer;transition:background .15s,border-color .15s}.mc-chip input{accent-color:#2563eb}.mc-chip:hover{background:var(--table-head);border-color:var(--border)}.mc-chip-on{background:#eff6ff;border-color:#bfdbfe}.mc-class-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:12px}.mc-class-sub{font-size:13px;color:var(--muted);margin:6px 0 0;max-width:440px}.mc-class-count{font-size:12px;font-weight:600;color:#2563eb;background:#eff6ff;border-radius:999px;padding:4px 10px}.mc-class-chip-name{font-weight:600;color:var(--text)}.mc-class-chip-code{font-size:12px;color:var(--muted)}.mc-class-empty{padding:14px;border:1px dashed #cbd5e1;border-radius:12px;background:#f8fafc;text-align:center}@media (max-width: 640px){.mc-mode-btn{flex:1 1 100%;min-width:100%}}.mc-banner{padding:6px 10px;border-radius:10px;font-size:13px;white-space:nowrap}.mc-ok{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.mc-err{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.mc-ghost{border-color:#d1d5db}.mc-ghost:hover{background:#f9fafb}.mc-danger{border-color:#ef4444;color:#ef4444}.mc-danger:hover{background:#fef2f2}.mc-table-wrap{overflow:auto;border-radius:12px;border:1px solid #e5e7eb}.mc-table{width:100%;border-collapse:separate;border-spacing:0}.mc-table thead th{position:sticky;top:0;background:#fafafa;z-index:1}.mc-table th,.mc-table td{padding:10px 12px}.mc-table tbody tr:nth-child(2n){background:#fcfcfd}.mc-col-actions{width:110px;text-align:right}.mu-create-card{margin-bottom:28px}.mu-create-form{display:grid;gap:20px}.mu-create-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:16px}.mu-create-eyebrow{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700}.mu-create-title{font-size:24px;font-weight:700;color:var(--text);margin-top:4px}.mu-create-sub{margin:6px 0 0;font-size:14px;color:var(--muted);max-width:420px}.mu-create-role-pill{align-self:flex-start;padding:6px 12px;border-radius:999px;background:#eff6ff;color:#1d4ed8;font-weight:600;text-transform:capitalize}.mu-create-banner{margin:0;border-radius:12px}.mu-field-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.mu-field{display:flex;flex-direction:column;gap:6px}.mu-field-label{font-size:12px;font-weight:700;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}.mu-role-toggle{display:flex;flex-wrap:wrap;gap:12px}.mu-role-chip{flex:1 1 200px;min-width:200px;border:1px solid var(--border);border-radius:14px;padding:12px 14px;display:flex;flex-direction:column;gap:6px;text-align:left;background:var(--card);cursor:pointer;transition:all .15s ease}.mu-role-chip:hover{border-color:#2563eb;box-shadow:0 12px 28px #2563eb1f;transform:translateY(-1px)}.mu-role-chip-active{border-color:#2563eb;background:#eff6ff;box-shadow:0 16px 32px #2563eb2e}.mu-role-chip-label{font-weight:700;color:var(--text)}.mu-role-chip-sub{font-size:13px;color:var(--muted);line-height:1.35}.mu-class-section{display:grid;gap:14px}.mu-class-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:12px}.mu-class-sub{font-size:13px;color:var(--muted);margin:6px 0 0}.mu-class-count{font-size:12px;font-weight:600;color:#2563eb;background:#eff6ff;border-radius:999px;padding:4px 10px}.mu-class-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.mu-class-chip{border:1px solid var(--border);border-radius:12px;padding:10px 12px;display:flex;align-items:center;gap:10px;background:var(--card);cursor:pointer;transition:all .15s ease}.mu-class-chip input{margin:0;flex-shrink:0;accent-color:#2563eb}.mu-class-chip:hover{border-color:#2563eb;background:var(--table-head)}.mu-class-chip-on{border-color:#2563eb;background:#eff6ff;box-shadow:0 0 0 2px #2563eb1f inset}.mu-class-chip-name{font-weight:600;color:var(--text)}.mu-class-chip-code{font-size:12px;color:var(--muted)}.mu-class-empty{padding:14px;border:1px dashed #cbd5e1;border-radius:12px;background:#f8fafc}.mu-create-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.mu-btn-secondary{background:var(--table-head);color:var(--text);border:1px solid var(--border)}.mu-btn-secondary:hover{background:#e2e8f0}.mu-table-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:20px}.mu-table-header-left{display:flex;flex-direction:column;gap:6px;max-width:540px}.mu-table-eyebrow{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700}.mu-table-title{font-size:24px;font-weight:700;color:var(--text)}.mu-table-sub{margin:6px 0 0;font-size:14px;color:var(--muted);line-height:1.5}.mu-table-meta{margin-top:10px;font-size:13px;color:var(--muted)}.mu-table-metrics{display:flex;align-items:stretch;gap:12px}.mu-metric{min-width:110px;padding:14px 16px;border-radius:16px;background:var(--card);border:1px solid var(--border);display:flex;flex-direction:column;gap:6px;align-items:flex-start}.mu-metric-positive{background:#ecfdf5;border-color:#bbf7d0}.mu-metric-muted{background:#fef3f2;border-color:#fecaca}.mu-metric-count{font-size:20px;font-weight:700;color:var(--text)}.mu-metric-label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}:root[data-theme=dark] .mu-metric-positive{background:#0a1f1a;border-color:#134e4a}:root[data-theme=dark] .mu-metric-muted{background:#2a0e0e;border-color:#7f1d1d}:root[data-theme=dark] .mu-metric-positive .mu-metric-label{color:#22c55e}:root[data-theme=dark] .mu-metric-muted .mu-metric-label{color:#ef4444}.mu-table-toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-bottom:18px}.mu-toolbar-actions{margin-left:auto;display:flex;gap:8px;align-items:center}.mu-toolbar-btn{min-width:120px}.mu-table-alert{margin-bottom:16px}.mu-table-empty{padding:36px 24px;border-radius:14px;border:1px dashed var(--border);background:var(--card);text-align:center;font-weight:600}.mu-table-wrap{overflow:auto;border-radius:14px;border:1px solid var(--border);box-shadow:inset 0 1px #0f172a05}.mu-status-cell{width:110px}.mu-status-pill{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600}.mu-status-active{background:#ecfdf5;color:#047857}.mu-status-inactive{background:#fef2f2;color:#b91c1c}:root[data-theme=dark] .mu-status-active{background:#0a1f1a;color:#22c55e;border:1px solid #134e4a}:root[data-theme=dark] .mu-status-inactive{background:#2a0e0e;color:#ef4444;border:1px solid #7f1d1d}@media (max-width: 640px){.mu-table-header{gap:16px}.mu-table-metrics{width:100%}.mu-metric{flex:1 1 auto;align-items:center}.mu-toolbar-actions{width:100%;justify-content:flex-start}}@media (max-width: 640px){.mu-role-chip{flex:1 1 100%}}.mu-table-card{padding:20px 20px 24px}.mu-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.mu-header-left{display:flex;flex-direction:column;gap:4px}.mu-title{font-size:22px;font-weight:700}.mu-count-pill{padding:4px 10px;border-radius:999px;background:var(--table-head);color:var(--muted);font-size:13px;font-weight:600}.mu-filter-bar{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-bottom:16px}.mu-search{position:relative;flex:1 1 220px;max-width:320px}.mu-search .input{padding-left:40px;height:42px}.mu-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;opacity:.5;pointer-events:none}.mu-filter{display:flex;flex-direction:column;gap:6px;min-width:160px}.mu-filter-label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-left:4px}.mu-filter .input{height:42px;min-width:160px;margin-top:-2px}.mu-user-table thead{background:var(--table-head);color:var(--text)}.mu-user-table thead th{font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);padding:12px}.mu-user-table tbody tr{transition:background .15s ease}.mu-user-table tbody tr:nth-child(2n){background:var(--card)}.mu-user-table tbody tr:hover{background:#e8f2ff}.mu-user-row-inactive{opacity:.6}.mu-user-row-inactive .mu-role-pill{background:var(--table-head);color:var(--muted)}.mu-user-table .td{padding:14px 12px;vertical-align:middle}.mu-name-cell{min-width:220px}.mu-name{font-weight:600;color:var(--text)}.mu-email{font-size:13px;color:var(--muted)}.mu-role-cell{width:120px}.mu-role-pill{display:inline-flex;align-items:center;justify-content:center;padding:3px 10px;border-radius:999px;font-weight:600;font-size:12px;text-transform:capitalize}.mu-role-student{background:#e0f2fe;color:#0369a1}.mu-role-teacher{background:#fef3c7;color:#92400e}.mu-role-admin{background:#dcfce7;color:#047857}.mu-role-unknown{background:#e2e8f0;color:#475569}:root[data-theme=dark] .mu-role-student{background:#0a1b2a;color:#93c5fd;border:1px solid #1e3a8a}:root[data-theme=dark] .mu-role-teacher{background:#2a1e0a;color:#f59e0b;border:1px solid #854d0e}:root[data-theme=dark] .mu-role-admin{background:#0a1f1a;color:#22c55e;border:1px solid #134e4a}:root[data-theme=dark] .mu-role-unknown{background:var(--table-head);color:var(--muted);border:1px solid var(--border)}.mu-date-cell{width:180px;display:flex;flex-direction:column;align-items:flex-start;gap:4px}.mu-date-main{font-weight:600;color:var(--text)}.mu-date-sub{font-size:12px;color:var(--muted)}.mu-actions-cell{position:relative;width:110px;text-align:right}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.mu-menu-trigger{width:40px;height:40px;border-radius:999px;border:1px solid var(--border);background:var(--table-head);color:var(--text);font-size:16px;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:inset 0 -1px #0f172a14;transition:background .15s ease,border-color .15s ease,transform .15s ease}.mu-menu-trigger:hover{background:#e2e8f0;border-color:#cbd5d9;transform:translateY(-1px)}.mu-menu{position:absolute;right:0;top:calc(100% + 8px);min-width:220px;padding:6px 0;border-radius:12px;border:1px solid var(--border);background:var(--card);box-shadow:0 18px 36px #0f172a1f;z-index:20}.mu-menu-item{width:100%;padding:10px 16px;background:none;border:none;text-align:left;font-size:14px;font-weight:600;color:var(--text);cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background .15s ease,color .15s ease}.mu-menu-item:hover{background:var(--table-head)}.mu-modal-backdrop{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:40;padding:16px}.mu-modal{background:var(--card);border-radius:16px;padding:24px;width:100%;max-width:360px;box-shadow:0 24px 48px #0f172a33;display:flex;flex-direction:column;gap:16px}.mu-modal-title{font-size:18px;font-weight:700;color:var(--text)}.mu-modal-desc{font-size:13px;color:var(--muted)}.mu-modal-field{display:flex;flex-direction:column;gap:6px}.mu-modal-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.mu-modal-input,.mu-modal-select{height:42px;border-radius:10px;border:1px solid var(--border);padding:0 12px;font-weight:600;background:var(--card);color:var(--text)}.mu-modal-input:focus,.mu-modal-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.mu-modal-error{font-size:13px;color:#b91c1c}.mu-modal-actions{display:flex;justify-content:flex-end;gap:8px}.mu-modal-btn{padding:10px 16px;border-radius:10px;border:none;font-weight:600;cursor:pointer;transition:background .15s ease,color .15s ease,opacity .15s ease}.mu-modal-btn[disabled]{opacity:.6;cursor:not-allowed}.mu-modal-btn-primary{background:#2563eb;color:#fff}.mu-modal-btn-primary:hover{background:#1d4ed8}.mu-modal-btn-secondary{background:var(--table-head);color:var(--text)}.mu-modal-btn-secondary:hover{background:#e2e8f0}.mc-table-toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:12px}.mc-search{display:flex;align-items:center;gap:8px;max-width:520px;width:100%}.mc-search .input{flex:1 1 auto}.mc-search-icon{width:20px!important;height:20px!important;flex:0 0 20px;color:var(--muted)}.mc-search svg{width:20px!important;height:20px!important;max-width:none}.mc-col-actions{width:90px;text-align:right}.mc-student-count-pill{display:inline-block;min-width:86px;text-align:center;padding:4px 10px;border-radius:999px;background:var(--table-head);border:1px solid var(--border);font-weight:700;font-size:12px;color:var(--text)}.mc-table-toolbar{gap:14px}.mc-kpis{display:flex;gap:12px;align-items:stretch;flex-wrap:wrap}.mc-kpi{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:14px 18px;min-width:160px;text-align:center;box-shadow:0 6px 24px #0f172a0f}.mc-kpi-value{font-size:28px;font-weight:800;line-height:1;color:var(--text)}.mc-kpi-label{margin-top:6px;font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.mc-col-center{text-align:center;width:150px}.mc-center{text-align:center}.mc-class-name{font-weight:700;color:var(--text);display:inline-block;margin-left:4px}.mc-code-pill{display:inline-block;padding:6px 10px;border-radius:999px;background:var(--table-head);border:1px solid var(--border);font-weight:700;font-size:12px;color:var(--text);letter-spacing:.02em}.mc-col-class{text-align:left!important;padding-left:16px}.mc-table thead th{background:var(--table-head);font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);position:sticky;top:0;z-index:1}.mc-table th.mc-col-center{text-align:center}.mc-table th.mc-col-actions{text-align:right;width:110px}.mc-table td.mc-center{text-align:center}.mc-col-class{min-width:220px}.mc-col-code{width:140px}.mc-student-count-pill{display:inline-block;min-width:100px;text-align:center;padding:6px 12px;border-radius:999px;background:var(--table-head);border:1px solid var(--border);font-weight:700;font-size:12px;color:var(--text)}.mc-class-cell{font-weight:700;color:var(--text)}.mc-col-code{text-align:left}.mc-pill-btn{cursor:pointer}.mc-pill-btn:disabled{cursor:not-allowed}.ap-nav{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.ap-link{padding:8px 12px;border-radius:10px;font-weight:700;color:var(--muted);text-decoration:none;border:1px solid var(--border);background:var(--card)}.ap-link:hover{background:var(--table-head)}.ap-active{color:#1d4ed8;border-color:#bfdbfe;background:#eff6ff}.nav-badge-new{margin-left:6px;padding:2px 6px;border-radius:999px;font-size:10.5px;font-weight:800;letter-spacing:.06em;color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.tt-inline-time{display:grid;grid-template-columns:1fr;gap:6px}.tt-time-label{font-size:12px;font-weight:600;color:var(--muted)}.tt-time-row{display:flex;gap:12px;align-items:center}.tt-time-row .input,.mu-modal .tt-time-row .mu-modal-input{flex:1}.tt-sep{font-weight:600;color:var(--text)}.mu-menu-trigger{width:32px;height:32px;border-radius:8px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;font-size:18px;line-height:1;padding:0}.mu-menu-trigger:hover{background:#f9fafb}.mu-menu{position:absolute;right:0;top:36px;min-width:180px;z-index:20;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:6px;box-shadow:0 8px 24px #00000014}.mu-menu-item{width:100%;text-align:left;border:0;background:transparent;cursor:pointer;padding:8px 10px;border-radius:8px;font-size:14px}.mu-menu-item:hover{background:#f3f4f6}.mu-menu-item-danger{color:#b91c1c}.mu-menu-item-danger:hover{background:#fee2e2;color:#991b1b}@media (max-width: 640px){.mu-filter-bar{align-items:stretch}.mu-filter{width:100%;align-items:flex-start;text-align:left}.mu-filter .input{width:100%;margin-top:0}}.app-shell{display:flex;min-height:100vh;background:var(--bg, #f6f7fb)}.app-aside{position:fixed;z-index:1000;top:0;left:0;width:248px;height:100vh;background:linear-gradient(180deg,#f5f6fa,#edf0f4);border-right:1px solid #e6e8ef;box-shadow:0 1px 3px #0000000a;padding:12px;display:flex;flex-direction:column;gap:10px;overflow-y:auto;overscroll-behavior:contain}.app-user-footer{position:sticky;bottom:12px}.app-main{margin-left:248px;min-width:0;display:flex;flex-direction:column;padding-left:16px;padding-right:16px}.app-topbar{position:sticky;top:0;z-index:10;background:#f6f7fbbf;-webkit-backdrop-filter:saturate(1.1) blur(6px);backdrop-filter:saturate(1.1) blur(6px);border-bottom:1px solid #e5e7eb}.app-topbar-inner{max-width:100%;margin:0;padding:10px 20px;display:flex;align-items:center;gap:12px}.app-content{max-width:100%;width:100%;margin:16px 0 24px;padding:0}@media (max-width: 1024px){.app-main{margin-left:0}}.profile-page .profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px}.profile-page .card{background:var(--card, #fff);border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:0 10px 30px #0208170f}.profile-page .profile-header{display:flex;align-items:center;gap:24px;margin-bottom:16px}.profile-page .avatar-frame{position:relative;width:176px;height:176px}.profile-page .avatar-ring{width:176px;height:176px;border-radius:50%;display:grid;place-items:center;border:4px solid var(--primary);background:#fff}.profile-page .avatar{width:160px;height:160px;border-radius:50%;object-fit:cover}.profile-page .avatar-initials{display:flex;align-items:center;justify-content:center;background:#e2e8f0;color:#475569;font-size:48px;font-weight:800}.profile-page .camera-badge{position:absolute;right:12px;bottom:12px;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:var(--primary);color:#fff;font-size:18px;box-shadow:0 6px 16px #2563eb59;cursor:pointer;border:2px solid #fff}.profile-page .name-stack{display:flex;flex-direction:column;gap:8px}.profile-page .name{margin:0;font-size:28px;font-weight:800;color:var(--text)}.profile-page .role-pill{display:inline-flex;align-items:center;height:24px;padding:0 10px;border-radius:999px;font-size:12px;font-weight:700}.profile-page .role-pill.light{background:#eef2f7;color:#475569;border:1px solid #e5e7eb}.profile-page .form{display:flex;flex-direction:column;gap:30px}.profile-page .back-link{margin-top:24px}.profile-page .breadcrumb{font-size:14px;color:var(--muted);margin-bottom:8px}.profile-page .page-title{margin:0 0 24px}@media (max-width: 900px){.profile-page .profile-grid{grid-template-columns:1fr}.profile-page .profile-header{flex-direction:column;align-items:center;text-align:center}.profile-page .name-stack{align-items:center}}.student-attendance-page{font-family:Inter,sans-serif;color:var(--text);padding:20px;background:var(--bg)}.attendance-header h2{font-size:24px;font-weight:700;margin:0}.attendance-header p{color:var(--muted);margin-top:4px;margin-bottom:20px}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px}.card{background:var(--card);border-radius:12px;box-shadow:0 4px 12px #0000000f;padding:20px}.card h3{font-size:24px;color:var(--text);margin:0}.card p{color:var(--muted);font-size:14px;margin:6px 0 0}.circle{width:90px;height:90px;border-radius:50%;border:6px solid #4f46e5;margin:0 auto 8px;display:flex;align-items:center;justify-content:center}.percent{font-size:20px;font-weight:700;color:#4f46e5}.toggle-section{display:flex;justify-content:center;margin-bottom:12px}.tabs button{background:#e5e7eb;border:none;padding:8px 18px;border-radius:8px;margin:0 4px;font-weight:600;cursor:pointer;transition:background .2s}.tabs button.active{background:#4f46e5;color:#fff}.attendance-table table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000000a}.attendance-table th,.attendance-table td{text-align:left;padding:12px 16px;border-bottom:1px solid #f1f1f1}.attendance-table th{background:#f9fafb;color:#374151;font-weight:600}.attendance-table a{color:#2563eb;text-decoration:none;font-weight:500}.attendance-footer{display:flex;flex-direction:column;align-items:center;gap:10px;margin-top:30px}.request-btn{background:#2563eb;color:#fff;border:none;padding:10px 18px;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s}.request-btn:hover{background:#1d4ed8}.attendance-footer a{color:#2563eb;font-size:14px;text-decoration:underline}.grid{display:grid}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.gap-12{gap:12px}.gap-20{gap:20px}.items-end{align-items:end}.items-center{align-items:center}.flex{display:flex}.w-full{width:100%}.small{font-size:.9rem}.mb-4{margin-bottom:4px}.pill{padding:.25rem .6rem;border-radius:999px;background:#eef0f4;font-weight:600}.pill-success{background:#e8faf0;color:#137a39}.pill-warn{background:#fff6e5;color:#a05a00}.pill-danger{background:#feecec;color:#b42318}.btn-blue{background:#2e6cf6;color:#fff;border:none;padding:10px 14px;border-radius:10px}
