
:root{--blue:#1a4fa0;--blue-dark:#122f6b;--blue-light:#2c6dd5;--red:#c0202a;--gold:#c9a227;--gray:#f0f4fa;--gray2:#e4eaf4;--text:#1a2340;--muted:#6b7a99;--border:#d0daea;--sidebar-w:240px;--bg-card:#ffffff;}
[data-theme="dark"]{--blue:#2c6dd5;--blue-dark:#0f172a;--blue-light:#60a5fa;--red:#ef4444;--gold:#fbbf24;--gray:#0f172a;--gray2:#1e293b;--text:#f8fafc;--muted:#94a3b8;--border:#334155;--bg-card:#1e293b;}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'Nunito',sans-serif;background:var(--gray);color:var(--text);min-height:100vh;overflow-x:hidden;}
.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px;}
.toast-msg{background:var(--bg-card);border-radius:10px;padding:12px 18px;box-shadow:0 4px 20px rgba(0,0,0,.15);font-size:.82rem;font-weight:700;display:flex;align-items:center;gap:10px;animation:slideIn .3s ease;border-left:4px solid var(--blue);}
.toast-msg.success{border-left-color:#059669;}.toast-msg.error{border-left-color:var(--red);}
@keyframes slideIn{from{opacity:0;transform:translateX(40px);}to{opacity:1;transform:translateX(0);}}
.loader-overlay{position:fixed;inset:0;background:rgba(18,47,107,.92);z-index:9998;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;}
.loader-overlay.hidden{display:none;}
.spinner{width:48px;height:48px;border:5px solid rgba(255,255,255,.2);border-top-color:white;border-radius:50%;animation:spin .8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.loader-overlay p{color:white;font-weight:700;font-size:.9rem;opacity:.8;}
#login-screen{min-height:100vh;background:linear-gradient(135deg,var(--blue-dark) 0%,var(--blue) 55%,var(--red) 100%);display:flex;align-items:center;justify-content:center;position:fixed;inset:0;z-index:1200;overflow:auto;padding:24px;}
.login-card{background:var(--bg-card);border-radius:20px;padding:36px 32px;width:100%;max-width:420px;box-shadow:0 24px 80px rgba(0,0,0,.35);animation:slideUp .5s ease both;position:relative;z-index:1;}
@keyframes slideUp{from{opacity:0;transform:translateY(30px);}to{opacity:1;transform:translateY(0);}}
.school-logo-wrap{text-align:center;margin-bottom:14px;}
.school-logo-wrap img{width:90px;height:90px;border-radius:50%;border:3px solid var(--blue);object-fit:cover;}
.school-name{font-family:'Merriweather',serif;font-size:.95rem;font-weight:900;color:var(--blue-dark);line-height:1.4;text-align:center;}
.school-sub{font-size:.68rem;color:var(--red);font-weight:700;text-align:center;letter-spacing:1px;text-transform:uppercase;margin-bottom:20px;}
.role-tabs{display:flex;gap:6px;margin-bottom:20px;background:var(--gray);border-radius:10px;padding:4px;}
.role-tab{flex:1;padding:8px;border:none;background:transparent;border-radius:7px;font-family:'Nunito',sans-serif;font-size:.78rem;font-weight:800;color:var(--muted);cursor:pointer;transition:all .2s;}
.role-tab.active{background:var(--bg-card);color:var(--blue);box-shadow:0 2px 8px rgba(0,0,0,.1);}
.form-label{font-size:.76rem;font-weight:800;color:var(--muted);margin-bottom:5px;}
.form-control,.form-select{border:1.5px solid var(--border)!important;border-radius:9px!important;font-family:'Nunito',sans-serif!important;font-size:.86rem!important;padding:10px 14px!important;color:var(--text)!important;background:var(--gray)!important;}
.form-control:focus,.form-select:focus{border-color:var(--blue)!important;box-shadow:0 0 0 3px rgba(26,79,160,.12)!important;background:var(--bg-card)!important;}
.btn-login{width:100%;padding:12px;border:none;border-radius:10px;background:linear-gradient(135deg,var(--blue),var(--blue-light));color:white;font-family:'Nunito',sans-serif;font-weight:800;font-size:.93rem;cursor:pointer;transition:opacity .2s;margin-top:6px;}
.btn-login:hover{opacity:.88;}
.login-hint{font-size:.72rem;color:var(--muted);text-align:center;margin-top:10px;}
.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-w);height:100vh;background:var(--blue-dark);display:flex;flex-direction:column;z-index:200;transition:transform .3s ease;overflow:hidden;}
.sidebar-top{padding:16px 16px 12px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:10px;}
.sidebar-top img{width:42px;height:42px;border-radius:50%;border:2px solid var(--gold);object-fit:cover;flex-shrink:0;}
.sname{font-family:'Merriweather',serif;font-size:.7rem;font-weight:900;color:white;line-height:1.4;}
.srole{font-size:.58rem;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:1px;}
.sidebar-nav{flex:1;overflow-y:auto;padding:8px 0;min-height:0;max-height:calc(100vh - 140px);}
.sidebar-nav::-webkit-scrollbar{width:3px;}
.sidebar-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);}
.nav-lbl{font-size:.57rem;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.3);padding:12px 16px 4px;font-weight:700;}
.nav-lnk{display:flex;align-items:center;gap:10px;padding:9px 16px;font-size:.81rem;font-weight:700;color:rgba(255,255,255,.55);cursor:pointer;border-radius:8px;margin:1px 8px;transition:all .18s;text-decoration:none;}
.nav-lnk i{font-size:.95rem;width:16px;text-align:center;}
.nav-lnk:hover,.nav-lnk.active{color:white;background:rgba(255,255,255,.1);}
.sidebar-foot{padding:14px 16px;border-top:1px solid rgba(255,255,255,.1);font-size:.8rem;color:rgba(255,255,255,.55);cursor:pointer;display:flex;align-items:center;gap:8px;flex-shrink:0;background:var(--blue-dark);}
.sidebar-foot:hover{color:#e63946;}
.topbar{position:sticky;top:0;z-index:100;background:var(--bg-card);border-bottom:2px solid var(--gray2);padding:10px 22px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 12px rgba(26,79,160,.06);}
.topbar-title{font-family:'Merriweather',serif;font-size:.93rem;font-weight:900;color:var(--blue-dark);}
.t-btn{background:var(--gray);border:1.5px solid var(--border);border-radius:8px;padding:6px 10px;font-size:.83rem;color:var(--muted);cursor:pointer;transition:all .18s;display:flex;align-items:center;gap:5px;}
.t-btn:hover{border-color:var(--blue);color:var(--blue);}
.notif-badge{background:var(--red);color:white;border-radius:50%;width:17px;height:17px;font-size:.58rem;font-weight:800;display:inline-flex;align-items:center;justify-content:center;}
.ham{background:none;border:none;font-size:1.3rem;color:var(--blue);cursor:pointer;display:none;}
.user-chip{background:var(--blue);color:white;border-radius:8px;padding:5px 11px;font-size:.73rem;font-weight:800;display:flex;align-items:center;gap:5px;}
.main{margin-left:var(--sidebar-w);min-height:100vh;}
.content{padding:24px;}
.page{display:none;animation:fadeIn .3s ease both;}
.page.active{display:block;}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
.card-box{background:var(--bg-card);border-radius:14px;border:1.5px solid var(--border);padding:20px;box-shadow:0 2px 12px rgba(26,79,160,.04);}
.stat-card{background:var(--bg-card);border-radius:14px;border:1.5px solid var(--border);padding:16px 18px;box-shadow:0 2px 12px rgba(26,79,160,.04);transition:transform .2s;}
.stat-card:hover{transform:translateY(-3px);}
.stat-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:10px;}
.stat-val{font-size:1.7rem;font-weight:900;font-family:'Merriweather',serif;color:var(--blue-dark);}
.stat-lbl{font-size:.72rem;color:var(--muted);font-weight:700;margin-top:2px;}
.sec-head{display:flex;align-items:center;gap:10px;margin-bottom:14px;}
.sec-head h5{font-family:'Merriweather',serif;font-size:.9rem;font-weight:900;color:var(--blue-dark);margin:0;white-space:nowrap;}
.sec-head .line{flex:1;height:2px;background:var(--gray2);}
.tbl-wrap{background:var(--bg-card);border-radius:14px;border:1.5px solid var(--border);overflow-x:auto;}
.tbl-wrap table{width:100%;border-collapse:collapse;}
.tbl-wrap th{background:var(--blue-dark);color:white;font-size:.67rem;letter-spacing:.5px;text-transform:uppercase;font-weight:800;padding:10px 13px;text-align:left;}
.tbl-wrap td{padding:9px 13px;font-size:.8rem;border-bottom:1px solid var(--gray2);}
.tbl-wrap tr:last-child td{border-bottom:none;}
.tbl-wrap tr:hover td{background:var(--gray);}
.bp{background:rgba(5,150,105,.12);color:#059669;padding:2px 9px;border-radius:20px;font-size:.66rem;font-weight:800;}
.bf{background:rgba(192,32,42,.12);color:var(--red);padding:2px 9px;border-radius:20px;font-size:.66rem;font-weight:800;}
.bb{background:rgba(26,79,160,.12);color:var(--blue);padding:2px 9px;border-radius:20px;font-size:.66rem;font-weight:800;}
.bg{background:rgba(201,162,39,.15);color:#a07c10;padding:2px 9px;border-radius:20px;font-size:.66rem;font-weight:800;}
.btn-p{background:var(--blue);border:none;color:white;border-radius:8px;padding:9px 18px;font-family:'Nunito',sans-serif;font-weight:800;font-size:.82rem;cursor:pointer;transition:opacity .2s;}
.btn-p:hover{opacity:.85;}
.btn-r{background:var(--red);border:none;color:white;border-radius:8px;padding:9px 18px;font-family:'Nunito',sans-serif;font-weight:800;font-size:.82rem;cursor:pointer;transition:opacity .2s;}
.btn-r:hover{opacity:.85;}
.btn-g{background:#059669;border:none;color:white;border-radius:8px;padding:9px 18px;font-family:'Nunito',sans-serif;font-weight:800;font-size:.82rem;cursor:pointer;transition:opacity .2s;}
.btn-g:hover{opacity:.85;}
.btn-o{background:var(--bg-card);border:1.5px solid var(--border);color:var(--muted);border-radius:8px;padding:8px 16px;font-family:'Nunito',sans-serif;font-weight:800;font-size:.82rem;cursor:pointer;transition:all .2s;}
.btn-o:hover{border-color:var(--blue);color:var(--blue);}
.sw{position:relative;margin-bottom:14px;}
.sw i{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--muted);}
.sw input{padding-left:34px!important;}
.welcome-banner{background:linear-gradient(135deg,var(--blue-dark),var(--blue) 60%,var(--blue-light));border-radius:14px;padding:24px 28px;color:white;position:relative;overflow:hidden;margin-bottom:20px;}
.welcome-banner::after{content:'🎓';position:absolute;right:28px;top:50%;transform:translateY(-50%);font-size:4rem;opacity:.12;}
.welcome-banner h4{font-family:'Merriweather',serif;font-size:1.1rem;font-weight:900;margin-bottom:4px;}
.welcome-banner p{font-size:.79rem;opacity:.78;margin:0;}
.welcome-banner .wdate{font-size:.67rem;opacity:.55;margin-top:6px;font-weight:700;}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:999;display:none;align-items:center;justify-content:center;padding:16px;}
.modal-overlay.open{display:flex;}
.modal-box{background:var(--bg-card);border-radius:16px;padding:26px;width:100%;max-width:520px;max-height:92vh;overflow-y:auto;animation:slideUp .3s ease both;}
.upload-zone{border:2px dashed var(--border);border-radius:11px;padding:24px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;}
.upload-zone:hover{border-color:var(--blue);background:rgba(26,79,160,.03);}
.upload-zone i{font-size:2rem;color:var(--blue);display:block;margin-bottom:6px;}
.upload-zone p{font-size:.79rem;color:var(--muted);margin:0;}
.notif-item{background:var(--bg-card);border-radius:11px;border:1.5px solid var(--border);padding:12px 15px;display:flex;gap:11px;align-items:flex-start;transition:border-color .2s;}
.notif-item:hover{border-color:var(--blue);}
.ndot{width:9px;height:9px;border-radius:50%;flex-shrink:0;margin-top:5px;}
.ev-card{background:var(--bg-card);border-radius:12px;border:1.5px solid var(--border);overflow:hidden;transition:transform .2s;}
.ev-card:hover{transform:translateY(-3px);}
.ev-hd{background:var(--blue);padding:12px 15px;color:white;}
.ev-date{font-family:'Merriweather',serif;font-size:1.3rem;font-weight:900;}
.ev-mo{font-size:.67rem;font-weight:700;opacity:.65;text-transform:uppercase;letter-spacing:1px;}
.ev-bd{padding:12px 15px;}
.ev-bd h6{font-weight:800;font-size:.84rem;color:var(--blue-dark);margin-bottom:3px;}
.ev-bd p{font-size:.72rem;color:var(--muted);margin:0;}
.tt-cell{background:var(--gray);border-radius:7px;padding:7px 9px;font-size:.72rem;font-weight:700;color:var(--blue-dark);border-left:3px solid var(--blue);line-height:1.4;}
.tt-cell small{font-weight:600;color:var(--muted);}
.step-indicator{display:flex;gap:6px;margin-bottom:18px;}
.step-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;border:2px solid var(--border);color:var(--muted);transition:all .3s;}
.step-dot.done{background:var(--blue);border-color:var(--blue);color:white;}
.step-dot.active{background:var(--blue-dark);border-color:var(--blue-dark);color:white;}
.step-line{flex:1;height:2px;background:var(--border);align-self:center;transition:background .3s;}
.step-line.done{background:var(--blue);}
.reg-step{display:none;}.reg-step.active{display:block;}
.file-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:11px;padding:13px 15px;display:flex;align-items:center;gap:11px;transition:border-color .2s;}
.file-card:hover{border-color:var(--blue);}
.file-icon{width:38px;height:38px;border-radius:9px;background:rgba(192,32,42,.1);color:var(--red);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;}
.file-info{flex:1;}
.file-info h6{font-size:.81rem;font-weight:800;color:var(--blue-dark);margin:0 0 2px;}
.file-info p{font-size:.7rem;color:var(--muted);margin:0;}
.pending-badge{background:rgba(201,162,39,.15);color:#a07c10;border:1px solid rgba(201,162,39,.3);border-radius:8px;padding:8px 14px;font-size:.78rem;font-weight:700;}
.approved-badge{background:rgba(5,150,105,.1);color:#059669;border:1px solid rgba(5,150,105,.2);border-radius:8px;padding:8px 14px;font-size:.78rem;font-weight:700;}
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px;}
@media(max-width:768px){.sidebar{transform:translateX(-100%);} .sidebar.open{transform:translateX(0);} .main{margin-left:0;} .ham{display:block;} .content{padding:14px;} .topbar{padding:9px 14px;}}
@media print{body>*{display:none!important;} #print-frame{display:block!important;position:fixed;inset:0;background:white;padding:24px;overflow:auto;z-index:99999;} #print-frame table{width:100%;border-collapse:collapse;} #print-frame th,#print-frame td{border:1px solid #ccc;padding:6px 8px;} } #print-frame{display:none;}
