@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap);:root{--primary:#00a99d;--primary-dark:#007f75;--primary-light:#e0f5f4;--primary-xlight:#f0fafa;--accent-orange:#f7941d;--accent-pink:#e91e8c;--accent-green:#4caf50;--accent-blue:#2196f3;--sidebar-bg:#00a99d;--sidebar-width:230px;--sidebar-collapsed:64px;--navbar-height:60px;--text-dark:#1a2332;--text-mid:#4a5568;--text-light:#718096;--border:#e2e8f0;--bg:#f4f6f9;--white:#fff;--card-shadow:0 2px 8px #00000014;--card-radius:12px;--danger:#e53e3e;--warning:#dd6b20;--success:#38a169}*{box-sizing:border-box;margin:0;padding:0}body{background:#f4f6f9;background:var(--bg);color:#1a2332;color:var(--text-dark);font-family:Inter,sans-serif;font-size:14px;line-height:1.5}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#a0aec0}button{background:none;border:none;cursor:pointer;font-family:inherit}a{color:inherit;text-decoration:none}input,select,textarea{font-family:inherit}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.w-full{width:100%}.text-center{text-align:center}.font-semibold{font-weight:600}.font-medium{font-weight:500}.text-sm{font-size:12px}.text-white{color:#fff}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.p-4{padding:16px}.rounded{border-radius:8px}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.relative{position:relative}.absolute{position:absolute}.hidden{display:none}.cursor-pointer{cursor:pointer}.sidebar{background:var(--sidebar-bg);bottom:0;display:flex;flex-direction:column;left:0;min-height:100vh;overflow:hidden;position:fixed;top:0;transition:width .25s ease;width:var(--sidebar-width);z-index:100}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-logo{border-bottom:1px solid #ffffff1f;gap:10px;min-height:64px;padding:16px 14px}.logo-icon,.sidebar-logo{align-items:center;display:flex}.logo-icon{background:#fff3;border-radius:10px;color:#fff;flex-shrink:0;font-size:18px;height:36px;justify-content:center;width:36px}.logo-text{flex:1 1;overflow:hidden}.logo-name{color:#fff;font-size:15px;font-weight:700}.logo-name,.logo-sub{display:block;white-space:nowrap}.logo-sub{color:#ffffffa6;font-size:10px;margin-top:1px}.sidebar-toggle{align-items:center;background:#ffffff26;border-radius:6px;color:#fff;display:flex;flex-shrink:0;font-size:10px;height:24px;justify-content:center;transition:background .15s;width:24px}.sidebar-toggle:hover{background:#ffffff40}.sidebar.collapsed .sidebar-toggle{margin:0 auto}.sidebar-nav{flex:1 1;overflow-x:hidden;overflow-y:auto;padding:10px 0}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.nav-group{padding:2px 0}.nav-item-wrap{position:relative}.nav-item{align-items:center;border-left:3px solid #0000;color:#ffffffd1;cursor:pointer;display:flex;font-size:13px;font-weight:400;gap:10px;padding:10px 14px;text-align:left;transition:all .15s;white-space:nowrap;width:100%}.nav-item:hover{background:#ffffff1f;color:#fff}.nav-item.active{background:#ffffff2e;border-left-color:#fff;color:#fff;font-weight:600}.nav-icon{flex-shrink:0;font-size:15px;text-align:center;width:18px}.nav-label{flex:1 1;overflow:hidden;text-overflow:ellipsis}.nav-arrow{flex-shrink:0;font-size:9px;opacity:.7;transition:transform .2s}.sidebar.collapsed .nav-item{border-left:none;border-radius:0;justify-content:center;padding:12px}.sidebar.collapsed .nav-item.active{background:#ffffff38}.sub-menu{background:#0000001f;padding:4px 0}.sub-item{align-items:center;color:#ffffffb8;display:flex;font-size:12.5px;gap:10px;overflow:hidden;padding:8px 14px 8px 44px;text-overflow:ellipsis;transition:all .15s;white-space:nowrap}.sub-item:hover{background:#ffffff1a;color:#fff}.sub-item.active{color:#fff;font-weight:600}.sub-dot{background:#ffffff80;border-radius:50%;flex-shrink:0;height:5px;width:5px}.sub-item.active .sub-dot{background:#fff}.sidebar-footer{border-top:1px solid #ffffff1f;color:#ffffff8c;font-size:11px;gap:8px;padding:14px 16px}.navbar,.sidebar-footer{align-items:center;display:flex}.navbar{background:var(--white);border-bottom:1px solid var(--border);gap:12px;height:var(--navbar-height);justify-content:space-between;padding:0 20px;position:fixed;right:0;top:0;transition:left .25s ease;z-index:99}.navbar-left{gap:14px}.navbar-hamburger,.navbar-left{align-items:center;display:flex}.navbar-hamburger{border-radius:8px;color:var(--text-mid);font-size:15px;height:34px;justify-content:center;transition:all .15s;width:34px}.navbar-hamburger:hover{background:var(--primary-light);color:var(--primary)}.navbar-school{align-items:center;color:var(--text-dark);display:flex;font-size:13px;font-weight:600;gap:7px}.navbar-school i{color:var(--primary);font-size:14px}.navbar-right{align-items:center;display:flex;gap:10px}.session-badge{background:var(--primary-light);border-radius:20px;color:var(--primary-dark);font-size:12px;font-weight:600;gap:6px;padding:5px 12px}.navbar-search,.session-badge{align-items:center;display:flex}.navbar-search{background:#f4f6f9;border:1px solid var(--border);border-radius:20px;gap:8px;padding:6px 14px;transition:all .2s}.navbar-search:focus-within{background:#fff;border-color:var(--primary);box-shadow:0 0 0 3px #00a99d14}.navbar-search i{color:var(--text-light);font-size:12px}.navbar-search input{background:#0000;border:none;color:var(--text-dark);font-size:13px;outline:none;width:160px}.navbar-search input::placeholder{color:var(--text-light)}.navbar-icon-btn{align-items:center;border-radius:10px;color:var(--text-mid);cursor:pointer;display:flex;font-size:15px;height:36px;justify-content:center;position:relative;transition:all .15s;width:36px}.navbar-icon-btn:hover{background:var(--primary-light);color:var(--primary)}.notif-badge{align-items:center;background:var(--accent-pink);border:2px solid #fff;border-radius:50%;color:#fff;display:flex;font-size:9px;font-weight:700;height:16px;justify-content:center;position:absolute;right:2px;top:2px;width:16px}.notif-dropdown{background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:0 8px 30px #0000001f;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:320px;z-index:200}.dropdown-header{align-items:center;border-bottom:1px solid var(--border);display:flex;font-size:13px;font-weight:600;justify-content:space-between;padding:14px 16px}.mark-all{color:var(--primary);font-size:11px;font-weight:500}.notif-item{border-bottom:1px solid #f7f7f7;cursor:pointer;display:flex;gap:12px;padding:12px 16px;transition:background .15s}.notif-item:hover{background:#fafafa}.notif-dot{align-items:center;border-radius:10px;color:#fff;display:flex;flex-shrink:0;font-size:13px;height:34px;justify-content:center;width:34px}.notif-body{flex:1 1}.notif-title{color:var(--text-dark);font-size:13px;font-weight:600;margin-bottom:2px}.notif-text{color:var(--text-mid);font-size:12px}.notif-time{color:var(--text-light);font-size:11px;margin-top:2px}.dropdown-footer{border-top:1px solid var(--border);padding:10px 16px;text-align:center}.dropdown-footer button{color:var(--primary);font-size:12px;font-weight:500}.navbar-profile{align-items:center;border-radius:10px;cursor:pointer;display:flex;gap:8px;padding:4px 8px;position:relative;transition:background .15s}.navbar-profile:hover{background:var(--primary-light)}.profile-avatar{align-items:center;background:var(--primary);border-radius:8px;display:flex;height:32px;justify-content:center;overflow:hidden;width:32px}.profile-avatar span{color:#fff;font-size:13px;font-weight:700}.profile-avatar img{height:100%;object-fit:cover;width:100%}.profile-name{color:var(--text-dark);display:block;font-size:12.5px;font-weight:600;white-space:nowrap}.profile-role{color:var(--text-light);display:block;font-size:10px;text-transform:capitalize}.profile-arrow{color:var(--text-light);font-size:9px}.profile-dropdown{background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:0 8px 30px #0000001f;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:220px;z-index:200}.profile-dropdown-header{align-items:center;display:flex;gap:10px;padding:14px 16px}.pd-avatar{align-items:center;background:var(--primary);border-radius:10px;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:36px;justify-content:center;width:36px}.pd-name{font-size:13px;font-weight:600}.pd-email{color:var(--text-light);font-size:11px}.pd-divider{background:var(--border);height:1px}.pd-item{align-items:center;color:var(--text-mid);display:flex;font-size:13px;gap:10px;padding:10px 16px;text-align:left;transition:all .15s;width:100%}.pd-item:hover{background:#f7f7f7;color:var(--text-dark)}.pd-item i{color:var(--text-light);font-size:13px;width:16px}.pd-logout,.pd-logout i{color:var(--danger)}.pd-logout:hover{background:#fff5f5}.session-select{background:var(--primary-light);border:1.5px solid var(--primary);border-radius:20px;color:var(--primary-dark);cursor:pointer;font-family:inherit;font-size:12px;font-weight:600;outline:none;padding:5px 12px}.session-select:hover{background:#b2dfdb}.layout-main,.school-layout{display:flex;min-height:100vh}.layout-main{flex:1 1;flex-direction:column;margin-left:var(--sidebar-width);transition:margin-left .25s ease}.layout-main.collapsed{margin-left:var(--sidebar-collapsed)}.layout-content{flex:1 1;margin-top:var(--navbar-height);overflow-y:auto;padding:24px}.admin-layout{display:flex;min-height:100vh}.admin-sidebar{background:#1a2332;bottom:0;display:flex;flex-direction:column;left:0;padding:0;position:fixed;top:0;width:220px}.admin-logo{align-items:center;border-bottom:1px solid #ffffff1a;color:#fff;display:flex;font-size:15px;font-weight:700;gap:10px;padding:20px 16px}.admin-logo i{color:#00a99d;font-size:20px}.admin-nav-item{align-items:center;color:#ffffffa6;display:flex;font-size:13px;gap:10px;padding:12px 16px;transition:all .15s}.admin-nav-item:hover{background:#ffffff12;color:#fff}.admin-nav-item.active{background:#00a99d26;color:#00a99d;font-weight:600}.admin-nav-item i{font-size:13px;width:16px}.admin-main{flex:1 1;margin-left:220px;padding:24px}.login-page{display:flex;min-height:100vh}.login-left{background:linear-gradient(145deg,#00a99d,#007f75);display:flex;flex-direction:column;justify-content:center;overflow:hidden;padding:60px 50px;position:relative;width:42%}.login-brand{color:#fff;margin-bottom:48px}.brand-logo{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-radius:20px;color:#fff;display:flex;font-size:32px;height:72px;justify-content:center;margin-bottom:20px;width:72px}.login-brand h1{font-size:36px;font-weight:700;letter-spacing:-.5px;margin-bottom:8px}.login-brand p{font-size:15px;opacity:.85}.login-features{display:flex;flex-direction:column;gap:20px}.feature-item{color:#ffffffe6;font-size:14px;gap:14px}.feature-item,.feature-item i{align-items:center;display:flex}.feature-item i{background:#ffffff26;border-radius:10px;flex-shrink:0;font-size:16px;height:40px;justify-content:center;width:40px}.login-wave{bottom:-60px;height:300px;right:-60px;width:300px}.login-wave,.login-wave:before{background:#ffffff0f;border-radius:50%;position:absolute}.login-wave:before{content:"";height:200px;left:-60px;top:-60px;width:200px}.login-right{align-items:center;background:#f4f6f9;display:flex;flex:1 1;justify-content:center;padding:40px 20px}.login-card{background:#fff;border-radius:20px;box-shadow:0 8px 40px #00000014;max-width:420px;padding:44px 40px;width:100%}.login-header{margin-bottom:28px;text-align:center}.login-icon{align-items:center;background:var(--primary-light);border-radius:16px;color:var(--primary);display:flex;font-size:24px;height:60px;justify-content:center;margin:0 auto 16px;width:60px}.login-header h2{color:var(--text-dark);font-size:22px;font-weight:700;margin-bottom:4px}.login-header p{color:var(--text-light);font-size:13px}.login-error{align-items:center;background:#fff5f5;border:1px solid #fed7d7;border-radius:10px;color:var(--danger);display:flex;font-size:13px;gap:8px;margin-bottom:20px;padding:10px 14px}.login-form{display:flex;flex-direction:column;gap:18px}.form-group label{color:var(--text-mid);display:block;font-size:13px;font-weight:500;margin-bottom:6px}.input-wrap{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-light);font-size:14px;left:14px;pointer-events:none;position:absolute}.input-wrap input{background:#fafafa;border:1.5px solid var(--border);border-radius:10px;color:var(--text-dark);font-size:14px;outline:none;padding:11px 40px;transition:all .2s;width:100%}.input-wrap input:focus{background:#fff;border-color:var(--primary);box-shadow:0 0 0 3px #00a99d1a}.pass-toggle{color:var(--text-light);font-size:14px;padding:4px;position:absolute;right:14px}.pass-toggle:hover{color:var(--primary)}.form-meta{justify-content:space-between}.form-meta,.remember{align-items:center;display:flex}.remember{color:var(--text-mid);cursor:pointer;font-size:13px;gap:6px}.remember input{accent-color:var(--primary)}.forgot-link{color:var(--primary);font-size:13px;font-weight:500}.forgot-link:hover{text-decoration:underline}.login-btn{align-items:center;background:var(--primary);border-radius:10px;color:#fff;display:flex;font-size:15px;font-weight:600;gap:8px;justify-content:center;margin-top:4px;padding:13px;transition:all .2s;width:100%}.login-btn:hover:not(:disabled){background:var(--primary-dark);box-shadow:0 4px 12px #00a99d59;transform:translateY(-1px)}.login-btn:disabled{cursor:not-allowed;opacity:.7}.demo-hint{background:#f0fafa;border:1px solid #b2dfdb;border-radius:10px;margin-top:24px;padding:12px 14px}.demo-title{color:var(--primary-dark);font-size:12px;font-weight:500;gap:6px;margin-bottom:8px}.demo-row,.demo-title{align-items:center;display:flex}.demo-row{border-radius:6px;cursor:pointer;justify-content:space-between;padding:6px 8px;transition:background .15s}.demo-row:hover{background:#00a99d1a}.demo-role{color:var(--primary);font-size:12px;font-weight:600}.demo-cred{color:var(--text-mid);font-family:monospace;font-size:12px}.login-footer{color:var(--text-light);font-size:12px;margin-top:24px;text-align:center}@media (max-width:768px){.login-left{display:none}.login-right{padding:20px 16px}.login-card{padding:32px 24px}}
/*# sourceMappingURL=main.6227e22d.css.map*/