:root{--sidebar-bg:#4e54c8;--sidebar-hover:#5a60d6;--sidebar-active:#6c72e0;--sidebar-width:80px;--header-height:60px;--primary:#4e54c8;--primary-light:#7c7ff2;--success:#28a745;--warning:#ffc107;--danger:#dc3545;--info:#17a2b8;--text-primary:#333;--text-secondary:#666;--text-muted:#999;--bg-main:#f5f6fa;--bg-white:#fff;--border:#e0e0e0;--shadow:0 2px 8px #00000014;--radius:8px}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-main);color:var(--text-primary);min-height:100vh;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}a{color:inherit;text-decoration:none}.loading-screen{flex-direction:column;justify-content:center;align-items:center;gap:16px;height:100vh;display:flex}.spinner{border:4px solid var(--border);border-top:4px solid var(--primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);color:#fff;z-index:100;flex-direction:column;align-items:center;height:100vh;padding-top:12px;display:flex;position:fixed;top:0;left:0;overflow:visible}.sidebar-logo{background:#fff3;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;margin-bottom:16px;font-size:20px;font-weight:700;display:flex}.sidebar-nav{flex-direction:column;align-items:center;gap:2px;width:100%;display:flex}.sidebar-section-label{text-transform:uppercase;letter-spacing:1px;opacity:.6;text-align:center;width:100%;margin-top:12px;margin-bottom:4px;font-size:9px}.sidebar-item{cursor:pointer;text-align:center;color:#fff;background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;width:100%;padding:10px 4px;font-family:inherit;text-decoration:none;transition:background .2s;display:flex;position:relative}.sidebar-item:hover{background:var(--sidebar-hover)}.sidebar-item.active{background:var(--sidebar-active)}.sidebar-item .icon{margin-bottom:3px;font-size:20px}.sidebar-item .label{opacity:.9;font-size:10px;line-height:1.2}.sidebar-dropdown{background:var(--bg-white);border-radius:0 var(--radius) var(--radius) 0;box-shadow:var(--shadow);z-index:200;min-width:200px;max-height:calc(100vh - 20px);padding:12px 0;position:absolute;top:0;left:80px;overflow-y:auto}.sidebar-dropdown-up{border-radius:0 var(--radius) var(--radius) 0;top:auto;bottom:0}.sidebar-dropdown-title{text-transform:uppercase;color:var(--primary);letter-spacing:.5px;padding:4px 20px 8px;font-size:11px;font-weight:700}.sidebar-dropdown a,.sidebar-dropdown .dropdown-link{color:var(--text-primary);cursor:pointer;padding:8px 20px;font-size:14px;transition:background .15s;display:block}.sidebar-dropdown a:hover,.sidebar-dropdown .dropdown-link:hover{color:var(--primary);background:#f0f0ff}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.top-header{height:var(--header-height);background:var(--bg-white);z-index:50;justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:sticky;top:0;box-shadow:0 1px 4px #0000000d}.search-bar{align-items:center;gap:0;display:flex}.search-bar input{border:1px solid var(--border);border-radius:var(--radius) 0 0 var(--radius);border-right:none;outline:none;width:280px;padding:8px 14px;font-size:14px}.search-bar input:focus{border-color:var(--primary)}.search-bar button{background:var(--primary);color:#fff;border-radius:0 var(--radius) var(--radius) 0;cursor:pointer;border:none;padding:8px 14px;font-size:14px}.header-right{align-items:center;gap:16px;display:flex}.header-badge{cursor:pointer;color:var(--text-secondary);font-size:20px;position:relative}.header-badge .count{background:var(--danger);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;display:flex;position:absolute;top:-6px;right:-6px}.header-user{color:var(--text-secondary);align-items:center;gap:8px;font-size:14px;display:flex}.header-avatar{background:var(--border);width:36px;height:36px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;font-size:16px;display:flex}.page-content{flex:1;padding:24px}.page-title{color:var(--text-primary);margin-bottom:20px;font-size:22px;font-weight:600}.school-year-badge{background:var(--primary);color:#fff;border-radius:var(--radius);float:right;padding:4px 14px;font-size:13px;font-weight:600;display:inline-block}.stat-cards{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow);border-left:4px solid;justify-content:space-between;align-items:center;padding:20px;display:flex}.stat-card.blue{border-left-color:var(--primary)}.stat-card.green{border-left-color:var(--success)}.stat-card.orange{border-left-color:var(--warning)}.stat-card.teal{border-left-color:var(--info)}.stat-card.red{border-left-color:var(--danger)}.stat-card .stat-info .stat-label{text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:11px;font-weight:700}.stat-card.blue .stat-label{color:var(--primary)}.stat-card.green .stat-label{color:var(--success)}.stat-card.orange .stat-label{color:var(--warning)}.stat-card.teal .stat-label{color:var(--info)}.stat-card.red .stat-label{color:var(--danger)}.stat-card .stat-value{color:var(--text-primary);font-size:28px;font-weight:700}.stat-card .stat-icon{opacity:.3;font-size:32px}.section-card{background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:24px;overflow:hidden}.section-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.section-title{color:var(--primary);font-size:16px;font-weight:600}.section-body{padding:20px}.filter-bar{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:16px;display:grid}.filter-group label{color:var(--text-secondary);margin-bottom:4px;font-size:13px;font-weight:600;display:block}.filter-group select,.filter-group input{border:1px solid var(--border);border-radius:var(--radius);outline:none;width:100%;padding:8px 12px;font-size:14px}.filter-group select:focus,.filter-group input:focus{border-color:var(--primary)}.filter-actions{align-items:flex-end;gap:8px;display:flex}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:6px;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;line-height:1.4;transition:background .2s,box-shadow .2s,transform .1s;display:inline-flex}.btn:hover{filter:brightness(1.08);box-shadow:0 2px 6px #0000001f}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.btn-primary{background:var(--primary);color:#fff}.btn-success{background:var(--success);color:#fff}.btn-danger{color:#fff;background:#e74c5a}.btn-warning{color:#fff;background:#f0ad4e}.btn-info{background:var(--info);color:#fff}.btn-secondary{color:#fff;background:#6c757d}.btn-outline{border:1px solid var(--border);color:var(--text-secondary);background:0 0}.btn-outline:hover{border-color:var(--primary);color:var(--primary)}.btn-sm{border-radius:5px;padding:6px 14px;font-size:12px}.btn-lg{padding:10px 24px;font-size:15px}.btn-icon{border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;padding:0;display:inline-flex}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;color:var(--text-secondary);border-bottom:2px solid var(--border);white-space:nowrap;background:#f8f9fa;padding:12px 16px;font-size:13px;font-weight:600}.data-table td{vertical-align:middle;border-bottom:1px solid #f0f0f0;padding:12px 16px;font-size:14px}.data-table tr:hover{background:#fafbff}.data-table .table-actions{flex-wrap:nowrap;align-items:center;gap:8px;display:flex}.table-empty{text-align:center;color:var(--text-muted);padding:30px!important}.link-cell{color:var(--primary);font-size:13px;text-decoration:underline}.link-cell:hover{color:var(--primary-light)}.badge{text-transform:uppercase;border-radius:4px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.badge-published,.badge-active,.badge-approved,.badge-present,.badge-completed{color:#155724;background:#d4edda}.badge-draft,.badge-pending{color:#856404;background:#fff3cd}.badge-inactive,.badge-rejected,.badge-absent{color:#721c24;background:#f8d7da}.badge-info,.badge-enrolled{color:#0c5460;background:#d1ecf1}.badge-late,.badge-excused{color:#383d94;background:#e2e3ff}.badge-published,.badge-graded{color:#155724;background:#d4edda}.badge-draft{color:#856404;background:#fff3cd}.badge-secondary{color:#fff;background:#6c757d}.badge-danger{background:var(--danger);color:#fff}.badge-warning{background:var(--warning);color:#333}.badge-primary{background:var(--primary);color:#fff}.badge-purple{color:#fff;background:#6f42c1}.badge-muted{color:#fff;background:#adb5bd}.badge-present{background:var(--success);color:#fff}.badge-absent{background:var(--danger);color:#fff}.badge-on-time{background:var(--success);color:#fff}.badge-late-status{background:var(--warning);color:#333}.badge-absent-status{background:var(--danger);color:#fff}.badge-excused-status{background:var(--info);color:#fff}.table-controls{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.entries-select{align-items:center;gap:8px;font-size:14px;display:flex}.entries-select select{border:1px solid var(--border);border-radius:4px;padding:4px 8px}.table-search input{border:1px solid var(--border);border-radius:4px;padding:6px 12px;font-size:14px}.pagination{justify-content:center;align-items:center;gap:4px;margin-top:16px;display:flex}.pagination button{border:1px solid var(--border);background:var(--bg-white);cursor:pointer;border-radius:4px;padding:6px 12px;font-size:13px}.pagination button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.pagination button:disabled{opacity:.5;cursor:not-allowed}.announcement-card{background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:16px;padding:20px}.announcement-meta{align-items:center;gap:12px;margin-bottom:12px;display:flex}.announcement-avatar{background:var(--border);border-radius:50%;width:40px;height:40px}.announcement-info .name{color:var(--text-secondary);font-size:13px}.announcement-info .date{color:var(--text-muted);font-size:11px}.announcement-title{color:var(--primary);margin-bottom:6px;font-size:16px;font-weight:700}.announcement-body{color:var(--text-secondary);font-size:14px;line-height:1.5}.form-group{margin-bottom:16px}.form-group label{color:var(--text-secondary);margin-bottom:4px;font-size:13px;font-weight:600;display:block}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border);border-radius:var(--radius);outline:none;width:100%;padding:10px 14px;font-family:inherit;font-size:14px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4e54c81a}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;display:grid}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal,.modal-content{background:var(--bg-white);border-radius:var(--radius);flex-direction:column;width:90%;max-width:600px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 20px 60px #0003}.modal>form,.modal-content>form{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.modal-header h3{color:var(--text-primary);font-size:18px}.modal-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;font-size:20px}.modal-body{flex:1;padding:24px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);flex-shrink:0;justify-content:flex-end;gap:8px;padding:16px 24px;display:flex}.login-page{background:linear-gradient(135deg,#6366f1,#a855f7,#7c3aed);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-container{border-radius:16px;width:100%;max-width:920px;min-height:560px;display:flex;overflow:hidden;box-shadow:0 24px 80px #00000040}.login-banner{color:#fff;background:linear-gradient(135deg,#4e54c8 0%,#7c3aed 100%);flex:0 0 44%;align-items:flex-end;padding:40px 32px;display:flex;position:relative;overflow:hidden}.login-banner:before{content:"";opacity:.25;background:url(https://images.unsplash.com/photo-1523050854058-8df90110c9f1?w=600&q=80) 50%/cover;position:absolute;inset:0}.login-banner-overlay{background:linear-gradient(#7c3aed80 0%,#4e54c8e6 100%);position:absolute;inset:0}.login-banner-content{z-index:1;position:relative}.login-banner-content h2{margin-bottom:10px;font-size:28px;font-weight:700}.login-banner-content p{opacity:.9;font-size:14px;line-height:1.6}.login-form-panel{background:var(--bg-white);flex:1;justify-content:center;align-items:center;padding:40px 36px;display:flex}.login-form-inner{width:100%;max-width:360px}.login-brand{text-align:center;margin-bottom:12px}.login-title{text-align:center;color:var(--text);margin-bottom:4px;font-size:26px;font-weight:700}.login-subtitle{text-align:center;color:var(--text-muted);margin-bottom:28px;font-size:14px}.login-form-inner .form-group{margin-bottom:18px}.login-pw-wrap{position:relative}.login-pw-icon{color:var(--text-muted);pointer-events:none;display:flex;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.login-pw-toggle{cursor:pointer;color:var(--text-muted);background:0 0;border:none;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.login-options{gap:20px;margin-bottom:20px;display:flex}.login-check{color:var(--text-muted);cursor:pointer;align-items:center;gap:6px;font-size:13px;display:flex}.login-check input{cursor:pointer}.login-btn{border-radius:8px;justify-content:center;width:100%;padding:12px;font-size:16px;font-weight:600}.login-help{text-align:center;color:var(--primary);cursor:pointer;margin-top:20px;font-size:13px}.login-divider{border:none;border-top:1px solid var(--border);margin:20px 0}.login-footer-text{text-align:center;color:var(--text-muted);font-size:13px}.login-link{color:var(--primary);font-weight:600;text-decoration:none}.login-link:hover{text-decoration:underline}.login-error{color:#721c24;border-radius:var(--radius);background:#f8d7da;margin-bottom:16px;padding:10px 14px;font-size:13px}@media (width<=700px){.login-container{flex-direction:column}.login-banner{flex:0 0 180px}}.toast-container{z-index:9999;flex-direction:column;gap:8px;display:flex;position:fixed;top:20px;right:20px}.toast{border-radius:var(--radius);color:#fff;box-shadow:var(--shadow);padding:12px 20px;font-size:14px;animation:.3s slideIn}.toast-success{background:var(--success)}.toast-error{background:var(--danger)}.toast-info{background:var(--info)}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.empty-state{text-align:center;color:var(--text-muted);padding:60px 20px}.empty-state .icon{margin-bottom:12px;font-size:48px}.empty-state p{font-size:16px}.tabs{border-bottom:2px solid var(--border);gap:0;margin-bottom:20px;display:flex}.tab{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .2s}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.tab:hover{color:var(--primary)}.mobile-menu-btn{cursor:pointer;color:var(--text-primary);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:4px;font-size:24px;display:none}.sidebar-backdrop{z-index:150;background:#00000073;display:none;position:fixed;inset:0}@media (width<=1024px){.stat-cards{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.fdb-stat-cards{grid-template-columns:repeat(2,1fr)}.fdb-columns{grid-template-columns:1fr}.pay-stat-row{grid-template-columns:repeat(2,1fr)}.page-content{padding:20px 16px}}@media (width<=768px){.mobile-menu-btn{display:flex}.sidebar,.faculty-sidebar{z-index:200;transition:transform .3s;transform:translate(-100%)}.app-layout.sidebar-open .sidebar,.app-layout.sidebar-open .faculty-sidebar{transform:translate(0)}.app-layout.sidebar-open .sidebar-backdrop{display:block}.main-content,.faculty-sidebar~.main-content,.faculty-sidebar.collapsed~.main-content{margin-left:0!important}.page-content{padding:16px 12px}.top-header{padding:8px 12px}.header-right{gap:8px}.user-dropdown-name{display:none}.search-bar input{width:140px}.header-search input{width:120px}.stat-cards,.fdb-stat-cards,.pay-stat-row{grid-template-columns:1fr 1fr}.filter-bar{grid-template-columns:1fr}.detail-grid{grid-template-columns:1fr 1fr}.table-controls{flex-direction:column;align-items:stretch;gap:10px}.table-controls .entries-select{flex-direction:row;align-items:center;gap:8px;font-size:13px;display:flex}.table-controls .entries-select select{width:auto}.table-controls .table-search{font-size:13px}.table-controls .table-search input,.table-controls .filter-group select{width:100%}.section-card{-webkit-overflow-scrolling:touch;overflow:auto visible}.section-body{padding:14px}.data-table{table-layout:fixed;width:100%;min-width:0;max-width:100%;display:block}.data-table tbody{width:100%;display:block}.data-table thead{display:none}.data-table tbody tr{border:1px solid var(--border);box-sizing:border-box;background:#f8fafc;border-radius:8px;width:100%;margin-bottom:10px;padding:12px 14px;display:block}.data-table tbody tr td{box-sizing:border-box;border:none;justify-content:space-between;align-items:center;width:100%;min-width:0;padding:4px 0;font-size:13px;display:flex}.data-table tbody tr td:before{content:attr(data-label);color:var(--text-muted);text-transform:uppercase;flex-shrink:0;max-width:40%;margin-right:12px;font-size:11px;font-weight:600}.data-table tbody tr td>*{text-overflow:ellipsis;min-width:0;overflow:hidden}.data-table tbody tr td.table-empty{text-align:center;background:0 0;border:none;padding:20px 0;display:block}.data-table tbody tr td.table-empty:before{content:none}.data-table tbody tr td:has(.btn){flex-wrap:wrap;justify-content:flex-end;gap:6px;padding-top:8px}.data-table tbody tr td:has(.btn):before{content:none}.no-card-mobile{table-layout:auto;width:auto;min-width:600px;max-width:none;display:table}.no-card-mobile thead{display:table-header-group}.no-card-mobile tbody{display:table-row-group}.no-card-mobile tbody tr{background:0 0;border:none;border-radius:0;margin-bottom:0;padding:0;display:table-row}.no-card-mobile tbody tr td{border-bottom:1px solid #f1f5f9;padding:10px 14px;display:table-cell}.no-card-mobile tbody tr td:before{content:none}.modal,.modal-content{width:96%;max-width:none}.modal-body{padding:16px}.modal-header,.modal-footer{padding:12px 16px}.form-row{grid-template-columns:1fr!important}.fdb-columns{grid-template-columns:1fr}.page-header-row{flex-direction:column;align-items:flex-start;gap:10px}.tabs,.ann-tabs{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto}.tab,.ann-tab{white-space:nowrap;flex-shrink:0}.profile-layout{flex-direction:column}.profile-layout>.section-card:last-child{width:100%!important}.schedule-grid,.admin-schedule-grid{min-width:700px}.announcement-card{padding:14px}.account-settings-card{max-width:100%;padding:20px 16px}.faculty-sidebar,.faculty-sidebar.collapsed{width:220px}.faculty-sidebar.collapsed .fs-section-label,.faculty-sidebar.collapsed .fs-item-label,.faculty-sidebar.collapsed .fs-title{display:block}.faculty-sidebar.collapsed .fs-item{justify-content:flex-start;padding:10px 16px}.faculty-sidebar.collapsed .fs-header{padding:24px 12px 16px}.faculty-sidebar.collapsed .fs-avatar{width:64px;height:64px}.login-container{flex-direction:column;min-height:auto}.login-banner{flex:0 0 150px}.login-form-panel{padding:28px 20px}.table-actions{flex-wrap:wrap}.pagination{flex-wrap:wrap;justify-content:center}.msg-preview{max-width:150px}.msg-subject{max-width:180px}}@media (width<=480px){.stat-cards,.fdb-stat-cards,.pay-stat-row,.detail-grid{grid-template-columns:1fr}.page-content{padding:12px 8px}.search-bar input,.header-search input{width:100px}.login-banner{display:none}.login-form-panel{padding:24px 16px}.credits-badge{padding:3px 8px;font-size:11px}}.student-avatar-sm{color:#666;background:#ddd;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:16px;font-weight:600;display:flex;overflow:hidden}.student-avatar-sm img{object-fit:cover;width:100%;height:100%}.profile-layout{align-items:flex-start;gap:20px;display:flex}.profile-avatar-large{color:#aaa;background:#e8e8e8;border-radius:50%;justify-content:center;align-items:center;width:180px;height:180px;margin:0 auto;font-size:64px;font-weight:700;display:flex;overflow:hidden}.profile-avatar-large img{object-fit:cover;width:100%;height:100%}.profile-form-row{align-items:flex-start;gap:8px;margin-bottom:14px;display:flex}.profile-label{white-space:nowrap;min-width:120px;padding-top:6px;font-size:14px;font-weight:600}.profile-input{border:1px solid var(--border);border-radius:4px;width:200px;padding:6px 10px;font-family:inherit;font-size:13px}.profile-input:focus{border-color:var(--primary);outline:none}textarea.profile-input{resize:vertical}.profile-name-fields{flex-wrap:wrap;gap:8px;display:flex}.profile-name-fields>div{flex-direction:column;display:flex}.field-hint{color:var(--text-muted);margin-top:2px;font-size:11px}.profile-divider{border:none;border-top:1px solid var(--border);margin:18px 0}.profile-section-heading{color:var(--text-primary);margin-bottom:14px;font-size:15px;font-weight:700}@media (width<=900px){.profile-layout{flex-direction:column}.profile-layout>.section-card:last-child{width:100%!important}}.schedule-grid{border-collapse:collapse;table-layout:fixed;width:100%}.schedule-grid th,.schedule-grid td{border:1px solid var(--border);text-align:center;vertical-align:middle;height:56px;padding:0}.schedule-time-header{color:var(--primary);background:#f0f0f5;min-width:100px;padding:8px 4px;font-size:13px;font-weight:600}.schedule-day-header{color:#fff;text-transform:uppercase;letter-spacing:1px;background:linear-gradient(135deg,#c59d2c,#e6b83a);padding:10px 4px;font-size:14px;font-weight:700}.schedule-time-cell{color:var(--primary);background:#f8f8fc;padding:6px;font-size:13px;font-weight:700}.schedule-subject-cell{color:#fff;cursor:default;border-radius:0;padding:6px 4px;font-size:13px;font-weight:600}.schedule-subject-cell small{opacity:.85;margin-top:2px;font-size:11px;font-weight:400;display:block}.schedule-empty-cell{background:#fafafa}.admin-schedule-grid td,.admin-schedule-grid th{height:44px}.admin-sched-empty{transition:background .15s}.admin-sched-empty:hover{background:#e8f0fe!important}.admin-sched-plus{color:var(--primary);opacity:.5;font-size:20px;font-weight:700;display:none}.admin-sched-empty:hover .admin-sched-plus{display:inline}.admin-sched-block{border-radius:0;transition:filter .15s,box-shadow .15s}.admin-sched-block:hover{filter:brightness(1.12);box-shadow:inset 0 0 0 2px #fff6}.admin-sched-delete{color:#fff;cursor:pointer;text-align:center;background:#00000040;border:none;border-radius:50%;width:18px;height:18px;padding:0;font-size:13px;line-height:16px;display:none;position:absolute;top:2px;right:4px}.admin-sched-block:hover .admin-sched-delete{display:block}.admin-sched-delete:hover{background:#dc3545}.subject-legend{flex-wrap:wrap;gap:10px;margin-top:16px;display:flex}.subject-legend-item{align-items:center;gap:6px;font-size:13px;display:flex}.subject-legend-dot{border-radius:3px;flex-shrink:0;width:14px;height:14px}.credits-badge{color:#fff;background:linear-gradient(135deg,#c59d2c,#e6b83a);border-radius:20px;align-items:center;gap:4px;padding:4px 12px;font-size:13px;font-weight:700;display:inline-flex}.stat-card.purple{background:linear-gradient(135deg,#7c3aed,#a855f7);position:relative}.stat-card.red{background:linear-gradient(135deg,#dc2626,#ef4444)}.stat-card.purple .stat-label,.stat-card.purple .stat-value,.stat-card.purple .stat-icon,.stat-card.red .stat-label,.stat-card.red .stat-value,.stat-card.red .stat-icon{color:#fff!important}.sidebar-logo-text{color:#fff;letter-spacing:1px;font-size:16px;font-weight:700;display:none}.header-search{flex:none;align-items:center;gap:4px;display:flex}.header-search input{border:1px solid var(--border);border-radius:var(--radius);width:220px;padding:6px 12px;font-size:13px}.stat-card.orange{background:linear-gradient(135deg,#ea580c,#f97316)}.stat-card.orange .stat-label,.stat-card.orange .stat-value,.stat-card.orange .stat-icon{color:#fff!important}.faculty-sidebar{background:var(--sidebar-bg);z-index:200;flex-direction:column;width:220px;min-height:100vh;transition:width .25s;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.faculty-sidebar.collapsed{width:64px}.faculty-sidebar~.main-content{margin-left:220px;transition:margin-left .25s}.faculty-sidebar.collapsed~.main-content{margin-left:64px}.fs-header{border-bottom:1px solid #ffffff26;flex-direction:column;align-items:center;padding:24px 12px 16px;display:flex}.fs-avatar{background:#fff3;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:8px;display:flex;overflow:hidden}.fs-avatar img{object-fit:cover;border-radius:50%;width:100%;height:100%}.fs-avatar span{color:#fff;font-size:24px;font-weight:700}.fs-title{color:#fff;letter-spacing:1.5px;text-transform:uppercase;font-size:14px;font-weight:700}.fs-nav{flex:1;padding:8px 0;overflow-y:auto}.fs-section{margin-bottom:4px}.fs-section-label{color:#ffffff80;letter-spacing:1px;text-transform:uppercase;padding:12px 16px 4px;font-size:10px;font-weight:700}.faculty-sidebar.collapsed .fs-section-label{display:none}.fs-item{color:#fffc;white-space:nowrap;border-radius:0;align-items:center;gap:12px;padding:10px 16px;font-size:13px;text-decoration:none;transition:background .15s,color .15s;display:flex}.fs-item:hover{background:var(--sidebar-hover);color:#fff}.fs-item.active{background:var(--sidebar-active);color:#fff;font-weight:600}.fs-item-icon{flex-shrink:0;font-size:18px}.fs-item-label{font-size:13px}.faculty-sidebar.collapsed .fs-item{justify-content:center;padding:10px}.faculty-sidebar.collapsed .fs-header{padding:16px 8px 12px}.faculty-sidebar.collapsed .fs-avatar{width:40px;height:40px}.faculty-sidebar.collapsed .fs-avatar span{font-size:16px}.fs-collapse-btn{color:#fff9;cursor:pointer;background:0 0;border:none;border-top:1px solid #ffffff26;justify-content:center;align-items:center;padding:12px;font-size:18px;transition:color .15s,background .15s;display:flex}.fs-collapse-btn:hover{color:#fff;background:var(--sidebar-hover)}.user-dropdown-wrap{position:relative}.user-dropdown-trigger{cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;padding:4px 8px;transition:background .15s;display:flex}.user-dropdown-trigger:hover{background:#0000000d}.user-dropdown-name{color:var(--text-primary,#1e293b);white-space:nowrap;font-size:14px;font-weight:500}.user-dropdown-menu{z-index:1000;background:#fff;border-radius:10px;min-width:200px;padding:8px 0;animation:.15s dropdownFadeIn;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 4px 24px #0000001f}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.user-dropdown-item{cursor:pointer;color:#334155;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:10px 18px;font-size:14px;text-decoration:none;transition:background .12s;display:flex}.user-dropdown-item:hover{background:#f1f5f9}.user-dropdown-icon{color:#64748b;flex-shrink:0;font-size:18px}.user-dropdown-divider{background:#e2e8f0;height:1px;margin:4px 0}.account-settings-card{background:#fff;border-radius:12px;max-width:500px;margin-top:16px;padding:28px 32px;box-shadow:0 1px 6px #00000014}.account-settings-card .form-group{margin-bottom:18px}.account-settings-card label{color:#475569;margin-bottom:6px;font-size:13px;font-weight:500;display:block}.account-settings-card .form-input{border:1px solid #cbd5e1;border-radius:8px;width:100%;padding:10px 14px;font-size:14px}.account-settings-card .form-input:disabled{color:#94a3b8;background:#f1f5f9}.account-settings-card .form-actions{gap:12px;margin-top:24px;display:flex}.alert{border-radius:8px;margin-bottom:16px;padding:10px 16px;font-size:14px}.alert-success{color:#166534;background:#dcfce7;border:1px solid #bbf7d0}.alert-error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.page-header-row{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.ann-tabs{border-bottom:2px solid #e2e8f0;gap:0;margin-bottom:20px;display:flex}.ann-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 20px;font-size:14px;font-weight:600;transition:color .2s,border-color .2s}.ann-tab:hover{color:var(--primary)}.ann-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.announcement-form-card{background:#fff;border-radius:12px;margin-bottom:20px;padding:24px 28px;box-shadow:0 1px 6px #00000014}.announcement-upload-btn{color:#64748b;cursor:pointer;border:2px dashed #cbd5e1;border-radius:8px;align-items:center;gap:8px;padding:10px 18px;font-size:14px;transition:border-color .15s,color .15s;display:inline-flex}.announcement-upload-btn:hover{border-color:var(--primary);color:var(--primary)}.announcement-image-preview{max-width:100%;display:inline-block;position:relative}.announcement-image-preview img{object-fit:cover;border-radius:8px;max-width:100%;max-height:300px}.announcement-remove-img{position:absolute;top:8px;right:8px}.fdb-title-row{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.fdb-school-year{color:var(--text-muted);font-size:14px;font-weight:500}.fdb-stat-cards{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.fdb-stat-card{background:#fff;border-left:4px solid #0000;border-radius:10px;justify-content:space-between;align-items:center;padding:18px 20px;display:flex;box-shadow:0 1px 4px #0000000f}.fdb-stat-blue{border-left-color:var(--primary)}.fdb-stat-green{border-left-color:#10b981}.fdb-stat-orange{border-left-color:#f59e0b}.fdb-stat-yellow{border-left-color:#eab308}.fdb-stat-label{text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:11px;font-weight:700}.fdb-stat-blue .fdb-stat-label{color:var(--primary)}.fdb-stat-green .fdb-stat-label{color:#10b981}.fdb-stat-orange .fdb-stat-label{color:#f59e0b}.fdb-stat-yellow .fdb-stat-label{color:#eab308}.fdb-stat-value{color:var(--text-primary);font-size:22px;font-weight:700}.fdb-stat-icon{color:#cbd5e1;font-size:32px}.fdb-columns{grid-template-columns:1fr 300px;align-items:start;gap:20px;display:grid}.fdb-ann-item{border-bottom:1px solid #f1f5f9;border-left:3px solid var(--primary);margin:0;padding:16px 20px}.fdb-ann-item:last-child{border-bottom:none}.fdb-ann-title{color:var(--primary);margin-bottom:4px;font-size:15px;font-weight:700}.fdb-ann-meta{color:var(--text-muted);margin-bottom:6px;font-size:12px}.fdb-ann-badge{color:#fff;background:#16a34a;border-radius:4px;margin-bottom:4px;padding:2px 10px;font-size:11px;font-weight:600;display:inline-block}.fdb-ann-content{color:var(--text-muted);margin-top:4px;font-size:13px}.fdb-quick-link{color:var(--text-primary);border-bottom:1px solid #f1f5f9;align-items:center;gap:12px;padding:14px 20px;font-size:14px;font-weight:500;text-decoration:none;transition:background .12s;display:flex}.fdb-quick-link:last-child{border-bottom:none}.fdb-quick-link:hover{background:#f8fafc}.fdb-quick-icon{flex-shrink:0;font-size:20px}.fdb-quick-link span{flex:1}.fdb-quick-arrow{color:#94a3b8;font-size:16px}@media (width<=900px){.fdb-stat-cards{grid-template-columns:repeat(2,1fr)}.fdb-columns{grid-template-columns:1fr}}@media (width<=768px){.fdb-title-row{flex-wrap:wrap;gap:8px}.fdb-stat-card{padding:14px 12px}.fdb-stat-value{word-break:break-word;font-size:18px}.fdb-stat-icon{font-size:24px}.fdb-ann-item{padding:12px 14px}.fdb-ann-meta{word-break:break-word}.fdb-quick-link{padding:12px 14px}}@media print{.sidebar,.faculty-sidebar,.top-header,.sidebar-backdrop,.mobile-menu-btn,.no-print{display:none!important}.main-content{margin-left:0!important}.page-content{padding:0!important}.section-card{border:1px solid #ddd;box-shadow:none!important}body{background:#fff!important}.data-table{min-width:0!important}}.pay-stat-row{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px;display:grid}.pay-stat-card{background:#fff;border-left:4px solid #0000;border-radius:10px;padding:16px 20px;position:relative;box-shadow:0 1px 4px #0000000f}.pay-stat-blue{border-left-color:var(--primary)}.pay-stat-teal{border-left-color:#14b8a6}.pay-stat-purple{border-left-color:#8b5cf6}.pay-stat-yellow{border-left-color:#eab308}.pay-stat-label{text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:11px;font-weight:700}.pay-stat-blue .pay-stat-label{color:var(--primary)}.pay-stat-teal .pay-stat-label{color:#14b8a6}.pay-stat-purple .pay-stat-label{color:#8b5cf6}.pay-stat-yellow .pay-stat-label{color:#eab308}.pay-stat-input{color:var(--text-primary);background:#f1f5f9;border-radius:6px;padding:10px 14px;font-size:15px;font-weight:600}.pay-stat-note{color:#ef4444;margin-top:8px;font-size:10px;font-style:italic}.pay-amount-card{border-left:4px solid var(--primary);background:#fff;border-radius:10px;margin-bottom:24px;padding:20px 24px;box-shadow:0 1px 4px #0000000f}.pay-amount-value{color:var(--text-primary);margin-top:4px;font-size:32px;font-weight:700}.pay-balance-row{gap:16px;margin-bottom:20px;display:flex}.pay-page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.pay-header-controls{flex-wrap:wrap;align-items:center;gap:8px;display:flex}@media (width<=900px){.pay-stat-row{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.pay-page-header{flex-direction:column;align-items:flex-start}.pay-header-controls{flex-wrap:wrap;width:100%}.pay-header-controls .form-input{width:100%!important}.pay-balance-row{flex-direction:column}.pay-amount-value{font-size:24px}.pay-stat-input{padding:8px 10px;font-size:13px}.pay-stat-row{background:#fff;border-radius:10px;flex-direction:column;gap:0;margin-bottom:16px;padding:4px 0;display:flex;box-shadow:0 1px 4px #0000000f}.pay-stat-card{box-shadow:none;border-bottom:1px solid #f1f5f9;border-left:none;border-radius:0;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.pay-stat-card:last-child{border-bottom:none}.pay-stat-label{flex-shrink:0;margin-bottom:0;font-size:12px}.pay-stat-input{text-align:right;background:0 0;padding:0;font-size:14px}.pay-stat-note{display:none}}@media (width<=480px){.pay-amount-value{font-size:20px}.pay-amount-card{padding:14px 16px}.pay-stat-card{padding:12px 14px}}.msg-item{border-bottom:1px solid #e2e8f0;align-items:center;gap:14px;padding:14px 20px;transition:background .15s;display:flex}.msg-item:hover{background:#f8fafc}.msg-avatar{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:16px;font-weight:700;display:flex}.msg-content{flex:1;min-width:0}.msg-sender{color:var(--text-primary);align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.msg-role{color:var(--text-muted);text-transform:capitalize;background:#f1f5f9;border-radius:8px;padding:1px 7px;font-size:11px;font-weight:500}.msg-subject{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:13px;font-weight:600;overflow:hidden}.msg-preview{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:12px;overflow:hidden}.msg-meta{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:6px;display:flex}.msg-date{color:var(--text-muted);white-space:nowrap;font-size:12px}.msg-unread-dot{background:var(--primary);border-radius:50%;width:10px;height:10px;display:inline-block}.alert-danger{color:#991b1b;border-radius:var(--radius);background:#fef2f2;border:1px solid #fecaca;margin-bottom:16px;padding:10px 16px;font-size:14px}.info-banner{background:linear-gradient(135deg, var(--primary), var(--primary-light));color:#fff;border-radius:var(--radius);margin-bottom:20px;padding:14px 20px;font-size:14px}.credential-card{border-radius:var(--radius);background:#f0f4ff;margin-bottom:12px;padding:16px}.credential-row{justify-content:space-between;align-items:center;display:flex}.credential-row+.credential-row{margin-top:8px}.credential-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-size:11px}.credential-value{font-family:monospace;font-size:16px;font-weight:600}.table-actions{flex-wrap:nowrap;align-items:center;gap:8px;display:flex}.detail-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;margin-bottom:20px;display:grid}.detail-label{color:var(--text-muted);margin-bottom:2px;font-size:13px}.detail-value{font-weight:600}
