._wrap_12djf_1{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;background:var(--bg)}._brand_12djf_10{display:flex;align-items:center;gap:10px;margin-bottom:32px}._brandIcon_12djf_16{width:40px;height:40px;background:var(--accent);border-radius:10px;display:flex;align-items:center;justify-content:center}._brandIcon_12djf_16 svg{width:22px;height:22px;fill:#fff}._brandName_12djf_23{font-family:DM Mono,monospace;font-size:18px;font-weight:500;color:var(--text);letter-spacing:-.3px}._card_12djf_30{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:40px;box-shadow:var(--shadow)}._card_12djf_30 h1{font-size:22px;font-weight:600;color:var(--text);margin-bottom:6px}._sub_12djf_45{font-size:13.5px;color:var(--muted);margin-bottom:28px}._alert_12djf_50{padding:11px 14px;border-radius:8px;font-size:13px;margin-bottom:18px;background:#fef2f2;border:1px solid #fecaca;color:var(--danger)}._field_12djf_59{margin-bottom:18px}._field_12djf_59 label{display:block;font-size:13px;font-weight:500;color:var(--text);margin-bottom:6px}._field_12djf_59 input{width:100%;padding:11px 14px;border:1px solid var(--border);border-radius:9px;font-size:14px;color:var(--text);background:#fafbfc;transition:border .15s,box-shadow .15s;outline:none}._field_12djf_59 input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1a56db1a;background:#fff}._inputError_12djf_83{border-color:var(--danger)!important}._inputWrap_12djf_84{position:relative}._inputWrap_12djf_84 input{padding-right:40px}._togglePw_12djf_86{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--muted);padding:0;line-height:1}._togglePw_12djf_86:hover{color:var(--text)}._fieldError_12djf_93{display:block;font-size:12px;color:var(--danger);margin-top:5px}._rowMeta_12djf_99{display:flex;justify-content:flex-end;margin-bottom:24px;margin-top:-10px}._rowMeta_12djf_99 a{font-size:13px;color:var(--accent)}._rowMeta_12djf_99 a:hover{text-decoration:underline}._btn_12djf_110{width:100%;padding:12px;background:var(--accent);color:#fff;border:none;border-radius:9px;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s,opacity .15s;display:flex;align-items:center;justify-content:center}._btn_12djf_110:hover{background:var(--accent-hover)}._btn_12djf_110:disabled{opacity:.6;cursor:not-allowed}._spinner_12djf_125{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:_spin_12djf_125 .7s linear infinite}@keyframes _spin_12djf_125{to{transform:rotate(360deg)}}._demoHint_12djf_133{margin-top:18px;padding:10px 14px;background:#1a56db0f;border:1px solid rgba(26,86,219,.15);border-radius:8px;font-size:12px;color:var(--muted);line-height:1.7}._demoHint_12djf_133 span{font-weight:600;color:var(--accent)}._demoHint_12djf_133 code{font-family:DM Mono,monospace;background:#0000000f;padding:1px 5px;border-radius:4px}._footerNote_12djf_150{text-align:center;font-size:12px;color:var(--muted);margin-top:20px}._layout_w8nlo_1{display:flex;min-height:100vh}._sidebar_w8nlo_6{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:20px 0;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform .25s ease}._brand_w8nlo_18{display:flex;align-items:center;gap:10px;padding:0 20px 20px;border-bottom:1px solid var(--border)}._brandIcon_w8nlo_25{width:34px;height:34px;background:var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}._brandIcon_w8nlo_25 svg{width:18px;height:18px;fill:#fff}._brandName_w8nlo_33{font-family:DM Mono,monospace;font-size:15px;font-weight:500;color:var(--text);letter-spacing:-.3px}._roleChip_w8nlo_40{margin:16px 20px 8px}._roleChip_w8nlo_40 span{display:inline-block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--accent);background:var(--accent-light);padding:3px 8px;border-radius:99px}._nav_w8nlo_54{flex:1;padding:8px 12px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}._navItem_w8nlo_62{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;font-size:13.5px;font-weight:500;color:var(--muted);transition:background .15s,color .15s;text-decoration:none}._navItem_w8nlo_62:hover{background:var(--bg);color:var(--text)}._navItem_w8nlo_62._active_w8nlo_78{background:var(--accent-light);color:var(--accent)}._navItem_w8nlo_62 svg{flex-shrink:0}._logoutBtn_w8nlo_83{margin:12px;padding:9px 12px;display:flex;align-items:center;gap:10px;font-size:13.5px;font-weight:500;color:var(--muted);background:none;border:none;border-radius:8px;cursor:pointer;transition:background .15s,color .15s;width:calc(100% - 24px)}._logoutBtn_w8nlo_83:hover{background:#fef2f2;color:var(--danger)}._main_w8nlo_104{flex:1;margin-left:var(--sidebar-w);display:flex;flex-direction:column;min-height:100vh}._topbar_w8nlo_111{height:60px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:50}._menuBtn_w8nlo_123{display:none;background:none;border:none;cursor:pointer;color:var(--text);padding:6px;border-radius:6px}._menuBtn_w8nlo_123:hover{background:var(--bg)}._topbarRight_w8nlo_133{display:flex;align-items:center;gap:10px}._userName_w8nlo_134{font-size:13px;color:var(--muted);font-weight:500}._avatar_w8nlo_139{width:34px;height:34px;background:var(--accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600}._content_w8nlo_148{padding:28px;flex:1}._overlay_w8nlo_152{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:90}@media (max-width: 768px){._sidebar_w8nlo_6{transform:translate(-100%)}._sidebar_w8nlo_6._open_w8nlo_162{transform:translate(0)}._overlay_w8nlo_152{display:block}._main_w8nlo_104{margin-left:0}._menuBtn_w8nlo_123{display:flex}._userName_w8nlo_134{display:none}._content_w8nlo_148{padding:20px 16px}}._page_1wqej_1{display:flex;flex-direction:column;gap:24px}._header_1wqej_2{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}._header_1wqej_2 h1{font-size:22px;font-weight:600;color:var(--text)}._header_1wqej_2 p{font-size:13.5px;color:var(--muted);margin-top:2px}._headerActions_1wqej_5{display:flex;gap:10px;align-items:center;flex-shrink:0}._statsGrid_1wqej_8{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}._statCard_1wqej_13{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow-sm)}._statIcon_1wqej_23{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}._statValue_1wqej_30{font-size:22px;font-weight:600;color:var(--text)}._statLabel_1wqej_31{font-size:12px;color:var(--muted);margin-top:1px}._statChange_1wqej_32{margin-left:auto;font-size:12px;font-weight:600;color:var(--success);font-family:DM Mono,monospace}._statChangeMuted_1wqej_39{color:var(--muted)}._row_1wqej_42{display:grid;grid-template-columns:1fr 1fr;gap:20px}._row3_1wqej_47{display:grid;grid-template-columns:2fr 1fr;gap:20px}._card_1wqej_54{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm)}._card_1wqej_54 h2{font-size:15px;font-weight:600;color:var(--text);margin-bottom:18px;display:flex;align-items:center;justify-content:space-between}._card_1wqej_54 h2 a{font-size:12px;font-weight:500;color:var(--accent)}._card_1wqej_54 h2 a:hover{text-decoration:underline}._table_1wqej_78{width:100%;border-collapse:collapse}._table_1wqej_78 th{text-align:left;font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);padding:0 0 12px;border-bottom:1px solid var(--border);white-space:nowrap}._table_1wqej_78 td{padding:11px 0;font-size:13.5px;color:var(--text);border-bottom:1px solid var(--border)}._table_1wqej_78 th+th,._table_1wqej_78 td+td{padding-left:16px}._table_1wqej_78 tr:last-child td{border-bottom:none}._table_1wqej_78 tr:hover td{background:var(--bg)}._tableWrap_1wqej_101{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}._tableToolbar_1wqej_108{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);gap:12px;flex-wrap:wrap}._tableToolbarLeft_1wqej_117{display:flex;align-items:center;gap:10px}._searchWrap_1wqej_118{position:relative}._searchWrap_1wqej_118 svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}._searchInput_1wqej_127{padding:8px 12px 8px 32px;border:1px solid var(--border);border-radius:8px;font-size:13.5px;color:var(--text);background:var(--bg);outline:none;width:220px;transition:border .15s,box-shadow .15s}._searchInput_1wqej_127:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1a56db1a}._select_1wqej_142{padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:13px;color:var(--text);background:var(--bg);outline:none;cursor:pointer}._tableScroll_1wqej_152{overflow-x:auto}._tableInner_1wqej_153{width:100%;border-collapse:collapse}._tableInner_1wqej_153 th{text-align:left;font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);padding:12px 20px;border-bottom:1px solid var(--border);background:var(--bg);white-space:nowrap}._tableInner_1wqej_153 td{padding:13px 20px;font-size:13.5px;color:var(--text);border-bottom:1px solid var(--border)}._tableInner_1wqej_153 tr:last-child td{border-bottom:none}._tableInner_1wqej_153 tr:hover td{background:#1a56db05}._tablePagination_1wqej_174{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-top:1px solid var(--border);font-size:13px;color:var(--muted)}._paginationBtns_1wqej_183{display:flex;gap:6px}._badge_1wqej_186{display:inline-block;padding:2px 8px;border-radius:99px;font-size:12px;font-weight:500;white-space:nowrap}._badgeGreen_1wqej_194{background:#dcfce7;color:#16a34a}._badgeYellow_1wqej_195{background:#fef9c3;color:#a16207}._badgeRed_1wqej_196{background:#fef2f2;color:#dc2626}._badgeBlue_1wqej_197{background:#eff6ff;color:#1a56db}._badgePurple_1wqej_198{background:#f3e8ff;color:#7c3aed}._badgeGray_1wqej_199{background:#f3f4f6;color:#6b7280}._btn_1wqej_202{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:8px;font-size:13.5px;font-weight:500;cursor:pointer;border:none;transition:background .15s,opacity .15s}._btnPrimary_1wqej_214{background:var(--accent);color:#fff}._btnPrimary_1wqej_214:hover{background:var(--accent-hover)}._btnSecondary_1wqej_216{background:var(--bg);color:var(--text);border:1px solid var(--border)}._btnSecondary_1wqej_216:hover{background:var(--border)}._btnSm_1wqej_218{padding:5px 10px;font-size:12px}._btnDanger_1wqej_219{background:#fef2f2;color:var(--danger);border:1px solid #fecaca}._btnDanger_1wqej_219:hover{background:#fecaca}._detailHeader_1wqej_223{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm)}._detailAvatar_1wqej_233{width:64px;height:64px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:600;flex-shrink:0}._detailName_1wqej_243{font-size:18px;font-weight:600;color:var(--text)}._detailMeta_1wqej_244{font-size:13px;color:var(--muted);margin-top:3px}._infoGrid_1wqej_247{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}._infoItem_1wqej_252 label{font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);display:block;margin-bottom:4px}._infoItem_1wqej_252 span{font-size:14px;color:var(--text)}._empty_1wqej_267{padding:48px 24px;text-align:center;color:var(--muted);font-size:14px}._back_1wqej_275{display:inline-flex;align-items:center;gap:6px;font-size:13.5px;color:var(--muted);margin-bottom:4px;cursor:pointer;background:none;border:none;padding:0}._back_1wqej_275:hover{color:var(--text)}._timetableGrid_1wqej_290{display:grid;gap:10px}._timetableRow_1wqej_294{display:flex;align-items:center;gap:14px;padding:12px 16px;background:var(--bg);border-radius:8px;border:1px solid var(--border)}._timetableTime_1wqej_303{font-family:DM Mono,monospace;font-size:12px;color:var(--muted);width:80px;flex-shrink:0}._timetableSubject_1wqej_310{font-size:14px;font-weight:500;color:var(--text);flex:1}._timetableClass_1wqej_316{font-size:12.5px;color:var(--muted)}._calStrip_1wqej_322{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px}._calDay_1wqej_328{flex-shrink:0;width:52px;padding:10px 6px;border-radius:10px;text-align:center;border:1px solid var(--border);background:var(--bg);cursor:pointer}._calDay_1wqej_328._active_1wqej_338{background:var(--accent);border-color:var(--accent)}._calDayName_1wqej_339{font-size:11px;color:var(--muted);text-transform:uppercase}._calDay_1wqej_328._active_1wqej_338 ._calDayName_1wqej_339{color:#ffffffb3}._calDayNum_1wqej_341{font-size:16px;font-weight:600;color:var(--text);margin-top:2px}._calDay_1wqej_328._active_1wqej_338 ._calDayNum_1wqej_341{color:#fff}._feeSummary_1wqej_345{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}._feeStat_1wqej_350{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:16px}._feeStatLabel_1wqej_356{font-size:12px;color:var(--muted);margin-bottom:6px}._feeStatValue_1wqej_357{font-size:20px;font-weight:600;color:var(--text)}._feeStatValue_1wqej_357._danger_1wqej_358{color:var(--danger)}._feeStatValue_1wqej_357._success_1wqej_359{color:var(--success)}._announcementList_1wqej_362{display:flex;flex-direction:column;gap:12px}._announcementItem_1wqej_363{padding:14px 16px;border:1px solid var(--border);border-radius:10px;background:var(--bg)}._announcementTitle_1wqej_369{font-size:14px;font-weight:600;color:var(--text)}._announcementMeta_1wqej_370{font-size:12px;color:var(--muted);margin-top:4px}._announcementBody_1wqej_371{font-size:13.5px;color:var(--text);margin-top:8px;line-height:1.55}._modalOverlay_1wqej_374{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}._modal_1wqej_374{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:28px;width:100%;max-width:480px;box-shadow:0 20px 60px #00000026}._modal_1wqej_374 h3{font-size:16px;font-weight:600;color:var(--text);margin-bottom:20px}._formGrid_1wqej_394{display:grid;grid-template-columns:1fr 1fr;gap:14px}._formField_1wqej_395{display:flex;flex-direction:column;gap:5px}._formField_1wqej_395._full_1wqej_396{grid-column:1 / -1}._formField_1wqej_395 label{font-size:12.5px;font-weight:500;color:var(--text)}._formField_1wqej_395 input,._formField_1wqej_395 select,._formField_1wqej_395 textarea{padding:9px 12px;border:1px solid var(--border);border-radius:8px;font-size:13.5px;color:var(--text);background:var(--bg);outline:none;transition:border .15s,box-shadow .15s;font-family:inherit}._formField_1wqej_395 input:focus,._formField_1wqej_395 select:focus,._formField_1wqej_395 textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1a56db1a}._formField_1wqej_395 textarea{resize:vertical;min-height:80px}._modalActions_1wqej_414{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}@media (max-width: 900px){._row_1wqej_42,._row3_1wqej_47{grid-template-columns:1fr}}@media (max-width: 600px){._statsGrid_1wqej_8{grid-template-columns:1fr 1fr}._formGrid_1wqej_394{grid-template-columns:1fr}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f4f6f9;--surface: #ffffff;--border: #e2e6ed;--text: #0f172a;--muted: #64748b;--accent: #1a56db;--accent-hover: #1648c2;--accent-light: rgba(26,86,219,.08);--danger: #dc2626;--success: #16a34a;--warning: #d97706;--shadow: 0 1px 3px rgba(0,0,0,.07), 0 4px 16px rgba(0,0,0,.06);--shadow-sm: 0 1px 3px rgba(0,0,0,.07);--radius: 12px;--radius-sm: 8px;--sidebar-w: 240px}body{font-family:DM Sans,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}button,input,select,textarea{font-family:DM Sans,sans-serif}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--muted)}
