@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700&family=DM+Sans:wght@300;400;500;600&display=swap');
:root{--navy:#0f2d56;--blue:#1a5fb4;--blue-l:#3584e4;--gold:#e8a020;--gold-l:#f5c842;--green:#26a269;--red:#c01c28;--g50:#f8fafc;--g100:#f1f5f9;--g200:#e2e8f0;--g400:#94a3b8;--g500:#64748b;--g600:#475569;--g700:#334155;--g800:#1e293b;--g900:#0f172a;--w:#fff;--sh:0 1px 3px rgba(0,0,0,.08);--sh2:0 4px 16px rgba(0,0,0,.10);--sh3:0 8px 32px rgba(0,0,0,.14);--r:10px;--rl:16px;--fh:'Playfair Display',Georgia,serif;--fb:'DM Sans',system-ui,sans-serif;--sw:260px;--th:64px}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--fb);background:var(--g50);color:var(--g800);line-height:1.6;font-size:15px}
a{color:var(--blue);text-decoration:none;transition:color .2s}a:hover{color:var(--blue-l)}
img{max-width:100%;display:block}
/* Loader */

.element.style {display: block !important;}








#page-loader{position:fixed;inset:0;background:var(--navy);display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity .4s,visibility .4s}
#page-loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-inner{display:flex;flex-direction:column;align-items:center;gap:20px}
.loader-logo{color:#fff;font-family:var(--fh);font-size:22px}
.loader-bar{width:160px;height:3px;background:rgba(255,255,255,.2);border-radius:2px;overflow:hidden}
.loader-bar::after{content:'';display:block;height:100%;background:var(--gold);animation:ldp 1.4s ease forwards}
@keyframes ldp{from{width:0}to{width:100%}}
/* Alerts */
.alert-stack{position:fixed;top:80px;right:20px;z-index:9000;display:flex;flex-direction:column;gap:10px;max-width:380px;width:calc(100% - 40px)}
.alert{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:var(--r);box-shadow:var(--sh3);animation:slr .3s ease;font-size:14px;font-weight:500}
.alert-success{background:#d3f3e3;border-left:4px solid var(--green);color:#145a32}
.alert-error{background:#fde8ea;border-left:4px solid var(--red);color:#7b1a23}
.alert-info{background:#dbeafe;border-left:4px solid var(--blue);color:#1e3a5f}
.alert-close{margin-left:auto;background:none;border:none;cursor:pointer;opacity:.5;font-size:18px;line-height:1;padding:0 2px}
.alert-close:hover{opacity:1}
@keyframes slr{from{transform:translateX(120%);opacity:0}to{transform:translateX(0);opacity:1}}
/* Public Nav */
.pub-nav{background:var(--navy);position:sticky;top:0;z-index:100;box-shadow:0 2px 12px rgba(0,0,0,.3)}
.pub-nav-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:68px}
.pub-nav-brand{display:flex;align-items:center;gap:12px;color:#fff;font-family:var(--fh);font-size:20px;font-weight:700}
.pub-nav-logo{width:40px;height:40px;background:var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.pub-nav-links{display:flex;align-items:center;gap:6px;list-style:none}
.pub-nav-links a{color:rgba(255,255,255,.82);padding:8px 14px;border-radius:6px;font-size:14px;font-weight:500;transition:all .2s}
.pub-nav-links a:hover,.pub-nav-links a.active{background:rgba(255,255,255,.12);color:#fff}
.pub-nav-links .btn-portal{background:var(--gold);color:var(--navy);font-weight:700;padding:8px 18px;border-radius:6px}
.pub-nav-links .btn-portal:hover{background:var(--gold-l)}
.pub-nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;flex-direction:column;gap:5px}
.pub-nav-toggle span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:all .3s}
/* Hero */
.hero{background:linear-gradient(135deg,var(--navy) 0%,#1a3a5c 60%,#1a4a7c 100%);padding:90px 24px 70px;text-align:center;color:#fff}
.hero-content{max-width:720px;margin:0 auto}
.hero-badge{display:inline-block;background:var(--gold);color:var(--navy);font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:5px 14px;border-radius:20px;margin-bottom:20px}
.hero h1{font-family:var(--fh);font-size:clamp(32px,5vw,52px);line-height:1.15;margin-bottom:16px}
.hero p{font-size:18px;opacity:.8;margin-bottom:36px}
.hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;border-radius:var(--r);font-family:var(--fb);font-size:14px;font-weight:600;cursor:pointer;border:2px solid transparent;transition:all .2s;white-space:nowrap;text-decoration:none;line-height:1.4}
.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue)}.btn-primary:hover{background:var(--blue-l);color:#fff}
.btn-gold{background:var(--gold);color:var(--navy);border-color:var(--gold)}.btn-gold:hover{background:var(--gold-l);color:var(--navy)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}.btn-outline:hover{background:rgba(255,255,255,.12);color:#fff}
.btn-danger{background:var(--red);color:#fff;border-color:var(--red)}.btn-danger:hover{background:#a01020;color:#fff}
.btn-success{background:var(--green);color:#fff;border-color:var(--green)}.btn-success:hover{background:#1e8a56;color:#fff}
.btn-light{background:var(--g100);color:var(--g700);border-color:var(--g200)}.btn-light:hover{background:var(--g200)}
.btn-sm{padding:6px 14px;font-size:13px}.btn-lg{padding:13px 28px;font-size:16px}
.btn-block{width:100%;justify-content:center}
/* Portal layout */
.portal-layout{display:flex;min-height:100vh}
.sidebar{width:var(--sw);background:var(--navy);position:fixed;top:0;left:0;bottom:0;overflow-y:auto;z-index:200;transition:transform .3s;display:flex;flex-direction:column}
.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px}
.sidebar-brand{padding:20px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:10px;min-height:var(--th)}
.sidebar-logo{width:38px;height:38px;background:var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.sidebar-brand-name{color:#fff;font-family:var(--fh);font-size:14px;line-height:1.2}
.sidebar-brand-sub{color:var(--gold);font-size:10px;font-weight:700;letter-spacing:.8px}
.sidebar-nav{padding:12px 0;flex:1}
.sidebar-section{padding:10px 16px 4px;font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:rgba(255,255,255,.35)}
.sidebar-nav a{display:flex;align-items:center;gap:10px;padding:10px 20px;color:rgba(255,255,255,.72);font-size:14px;font-weight:500;border-left:3px solid transparent;transition:all .2s}
.sidebar-nav a:hover{color:#fff;background:rgba(255,255,255,.07)}.sidebar-nav a.active{color:#fff;background:rgba(255,255,255,.1);border-left-color:var(--gold)}
.sidebar-nav a svg{width:17px;height:17px;flex-shrink:0}
.sidebar-footer{padding:16px 20px;border-top:1px solid rgba(255,255,255,.1)}
.sidebar-user{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.8);font-size:13px}
.sidebar-avatar{width:34px;height:34px;border-radius:50%;background:var(--blue-l);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:13px;flex-shrink:0}
.sidebar-user-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-user-role{font-size:11px;color:var(--gold);font-weight:700;text-transform:capitalize}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:199}
.sidebar-overlay.active{display:block}
.portal-main{margin-left:var(--sw);flex:1;display:flex;flex-direction:column;min-height:100vh}
.topbar{height:var(--th);background:#fff;border-bottom:1px solid var(--g200);display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:100;box-shadow:var(--sh)}
.topbar-left{display:flex;align-items:center;gap:14px}
.topbar-toggle{display:none;background:none;border:none;cursor:pointer;padding:6px}
.topbar-title{font-weight:700;font-size:18px;color:var(--g800)}
.topbar-right{display:flex;align-items:center;gap:16px}
.topbar-logout{display:flex;align-items:center;gap:6px;color:var(--g500);font-size:13px;font-weight:500;padding:6px 12px;border-radius:6px;border:1px solid var(--g200);background:#fff;transition:all .2s;text-decoration:none}
.topbar-logout:hover{background:var(--g100);color:var(--red);border-color:var(--red)}
.page-content{padding:28px;flex:1}
/* Stats */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:18px;margin-bottom:28px}
.stat-card{background:#fff;border-radius:var(--rl);padding:22px;box-shadow:var(--sh);border:1px solid var(--g100);display:flex;align-items:center;gap:16px;transition:box-shadow .2s}
.stat-card:hover{box-shadow:var(--sh2)}
.stat-icon{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.stat-icon svg{width:24px;height:24px}
.stat-icon.blue{background:#dbeafe;color:var(--blue)}.stat-icon.gold{background:#fef3cd;color:var(--gold)}
.stat-icon.green{background:#d3f3e3;color:var(--green)}.stat-icon.red{background:#fde8ea;color:var(--red)}
.stat-icon.purple{background:#ede9fe;color:#7c3aed}
.stat-num{font-size:28px;font-weight:700;color:var(--g900);line-height:1}
.stat-label{font-size:13px;color:var(--g500);margin-top:3px}
/* Cards */
.card{background:#fff;border-radius:var(--rl);box-shadow:var(--sh);border:1px solid var(--g100);overflow:hidden}
.card-header{padding:18px 24px;border-bottom:1px solid var(--g100);display:flex;align-items:center;justify-content:space-between;gap:12px}
.card-title{font-size:16px;font-weight:700;color:var(--g800)}
.card-body{padding:24px}
/* Tables */
.table-wrap{overflow-x:auto}
.table{width:100%;border-collapse:collapse;font-size:14px}
.table th{padding:12px 16px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--g500);background:var(--g50);border-bottom:1px solid var(--g200)}
.table td{padding:13px 16px;border-bottom:1px solid var(--g100);color:var(--g700);vertical-align:middle}
.table tr:last-child td{border-bottom:none}.table tbody tr:hover{background:var(--g50)}
.table-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
/* Badges */
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600}
.badge-success{background:#d3f3e3;color:#145a32}.badge-danger{background:#fde8ea;color:#7b1a23}
.badge-warning{background:#fef3cd;color:#7a4a00}.badge-info{background:#dbeafe;color:#1e3a5f}
.badge-gray{background:var(--g100);color:var(--g600)}.badge-navy{background:var(--navy);color:#fff}
/* Forms */
.form-group{margin-bottom:20px}
.form-label{display:block;font-size:13px;font-weight:600;color:var(--g700);margin-bottom:7px}
.form-label span{color:var(--red)}
.form-control,.form-select{display:block;width:100%;padding:10px 14px;border:1.5px solid var(--g200);border-radius:var(--r);font-family:var(--fb);font-size:14px;color:var(--g800);background:#fff;transition:border-color .2s,box-shadow .2s;appearance:none;-webkit-appearance:none}
.form-control:focus,.form-select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,95,180,.12)}
.form-control::placeholder{color:var(--g400)}
textarea.form-control{resize:vertical;min-height:100px}
.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}
.form-hint{font-size:12px;color:var(--g400);margin-top:5px}
.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:0 20px}
.form-divider{border:none;border-top:1px solid var(--g200);margin:24px 0}
.form-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--navy);margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--gold);display:inline-block}
.search-bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.search-wrap{position:relative;flex:1;min-width:220px}
.search-wrap svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--g400);pointer-events:none}
.search-wrap input{padding-left:38px}
.page-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:1.5px solid var(--g200);background:#fff;font-size:14px;font-weight:500;color:var(--g700);text-decoration:none;transition:all .2s}
.page-btn:hover{border-color:var(--blue);color:var(--blue)}.page-btn.active{background:var(--blue);border-color:var(--blue);color:#fff}
/* Result grades */
.grade-A{color:var(--green);font-weight:700}.grade-B{color:var(--blue);font-weight:700}
.grade-C{color:var(--gold);font-weight:700}.grade-D{color:#e67e22;font-weight:700}
.grade-F{color:var(--red);font-weight:700}
.gpa-badge{display:inline-flex;align-items:center;gap:6px;background:var(--navy);color:#fff;padding:8px 20px;border-radius:20px;font-size:15px;font-weight:700}
.gpa-badge span{color:var(--gold);font-size:20px}
/* Announcements */
.ann-card{border-left:3px solid var(--blue);padding:14px 18px;background:#fff;border-radius:0 var(--r) var(--r) 0;margin-bottom:12px;box-shadow:var(--sh)}
.ann-card.urgent{border-left-color:var(--red)}.ann-card.academic{border-left-color:var(--green)}.ann-card.event{border-left-color:var(--gold)}
.ann-title{font-weight:700;font-size:14px;margin-bottom:4px}
.ann-meta{font-size:12px;color:var(--g400);margin-bottom:6px}
.ann-body{font-size:13px;color:var(--g600)}
/* Auth */
.auth-page{min-height:100vh;display:flex;align-items:stretch}
.auth-left{flex:1;background:linear-gradient(155deg,var(--navy) 0%,#1a4a7c 100%);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:60px 40px;text-align:center}
.auth-left h1{font-family:var(--fh);color:#fff;font-size:36px;margin-bottom:12px}
.auth-left p{color:rgba(255,255,255,.7);font-size:16px;max-width:360px;line-height:1.7}
.auth-motto{color:var(--gold);font-style:italic;font-size:14px;margin-top:20px}
.auth-right{width:460px;display:flex;flex-direction:column;justify-content:center;padding:60px 50px;background:#fff;box-shadow:-4px 0 30px rgba(0,0,0,.08)}
.auth-logo h2{font-size:24px;font-weight:700;color:var(--g900);margin-bottom:6px}
.auth-logo p{font-size:14px;color:var(--g400);margin-bottom:28px}
.auth-demo{margin-top:22px;padding:14px 16px;background:var(--g50);border-radius:var(--r);border:1px solid var(--g200);font-size:13px}
.auth-demo strong{color:var(--navy);display:block;margin-bottom:8px}
/* Footer */
.pub-footer{background:var(--g900);color:var(--g400);padding:48px 24px 24px}
.pub-footer-inner{max-width:1200px;margin:0 auto}
.pub-footer-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:36px;margin-bottom:36px}
.pub-footer h4{color:#fff;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--gold);display:inline-block}
.pub-footer p,.pub-footer li{font-size:14px;line-height:1.8}
.pub-footer ul{list-style:none}.pub-footer ul li a{color:var(--g400);transition:color .2s}.pub-footer ul li a:hover{color:var(--gold)}
.pub-footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:20px;display:flex;align-items:center;justify-content:space-between;font-size:13px;color:var(--g500);flex-wrap:wrap;gap:10px}
/* Utilities */
.divider{border:none;border-top:1px solid var(--g200);margin:20px 0}
.text-muted{color:var(--g500)}.text-center{text-align:center}
/* Responsive */
@media(max-width:900px){
  .sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}
  .portal-main{margin-left:0}.topbar-toggle{display:flex!important}
  .auth-left{display:none}.auth-right{width:100%;padding:40px 28px}}
@media(max-width:640px){
  .page-content{padding:16px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .pub-nav-links{display:none}.pub-nav-toggle{display:flex}
  .pub-nav-links.open{display:flex;flex-direction:column;position:absolute;top:68px;left:0;right:0;background:var(--navy);padding:12px;z-index:99}
  .form-row{grid-template-columns:1fr}}
@media print{.sidebar,.topbar,.btn,.alert-stack{display:none!important}.portal-main{margin-left:0!important}}
