
@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.8e0177b5.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.b97b3418.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.853070df.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_9a252bad-module__rsvCoW__className{font-family:Geist,Geist Fallback;font-style:normal}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.c1fdd6c2.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.799d8ef8.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.dbea232f.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_8ea776c3-module__ryDx5G__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}
:root{--background:#f9fafb;--foreground:#111827;--card:#fff;--card-foreground:#111827;--popover:#fff;--popover-foreground:#111827;--primary:#3b82f6;--primary-dark:#2563eb;--secondary:#6b7280;--secondary-foreground:#fff;--muted:#f3f4f6;--muted-foreground:#6b7280;--accent:#f5f7ff;--accent-foreground:#3b82f6;--destructive:#ef4444;--destructive-foreground:white;--border:#e5e7eb;--input:#e5e7eb;--ring:#3b82f680;--radius:12px;--font-sans:"Inter",system-ui,-apple-system,sans-serif;--font-mono:"Geist Mono",monospace;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-soft:0 10px 15px -3px #0000000d,0 4px 6px -2px #00000005;--color-student:#3b82f6;--color-teacher:#8b5cf6;--color-admin:#111827;--color-success:#10b981;--color-warning:#f59e0b;--color-attendance:#06b6d4;--color-assignments:#f43f5e}.dark{--background:#09090b;--foreground:#f8fafc;--card:#18181b;--card-foreground:#f8fafc;--popover:#18181b;--popover-foreground:#f8fafc;--primary:#3b82f6;--primary-dark:#60a5fa;--secondary:#3f3f46;--secondary-foreground:#f8fafc;--muted:#27272a;--muted-foreground:#a1a1aa;--accent:#1e293b;--accent-foreground:#3b82f6;--destructive:#7f1d1d;--destructive-foreground:#f8fafc;--border:#27272a;--input:#27272a;--ring:#3b82f64d;--shadow-sm:0 1px 2px 0 #0006;--shadow-md:0 4px 6px -1px #00000080,0 2px 4px -1px #0000004d;--shadow-soft:0 10px 15px -3px #0009,0 4px 6px -2px #0006;--color-admin:#f8fafc;--color-attendance:#22d3ee;--color-assignments:#fb7185}*{box-sizing:border-box;border-color:var(--border);margin:0;padding:0}body{background-color:var(--background);color:var(--foreground);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}button{cursor:pointer;font-family:inherit}a{color:inherit;text-decoration:none}.section{background:var(--card);box-shadow:var(--shadow-sm);border:1px solid var(--border);border-radius:12px;padding:24px}.section__header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.section__title{color:var(--foreground);margin:0 0 8px;font-size:28px;font-weight:700}.section__subtitle{color:var(--muted-foreground);margin:0;font-size:14px}.section__subsection-title{color:var(--foreground);margin-bottom:16px;font-size:18px;font-weight:600}.section__stats-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:32px;display:grid}.section__table-wrapper{border:1px solid var(--border);border-radius:8px;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:14px}.data-table thead{background-color:var(--muted);border-bottom:2px solid var(--border)}.data-table th{text-align:left;color:var(--muted-foreground);padding:16px;font-weight:600}.data-table td{border-bottom:1px solid var(--border);color:var(--foreground);padding:16px}.data-table tbody tr:hover{background-color:var(--muted)}.data-table tbody tr:last-child td{border-bottom:none}.badge{white-space:nowrap;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:600;display:inline-block}.badge--active{color:#1e40af;background-color:#dbeafe}.badge--inactive{color:#6b7280;background-color:#f3f4f6}.badge--present{color:#166534;background-color:#dcfce7}.badge--absent{color:#991b1b;background-color:#fee2e2}.badge--late{color:#92400e;background-color:#fef3c7}.badge--completed{color:#065f46;background-color:#d1fae5}.btn{cursor:pointer;border:none;border-radius:6px;align-items:center;gap:8px;padding:10px 16px;font-size:14px;font-weight:500;line-height:normal;text-decoration:none;transition:all .2s;display:inline-flex}.btn--primary{background-color:var(--primary);color:#fff}.btn--primary:hover{background-color:var(--primary-dark)}.btn--gradient{background:var(--primary);color:#fff}.btn--gradient:hover{background-color:var(--primary-dark)}.btn--secondary{background-color:var(--secondary);color:var(--secondary-foreground)}.btn--secondary:hover{background-color:#d1d5db}.btn--danger{color:#991b1b;background-color:#fecaca}.btn--danger:hover{background-color:#fca5a5}.btn--small{border-radius:4px;padding:6px 12px;font-size:12px}@media (max-width:768px){.section{padding:16px}.section__header{flex-direction:column;align-items:flex-start;gap:16px}.section__title{font-size:24px}.section__stats-grid{grid-template-columns:1fr}.data-table{font-size:13px}.data-table th,.data-table td{padding:12px 8px}.btn{padding:8px 12px;font-size:13px}}
