@import "https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap";:root{--primary:#2563eb;--primary-hover:#1d4ed8;--primary-light:#dbeafe;--primary-50:#eff6ff;--primary-100:#dbeafe;--primary-600:#2563eb;--primary-700:#1d4ed8;--success:#16a34a;--success-light:#dcfce7;--warning:#f59e0b;--warning-light:#fef3c7;--danger:#dc2626;--danger-light:#fef2f2;--info:#0891b2;--info-light:#cffafe;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--text-primary:var(--gray-900);--text-secondary:var(--gray-600);--text-muted:var(--gray-400);--bg-main:var(--gray-50);--bg-white:#fff;--border:var(--gray-200);--border-light:var(--gray-100);--sidebar-bg:var(--gray-900);--sidebar-hover:#ffffff14;--sidebar-active:#2563eb33;--sidebar-active-border:var(--primary);--sidebar-width:260px;--sidebar-collapsed:72px;--header-height:64px;--radius:8px;--radius-lg:12px;--radius-xl:16px;--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--shadow-md:0 10px 15px -3px #00000014, 0 4px 6px -4px #0000000a;--shadow-lg:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000000a;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.2s cubic-bezier(.4, 0, .2, 1);--transition-slow:.3s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility}body{background:var(--bg-main);color:var(--text-primary);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.6}a{color:inherit;text-decoration:none}img{max-width:100%}.loading-screen{background:var(--bg-main);flex-direction:column;justify-content:center;align-items:center;gap:20px;height:100vh;display:flex}.spinner{border:3px solid var(--gray-200);border-top:3px solid var(--primary);border-radius:50%;width:40px;height:40px;animation:.7s 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;height:100vh;transition:width var(--transition-slow);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow:visible}.sidebar-logo{color:#fff;letter-spacing:-.3px;border-bottom:1px solid #ffffff14;flex-shrink:0;justify-content:center;align-items:center;gap:10px;height:64px;padding:0 20px;font-size:20px;font-weight:700;text-decoration:none;display:flex}.sidebar-logo svg{color:var(--primary);font-size:24px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px;display:flex;overflow:hidden auto}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:4px}.sidebar-section-label{text-transform:uppercase;letter-spacing:1.2px;color:#ffffff59;white-space:nowrap;padding:20px 12px 8px;font-size:11px;font-weight:600}.sidebar-item{cursor:pointer;width:100%;transition:all var(--transition-fast);border-radius:var(--radius);color:#ffffffa6;white-space:nowrap;background:0 0;border:none;align-items:center;gap:12px;padding:10px 12px;font-family:inherit;font-size:13.5px;font-weight:500;text-decoration:none;display:flex;position:relative}.sidebar-item:hover{background:var(--sidebar-hover);color:#fff}.sidebar-item.active{background:var(--sidebar-active);color:#fff;font-weight:600}.sidebar-item.active:before{content:"";background:var(--primary);border-radius:0 3px 3px 0;width:3px;position:absolute;top:6px;bottom:6px;left:0}.sidebar-item .icon{opacity:.85;flex-shrink:0;font-size:20px}.sidebar-item.active .icon{opacity:1;color:var(--primary)}.sidebar-item .label{opacity:1;font-size:13.5px;line-height:1.3}.sidebar-chevron{opacity:.5;transition:transform var(--transition-fast);flex-shrink:0;margin-left:auto;font-size:14px}.sidebar-chevron.open{transform:rotate(90deg)}.sidebar-submenu{max-height:0;transition:max-height var(--transition-slow);padding-left:0;overflow:hidden}.sidebar-submenu.open{max-height:600px}.sidebar-sub-item{color:#ffffff80;border-radius:var(--radius);transition:all var(--transition-fast);white-space:nowrap;align-items:center;gap:10px;padding:8px 12px 8px 44px;font-size:13px;font-weight:500;text-decoration:none;display:flex}.sidebar-sub-item:hover{color:#ffffffd9;background:var(--sidebar-hover)}.sidebar-sub-item.active{color:#fff;background:var(--sidebar-active);font-weight:600}.sidebar-sub-item:before{content:"";background:#ffffff40;border-radius:50%;flex-shrink:0;width:6px;height:6px}.sidebar-sub-item.active:before{background:var(--primary)}.sidebar-dropdown{left:calc(var(--sidebar-width) - 12px);background:var(--bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:200;border:1px solid var(--border);min-width:220px;max-height:calc(100vh - 20px);padding:8px;animation:.15s dropdownFadeIn;display:none;position:absolute;top:0;overflow-y:auto}.sidebar-dropdown-up{top:auto;bottom:0}.sidebar-dropdown-title{text-transform:uppercase;color:var(--text-muted);letter-spacing:.8px;padding:8px 12px 6px;font-size:11px;font-weight:700}.sidebar-dropdown a,.sidebar-dropdown .dropdown-link{color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);border-radius:var(--radius);padding:9px 12px;font-size:13.5px;font-weight:500;display:block}.sidebar-dropdown a:hover,.sidebar-dropdown .dropdown-link:hover{background:var(--primary-50);color:var(--primary)}.main-content{margin-left:var(--sidebar-width);min-height:100vh;transition:margin-left var(--transition-slow);background:var(--bg-main);flex-direction:column;flex:1;display:flex}.top-header{height:var(--header-height);background:var(--bg-white);border-bottom:1px solid var(--border);z-index:50;justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:sticky;top:0}.search-bar{align-items:center;gap:0;display:flex}.search-bar input{border:1px solid var(--gray-200);border-radius:var(--radius) 0 0 var(--radius);background:var(--gray-50);width:300px;transition:all var(--transition-fast);border-right:none;outline:none;padding:8px 16px;font-family:inherit;font-size:13px}.search-bar input:focus{border-color:var(--primary);background:var(--bg-white);box-shadow:0 0 0 3px #2563eb1a}.search-bar button{background:var(--primary);color:#fff;border-radius:0 var(--radius) var(--radius) 0;cursor:pointer;transition:background var(--transition-fast);border:none;padding:8px 14px;font-size:14px}.search-bar button:hover{background:var(--primary-hover)}.header-right{align-items:center;gap:8px;display:flex}.header-badge{cursor:pointer;color:var(--gray-500);border-radius:var(--radius);width:40px;height:40px;transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:20px;display:flex;position:relative}.header-badge:hover{background:var(--gray-100);color:var(--gray-700)}.header-badge .count{background:var(--danger);color:#fff;border:2px solid var(--bg-white);border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;font-weight:700;display:flex;position:absolute;top:4px;right:4px}.header-user{color:var(--text-secondary);align-items:center;gap:10px;font-size:13px;display:flex}.header-avatar{background:var(--primary-light);width:36px;height:36px;color:var(--primary);border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:600;display:flex}.page-content{flex:1;max-width:1400px;padding:28px 32px}.page-title{color:var(--text-primary);letter-spacing:-.3px;margin-bottom:24px;font-size:24px;font-weight:700}.school-year-badge{background:var(--primary);color:#fff;float:right;border-radius:20px;align-items:center;padding:5px 14px;font-size:12px;font-weight:600;display:inline-flex}.stat-cards{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:28px;display:grid}.stat-card{background:var(--bg-white);border-radius:var(--radius-lg);border:1px solid var(--border);transition:all var(--transition-base);justify-content:space-between;align-items:center;padding:22px 24px;display:flex;position:relative;overflow:hidden}.stat-card:before{content:"";width:4px;position:absolute;top:0;bottom:0;left:0}.stat-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.stat-card.blue:before{background:var(--primary)}.stat-card.green:before{background:var(--success)}.stat-card.orange:before{background:var(--warning)}.stat-card.teal:before{background:var(--info)}.stat-card.red:before{background:var(--danger)}.stat-card .stat-info .stat-label{text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600}.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);letter-spacing:-.5px;font-size:30px;font-weight:800}.stat-card .stat-icon{color:var(--gray-200);font-size:36px}.section-card{background:var(--bg-white);border-radius:var(--radius-lg);border:1px solid var(--border);margin-bottom:24px;overflow:hidden}.section-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 24px;display:flex}.section-title{color:var(--text-primary);letter-spacing:-.2px;font-size:15px;font-weight:700}.section-body{padding:24px}.filter-bar{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:20px;display:grid}.filter-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.filter-group select,.filter-group input{border:1px solid var(--gray-200);border-radius:var(--radius);background:var(--bg-white);width:100%;color:var(--text-primary);transition:all var(--transition-fast);outline:none;padding:9px 12px;font-family:inherit;font-size:13px}.filter-group select:focus,.filter-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb14}.filter-actions{align-items:flex-end;gap:8px;display:flex}.btn{border-radius:var(--radius);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);letter-spacing:.01em;border:none;justify-content:center;align-items:center;gap:7px;padding:9px 18px;font-family:inherit;font-size:13px;font-weight:600;line-height:1.4;display:inline-flex}.btn:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn:active{box-shadow:none;transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#15803d}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-warning{background:var(--warning);color:#fff}.btn-warning:hover{background:#d97706}.btn-info{background:var(--info);color:#fff}.btn-info:hover{background:#0e7490}.btn-secondary{background:var(--gray-600);color:#fff}.btn-secondary:hover{background:var(--gray-700)}.btn-outline{background:var(--bg-white);border:1px solid var(--gray-300);color:var(--text-secondary)}.btn-outline:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-50)}.btn-sm{border-radius:6px;padding:6px 12px;font-size:12px}.btn-lg{padding:12px 28px;font-size:15px}.btn-icon{border-radius:var(--radius);justify-content:center;align-items:center;width:36px;height:36px;padding:0;display:inline-flex}.data-table{border-collapse:collapse;width:100%}.data-table th{background:var(--gray-50);text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);white-space:nowrap;padding:12px 16px;font-size:12px;font-weight:700}.data-table td{border-bottom:1px solid var(--gray-100);vertical-align:middle;color:var(--text-primary);padding:14px 16px;font-size:13.5px}.data-table tr{transition:background var(--transition-fast)}.data-table tr:hover{background:var(--gray-50)}.data-table .table-actions{flex-wrap:nowrap;align-items:center;gap:6px;display:flex}.table-empty{text-align:center;color:var(--text-muted);font-size:14px;padding:40px!important}.link-cell{color:var(--primary);transition:color var(--transition-fast);font-size:13px;font-weight:500}.link-cell:hover{color:var(--primary-hover);text-decoration:underline}.badge{letter-spacing:.3px;text-transform:uppercase;border-radius:20px;align-items:center;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.badge-published,.badge-active,.badge-approved,.badge-present,.badge-completed{background:var(--success-light);color:var(--success)}.badge-draft,.badge-pending{background:var(--warning-light);color:#92400e}.badge-inactive,.badge-rejected,.badge-absent{background:var(--danger-light);color:var(--danger)}.badge-info,.badge-enrolled{background:var(--info-light);color:#155e75}.badge-late,.badge-excused{background:var(--primary-light);color:var(--primary)}.badge-graded{background:var(--success-light);color:var(--success)}.badge-secondary{background:var(--gray-600);color:#fff}.badge-danger{background:var(--danger);color:#fff}.badge-warning{background:var(--warning);color:#fff}.badge-primary{background:var(--primary);color:#fff}.badge-purple{color:#fff;background:#7c3aed}.badge-muted{background:var(--gray-400);color:#fff}.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:#fff}.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;gap:12px;margin-bottom:16px;display:flex}.entries-select{color:var(--text-secondary);align-items:center;gap:8px;font-size:13px;display:flex}.entries-select select{border:1px solid var(--gray-200);border-radius:var(--radius);background:var(--bg-white);padding:6px 10px;font-family:inherit;font-size:13px}.table-search input{border:1px solid var(--gray-200);border-radius:var(--radius);transition:all var(--transition-fast);background:var(--bg-white);outline:none;padding:8px 14px;font-family:inherit;font-size:13px}.table-search input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb14}.pagination{justify-content:center;align-items:center;gap:4px;margin-top:20px;display:flex}.pagination button{border:1px solid var(--gray-200);background:var(--bg-white);border-radius:var(--radius);cursor:pointer;color:var(--text-secondary);transition:all var(--transition-fast);padding:7px 12px;font-family:inherit;font-size:13px;font-weight:500}.pagination button:hover:not(:disabled){border-color:var(--primary);color:var(--primary);background:var(--primary-50)}.pagination button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.announcement-card{background:var(--bg-white);border-radius:var(--radius-lg);border:1px solid var(--border);transition:box-shadow var(--transition-base);margin-bottom:16px;padding:22px 24px}.announcement-card:hover{box-shadow:var(--shadow-sm)}.announcement-meta{align-items:center;gap:12px;margin-bottom:14px;display:flex}.announcement-avatar{background:var(--primary-light);border-radius:50%;flex-shrink:0;width:40px;height:40px;overflow:hidden}.announcement-info .name{color:var(--text-primary);font-size:13px;font-weight:600}.announcement-info .date{color:var(--text-muted);font-size:12px}.announcement-title{color:var(--text-primary);margin-bottom:8px;font-size:16px;font-weight:700}.announcement-body{color:var(--text-secondary);font-size:14px;line-height:1.7}.form-group{margin-bottom:18px}.form-group label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--gray-200);border-radius:var(--radius);background:var(--bg-white);width:100%;color:var(--text-primary);transition:all var(--transition-fast);outline:none;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 #2563eb1a}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background:var(--gray-50);color:var(--gray-500)}.form-group input[readonly]{background:var(--gray-50);color:var(--text-secondary);cursor:default}.form-row{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;display:grid}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f172a80;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal,.modal-content{background:var(--bg-white);border-radius:var(--radius-xl);width:90%;max-width:640px;max-height:90vh;box-shadow:var(--shadow-lg);border:1px solid var(--border);flex-direction:column;animation:.2s modalSlideIn;display:flex;overflow:hidden}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.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:20px 24px;display:flex}.modal-header h3{color:var(--text-primary);letter-spacing:-.2px;font-size:18px;font-weight:700}.modal-close{cursor:pointer;color:var(--text-muted);border-radius:var(--radius);width:36px;height:36px;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;font-size:20px;display:flex}.modal-close:hover{background:var(--gray-100);color:var(--text-primary)}.modal-body{flex:1;padding:24px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);background:var(--gray-50);flex-shrink:0;justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}.login-page{background:linear-gradient(135deg,#1e3a5f 0%,#0f172a 50%,#1e293b 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-container{border-radius:var(--radius-xl);width:100%;max-width:960px;min-height:580px;display:flex;overflow:hidden;box-shadow:0 32px 64px #00000059}.login-banner{color:#fff;background:linear-gradient(135deg,#1e40af 0%,#2563eb 100%);flex:0 0 44%;align-items:flex-end;padding:48px 36px;display:flex;position:relative;overflow:hidden}.login-banner:before{content:"";opacity:.55;background:url(/student-banner.svg) 50%/cover;position:absolute;inset:0}.login-banner-overlay{background:linear-gradient(#2563eb80 0%,#1e40afeb 100%);position:absolute;inset:0}.login-banner-content{z-index:1;position:relative}.login-banner-content h2{letter-spacing:-.5px;margin-bottom:12px;font-size:32px;font-weight:800}.login-banner-content p{opacity:.9;font-size:15px;line-height:1.7}.login-form-panel{background:var(--bg-white);flex:1;justify-content:center;align-items:center;padding:48px 40px;display:flex}.login-form-inner{width:100%;max-width:380px}.login-brand{text-align:center;margin-bottom:16px}.login-title{text-align:center;color:var(--text-primary);letter-spacing:-.5px;margin-bottom:6px;font-size:28px;font-weight:800}.login-subtitle{text-align:center;color:var(--text-muted);margin-bottom:32px;font-size:14px}.login-form-inner .form-group{margin-bottom:20px}.login-pw-wrap{position:relative}.login-pw-icon{color:var(--text-muted);pointer-events:none;display:flex;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.login-pw-toggle{cursor:pointer;color:var(--text-muted);transition:color var(--transition-fast);background:0 0;border:none;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.login-pw-toggle:hover{color:var(--text-primary)}.login-options{gap:20px;margin-bottom:24px;display:flex}.login-check{color:var(--text-secondary);cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.login-check input{cursor:pointer;accent-color:var(--primary)}.login-btn{border-radius:var(--radius);letter-spacing:.01em;justify-content:center;width:100%;padding:13px;font-size:15px;font-weight:700}.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(--gray-200);margin:24px 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{background:var(--danger-light);color:var(--danger);border-radius:var(--radius);border:1px solid #fecaca;margin-bottom:20px;padding:12px 16px;font-size:13px;font-weight:500}@media (width<=700px){.login-container{flex-direction:column;min-height:auto}.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-lg);color:#fff;box-shadow:var(--shadow-md);padding:14px 20px;font-size:14px;font-weight:500;animation:.3s toastSlideIn}.toast-success{background:var(--success)}.toast-error{background:var(--danger)}.toast-info{background:var(--primary)}@keyframes toastSlideIn{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{opacity:.5;margin-bottom:16px;font-size:52px}.empty-state p{font-size:15px}.tabs{border-bottom:2px solid var(--gray-200);gap:0;margin-bottom:24px;display:flex}.tab{cursor:pointer;color:var(--text-muted);transition:all var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:12px 20px;font-family:inherit;font-size:14px;font-weight:600}.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{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:150;background:#0f172a80;display:none;position:fixed;inset:0}.student-avatar-sm{background:var(--primary-light);width:40px;height:40px;color:var(--primary);border-radius:50%;justify-content:center;align-items:center;font-size:15px;font-weight:700;display:flex;overflow:hidden}.student-avatar-sm img{object-fit:cover;width:100%;height:100%}.profile-layout{align-items:flex-start;gap:24px;display:flex}.profile-avatar-large{background:var(--primary-light);width:160px;height:160px;color:var(--primary);border-radius:50%;justify-content:center;align-items:center;margin:0 auto;font-size:56px;font-weight:800;display:flex;overflow:hidden}.profile-avatar-large img{object-fit:cover;width:100%;height:100%}.profile-form-row{align-items:flex-start;gap:10px;margin-bottom:14px;display:flex}.profile-label{white-space:nowrap;min-width:130px;color:var(--text-secondary);padding-top:8px;font-size:13px;font-weight:600}.profile-input{border:1px solid var(--gray-200);border-radius:var(--radius);width:220px;transition:all var(--transition-fast);padding:8px 12px;font-family:inherit;font-size:13px}.profile-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563eb14}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:3px;font-size:11px}.profile-divider{border:none;border-top:1px solid var(--gray-200);margin:20px 0}.profile-section-heading{color:var(--text-primary);margin-bottom:16px;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(--gray-200);text-align:center;vertical-align:middle;height:56px;padding:0}.schedule-time-header{background:var(--gray-50);color:var(--primary);min-width:100px;padding:8px 4px;font-size:12px;font-weight:700}.schedule-day-header{background:var(--primary);color:#fff;text-transform:uppercase;letter-spacing:1px;padding:10px 4px;font-size:13px;font-weight:700}.schedule-time-cell{background:var(--gray-50);color:var(--primary);padding:6px;font-size:12px;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:var(--gray-50)}.admin-schedule-grid td,.admin-schedule-grid th{height:44px}.admin-sched-empty{transition:background var(--transition-fast)}.admin-sched-empty:hover{background:var(--primary-50)!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{transition:filter var(--transition-fast), box-shadow var(--transition-fast);border-radius:0}.admin-sched-block:hover{filter:brightness(1.08);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:var(--danger)}.subject-legend{flex-wrap:wrap;gap:12px;margin-top:16px;display:flex}.subject-legend-item{align-items:center;gap:7px;font-size:13px;display:flex}.subject-legend-dot{border-radius:4px;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:5px 14px;font-size:13px;font-weight:700;display:inline-flex}.stat-card.purple{background:linear-gradient(135deg,#7c3aed,#a855f7);border:none;position:relative}.stat-card.purple:before{display:none}.stat-card.red{background:linear-gradient(135deg,#dc2626,#ef4444);border:none}.stat-card.red:before{display:none}.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(--gray-200);border-radius:var(--radius);background:var(--gray-50);width:240px;transition:all var(--transition-fast);padding:8px 14px;font-family:inherit;font-size:13px}.header-search input:focus{border-color:var(--primary);background:var(--bg-white);box-shadow:0 0 0 3px #2563eb14}.stat-card.orange{background:linear-gradient(135deg,#ea580c,#f97316);border:none}.stat-card.orange:before{display:none}.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;width:240px;min-height:100vh;transition:width var(--transition-slow);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.faculty-sidebar.collapsed{width:64px}.faculty-sidebar~.main-content{transition:margin-left var(--transition-slow);margin-left:240px}.faculty-sidebar.collapsed~.main-content{margin-left:64px}.fs-header{border-bottom:1px solid #ffffff14;flex-direction:column;align-items:center;padding:28px 16px 20px;display:flex}.fs-avatar{background:#ffffff1f;border:2px solid #ffffff26;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:10px;display:flex;overflow:hidden}.fs-avatar img{object-fit:cover;border-radius:50%;width:100%;height:100%}.fs-avatar span{color:#fff;font-size:22px;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:#ffffff59;letter-spacing:1.2px;text-transform:uppercase;padding:16px 16px 6px;font-size:10px;font-weight:700}.faculty-sidebar.collapsed .fs-section-label{display:none}.fs-item{color:#ffffffa6;transition:all var(--transition-fast);white-space:nowrap;border-radius:0;align-items:center;gap:12px;padding:10px 16px;font-size:13px;font-weight:500;text-decoration:none;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:#fff6;cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-top:1px solid #ffffff14;justify-content:center;align-items:center;padding:14px;font-size:18px;display:flex}.fs-collapse-btn:hover{color:#fff;background:var(--sidebar-hover)}.user-dropdown-wrap{position:relative}.user-dropdown-trigger{cursor:pointer;border-radius:var(--radius);transition:background var(--transition-fast);background:0 0;border:none;align-items:center;gap:10px;padding:6px 10px;display:flex}.user-dropdown-trigger:hover{background:var(--gray-100)}.user-dropdown-name{color:var(--text-primary);white-space:nowrap;font-size:13px;font-weight:600}.user-dropdown-menu{background:var(--bg-white);border-radius:var(--radius-lg);min-width:220px;box-shadow:var(--shadow-lg);z-index:1000;border:1px solid var(--border);padding:6px;animation:.15s dropdownFadeIn;position:absolute;top:calc(100% + 8px);right:0}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.user-dropdown-item{cursor:pointer;width:100%;color:var(--text-secondary);transition:all var(--transition-fast);border-radius:var(--radius);background:0 0;border:none;align-items:center;gap:12px;padding:10px 14px;font-family:inherit;font-size:13px;font-weight:500;text-decoration:none;display:flex}.user-dropdown-item:hover{background:var(--gray-50);color:var(--text-primary)}.user-dropdown-icon{color:var(--gray-400);flex-shrink:0;font-size:18px}.user-dropdown-divider{background:var(--gray-200);height:1px;margin:4px 0}.account-settings-card{background:var(--bg-white);border-radius:var(--radius-lg);border:1px solid var(--border);max-width:520px;margin-top:16px;padding:32px}.account-settings-card .form-group{margin-bottom:20px}.account-settings-card label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.account-settings-card .form-input{border:1px solid var(--gray-200);border-radius:var(--radius);width:100%;transition:all var(--transition-fast);padding:10px 14px;font-family:inherit;font-size:14px}.account-settings-card .form-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563eb14}.account-settings-card .form-input:disabled{background:var(--gray-50);color:var(--gray-400)}.account-settings-card .form-actions{gap:12px;margin-top:28px;display:flex}.alert{border-radius:var(--radius);margin-bottom:16px;padding:12px 16px;font-size:14px;font-weight:500}.alert-success{background:var(--success-light);color:var(--success);border:1px solid #bbf7d0}.alert-error{background:var(--danger-light);color:var(--danger);border:1px solid #fecaca}.page-header-row{justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;display:flex}.ann-tabs{border-bottom:2px solid var(--gray-200);gap:0;margin-bottom:24px;display:flex}.ann-tab{color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:12px 22px;font-family:inherit;font-size:14px;font-weight:600}.ann-tab:hover{color:var(--primary)}.ann-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.announcement-form-card{background:var(--bg-white);border-radius:var(--radius-lg);border:1px solid var(--border);margin-bottom:20px;padding:24px 28px}.announcement-upload-btn{border:2px dashed var(--gray-300);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:8px;padding:12px 20px;font-size:14px;display:inline-flex}.announcement-upload-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-50)}.announcement-image-preview{max-width:100%;display:inline-block;position:relative}.announcement-image-preview img{border-radius:var(--radius);object-fit:cover;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:24px;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:20px;margin-bottom:28px;display:grid}.fdb-stat-card{background:var(--bg-white);border-radius:var(--radius-lg);border:1px solid var(--border);transition:all var(--transition-base);justify-content:space-between;align-items:center;padding:20px 22px;display:flex;position:relative;overflow:hidden}.fdb-stat-card:before{content:"";width:4px;position:absolute;top:0;bottom:0;left:0}.fdb-stat-card:hover{box-shadow:var(--shadow-sm)}.fdb-stat-blue:before{background:var(--primary)}.fdb-stat-green:before{background:#10b981}.fdb-stat-orange:before{background:#f59e0b}.fdb-stat-yellow:before{background:#eab308}.fdb-stat-label{text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;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);letter-spacing:-.3px;font-size:24px;font-weight:800}.fdb-stat-icon{color:var(--gray-200);font-size:32px}.fdb-columns{grid-template-columns:1fr 320px;align-items:start;gap:24px;display:grid}.fdb-ann-item{border-bottom:1px solid var(--gray-100);border-left:3px solid var(--primary);transition:background var(--transition-fast);margin:0;padding:18px 24px}.fdb-ann-item:last-child{border-bottom:none}.fdb-ann-item:hover{background:var(--gray-50)}.fdb-ann-title{color:var(--text-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:var(--success);border-radius:20px;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 var(--gray-100);transition:all var(--transition-fast);align-items:center;gap:14px;padding:14px 22px;font-size:13.5px;font-weight:500;text-decoration:none;display:flex}.fdb-quick-link:last-child{border-bottom:none}.fdb-quick-link:hover{background:var(--gray-50);color:var(--primary)}.fdb-quick-icon{color:var(--gray-400);flex-shrink:0;font-size:20px}.fdb-quick-link span{flex:1}.fdb-quick-arrow{color:var(--gray-300);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,.fdb-quick-link{padding:12px 14px}}.pay-stat-row{grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:24px;display:grid}.pay-stat-card{background:var(--bg-white);border-radius:var(--radius-lg);border:1px solid var(--border);padding:18px 22px;position:relative;overflow:hidden}.pay-stat-card:before{content:"";width:4px;position:absolute;top:0;bottom:0;left:0}.pay-stat-blue:before{background:var(--primary)}.pay-stat-teal:before{background:#14b8a6}.pay-stat-purple:before{background:#8b5cf6}.pay-stat-yellow:before{background:#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{background:var(--gray-50);border-radius:var(--radius);color:var(--text-primary);padding:10px 14px;font-size:15px;font-weight:600}.pay-stat-note{color:var(--danger);margin-top:8px;font-size:10px;font-style:italic}.pay-amount-card{background:var(--bg-white);border-radius:var(--radius-lg);border:1px solid var(--border);margin-bottom:24px;padding:22px 26px;position:relative;overflow:hidden}.pay-amount-card:before{content:"";background:var(--primary);width:4px;position:absolute;top:0;bottom:0;left:0}.pay-amount-value{color:var(--text-primary);margin-top:4px;font-size:32px;font-weight:800}.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:24px;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<=1024px){:root{--sidebar-width:72px}.sidebar-item .label,.sidebar-section-label,.sidebar-chevron{display:none}.sidebar-item{justify-content:center;padding:12px 8px}.sidebar-logo{justify-content:center;padding:0}.sidebar-logo .sidebar-logo-label,.sidebar-submenu{display:none}.sidebar-dropdown{display:block;left:72px}.stat-cards{grid-template-columns:repeat(auto-fit,minmax(180px,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){:root{--sidebar-width:260px}.mobile-menu-btn{display:flex}.sidebar,.faculty-sidebar{transition:transform var(--transition-slow);z-index:200;transform:translate(-100%)}.sidebar-item .label,.sidebar-section-label,.sidebar-chevron{display:block}.sidebar-item{justify-content:flex-start;padding:10px 12px}.sidebar-logo{justify-content:center;padding:0 20px}.sidebar-logo .sidebar-logo-label{display:inline}.sidebar-submenu{display:block}.sidebar-dropdown{display:none}.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 14px}.top-header{padding:8px 14px}.header-right{gap:4px}.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:16px}.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{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-lg);box-sizing:border-box;width:100%;margin-bottom:12px;padding:14px 16px;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:5px 0;font-size:13px;display:flex}.data-table tbody tr td:before{content:attr(data-label);color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;flex-shrink:0;max-width:40%;margin-right:12px;font-size:11px;font-weight:700}.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:10px}.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 var(--gray-100);padding:10px 14px;display:table-cell}.no-card-mobile tbody tr td:before{content:none}.modal,.modal-content{border-radius:var(--radius-lg);width:96%;max-width:none}.modal-body{padding:16px}.modal-header{padding:14px 16px}.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:16px}.account-settings-card{max-width:100%;padding:20px}.faculty-sidebar,.faculty-sidebar.collapsed{width:240px}.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 160px}.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 10px}.search-bar input,.header-search input{width:100px}.login-banner{display:none}.login-form-panel{padding:24px 18px}.credits-badge{padding:3px 8px;font-size:11px}}@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}}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--text-muted)}.text-primary{color:var(--primary)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.font-semibold{font-weight:600}.font-bold{font-weight:700}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.w-full{width:100%}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}
