:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box;margin:0;padding:0}body{background:#f8fafc;min-height:100vh}#root{min-height:100vh}a{color:inherit;text-decoration:none}button,input{font-family:inherit}.login-page{background:#f8fafc;min-height:100vh;display:flex}.login-left{background:linear-gradient(135deg,#1e3a5f 0%,#0f2744 100%);flex-direction:column;flex:1;padding:2rem;display:flex;position:relative;overflow:hidden}.login-left:before{content:"";pointer-events:none;background:radial-gradient(circle,#3b82f626 0%,#0000 70%);width:100%;height:100%;position:absolute;top:-50%;right:-50%}.login-brand{color:#fff;z-index:1;align-items:center;gap:.75rem;display:flex}.logo-icon{color:#60a5fa;width:2.5rem;height:2.5rem}.login-brand h1{letter-spacing:-.02em;margin:0;font-size:1.75rem;font-weight:700}.login-illustration{flex:1;justify-content:center;align-items:center;padding:2rem;display:flex}.illustration-content{color:#fff;text-align:center;max-width:400px}.illustration-content h2{color:#fff;margin-bottom:1rem;font-size:2rem;font-weight:600}.illustration-content p{opacity:.8;margin-bottom:1.5rem;font-size:1.1rem;line-height:1.6}.feature-tags{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.feature-tags span{background:#ffffff1a;border:1px solid #fff3;border-radius:2rem;padding:.5rem 1rem;font-size:.875rem}.login-right{background:#fff;flex:1;justify-content:center;align-items:center;padding:2rem;display:flex}.login-form-container{width:100%;max-width:400px}.login-header{margin-bottom:2rem}.login-header h2{color:#1e293b;margin:0 0 .5rem;font-size:1.75rem;font-weight:600}.login-header p{color:#64748b;margin:0}.login-form{flex-direction:column;gap:1.25rem;display:flex}.error-message{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;padding:.875rem 1rem;font-size:.875rem}.form-group label{color:#374151;margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:#9ca3af;pointer-events:none;width:1.25rem;height:1.25rem;position:absolute;left:1rem}.input-wrapper input{background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:.5rem;width:100%;padding:.875rem 1rem .875rem 3rem;font-size:.9375rem;transition:all .2s}.input-wrapper input:focus{background:#fff;border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.input-wrapper input::placeholder{color:#9ca3af}.toggle-password{cursor:pointer;color:#9ca3af;background:0 0;border:none;justify-content:center;align-items:center;padding:.25rem;display:flex;position:absolute;right:.75rem}.toggle-password:hover{color:#6b7280}.toggle-password svg{width:1.25rem;height:1.25rem}.form-options{justify-content:space-between;align-items:center;display:flex}.remember-me{cursor:pointer;color:#4b5563;align-items:center;gap:.5rem;font-size:.875rem;display:flex}.remember-me input{accent-color:#3b82f6;width:1rem;height:1rem}.forgot-password{color:#3b82f6;font-size:.875rem;font-weight:500;text-decoration:none}.forgot-password:hover{text-decoration:underline}.login-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border:none;border-radius:.5rem;justify-content:center;align-items:center;gap:.5rem;width:100%;margin-top:.5rem;padding:1rem;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.login-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.login-button:disabled{opacity:.7;cursor:not-allowed}.spin{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.demo-credentials{text-align:center;background:#f1f5f9;border-radius:.5rem;margin-top:2rem;padding:1rem}.demo-credentials p{color:#64748b;margin:0 0 .5rem;font-size:.75rem}.demo-credentials code{color:#475569;cursor:pointer;border-radius:.25rem;margin:.25rem 0;padding:.125rem .25rem;font-family:ui-monospace,monospace;font-size:.8125rem;transition:background .15s;display:block}.demo-credentials code:hover{color:#1e293b;background:#e2e8f0}@media (width<=768px){.login-left{display:none}.login-right{padding:1.5rem}}.dashboard{background:#f1f5f9;min-height:100vh;display:flex}.sidebar{color:#fff;z-index:100;background:linear-gradient(#1e3a5f 0%,#0f2744 100%);flex-direction:column;width:260px;transition:transform .3s;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{border-bottom:1px solid #ffffff1a;align-items:center;gap:.75rem;padding:1.25rem 1.5rem;font-size:1.25rem;font-weight:700;display:flex}.sidebar-logo{color:#60a5fa;width:2rem;height:2rem}.sidebar-close{color:#fff;cursor:pointer;background:0 0;border:none;margin-left:auto;font-size:1.5rem;display:none}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto}.nav-item{color:#ffffffb3;cursor:pointer;border-left:3px solid #0000;align-items:center;gap:.75rem;padding:.875rem 1.5rem;text-decoration:none;transition:all .2s;display:flex}.nav-item:hover{color:#fff;background:#ffffff1a}.nav-item.active{color:#60a5fa;background:#60a5fa26;border-left-color:#60a5fa}.nav-item svg{flex-shrink:0;width:1.25rem;height:1.25rem}.sidebar-footer{border-top:1px solid #ffffff1a;padding:1rem 0}.main-content{flex-direction:column;flex:1;min-height:100vh;margin-left:260px;display:flex}.dashboard-header{z-index:50;background:#fff;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex;position:sticky;top:0}.menu-toggle{cursor:pointer;color:#64748b;background:0 0;border:none;padding:.5rem;display:none}.header-left h1{color:#1e293b;margin:0;font-size:1.5rem;font-weight:600}.header-subtitle{color:#64748b;margin:0;font-size:.875rem}.header-right{align-items:center;gap:1.5rem;display:flex}.notification-btn{cursor:pointer;color:#64748b;background:0 0;border:none;border-radius:.5rem;padding:.5rem;position:relative}.notification-btn:hover{background:#f1f5f9}.notification-badge{color:#fff;background:#ef4444;border-radius:999px;padding:.125rem .375rem;font-size:.625rem;font-weight:600;position:absolute;top:0;right:0}.user-menu{align-items:center;gap:.75rem;display:flex}.user-avatar{object-fit:cover;border:2px solid #e2e8f0;border-radius:50%;width:2.5rem;height:2.5rem}.user-info{flex-direction:column;display:flex}.user-name{color:#1e293b;font-size:.875rem;font-weight:600}.user-role{color:#64748b;text-transform:capitalize;font-size:.75rem}.logout-btn{cursor:pointer;color:#94a3b8;background:0 0;border:none;border-radius:.5rem;margin-left:.5rem;padding:.5rem}.logout-btn:hover{color:#dc2626;background:#fee2e2}.dashboard-content{flex:1;padding:1.5rem 2rem}.sidebar-overlay{z-index:90;background:#00000080;display:none;position:fixed;inset:0}.stats-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:1.5rem;display:grid}.stat-card{background:#fff;border-radius:.75rem;align-items:center;gap:1rem;padding:1.25rem;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 1px 3px #0000000d}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.stat-icon{border-radius:.75rem;flex-shrink:0;justify-content:center;align-items:center;width:3rem;height:3rem;display:flex}.stat-card.blue .stat-icon{color:#3b82f6;background:#eff6ff}.stat-card.green .stat-icon{color:#22c55e;background:#f0fdf4}.stat-card.purple .stat-icon{color:#a855f7;background:#faf5ff}.stat-card.orange .stat-icon{color:#f97316;background:#fff7ed}.stat-card.teal .stat-icon{color:#14b8a6;background:#f0fdfa}.stat-card.rose .stat-icon{color:#f43f5e;background:#fff1f2}.stat-icon svg{width:1.5rem;height:1.5rem}.stat-info{flex-direction:column;flex:1;display:flex}.stat-label{color:#64748b;font-size:.8125rem}.stat-value{color:#1e293b;font-size:1.5rem;font-weight:700}.stat-change{border-radius:.375rem;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:.75rem;font-weight:600;display:flex}.stat-change.up{color:#22c55e;background:#f0fdf4}.stat-change.down{color:#ef4444;background:#fef2f2}.dashboard-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem;display:grid}.dashboard-card{background:#fff;border-radius:.75rem;padding:1.5rem;box-shadow:0 1px 3px #0000000d}.dashboard-card h2{color:#1e293b;margin:0 0 1rem;font-size:1rem;font-weight:600}.card-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.card-header h2{margin:0}.view-all{color:#3b82f6;cursor:pointer;align-items:center;gap:.125rem;font-size:.8125rem;font-weight:500;text-decoration:none;display:flex}.view-all:hover{text-decoration:underline}.view-all svg{width:1rem;height:1rem}.badge{border-radius:999px;align-items:center;padding:.25rem .625rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge-green{color:#166534;background:#dcfce7}.badge-yellow{color:#854d0e;background:#fef9c3}.badge-red{color:#991b1b;background:#fee2e2}.badge-blue{color:#1e40af;background:#dbeafe}.badge-purple{color:#6b21a8;background:#f3e8ff}.badge-orange{color:#9a3412;background:#ffedd5}.progress-fill{background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:999px;height:100%;transition:width .3s}.status-dot{border-radius:50%;flex-shrink:0;width:.5rem;height:.5rem}.status-dot.active{background:#22c55e}.status-dot.inactive{background:#cbd5e1}.activity-list{flex-direction:column;display:flex}.activity-item{border-bottom:1px solid #f1f5f9;gap:.75rem;padding:.875rem 0;display:flex}.activity-item:last-child{border-bottom:none}.activity-dot{background:#3b82f6;border-radius:50%;flex-shrink:0;width:.5rem;height:.5rem;margin-top:.375rem}.activity-content{flex:1}.activity-content p{color:#334155;margin:0;font-size:.875rem}.activity-time{color:#94a3b8;align-items:center;gap:.25rem;margin-top:.25rem;font-size:.75rem;display:flex}.activity-time svg{width:.75rem;height:.75rem}.event-item{background:#f8fafc;border-radius:.5rem;align-items:center;gap:1rem;padding:.75rem;transition:background .2s;display:flex}.event-item:hover{background:#f1f5f9}.event-date{background:#fff;border-radius:.375rem;flex-direction:column;align-items:center;min-width:3rem;padding:.5rem;display:flex}.event-day{color:#1e293b;font-size:1.125rem;font-weight:700;line-height:1}.event-month{color:#64748b;text-transform:uppercase;font-size:.6875rem}.event-info h3{color:#1e293b;margin:0;font-size:.875rem;font-weight:500}.event-time{color:#64748b;font-size:.75rem}@media (width<=1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=1024px){.dashboard-grid{grid-template-columns:1fr}}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-close,.sidebar-overlay{display:block}.main-content{margin-left:0}.menu-toggle{display:block}.dashboard-header{padding:1rem}.header-left h1{font-size:1.25rem}.user-info{display:none}.dashboard-content{padding:1rem}.stats-grid{grid-template-columns:1fr}}.sa-grid{grid-template-columns:1fr 380px;gap:1.5rem;display:grid}.sa-institutions{grid-column:1;overflow:hidden}.sa-modules{grid-column:2}.btn-primary-sm{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:.4rem;padding:.4rem .875rem;font-size:.8125rem;font-weight:600;transition:opacity .2s}.td-muted{color:#94a3b8}.badge{border-radius:999px;align-items:center;gap:.25rem;padding:.25rem .625rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge svg{width:.75rem;height:.75rem}.modules-sub{color:#64748b;margin:-.5rem 0 1rem;font-size:.8125rem}.modules-list{flex-direction:column;gap:.75rem;display:flex}.module-row{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:.5rem;justify-content:space-between;align-items:center;gap:1rem;padding:.875rem 1rem;transition:all .2s;display:flex}.module-row.enabled{background:#eff6ff;border-color:#bfdbfe}.module-info{flex-direction:column;gap:.2rem;display:flex}.module-name{color:#1e293b;font-size:.875rem;font-weight:600}.module-desc{color:#94a3b8;font-size:.75rem;line-height:1.4}.toggle-btn{cursor:pointer;background:0 0;border:none;border-radius:.375rem;flex-shrink:0;align-items:center;gap:.375rem;padding:.25rem .5rem;font-size:.75rem;font-weight:700;transition:all .2s;display:flex}.toggle-btn svg{width:1.75rem;height:1.75rem}.toggle-btn.on{color:#2563eb}.toggle-btn.off{color:#94a3b8}.toggle-btn:hover{opacity:.75}@media (width<=1200px){.sa-grid{grid-template-columns:1fr}.sa-institutions,.sa-modules{grid-column:1}}.actions-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;display:grid}.action-btn{cursor:pointer;color:#475569;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:.5rem;align-items:center;gap:.75rem;padding:1rem;font-size:.875rem;font-weight:500;transition:all .2s;display:flex}.action-btn:hover{color:#3b82f6;background:#eff6ff;border-color:#3b82f6}.action-btn svg{width:1.25rem;height:1.25rem}.admission-list{flex-direction:column;gap:.75rem;display:flex}.admission-row{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 0;display:flex}.admission-row:last-child{border-bottom:none}.admission-info{flex-direction:column;gap:.125rem;display:flex}.admission-name{color:#1e293b;font-size:.875rem;font-weight:500}.admission-meta{color:#94a3b8;font-size:.75rem}.admission-actions{gap:.5rem;display:flex}.btn-approve{color:#166534;cursor:pointer;background:#dcfce7;border:none;border-radius:.375rem;padding:.35rem .75rem;font-size:.75rem;font-weight:600;transition:background .2s}.btn-approve:hover{background:#bbf7d0}.btn-reject{color:#991b1b;cursor:pointer;background:#fee2e2;border:none;border-radius:.375rem;padding:.35rem .75rem;font-size:.75rem;font-weight:600;transition:background .2s}.btn-reject:hover{background:#fecaca}.attendance-cell{align-items:center;gap:.5rem;display:flex}.mini-progress{background:#e2e8f0;border-radius:999px;width:4rem;height:.375rem;overflow:hidden}.empty-state{color:#94a3b8;text-align:center;padding:1rem 0;font-size:.875rem}@media (width<=768px){.actions-grid{grid-template-columns:1fr}}.class-list{flex-direction:column;gap:.875rem;display:flex}.class-row{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:.5rem;align-items:center;gap:1rem;padding:.875rem 1rem;transition:border-color .2s;display:flex}.class-row:hover{border-color:#93c5fd}.class-badge-big{color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:.625rem;flex-shrink:0;justify-content:center;align-items:center;width:3.5rem;height:3.5rem;font-size:.875rem;font-weight:700;display:flex}.class-details{flex-direction:column;flex:1;gap:.25rem;display:flex}.class-detail-row{align-items:center;gap:.5rem;font-size:.8125rem;display:flex}.class-detail-label{color:#94a3b8;min-width:5rem}.class-detail-value{color:#334155;font-weight:500}.class-action-btn{color:#2563eb;cursor:pointer;white-space:nowrap;background:#eff6ff;border:1.5px solid #bfdbfe;border-radius:.375rem;flex-shrink:0;padding:.5rem .875rem;font-size:.75rem;font-weight:600;transition:all .2s}.class-action-btn:hover{background:#dbeafe}.grade-list{flex-direction:column;gap:0;display:flex}.grade-row{border-bottom:1px solid #f1f5f9;align-items:center;gap:.75rem;padding:.75rem 0;display:flex}.grade-row:last-child{border-bottom:none}.student-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:2.25rem;height:2.25rem}.grade-info{flex-direction:column;flex:1;display:flex}.grade-name{color:#1e293b;font-size:.875rem;font-weight:500}.grade-subject{color:#94a3b8;font-size:.75rem}.grade-score{flex-direction:column;align-items:flex-end;gap:.125rem;display:flex}.grade-total{color:#94a3b8;font-size:.75rem}.grade-badge{color:#1d4ed8;background:#eff6ff;border-radius:.25rem;padding:.125rem .5rem;font-size:.8125rem;font-weight:700;display:inline-block}.today-attendance{flex-direction:column;gap:0;display:flex}.today-student{border-bottom:1px solid #f1f5f9;align-items:center;gap:.75rem;padding:.625rem 0;display:flex}.today-student:last-of-type{border-bottom:none}.today-name{color:#334155;flex:1;font-size:.875rem}.today-more{color:#94a3b8;text-align:center;padding:.75rem 0 0;font-size:.8125rem}.child-card{background:#fff;border-left:4px solid #3b82f6;border-radius:.75rem;align-items:center;gap:1.25rem;margin-bottom:1.5rem;padding:1.25rem 1.5rem;display:flex;box-shadow:0 1px 3px #0000000d}.child-avatar-wrap{flex-shrink:0;position:relative}.child-avatar{object-fit:cover;border:2px solid #e2e8f0;border-radius:50%;width:3.5rem;height:3.5rem}.child-status-dot{background:#22c55e;border:2px solid #fff;border-radius:50%;width:.75rem;height:.75rem;position:absolute;bottom:2px;right:2px}.child-info{flex:1}.child-info h2{color:#1e293b;margin:0 0 .125rem;font-size:1.125rem;font-weight:600}.child-meta{color:#64748b;font-size:.8125rem}.child-quick-stats{align-items:center;gap:1.25rem;display:flex}.child-qs-item{flex-direction:column;align-items:center;gap:.125rem;display:flex}.child-qs-val{color:#1e293b;font-size:1.25rem;font-weight:700}.child-qs-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.04em;font-size:.6875rem}.child-qs-divider{background:#e2e8f0;width:1px;height:2.5rem}.qs-green{color:#22c55e}.qs-yellow{color:#f59e0b}.qs-red{color:#ef4444}.att-month-chart{align-items:flex-end;gap:.625rem;height:160px;margin-top:.5rem;display:flex}.att-month-col{flex-direction:column;flex:1;align-items:center;gap:.2rem;height:100%;display:flex}.att-month-pct{color:#475569;font-size:.6875rem;font-weight:600}.att-month-track{background:#e2e8f0;border-radius:.375rem;flex:1;align-items:flex-end;width:100%;display:flex;overflow:hidden}.att-month-fill{border-radius:.375rem;width:100%;transition:height .4s}.fill-green{background:linear-gradient(#86efac,#22c55e)}.fill-blue{background:linear-gradient(#93c5fd,#3b82f6)}.fill-red{background:linear-gradient(#fca5a5,#ef4444)}.att-month-label{color:#475569;font-size:.75rem;font-weight:600}.att-month-sub{color:#94a3b8;font-size:.6875rem}.parent-invoice-list{flex-direction:column;gap:0;display:flex}.parent-invoice-row{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;gap:1rem;padding:.875rem 0;display:flex}.parent-invoice-row:last-child{border-bottom:none}.parent-inv-info{flex-direction:column;gap:.125rem;display:flex}.parent-inv-term{color:#64748b;font-size:.8125rem}.parent-inv-amount{color:#1e293b;font-size:1rem;font-weight:700}.parent-inv-outstanding{color:#ef4444;font-size:.75rem;font-weight:500}.parent-inv-right{flex-direction:column;align-items:flex-end;gap:.5rem;display:flex}.pay-now-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:.4rem;align-items:center;gap:.375rem;padding:.4rem .875rem;font-size:.75rem;font-weight:600;transition:opacity .2s;display:flex}.pay-now-btn svg{width:.875rem;height:.875rem}.pay-now-btn:hover{opacity:.9}.report-preview{flex-direction:column;gap:1rem;display:flex}.report-header-bar{background:#eff6ff;border-radius:.5rem;align-items:center;gap:.875rem;padding:.875rem 1rem;display:flex}.report-header-bar svg{color:#3b82f6;flex-shrink:0;width:2rem;height:2rem}.report-title{color:#1e293b;font-size:.9375rem;font-weight:600;display:block}.report-subtitle{color:#64748b;font-size:.8125rem;display:block}.report-subjects{flex-direction:column;gap:.5rem;display:flex}.report-subject-row{align-items:center;gap:.75rem;display:flex}.report-subject-name{color:#475569;flex-shrink:0;width:6.5rem;font-size:.8125rem}.report-subject-bar{background:#e2e8f0;border-radius:999px;flex:1;height:.5rem;overflow:hidden}.report-subject-fill{background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:999px;height:100%}.report-subject-grade{color:#1e293b;text-align:right;width:2rem;font-size:.8125rem;font-weight:700}.announcement-list{flex-direction:column;gap:.875rem;display:flex}.announcement-item{background:#f8fafc;border-left:3px solid #e2e8f0;border-radius:.5rem;padding:.875rem 1rem}.announcement-item.ann-high{background:#fff5f5;border-left-color:#ef4444}.ann-badge{margin-bottom:.375rem}.ann-title{color:#1e293b;margin:0 0 .25rem;font-size:.875rem;font-weight:600}.ann-body{color:#475569;margin:0 0 .375rem;font-size:.8125rem;line-height:1.5}.ann-date{color:#94a3b8;font-size:.75rem}@media (width<=768px){.child-card{flex-direction:column;align-items:flex-start}.child-quick-stats{flex-wrap:wrap}}.att-summary-bar{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;display:flex}.att-summary-item{background:#fff;border-radius:.75rem;flex:1;align-items:center;gap:.75rem;min-width:120px;padding:1rem 1.25rem;display:flex;box-shadow:0 1px 3px #0000000d}.att-summary-item svg{flex-shrink:0;width:1.5rem;height:1.5rem}.att-summary-present{border-left:3px solid #22c55e}.att-summary-present svg{color:#22c55e}.att-summary-absent{border-left:3px solid #ef4444}.att-summary-absent svg{color:#ef4444}.att-summary-excused{border-left:3px solid #f59e0b}.att-summary-excused svg{color:#f59e0b}.att-summary-late{border-left:3px solid #8b5cf6}.att-summary-late svg{color:#8b5cf6}.att-summary-rate{border-left:3px solid #3b82f6}.att-summary-rate svg{color:#3b82f6}.att-summary-item>div{flex-direction:column;display:flex}.att-summary-val{color:#1e293b;font-size:1.5rem;font-weight:700;line-height:1}.att-summary-label{color:#64748b;margin-top:.125rem;font-size:.75rem}.att-layout{grid-template-columns:1fr 280px;align-items:start;gap:1.5rem;display:grid}.att-card{grid-column:1}.att-weekly{grid-column:2}.att-hint{color:#94a3b8;margin:-.5rem 0 1rem;font-size:.8125rem}.att-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem;display:grid}.att-student-card{text-align:center;-webkit-user-select:none;user-select:none;border:2px solid;border-radius:.625rem;flex-direction:column;align-items:center;gap:.5rem;padding:1rem .75rem;transition:all .15s;display:flex}.att-student-card.clickable{cursor:pointer}.att-student-card.clickable:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.att-present{background:#f0fdf4;border-color:#86efac}.att-absent{background:#fef2f2;border-color:#fca5a5}.att-excused{background:#fffbeb;border-color:#fde68a}.att-late{background:#faf5ff;border-color:#c4b5fd}.att-avatar{object-fit:cover;border-radius:50%;width:3rem;height:3rem}.att-student-name{color:#1e293b;font-size:.8125rem;font-weight:500;line-height:1.2}.att-status-icon{align-items:center;gap:.25rem;font-size:.75rem;font-weight:600;display:flex}.att-present .att-status-icon{color:#166534}.att-absent .att-status-icon{color:#991b1b}.att-excused .att-status-icon{color:#92400e}.att-late .att-status-icon{color:#5b21b6}.att-status-icon svg{width:.875rem;height:.875rem}.weekly-chart{align-items:flex-end;gap:.75rem;height:180px;margin-top:1rem;display:flex}.weekly-bar-col{flex-direction:column;flex:1;align-items:center;gap:.25rem;height:100%;display:flex}.weekly-pct{color:#1e293b;font-size:.75rem;font-weight:600}.weekly-bar-track{background:#e2e8f0;border-radius:.375rem;flex:1;align-items:flex-end;width:100%;display:flex;overflow:hidden}.weekly-bar-fill{background:linear-gradient(#60a5fa,#3b82f6);border-radius:.375rem;width:100%;transition:height .4s}.weekly-day{color:#475569;font-size:.75rem;font-weight:600}.weekly-count{color:#94a3b8;font-size:.6875rem}@media (width<=1024px){.att-layout{grid-template-columns:1fr}.att-weekly{grid-column:1}}@media (width<=640px){.att-summary-bar{gap:.5rem}.att-summary-item{min-width:100px;padding:.75rem 1rem}.att-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}}.gb-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.gb-mode-toggle{background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;gap:.25rem;padding:.25rem;display:flex}.mode-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.mode-btn.active{color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb)}.save-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:.4rem;align-items:center;gap:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.save-btn svg{width:.875rem;height:.875rem}.save-btn.saved{background:linear-gradient(135deg,#22c55e,#16a34a)}.gb-hint{color:#94a3b8;margin:-.5rem 0 1rem;font-size:.8125rem}.th-max{color:#cbd5e1;text-transform:none;font-weight:400}.gb-table{min-width:700px}.student-cell{color:#1e293b;align-items:center;gap:.625rem;font-weight:500;display:flex}.score-input{text-align:center;color:#1e293b;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:.375rem;width:3.5rem;padding:.375rem .5rem;font-size:.875rem;transition:all .2s}.score-input:focus{background:#fff;border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.td-total{color:#1e293b;font-weight:700}.grade-badge{border-radius:.375rem;padding:.2rem .6rem;font-size:.875rem;font-weight:700;display:inline-block}.grade-a{color:#166534;background:#dcfce7}.grade-b{color:#1e40af;background:#dbeafe}.grade-c{color:#854d0e;background:#fef9c3}.rating-badge{white-space:nowrap;border-radius:.375rem;padding:.25rem .5rem;font-size:.75rem;font-weight:600;display:inline-block}.rating-badge.clickable{cursor:pointer;transition:opacity .15s}.rating-badge.clickable:hover{opacity:.75}.rating-na{color:#94a3b8;background:#f1f5f9}.rating-dev{color:#854d0e;background:#fef9c3}.rating-meet{color:#1e40af;background:#dbeafe}.rating-exceed{color:#166534;background:#dcfce7}.rating-legend{border-top:1px solid #f1f5f9;flex-wrap:wrap;gap:.75rem;margin-top:1rem;padding-top:.875rem;display:flex}.legend-item{color:#64748b;align-items:center;gap:.375rem;font-size:.75rem;display:flex}.btn-primary{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:.5rem;align-items:center;gap:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;transition:opacity .2s;display:flex}.btn-primary:hover{opacity:.9}.btn-primary svg{width:1rem;height:1rem}.student-cell{align-items:center;gap:.625rem;display:flex}.student-avatar{object-fit:cover;border-radius:50%;width:2.25rem;height:2.25rem}.student-name{color:#1e293b;font-size:.875rem;font-weight:500}.student-parent{color:#94a3b8;font-size:.75rem}.class-tag{color:#475569;background:#f1f5f9;border-radius:.25rem;padding:.2rem .5rem;font-size:.8125rem;font-weight:600;display:inline-block}.grade-tag{color:#1d4ed8;background:#eff6ff;border-radius:.25rem;padding:.2rem .5rem;font-size:.8125rem;font-weight:700;display:inline-block}.att-cell{align-items:center;gap:.5rem;display:flex}.mini-bar{background:#e2e8f0;border-radius:999px;width:4rem;height:.375rem;overflow:hidden}.mini-fill{background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:999px;height:100%}.row-actions{gap:.375rem;display:flex}.action-link{color:#3b82f6;cursor:pointer;background:0 0;border:1px solid #e2e8f0;border-radius:.25rem;padding:.25rem .5rem;font-size:.75rem;font-weight:500;transition:all .15s}.action-link:hover{background:#eff6ff;border-color:#93c5fd}.empty-cell{text-align:center;color:#94a3b8;padding:2rem;font-size:.875rem}.table-footer{color:#94a3b8;border-top:1px solid #f1f5f9;margin-top:.5rem;padding:.875rem .75rem 0;font-size:.8125rem}.adm-summary{flex-wrap:wrap;gap:1rem;margin-bottom:1.25rem;display:flex}.adm-stat-card{background:#fff;border-radius:.75rem;flex:1;align-items:center;gap:.75rem;min-width:120px;padding:1rem 1.25rem;display:flex;box-shadow:0 1px 3px #0000000d}.adm-stat-card svg{flex-shrink:0;width:1.5rem;height:1.5rem}.adm-stat-card>div{flex-direction:column;display:flex}.adm-stat-val{color:#1e293b;font-size:1.5rem;font-weight:700;line-height:1}.adm-stat-label{color:#64748b;margin-top:.125rem;font-size:.75rem}.page-toolbar{flex-wrap:wrap;align-items:center;gap:.875rem;margin-bottom:1.25rem;display:flex}.search-box{background:#fff;border:1.5px solid #e2e8f0;border-radius:.5rem;flex:1;align-items:center;gap:.5rem;min-width:200px;max-width:320px;padding:.5rem .875rem;transition:border-color .2s;display:flex}.search-box:focus-within{border-color:#3b82f6}.search-box svg{color:#94a3b8;flex-shrink:0;width:1rem;height:1rem}.search-box input{color:#1e293b;background:0 0;border:none;outline:none;width:100%;font-size:.875rem}.search-box input::placeholder{color:#94a3b8}.filter-group{background:#fff;border:1.5px solid #e2e8f0;border-radius:.5rem;align-items:center;gap:.25rem;padding:.375rem;display:flex}.filter-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:.375rem;padding:.3rem .625rem;font-size:.8125rem;font-weight:500;transition:all .15s}.filter-btn.active{color:#2563eb;background:#eff6ff;font-weight:600}.filter-btn:hover:not(.active){background:#f8fafc}.adm-cards{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1rem;display:grid}.adm-card{background:#fff;border-top:3px solid #e2e8f0;border-radius:.75rem;flex-direction:column;gap:.875rem;padding:1.25rem;transition:box-shadow .2s;display:flex;box-shadow:0 1px 3px #0000000d}.adm-card:hover{box-shadow:0 4px 12px #00000014}.adm-card.pending{border-top-color:#f59e0b}.adm-card.approved{border-top-color:#22c55e}.adm-card.rejected{border-top-color:#ef4444}.adm-card-header{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.adm-applicant{align-items:center;gap:.75rem;display:flex}.adm-initials{color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;font-size:.875rem;font-weight:700;display:flex}.adm-name{color:#1e293b;font-size:.9375rem;font-weight:600;display:block}.adm-meta{color:#94a3b8;font-size:.75rem;display:block}.adm-status-badge{flex-shrink:0;align-items:center;gap:.25rem;display:flex}.adm-status-badge svg{width:.75rem;height:.75rem}.adm-details{flex-direction:column;gap:.5rem;display:flex}.adm-detail-item{align-items:baseline;gap:.75rem;display:flex}.adm-detail-label{color:#94a3b8;flex-shrink:0;min-width:5.5rem;font-size:.75rem}.adm-detail-val{color:#334155;font-size:.875rem}.adm-notes{color:#64748b;font-style:italic}.adm-docs{flex-wrap:wrap;gap:.375rem;display:flex}.doc-tag{color:#475569;background:#f1f5f9;border-radius:.25rem;align-items:center;gap:.25rem;padding:.2rem .5rem;font-size:.75rem;display:flex}.doc-tag svg{color:#94a3b8;width:.75rem;height:.75rem}.adm-actions{gap:.625rem;padding-top:.375rem;display:flex}.btn-approve-lg{color:#166534;cursor:pointer;background:#dcfce7;border:1.5px solid #86efac;border-radius:.5rem;flex:1;justify-content:center;align-items:center;gap:.375rem;padding:.5rem;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.btn-approve-lg:hover{background:#bbf7d0}.btn-approve-lg svg{width:1rem;height:1rem}.btn-reject-lg{color:#991b1b;cursor:pointer;background:#fee2e2;border:1.5px solid #fca5a5;border-radius:.5rem;flex:1;justify-content:center;align-items:center;gap:.375rem;padding:.5rem;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.btn-reject-lg:hover{background:#fecaca}.btn-reject-lg svg{width:1rem;height:1rem}.empty-state-full{text-align:center;color:#94a3b8;background:#fff;border-radius:.75rem;grid-column:1/-1;padding:3rem;font-size:.875rem}@media (width<=640px){.adm-cards{grid-template-columns:1fr}}.stat-card.red .stat-icon,.stat-change.down{color:#ef4444;background:#fef2f2}.stat-change svg{width:.875rem;height:.875rem}.btn-primary-sm{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:.4rem;align-items:center;gap:.375rem;padding:.4rem .875rem;font-size:.8125rem;font-weight:600;transition:opacity .2s;display:flex}.btn-primary-sm:hover{opacity:.9}.table-wrapper{overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:.875rem}.data-table th{text-align:left;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;border-bottom:1px solid #e2e8f0;padding:.625rem .75rem;font-size:.75rem;font-weight:600}.data-table td{color:#334155;vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:.875rem .75rem}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover td{background:#f8fafc}.td-mono{color:#64748b;font-family:ui-monospace,monospace;font-size:.8125rem}.td-name{color:#1e293b;font-weight:500}.td-paid{color:#166534;font-weight:500}.td-outstanding{color:#dc2626;font-weight:600}.td-clear{color:#94a3b8}.pay-btn{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:.375rem;align-items:center;gap:.35rem;padding:.35rem .75rem;font-size:.75rem;font-weight:600;transition:opacity .2s;display:flex}.pay-btn:hover{opacity:.9}.pay-btn svg{width:.75rem;height:.75rem}.paid-check{color:#22c55e;align-items:center;gap:.25rem;font-size:.75rem;font-weight:500;display:flex}.paid-check svg{width:.875rem;height:.875rem}.pay-modal-overlay{z-index:200;background:#0006;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.pay-modal{background:#fff;border-radius:.875rem;width:100%;max-width:440px;overflow:hidden;box-shadow:0 20px 60px #0003}.pay-modal-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.pay-modal-header h3{color:#1e293b;margin:0;font-size:1.0625rem;font-weight:600}.modal-close{cursor:pointer;color:#94a3b8;background:0 0;border:none;border-radius:.375rem;padding:.375rem;display:flex}.modal-close:hover{color:#1e293b;background:#f1f5f9}.modal-close svg{width:1.25rem;height:1.25rem}.pay-modal-body{flex-direction:column;gap:1.25rem;padding:1.5rem;display:flex}.pay-invoice-summary{flex-direction:column;gap:.625rem;display:flex}.pay-row{color:#475569;justify-content:space-between;font-size:.875rem;display:flex}.pay-row>span:first-child{color:#94a3b8}.pay-row>span:last-child{color:#1e293b;font-weight:500}.pay-total>span{font-size:1rem;font-weight:700!important}.pay-total>span:first-child{color:#ef4444!important}.pay-total>span:last-child{color:#dc2626!important}.pay-divider{background:#f1f5f9;height:1px;margin:.25rem 0}.pay-methods{flex-direction:column;gap:.625rem;display:flex}.pay-methods-label{color:#1e293b;font-size:.8125rem;font-weight:600}.pay-method-grid{flex-direction:column;gap:.375rem;display:flex}.pay-method-btn{color:#475569;cursor:pointer;text-align:left;background:0 0;border:1.5px solid #e2e8f0;border-radius:.5rem;padding:.625rem 1rem;font-size:.875rem;font-weight:500;transition:all .15s}.pay-method-btn:hover{color:#2563eb;background:#eff6ff;border-color:#93c5fd}.pay-method-btn.active{color:#2563eb;background:#eff6ff;border-color:#3b82f6;font-weight:600}.pay-modal-footer{background:#f8fafc;border-top:1px solid #e2e8f0;gap:.75rem;padding:1.25rem 1.5rem;display:flex}.btn-cancel{color:#64748b;cursor:pointer;background:#fff;border:1.5px solid #e2e8f0;border-radius:.5rem;flex:1;padding:.75rem;font-size:.9375rem;font-weight:500;transition:all .2s}.btn-cancel:hover{background:#f1f5f9}.btn-confirm-pay{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:.5rem;flex:2;justify-content:center;align-items:center;gap:.5rem;padding:.75rem;font-size:.9375rem;font-weight:600;transition:opacity .2s;display:flex}.btn-confirm-pay:hover{opacity:.9}.btn-confirm-pay svg{width:1rem;height:1rem}.institutions-container{flex-direction:column;gap:24px;display:flex}.page-actions{align-items:center;gap:16px;display:flex}.search-bar{flex:1;align-items:center;display:flex;position:relative}.search-icon{color:#94a3b8;width:20px;height:20px;position:absolute;left:16px}.search-bar input{border:1px solid #e2e8f0;border-radius:8px;outline:none;width:100%;padding:12px 16px 12px 48px;font-size:15px;transition:all .2s}.search-bar input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #1e3a5f1a}.btn-secondary{color:#475569;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:8px;padding:12px 20px;font-weight:500;transition:all .2s;display:flex}.btn-secondary:hover{background:#f8fafc;border-color:#cbd5e1}.btn-primary{background:var(--primary);border:1px solid var(--primary);color:#fff;cursor:pointer;border-radius:8px;align-items:center;gap:8px;padding:12px 20px;font-weight:500;transition:all .2s;display:flex}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;display:grid}.stat-card{background:#fff;border-radius:16px;align-items:center;gap:20px;padding:24px;display:flex;box-shadow:0 4px 20px #00000008}.stat-icon-wrapper{width:60px;height:60px;color:var(--primary);background:#eff6ff;border-radius:16px;justify-content:center;align-items:center;display:flex}.stat-icon-wrapper svg{width:28px;height:28px}.stat-info h3{color:#64748b;margin:0 0 4px;font-size:14px;font-weight:600}.stat-value{color:#0f172a;margin:0;font-size:28px;font-weight:700}.table-card{overflow:hidden}.card-header{border-bottom:1px solid #e2e8f0;padding:24px}.card-header h2{margin:0;font-size:18px;font-weight:600}.table-responsive{overflow-x:auto}.data-table{border-collapse:collapse;text-align:left;width:100%}.data-table th,.data-table td{border-bottom:1px solid #f1f5f9;padding:16px 24px}.data-table th{color:#64748b;text-transform:uppercase;letter-spacing:.5px;background:#f8fafc;font-size:13px;font-weight:600}.data-table tbody tr:hover{background-color:#f8fafc}.fw-600{color:#0f172a;font-weight:600}.text-muted{color:#64748b}.badge{border-radius:20px;padding:6px 12px;font-size:12px;font-weight:600;display:inline-block}.badge-gray{color:#475569;background:#f1f5f9}.btn-icon{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:8px;transition:all .2s}.btn-icon:hover{color:#0f172a;background:#f1f5f9}.empty-state{text-align:center;color:#64748b;padding:48px}.modules-container{flex-direction:column;gap:24px;display:flex}.info-banner{background:#1e3a5f0d;border:1px solid #1e3a5f1a;border-radius:12px;align-items:flex-start;gap:16px;padding:20px;display:flex}.banner-icon{color:var(--primary);flex-shrink:0;width:24px;height:24px;margin-top:2px}.banner-text h4{color:var(--primary);margin:0 0 4px;font-size:15px}.banner-text p{color:#475569;margin:0;font-size:14px;line-height:1.5}.modules-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;display:grid}.module-card{background:#fff;border:1px solid #f1f5f9;border-radius:16px;flex-direction:column;padding:24px;transition:all .3s;display:flex;box-shadow:0 4px 20px #00000008}.module-card.disabled{opacity:.8;background:#fafafa}.module-card:hover{transform:translateY(-2px);box-shadow:0 8px 30px #0000000f}.module-header{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.module-icon{width:48px;height:48px;color:var(--primary);background:#eff6ff;border-radius:12px;justify-content:center;align-items:center;display:flex}.module-icon svg{width:24px;height:24px}.module-card.disabled .module-icon{color:#94a3b8;background:#f1f5f9}.toggle-switch{width:50px;height:28px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;background-color:#cbd5e1;border-radius:34px;transition:all .4s;position:absolute;inset:0}.slider:before{content:"";background-color:#fff;border-radius:50%;width:20px;height:20px;transition:all .4s;position:absolute;bottom:4px;left:4px;box-shadow:0 2px 4px #0003}input:checked+.slider{background-color:var(--success)}input:checked+.slider:before{transform:translate(22px)}.module-content{flex:1}.module-content h3{color:#0f172a;margin:0 0 8px;font-size:18px;font-weight:600}.module-content p{color:#64748b;margin:0 0 24px;font-size:14px;line-height:1.5}.module-status{color:#64748b;border-top:1px solid #f1f5f9;align-items:center;gap:8px;padding-top:16px;font-size:13px;font-weight:500;display:flex}.status-dot{border-radius:50%;width:8px;height:8px}.status-dot.on{background:var(--success);box-shadow:0 0 0 4px #22c55e1a}.status-dot.off{background:#cbd5e1}.users-container{flex-direction:column;gap:24px;display:flex}.user-cell{align-items:center;gap:12px;display:flex}.avatar-img{object-fit:cover;border:2px solid #fff;border-radius:50%;width:36px;height:36px;box-shadow:0 2px 4px #0000001a}.role-badge{letter-spacing:.5px;border-radius:6px;align-items:center;gap:6px;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex}.role-badge.super-admin{color:#dc2626;background:#fee2e2}.role-badge.admin{color:#4338ca;background:#e0e7ff}.role-badge.teacher{color:#15803d;background:#dcfce7}.role-badge.parent{color:#b45309;background:#fef3c7}.role-badge.staff{color:#4b5563;background:#f3f4f6}.badge-active{color:var(--success);background:#22c55e1a}.teachers-container{flex-direction:column;gap:24px;display:flex}.teachers-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;display:grid}.teacher-card{background:#fff;border-radius:16px;flex-direction:column;gap:16px;padding:24px;transition:transform .2s;display:flex;box-shadow:0 4px 20px #00000008}.teacher-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #00000014}.teacher-header{justify-content:space-between;align-items:flex-start;display:flex}.teacher-avatar{object-fit:cover;border:3px solid #eff6ff;border-radius:50%;width:72px;height:72px}.status-badge{text-transform:uppercase;border-radius:20px;padding:4px 10px;font-size:11px;font-weight:700}.status-badge.active{color:var(--success);background:#22c55e1a}.status-badge.leave{color:#b45309;background:#fef3c7}.teacher-info h3{color:#0f172a;margin:0 0 4px;font-size:18px;font-weight:700}.teacher-subject{color:var(--primary);align-items:center;gap:6px;margin:0 0 16px;font-size:14px;font-weight:500;display:flex}.teacher-classes{flex-wrap:wrap;gap:8px;display:flex}.class-chip{color:#475569;background:#f1f5f9;border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600}.teacher-footer{border-top:1px solid #f1f5f9;justify-content:space-between;align-items:center;margin-top:auto;padding-top:16px;display:flex}.attendance-metric{flex-direction:column;display:flex}.metric-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.metric-value{color:#0f172a;font-size:16px;font-weight:700}.classrooms-container{flex-direction:column;gap:24px;display:flex}.classrooms-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:24px;display:grid}.classroom-card{background:#fff;border-radius:16px;flex-direction:column;gap:20px;padding:24px;display:flex;box-shadow:0 4px 20px #00000008}.classroom-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding-bottom:16px;display:flex}.room-title{align-items:center;gap:12px;display:flex}.room-icon{color:var(--primary);width:24px;height:24px}.room-title h3{color:#0f172a;margin:0;font-size:20px;font-weight:700}.room-badge{color:#475569;background:#f1f5f9;border-radius:8px;padding:6px 12px;font-size:13px;font-weight:600}.classroom-teacher{flex-direction:column;gap:4px;display:flex}.classroom-teacher .label{color:#94a3b8;text-transform:uppercase;font-size:12px;font-weight:600}.classroom-teacher .value{color:#0f172a;font-size:15px;font-weight:500}.classroom-capacity{background:#f8fafc;border-radius:12px;padding:16px}.capacity-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.capacity-info{color:#475569;align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.util-percent{color:var(--primary);font-size:14px;font-weight:700}.util-percent.full{color:var(--danger)}.progress-bar{background:#e2e8f0;border-radius:4px;height:8px;overflow:hidden}.progress-fill{border-radius:4px;height:100%;transition:width .3s}.bg-primary{background:var(--primary)}.bg-danger{background:var(--danger)}.classroom-assets h4{color:#0f172a;margin:0 0 12px;font-size:14px;font-weight:600}.asset-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.asset-item{justify-content:space-between;align-items:center;font-size:13px;display:flex}.asset-name{color:#475569;font-weight:500}.asset-status{border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600}.asset-status.good{color:var(--success);background:#22c55e1a}.asset-status.needs-repair{color:#b45309;background:#fef3c7}.asset-status.damaged{color:#dc2626;background:#fee2e2}.schedule-container{flex-direction:column;gap:24px;display:flex}.schedule-header{justify-content:space-between;align-items:center;display:flex}.week-selector{align-items:center;gap:16px;display:flex}.week-selector h3{color:#0f172a;margin:0;font-size:18px;font-weight:700}.schedule-content{grid-template-columns:1fr 320px;gap:24px;display:grid}.timetable-card{padding:0;overflow:hidden}.timetable-grid{flex-direction:column;display:flex}.time-col-header{border-bottom:1px solid #f1f5f9;border-right:1px solid #f1f5f9;flex-shrink:0;width:80px}.day-header{text-align:center;color:#475569;background:#f8fafc;border-bottom:1px solid #f1f5f9;border-right:1px solid #f1f5f9;flex:1;padding:16px;font-weight:600}.day-header:last-child{border-right:none}.timetable-grid{grid-template-columns:80px repeat(5,1fr);display:grid}.time-col-header{background:#f8fafc}.timetable-row{display:contents}.time-label{color:#94a3b8;text-align:right;background:#fff;border-bottom:1px solid #f1f5f9;border-right:1px solid #f1f5f9;justify-content:flex-end;align-items:center;padding:16px 8px;font-size:12px;font-weight:600;display:flex}.timetable-cell{background:#fff;border-bottom:1px solid #f1f5f9;border-right:1px solid #f1f5f9;min-height:100px;padding:8px}.timetable-cell.break-cell{background:#f8fafc;justify-content:center;align-items:center;display:flex}.break-text{color:#94a3b8;text-transform:uppercase;letter-spacing:1px;font-size:13px;font-weight:600}.class-block{border-radius:8px;flex-direction:column;gap:4px;height:100%;padding:12px;display:flex}.class-block.math{background:#3b82f61a;border-left:4px solid #3b82f6}.class-block.science{background:#22c55e1a;border-left:4px solid #22c55e}.class-title{color:#0f172a;font-size:14px;font-weight:600}.class-room{color:#475569;font-size:12px}.upcoming-events{background:#fff;border-radius:16px;height:fit-content;padding:24px;box-shadow:0 4px 20px #00000008}.events-header{align-items:center;gap:12px;margin-bottom:24px;display:flex}.events-header h3{margin:0;font-size:18px;font-weight:700}.text-primary{color:var(--primary)}.events-list{flex-direction:column;gap:20px;display:flex}.event-item{gap:16px;display:flex}.event-date-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:54px;height:54px;display:flex}.event-date-box .month{color:var(--primary);text-transform:uppercase;font-size:11px;font-weight:700}.event-date-box .day{color:#0f172a;font-size:18px;font-weight:700}.event-details{flex-direction:column;gap:4px;display:flex}.event-details h4{color:#0f172a;margin:0;font-size:14px;font-weight:600;line-height:1.4}.event-time{color:#64748b;align-items:center;gap:4px;margin:0;font-size:12px;display:flex}.event-type{color:#475569;background:#f1f5f9;border-radius:4px;width:fit-content;margin-top:4px;padding:2px 8px;font-size:11px;font-weight:600}@media (width<=1024px){.schedule-content{grid-template-columns:1fr}}.loading-screen{color:#64748b;flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:100vh;display:flex}.loading-screen .spin{color:#3b82f6;width:2rem;height:2rem;animation:1s linear infinite spin}
