@import "https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;600;700&family=Roboto+Slab:wght@600;700&display=swap";
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid}}}.collapse{visibility:collapse}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.uppercase{text-transform:uppercase}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}:root{--primary:#0f2744;--primary-mid:#1a3a5c;--primary-light:#2563a8;--accent:#e05c2a;--bg:#f0f2f7;--card:#fff;--border:#dde2ed;--border-light:#eef1f7;--text:#0f1f35;--text-mid:#3a4f6a;--text-muted:#6b7e99;--success:#0d9f6e;--success-bg:#d1fae5;--warning:#c97a10;--warning-bg:#fef3c7;--danger:#dc2626;--danger-bg:#fee2e2;--info:#2563eb;--info-bg:#dbeafe;--sidebar-width:268px;--radius:14px;--radius-sm:8px;--shadow:0 1px 3px #0f274414, 0 4px 16px #0f27440d;--shadow-lg:0 8px 32px #0f274424;--font-body:"Roboto", sans-serif;--font-heading:"Roboto Slab", serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh}h1,h2,h3,h4{font-family:var(--font-heading);letter-spacing:-.01em}a{text-decoration:none}.main-content{margin-left:var(--sidebar-width);min-height:100vh}.page-header{background:var(--card);border-bottom:1px solid var(--border);z-index:30;height:64px;box-shadow:0 1px 0 var(--border);justify-content:space-between;align-items:center;padding:0 2rem;display:flex;position:sticky;top:0}.page-body{padding:2rem}.page-title{color:var(--primary);font-size:1.375rem;font-weight:700;font-family:var(--font-heading)}.page-subtitle{color:var(--text-muted);align-items:center;gap:.375rem;margin-top:2px;font-size:.8125rem;display:flex}.sidebar{width:var(--sidebar-width);z-index:40;min-height:100vh;font-family:var(--font-body);background:linear-gradient(#0f2744 0%,#0d2240 100%);border-right:1px solid #ffffff0f;flex-direction:column;display:flex;position:fixed;top:0;left:0}.sidebar-logo{border-bottom:1px solid #ffffff14;align-items:center;gap:.875rem;padding:1.375rem 1.25rem 1.25rem;display:flex}.sidebar-logo-icon{background:linear-gradient(135deg,#e05c2a,#c0392b);border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex;box-shadow:0 4px 14px #e05c2a73}.sidebar-logo-title{color:#fff;font-size:1rem;font-weight:700;font-family:var(--font-heading);line-height:1.2}.sidebar-logo-sub{color:#fff6;letter-spacing:.08em;text-transform:uppercase;margin-top:2px;font-size:.68rem;font-weight:600}.sidebar-nav{flex:1;padding:1rem .875rem;overflow-y:auto}.sidebar-section-label{text-transform:uppercase;letter-spacing:.12em;color:#ffffff47;margin:.25rem 0 .5rem;padding:0 .5rem;font-size:.65rem;font-weight:700}.nav-item{color:#ffffff94;border-left:3px solid #0000;border-radius:10px;align-items:center;gap:.75rem;margin-bottom:3px;padding:.625rem .75rem;font-size:.875rem;font-weight:400;text-decoration:none;transition:all .15s;display:flex}.nav-item:hover{color:#ffffffe6;background:#ffffff12}.nav-item.active{color:#fff;background:#ffffff1c;border-left-color:#e05c2a;font-weight:600}.nav-item-icon{background:#ffffff0f;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:background .15s;display:flex}.nav-item:hover .nav-item-icon,.nav-item.active .nav-item-icon{background:#ffffff21}.sidebar-footer{color:#ffffff40;border-top:1px solid #ffffff12;justify-content:space-between;align-items:center;padding:1rem 1.25rem;font-size:.72rem;font-weight:500;display:flex}.btn-primary{background:var(--primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;font-weight:600;font-family:var(--font-body);white-space:nowrap;border:none;align-items:center;gap:.5rem;padding:.5rem 1.25rem;transition:opacity .15s,transform .15s;display:inline-flex}.btn-primary:hover{opacity:.87;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-outline{color:var(--primary);border-radius:var(--radius-sm);border:1.5px solid var(--border);cursor:pointer;font-size:.875rem;font-weight:600;font-family:var(--font-body);white-space:nowrap;background:#fff;align-items:center;gap:.5rem;padding:.5rem 1.25rem;transition:border-color .15s,transform .15s;display:inline-flex}.btn-outline:hover{border-color:var(--primary);transform:translateY(-1px)}.btn-outline:active{transform:translateY(0)}.btn-danger{background:var(--danger-bg);color:var(--danger);border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;font-weight:600;font-family:var(--font-body);border:none;align-items:center;gap:.5rem;padding:.5rem 1.25rem;display:inline-flex}.btn-danger:hover{background:#fecaca}.btn-sm{padding:.35rem .875rem!important;font-size:.8125rem!important}.btn-xs{border-radius:6px!important;padding:.25rem .625rem!important;font-size:.75rem!important}.btn-icon{justify-content:center;width:34px!important;height:34px!important;padding:0!important}.card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow)}.section-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden}.section-card-header{border-bottom:1px solid var(--border-light);background:#fafbfd;justify-content:space-between;align-items:center;padding:1.125rem 1.5rem;display:flex}.section-card-title{color:var(--text);align-items:center;gap:.625rem;font-size:.9375rem;font-weight:700;display:flex}.stat-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);align-items:center;gap:1rem;padding:1.25rem 1.375rem;transition:transform .15s,box-shadow .15s;display:flex}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.stat-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:50px;height:50px;display:flex}.stat-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:3px;font-size:.72rem;font-weight:700}.stat-value{color:var(--text);font-size:1.5rem;font-weight:700;line-height:1;font-family:var(--font-heading)}.stat-sub{color:var(--text-muted);margin-top:3px;font-size:.75rem}.filter-bar{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-wrap:wrap;align-items:center;gap:.875rem;margin-bottom:1.25rem;padding:.875rem 1.25rem;display:flex}.form-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.375rem;font-size:.75rem;font-weight:700;display:block}.form-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);font-size:.875rem;font-family:var(--font-body);background:#fff;outline:none;padding:.5625rem .875rem;transition:border-color .15s,box-shadow .15s}.form-input:hover{border-color:#b0bcd0}.form-input:focus{border-color:var(--primary-light);box-shadow:0 0 0 3px #2563a81f}.form-input::placeholder{color:#b0bcd0}select.form-input{cursor:pointer}.table-wrapper{overflow-x:auto}table{border-collapse:collapse;width:100%}thead tr{background:#f7f9fc}th{text-align:left;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);border-bottom:2px solid var(--border);white-space:nowrap;padding:.75rem 1.25rem;font-size:.7rem;font-weight:700}td{border-bottom:1px solid var(--border-light);color:var(--text-mid);vertical-align:middle;padding:.875rem 1.25rem;font-size:.875rem}tbody tr{transition:background .1s}tbody tr:hover td{background:#f7f9ff}tbody tr:last-child td{border-bottom:none}.badge{letter-spacing:.02em;border-radius:9999px;align-items:center;gap:.3rem;padding:.2rem .625rem;font-size:.72rem;font-weight:700;display:inline-flex}.badge-dot:before{content:"";background:currentColor;border-radius:50%;flex-shrink:0;width:5px;height:5px}.badge-success{background:var(--success-bg);color:var(--success)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-info{background:var(--info-bg);color:var(--info)}.badge-muted{background:var(--bg);color:var(--text-muted)}.badge-primary{color:var(--primary);background:#e8eef8}.avatar{width:38px;height:38px;font-size:.8125rem;font-weight:700;font-family:var(--font-heading);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.avatar-circle{border-radius:50%}.avatar img{object-fit:cover;width:100%;height:100%}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0a142899;justify-content:center;align-items:center;padding:1.5rem;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:18px;width:100%;max-width:720px;max-height:90vh;animation:.2s slideUp;overflow-y:auto;box-shadow:0 24px 80px #0a142859}.modal-header{border-bottom:1px solid var(--border-light);z-index:1;background:#fff;border-radius:18px 18px 0 0;justify-content:space-between;align-items:center;padding:1.375rem 1.75rem;display:flex;position:sticky;top:0}.modal-title{color:var(--primary);font-size:1.125rem;font-family:var(--font-heading)}.modal-body{padding:1.75rem}.modal-footer{border-top:1px solid var(--border-light);background:#fff;border-radius:0 0 18px 18px;justify-content:flex-end;gap:.75rem;padding:1.125rem 1.75rem;display:flex;position:sticky;bottom:0}.tab-bar{border-bottom:2px solid var(--border-light);margin-bottom:1.25rem;display:flex}.tab-btn{cursor:pointer;color:var(--text-muted);font-size:.875rem;font-weight:500;font-family:var(--font-body);background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:.5rem;margin-bottom:-2px;padding:.75rem 1.25rem;transition:all .15s;display:flex}.tab-btn:hover{color:var(--primary)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:700}.class-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:1rem;display:grid}.class-card{border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow);background:#fff;padding:1.375rem;transition:all .2s;position:relative;overflow:hidden}.class-card:before{content:"";background:linear-gradient(90deg, var(--primary), var(--primary-light));opacity:0;height:3px;transition:opacity .2s;position:absolute;top:0;left:0;right:0}.class-card:hover{border-color:var(--primary-light);box-shadow:var(--shadow-lg);transform:translateY(-3px)}.class-card:hover:before{opacity:1}.class-card-name{color:var(--primary);font-size:1.625rem;font-weight:700;font-family:var(--font-heading);margin-bottom:4px;line-height:1}.class-card-sub{color:var(--text-muted);font-size:.8125rem;font-weight:500}.breadcrumb{align-items:center;gap:.5rem;margin-bottom:1.25rem;font-size:.875rem;display:flex}.breadcrumb-link{color:var(--primary-light);cursor:pointer;font-weight:600;font-family:var(--font-body);background:0 0;border:none;padding:0}.breadcrumb-link:hover{text-decoration:underline}.breadcrumb-sep{color:var(--text-muted)}.breadcrumb-current{color:var(--text);font-weight:600}.summary-pills{flex-wrap:wrap;gap:.75rem;margin-bottom:1.25rem;display:flex}.summary-pill{border-radius:9999px;align-items:center;gap:.625rem;padding:.625rem 1.125rem;font-size:.875rem;font-weight:600;display:flex}.summary-pill-count{font-size:1.25rem;font-weight:700}.att-bulk-btn{cursor:pointer;font-size:.8125rem;font-weight:700;font-family:var(--font-body);border-style:solid;border-width:1.5px;border-radius:8px;align-items:center;padding:.4rem 1rem;transition:opacity .15s;display:inline-flex}.att-bulk-btn:hover{opacity:.82}.att-bulk-present{background:var(--success-bg);color:var(--success);border-color:var(--success)}.att-bulk-absent{background:var(--danger-bg);color:var(--danger);border-color:var(--danger)}.att-bulk-late{background:var(--warning-bg);color:var(--warning);border-color:var(--warning)}.att-bulk-excused{background:var(--info-bg);color:var(--info);border-color:var(--info)}.att-radio{border:1.5px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;width:34px;height:34px;color:var(--text-muted);background:#fff;border-radius:8px;justify-content:center;align-items:center;margin:0 auto;font-size:.75rem;font-weight:800;transition:all .12s;display:flex}.att-radio:hover{background:#f7f9ff;border-color:#8a9bb5}.att-radio.present.selected{background:var(--success-bg);border-color:var(--success);color:var(--success)}.att-radio.absent.selected{background:var(--danger-bg);border-color:var(--danger);color:var(--danger)}.att-radio.late.selected{background:var(--warning-bg);border-color:var(--warning);color:var(--warning)}.att-radio.excused.selected{background:var(--info-bg);border-color:var(--info);color:var(--info)}.search-bar{flex:1;position:relative}.search-bar-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:.875rem;transform:translateY(-50%)}.search-bar input{padding-left:2.5rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#c8d0de;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#a0aec0}@media print{.sidebar,.no-print,.page-header{display:none!important}.main-content{margin-left:0}.page-body{padding:0}}@media (max-width:768px){.sidebar{display:none}.main-content{margin-left:0}.page-body{padding:1rem}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}
