/* ============================================================
   HIGHLAND COLLEGE — style.css
   Hilton College inspired aesthetic
   Fonts: EB Garamond (display) + Lato (body)
   Colors: Navy #002366 + White + Gold accent
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Lato:wght@300;400;700&display=swap');

:root {
  --navy:       #002366;
  --navy-dark:  #0d0d0d;
  --navy-mid:   #1a2a4a;
  --navy-light: #1c3a6e;
  --navy-pale:  #eef1f8;
  --gold:       #c9a84c;
  --gold-light: #e8c97a;
  --white:      #ffffff;
  --off-white:  #f8f7f4;
  --text:       #1a1a1a;
  --text-mid:   #555;
  --text-light: #999;
  --border:     #e0e0e0;
  --success:    #2d6a4f;
  --error:      #b5292e;
  --warning:    #c97a1a;
  --shadow:     0 2px 20px rgba(0,0,0,.08);
  --shadow-lg:  0 8px 48px rgba(0,0,0,.18);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Lato',system-ui,sans-serif;color:var(--text);background:var(--white);font-size:15px;line-height:1.75;overflow-x:hidden;font-weight:300}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:inherit}
input,select,textarea{font-family:inherit}

h1,h2,h3,h4{font-family:'EB Garamond',Georgia,serif;line-height:1.15;font-weight:400}
h1{font-size:clamp(3rem,7vw,6.5rem);letter-spacing:.04em}
h2{font-size:clamp(2rem,4vw,3rem)}
h3{font-size:1.5rem}
h4{font-size:1.15rem}

.container{max-width:1200px;margin:0 auto;padding:0 40px}
.hidden{display:none!important}

/* LOADER */
#loader{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:9999;opacity:0;pointer-events:none;transition:opacity .2s}
#loader.active{opacity:1;pointer-events:all}
.loader-ring{width:44px;height:44px;border:3px solid rgba(255,255,255,.15);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* TOAST */
#toast-container{position:fixed;bottom:28px;right:28px;z-index:9998;display:flex;flex-direction:column;gap:10px}
.toast{padding:14px 22px;font-size:.84rem;letter-spacing:.02em;box-shadow:var(--shadow-lg);min-width:240px;animation:toastIn .3s ease forwards}
@keyframes toastIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}
.toast-success{background:var(--success);color:#fff}
.toast-error{background:var(--error);color:#fff}
.toast-info{background:var(--navy);color:#fff}
.toast-warning{background:var(--warning);color:#fff}

/* ── NAVBAR ─────────────────────────────────────────────── */
#navbar{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(10,10,10,.9);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.05);transition:background .3s}
.nav-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;height:70px;gap:0}
.nav-left{display:flex;align-items:center;gap:4px}
.nav-right{display:flex;align-items:center;gap:4px;justify-content:flex-end}
.nav-center{text-align:center}
.nav-brand-name{font-family:'EB Garamond',serif;font-size:1.25rem;font-weight:500;color:#fff;letter-spacing:.22em;text-transform:uppercase;display:block}
.nav-brand-motto{font-size:.55rem;letter-spacing:.28em;color:var(--gold);text-transform:uppercase}
.nav-crest{width:0;height:0;display:none}
.nav-links{display:flex;align-items:center;gap:0;list-style:none}
.nav-links a{color:rgba(255,255,255,.7);font-size:.68rem;font-weight:400;letter-spacing:.16em;text-transform:uppercase;padding:8px 14px;transition:color .2s}
.nav-links a:hover{color:#fff}
.nav-cta{color:var(--gold)!important;border:1px solid var(--gold);padding:8px 20px!important;transition:background .2s,color .2s!important}
.nav-cta:hover{background:var(--gold)!important;color:#000!important}
.hamburger{display:none;background:none;border:none;flex-direction:column;gap:5px;padding:6px;margin-left:auto}
.hamburger span{display:block;width:22px;height:1.5px;background:#fff;transition:.3s}
.mobile-nav{display:none;position:fixed;inset:0;top:70px;background:#0d0d0d;z-index:999;padding:24px 20px;flex-direction:column;gap:0}
.mobile-nav.open{display:flex}
.mobile-nav a{color:rgba(255,255,255,.75);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.mobile-nav a:hover{color:var(--gold)}
.mobile-nav .m-cta{color:var(--gold)!important;margin-top:20px;border-bottom:none}

/* ── HERO ───────────────────────────────────────────────── */
#hero{height:100vh;min-height:640px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;background:linear-gradient(to bottom,rgba(0,0,0,.3) 0%,rgba(0,0,0,.15) 50%,rgba(0,0,0,.6) 100%),url('school-bg.jpg') center/cover no-repeat;background-color:#001540}
.hero-pattern{position:absolute;inset:0;opacity:.03;pointer-events:none;background-image:repeating-linear-gradient(0deg,transparent,transparent 60px,rgba(255,255,255,1) 60px,rgba(255,255,255,1) 61px),repeating-linear-gradient(90deg,transparent,transparent 60px,rgba(255,255,255,1) 60px,rgba(255,255,255,1) 61px)}
.hero-glow{display:none}
.hero-content{position:relative;text-align:center;color:#fff;padding:0 24px;max-width:960px;z-index:1}
.hero-crest-wrap{margin-bottom:24px;display:flex;flex-direction:column;align-items:center}
.hero-crest-svg{width:80px;height:80px;filter:drop-shadow(0 4px 24px rgba(0,0,0,.5))}
.hero-rule{width:1px;height:36px;background:rgba(255,255,255,.35);margin:14px auto 0}
.hero-tag{display:none}
.hero-pretitle{font-family:'Lato',sans-serif;font-size:.65rem;font-weight:400;letter-spacing:.38em;text-transform:uppercase;color:rgba(255,255,255,.75);margin-bottom:14px;display:block}
.hero-title{font-family:'EB Garamond',serif;font-weight:400;font-size:clamp(3rem,9vw,7rem);letter-spacing:.08em;text-transform:uppercase;line-height:.95;margin-bottom:22px;text-shadow:0 2px 40px rgba(0,0,0,.4)}
.hero-subtitle{font-family:'EB Garamond',serif;font-style:italic;font-size:clamp(1rem,2.5vw,1.4rem);color:rgba(255,255,255,.82);margin-bottom:44px;font-weight:400;letter-spacing:.02em}
.hero-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.5);font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:10px;z-index:1}
.scroll-dot{width:1px;height:36px;background:rgba(255,255,255,.35);animation:scrollPulse 2s infinite}
@keyframes scrollPulse{0%,100%{opacity:.35;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.15)}}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 38px;font-size:.68rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;border:none;cursor:pointer;transition:.25s;font-family:'Lato',sans-serif}
.btn-gold{background:var(--gold);color:#000}
.btn-gold:hover{background:var(--gold-light)}
.btn-outline-white{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.55)}
.btn-outline-white:hover{background:rgba(255,255,255,.08);border-color:#fff}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-light)}
.btn-dark{background:#111;color:#fff}
.btn-dark:hover{background:#222}
.btn-sm{padding:9px 22px;font-size:.65rem}
.btn-xs{padding:5px 12px;font-size:.62rem}
.btn-outline{background:transparent;color:var(--navy);border:1px solid var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff}
.btn-green{background:var(--success);color:#fff}
.btn-green:hover{background:#245a41}
.btn-red{background:var(--error);color:#fff}
.btn-red:hover{background:#8e1e22}

/* ── TICKER ─────────────────────────────────────────────── */
.ticker-bar{background:var(--navy);padding:11px 0;overflow:hidden;white-space:nowrap}
.ticker-inner{display:flex;align-items:center;animation:ticker 35s linear infinite}
.ticker-label{font-size:.6rem;font-weight:700;letter-spacing:.25em;text-transform:uppercase;color:#000;background:var(--gold);padding:3px 18px;margin-right:36px;flex-shrink:0}
.ticker-item{font-size:.76rem;color:rgba(255,255,255,.75);padding-right:64px;letter-spacing:.04em;font-weight:300}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── STATS ──────────────────────────────────────────────── */
.stats-strip{background:#111;padding:0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat-cell{text-align:center;padding:44px 20px;color:#fff;border-right:1px solid rgba(255,255,255,.06)}
.stat-cell:last-child{border-right:none}
.stat-num{font-family:'EB Garamond',serif;font-size:3.4rem;font-weight:400;color:var(--gold);line-height:1;margin-bottom:8px}
.stat-lbl{font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.38);font-weight:700}

/* ── SECTIONS ───────────────────────────────────────────── */
.section{padding:100px 0}
.section-alt{background:var(--off-white)}
.section-dark{background:#111;color:#fff}
.section-navy{background:var(--navy);color:#fff}
.section-header{text-align:center;margin-bottom:64px}
.section-label{font-size:.6rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:12px;display:block}
.section-title{margin-bottom:16px;color:var(--text)}
.section-dark .section-title,.section-navy .section-title{color:#fff}
.section-sub{font-size:.94rem;color:var(--text-mid);max-width:520px;margin:0 auto;font-weight:300}
.section-dark .section-sub,.section-navy .section-sub{color:rgba(255,255,255,.5)}
.divider{width:40px;height:1px;background:var(--gold);margin:18px auto 0}

/* ── ABOUT ──────────────────────────────────────────────── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:88px;align-items:center}
.about-img-wrap{position:relative}
.about-img-frame{width:100%;aspect-ratio:4/5;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
.about-img-overlay{display:none}
.about-img-crest{width:180px;}
.about-badge{position:absolute;bottom:-24px;right:-24px;background:var(--gold);width:120px;height:120px;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:var(--shadow-lg)}
.about-badge-yr{font-family:'EB Garamond',serif;font-size:1.8rem;font-weight:400;color:#000;line-height:1}
.about-badge-lbl{font-size:.52rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(0,0,0,.65);font-weight:700}
.about-text .section-title{text-align:left}
.about-text .divider{margin-left:0}
.about-body{color:var(--text-mid);margin:24px 0;line-height:1.9;font-weight:300;font-size:.95rem}
.values-list{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:28px}
.value-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-left:2px solid var(--gold);background:var(--off-white)}
.value-icon{font-size:.95rem}
.value-text{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--navy)}

/* ── NEWS ───────────────────────────────────────────────── */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border)}
.news-card{background:var(--white);transition:transform .25s,box-shadow .25s;position:relative}
.news-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);z-index:1}
.news-card-top{height:3px;background:var(--gold)}
.news-card-body{padding:28px}
.news-cat{font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:10px}
.news-title{font-size:1.2rem;color:var(--text);margin-bottom:12px;line-height:1.3}
.news-excerpt{font-size:.84rem;color:var(--text-mid);line-height:1.75;font-weight:300}
.news-footer{padding:16px 28px;border-top:1px solid var(--border);font-size:.7rem;color:var(--text-light);display:flex;justify-content:space-between;letter-spacing:.04em}
.no-news{text-align:center;padding:60px;color:var(--text-light);grid-column:1/-1}

/* ── ACADEMICS ──────────────────────────────────────────── */
.dept-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.07)}
.dept-card{background:rgba(255,255,255,.03);padding:36px 28px;border-bottom:2px solid transparent;transition:background .2s,border-color .2s}
.dept-card:hover{background:rgba(255,255,255,.07);border-bottom-color:var(--gold)}
.dept-icon{font-size:1.8rem;margin-bottom:14px}
.dept-name{color:#fff;font-family:'EB Garamond',serif;font-size:1.3rem;margin-bottom:8px;font-weight:400}
.dept-subs{font-size:.78rem;color:rgba(255,255,255,.38);line-height:1.85;font-weight:300}

/* ── APPLICATION ────────────────────────────────────────── */
.apply-layout{display:grid;grid-template-columns:300px 1fr;gap:56px;align-items:start}
.apply-info{position:sticky;top:100px}
.apply-info-card{background:var(--navy);padding:36px;color:#fff}
.apply-info-card h3{color:var(--gold);font-size:1.1rem;margin-bottom:20px;font-family:'EB Garamond',serif;font-weight:400;letter-spacing:.06em}
.apply-info-list{list-style:none;display:flex;flex-direction:column;gap:14px}
.apply-info-list li{display:flex;gap:12px;font-size:.82rem;color:rgba(255,255,255,.65);font-weight:300;line-height:1.6}
.apply-info-list li span:first-child{color:var(--gold);flex-shrink:0}
.apply-form-card{background:var(--white);padding:44px;box-shadow:var(--shadow)}
.form-section{margin-bottom:40px}
.form-section-title{font-family:'EB Garamond',serif;font-size:1.2rem;color:var(--navy);border-bottom:1px solid var(--gold);padding-bottom:10px;margin-bottom:24px;font-weight:400;letter-spacing:.04em}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-grid-3{grid-template-columns:1fr 1fr 1fr}
.form-full{grid-column:1/-1}
.form-group{display:flex;flex-direction:column;gap:7px}
.form-label{font-size:.65rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--text-mid)}
.form-label span{color:var(--error)}
.form-control{padding:11px 14px;border:none;border-bottom:1.5px solid #ccc;background:var(--off-white);font-size:.9rem;color:var(--text);transition:border-color .2s,background .2s;outline:none;font-weight:300}
.form-control:focus{border-bottom-color:var(--navy);background:#fff}
.form-control::placeholder{color:#bbb}
select.form-control{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%23555' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
textarea.form-control{resize:vertical;min-height:90px;border:1px solid var(--border)}
.apply-submit{text-align:right;margin-top:32px}
.apply-success{display:none;text-align:center;padding:56px 24px}
.success-icon{font-size:3rem;margin-bottom:18px}
.success-ref{display:inline-block;border:1px solid var(--navy);padding:14px 40px;font-family:'EB Garamond',serif;font-size:2.2rem;color:var(--navy);letter-spacing:.12em;margin:18px 0}

/* ── CONTACT ────────────────────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--border)}
.contact-card{text-align:center;padding:44px 28px;background:var(--white)}
.contact-icon{width:54px;height:54px;border:1px solid var(--gold);display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:1.2rem}
.contact-label{font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;color:var(--text-light);font-weight:700;margin-bottom:10px}
.contact-value{font-size:.92rem;color:var(--text);font-weight:300;line-height:1.85}
.contact-value a{color:var(--text);transition:color .2s}
.contact-value a:hover{color:var(--gold)}

footer{background:#0d0d0d;color:rgba(255,255,255,.45);padding:60px 0 28px}
.footer-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-brand{display:flex;gap:16px;align-items:flex-start}
.footer-logo{width:32px;height:32px;flex-shrink:0}
.footer-name{color:#fff;font-family:'EB Garamond',serif;font-size:.95rem;letter-spacing:.18em;text-transform:uppercase;font-weight:400}
.footer-motto{color:var(--gold);font-size:.56rem;letter-spacing:.24em;text-transform:uppercase}
.footer-desc{font-size:.8rem;line-height:1.85;margin-top:12px;font-weight:300}
.footer-col h5{color:rgba(255,255,255,.7);font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;margin-bottom:18px;font-family:'Lato',sans-serif;font-weight:700}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-links a{font-size:.8rem;color:rgba(255,255,255,.38);transition:color .2s;font-weight:300}
.footer-links a:hover{color:var(--gold)}
.footer-bar{border-top:1px solid rgba(255,255,255,.06);padding-top:24px;display:flex;justify-content:space-between;font-size:.7rem;letter-spacing:.06em;flex-wrap:wrap;gap:8px}

/* ── MODALS ─────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.78);z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .25s;backdrop-filter:blur(5px)}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--white);width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);transform:translateY(16px);transition:transform .25s}
.modal-overlay.open .modal-box{transform:none}
.modal-box.modal-sm{max-width:440px}
.modal-box.modal-md{max-width:620px}
.modal-box.modal-lg{max-width:900px}
.modal-header{background:#0d0d0d;padding:24px 32px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.05)}
.modal-title{color:#fff;font-family:'EB Garamond',serif;font-size:1.4rem;font-weight:400;letter-spacing:.04em;display:flex;align-items:center;gap:12px}
.modal-title-sub{color:rgba(255,255,255,.38);font-size:.7rem;font-family:'Lato',sans-serif;font-weight:300;margin-top:4px}
.modal-close{background:rgba(255,255,255,.08);border:none;color:#fff;width:32px;height:32px;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:background .2s}
.modal-close:hover{background:rgba(255,255,255,.18)}
.modal-body{padding:32px}
.modal-footer{padding:18px 32px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end}
.login-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:28px}
.login-tab{flex:1;padding:14px;text-align:center;font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--text-light);border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:.2s;cursor:pointer}
.login-tab.active{color:var(--navy);border-bottom-color:var(--navy)}
.login-form{display:flex;flex-direction:column;gap:18px}
.login-input-wrap{position:relative}
.login-input-wrap .form-control{padding-left:42px;border:1px solid var(--border)}
.login-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:.95rem;color:var(--text-light);pointer-events:none}
.login-submit{margin-top:6px}

/* ── STUDENT PORTAL ─────────────────────────────────────── */
#portal-overlay{display:none;position:fixed;inset:0;background:var(--off-white);z-index:1500;overflow-y:auto}
#portal-overlay.open{display:block}
.portal-bar{background:#0d0d0d;padding:0 28px;height:58px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10;border-bottom:1px solid rgba(255,255,255,.05)}
.portal-bar-brand{font-family:'EB Garamond',serif;color:#fff;font-size:1.1rem;font-weight:400;letter-spacing:.1em;display:flex;align-items:center;gap:12px}
.portal-bar-user{font-size:.76rem;color:rgba(255,255,255,.55);display:flex;align-items:center;gap:16px;font-weight:300}
.portal-bar-user strong{color:#fff;font-weight:400}
.portal-layout{display:grid;grid-template-columns:220px 1fr;min-height:calc(100vh - 58px)}
.portal-sidebar{background:var(--white);border-right:1px solid var(--border);padding:28px 0;position:sticky;top:58px;height:calc(100vh - 58px);overflow-y:auto}
.sidebar-nav{list-style:none}
.sidebar-nav a{display:flex;align-items:center;gap:10px;padding:12px 24px;font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--text-light);transition:.2s;border-left:2px solid transparent}
.sidebar-nav a:hover{color:var(--navy);background:var(--off-white)}
.sidebar-nav a.active{color:var(--navy);background:var(--off-white);border-left-color:var(--navy)}
.sidebar-nav .s-icon{font-size:.85rem}
.portal-main{padding:44px}
.portal-section{display:none}
.portal-section.active{display:block}
.info-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);margin:24px 0}
.info-card{background:var(--white);padding:24px;text-align:center;border-top:2px solid var(--navy)}
.info-card-lbl{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-light);font-weight:700;margin-bottom:8px}
.info-card-val{font-family:'EB Garamond',serif;font-size:1.6rem;font-weight:400;color:var(--navy)}
.info-card.gold{border-top-color:var(--gold)}
.info-card.gold .info-card-val{color:var(--warning)}
.fees-warning{background:#fff8ec;border-left:3px solid var(--warning);padding:16px 20px;margin-bottom:24px;display:flex;gap:14px}
.fees-warning-icon{font-size:1.3rem;flex-shrink:0}
.fees-warning h4{color:#7a4400;margin-bottom:4px;font-size:1rem}
.fees-warning p{font-size:.84rem;color:#7a4200;font-weight:300}
.fees-block-wall{text-align:center;padding:72px 24px;background:var(--white);box-shadow:var(--shadow)}
.fees-block-icon{font-size:3rem;margin-bottom:18px}
.fees-block-wall h3{color:var(--navy);margin-bottom:10px}
.fees-block-wall p{color:var(--text-mid);font-size:.9rem;max-width:380px;margin:0 auto;font-weight:300}
.first-login-banner{background:var(--navy);padding:32px 36px;color:#fff;margin-bottom:32px}
.first-login-banner h3{color:var(--gold-light);margin-bottom:8px;font-size:1.3rem}
.first-login-banner p{font-size:.88rem;color:rgba(255,255,255,.7);margin-bottom:18px;font-weight:300}
.pw-form{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}
.pw-form .form-control{max-width:240px;background:rgba(255,255,255,.1);border-bottom-color:rgba(255,255,255,.35);color:#fff}
.pw-form .form-control::placeholder{color:rgba(255,255,255,.4)}

/* TABLES */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;background:var(--white);font-size:.84rem}
thead th{background:#0d0d0d;color:rgba(255,255,255,.65);padding:13px 18px;text-align:left;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700}
tbody tr{border-bottom:1px solid var(--border);transition:background .15s}
tbody tr:hover{background:var(--off-white)}
tbody td{padding:13px 18px;color:var(--text);font-weight:300}
tbody tr:last-child{border-bottom:none}
.grade-badge{display:inline-block;padding:2px 10px;font-size:.7rem;font-weight:700;letter-spacing:.06em}
.grade-A{background:#d4edda;color:#1a6e34}
.grade-B{background:#cce5ff;color:#004085}
.grade-C{background:#fff3cd;color:#856404}
.grade-D{background:#fde8d8;color:#7a3b00}
.grade-E{background:#f8d7da;color:#721c24}
.grade-U{background:#e2e3e5;color:#383d41}
.status-badge{display:inline-block;padding:3px 10px;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em}
.status-pending{background:#fff3cd;color:#856404}
.status-reviewing{background:#cce5ff;color:#004085}
.status-accepted{background:#d4edda;color:#1a6e34}
.status-rejected{background:#f8d7da;color:#721c24}
.status-active{background:#d4edda;color:#1a6e34}
.status-inactive{background:#e2e3e5;color:#383d41}
.status-cleared{background:#d4edda;color:#1a6e34}
.status-owed{background:#f8d7da;color:#721c24}
.results-filter{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap;align-items:center}
.results-filter select,.form-select{padding:9px 16px;border:1px solid var(--border);font-size:.8rem;font-weight:300;background:var(--white)}
.results-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}
.rs-card{background:var(--white);padding:14px 18px;text-align:center;border-top:2px solid var(--navy);box-shadow:var(--shadow)}
.rs-num{font-family:'EB Garamond',serif;font-size:1.7rem;color:var(--navy)}
.rs-lbl{font-size:.6rem;color:var(--text-light);text-transform:uppercase;letter-spacing:.14em;font-weight:700}

/* ── ADMIN PANEL ─────────────────────────────────────────── */
#admin-overlay{display:none;position:fixed;inset:0;background:var(--off-white);z-index:1500;overflow:hidden}
#admin-overlay.open{display:flex;flex-direction:column}
.admin-topbar{background:#0d0d0d;height:54px;display:flex;align-items:center;padding:0 28px;gap:16px;flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.05)}
.admin-topbar-brand{font-family:'EB Garamond',serif;color:#fff;font-size:1rem;font-weight:400;letter-spacing:.14em;text-transform:uppercase}
.admin-topbar-tag{font-size:.58rem;color:var(--gold);letter-spacing:.24em;text-transform:uppercase}
.admin-topbar-right{margin-left:auto;display:flex;align-items:center;gap:16px;font-size:.76rem;color:rgba(255,255,255,.45);font-weight:300}
.admin-topbar-right strong{color:#fff;font-weight:400}
.admin-body{display:flex;flex:1;overflow:hidden}
.admin-sidebar{width:220px;background:var(--white);border-right:1px solid var(--border);flex-shrink:0;overflow-y:auto}
.admin-sidebar .sidebar-section{padding:20px 0 6px}
.admin-sidebar .sidebar-section-label{font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;color:var(--text-light);font-weight:700;padding:0 20px;margin-bottom:4px}
.admin-sidebar a{display:flex;align-items:center;gap:10px;padding:11px 20px;font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-light);transition:.15s;border-left:2px solid transparent;cursor:pointer}
.admin-sidebar a:hover{color:var(--navy);background:var(--off-white)}
.admin-sidebar a.active{color:var(--navy);background:var(--off-white);border-left-color:var(--navy)}
.admin-sidebar .sidebar-icon{font-size:.85rem}
.admin-content{flex:1;overflow-y:auto;padding:36px}
.admin-page{display:none}
.admin-page.active{display:block}
.admin-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;border-bottom:1px solid var(--border);padding-bottom:20px}
.admin-page-title{font-family:'EB Garamond',serif;font-size:1.9rem;color:var(--text);font-weight:400}
.stat-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);margin-bottom:36px}
.stat-card{background:var(--white);padding:24px 26px;border-top:2px solid var(--navy)}
.stat-card.gold-border{border-top-color:var(--gold)}
.stat-card.green-border{border-top-color:var(--success)}
.stat-card.red-border{border-top-color:var(--error)}
.stat-card-num{font-family:'EB Garamond',serif;font-size:2.6rem;font-weight:400;color:var(--navy);line-height:1;margin-bottom:6px}
.stat-card.gold-border .stat-card-num{color:var(--warning)}
.stat-card.green-border .stat-card-num{color:var(--success)}
.stat-card.red-border .stat-card-num{color:var(--error)}
.stat-card-lbl{font-size:.6rem;text-transform:uppercase;letter-spacing:.16em;color:var(--text-light);font-weight:700}
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:20px}
.filter-btn{padding:7px 18px;font-size:.65rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;border:1px solid var(--border);background:var(--white);color:var(--text-mid);cursor:pointer;transition:.15s}
.filter-btn:hover{border-color:var(--navy);color:var(--navy)}
.filter-btn.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.action-btns{display:flex;gap:6px;flex-wrap:wrap}
.table-section{background:var(--white);box-shadow:var(--shadow)}
.table-section-head{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.table-section-head h4{color:var(--text);font-size:1.05rem}
.bypass-toggle{display:inline-flex;align-items:center;gap:6px;font-size:.65rem;font-weight:700;letter-spacing:.06em;padding:4px 12px;cursor:pointer;transition:.15s;border:none;text-transform:uppercase}
.bypass-on{background:#d4edda;color:#1a6e34}
.bypass-off{background:#e2e3e5;color:#41464b}
.mark-sheet-wrap{background:var(--white);box-shadow:var(--shadow)}
.mark-sheet-controls{padding:22px 26px;border-bottom:1px solid var(--border);display:flex;gap:14px;flex-wrap:wrap;align-items:flex-end}
.mark-control{display:flex;flex-direction:column;gap:6px}
.mark-control label{font-size:.6rem;text-transform:uppercase;letter-spacing:.14em;color:var(--navy);font-weight:700}
.mark-input{width:70px;padding:8px 10px;border:1px solid var(--border);font-size:.88rem;text-align:center}
.mark-input:focus{border-color:var(--navy);outline:none}
.mark-comment{width:150px;padding:8px 10px;border:1px solid var(--border);font-size:.82rem;font-weight:300}
.pub-check{width:16px;height:16px;accent-color:var(--navy)}
.app-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.app-field{margin-bottom:14px}
.app-field-label{font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-light);font-weight:700;margin-bottom:4px}
.app-field-value{font-size:.92rem;color:var(--text);font-weight:300}
.review-form{margin-top:24px}
.review-form textarea{width:100%;min-height:80px;resize:vertical;border:1px solid var(--border)}

/* REVEAL */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:none}

/* RESPONSIVE */
@media(max-width:1024px){
  .about-grid{grid-template-columns:1fr;gap:36px}
  .about-img-wrap{display:none}
  .apply-layout{grid-template-columns:1fr}
  .apply-info{position:static}
  .stat-cards{grid-template-columns:1fr 1fr}
  .nav-left,.nav-right{gap:2px}
}
@media(max-width:768px){
  .container{padding:0 20px}
  .nav-left,.nav-right{display:none}
  .hamburger{display:flex}
  .stats-grid{grid-template-columns:1fr 1fr}
  .news-grid{grid-template-columns:1fr;gap:0}
  .dept-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr;gap:0}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .form-grid{grid-template-columns:1fr}
  .portal-layout{grid-template-columns:1fr}
  .portal-sidebar{display:none}
  .info-cards{grid-template-columns:1fr 1fr;gap:0}
  .results-summary{grid-template-columns:1fr 1fr}
  .admin-sidebar{display:none}
  .stat-cards{grid-template-columns:1fr 1fr;gap:0}
  .app-detail-grid{grid-template-columns:1fr}
  .hero-title{font-size:clamp(2.4rem,12vw,4rem)}
  .nav-inner{grid-template-columns:1fr auto}
}

/* ══ APPLICATION STATUS TRACKER ══════════════════════════════ */
.track-wrap {
  max-width: 620px;
  margin: 0 auto;
}
.track-input-row {
  display: flex;
  gap: 12px;
  margin-bottom: 24px;
}
.track-input {
  flex: 1;
  font-size: 1rem;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.track-loading {
  text-align: center;
  padding: 32px;
  color: var(--text-light);
  font-style: italic;
}
.track-card {
  background: #fff;
  border-left: 5px solid var(--gold);
  border-radius: var(--radius);
  padding: 24px 28px;
  box-shadow: var(--shadow);
}
.track-notfound {
  text-align: center;
  border-left-color: var(--text-light);
  background: #f9f9f9;
}
.track-icon {
  font-size: 2rem;
  margin-bottom: 8px;
}
.track-card-top {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 14px;
  flex-wrap: wrap;
}
.track-status-icon {
  font-size: 2rem;
  line-height: 1;
}
.track-ref-label {
  font-size: .82rem;
  color: var(--text-mid);
  text-transform: uppercase;
  letter-spacing: .06em;
}
.track-name {
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--navy);
  margin-top: 2px;
}
.track-badge {
  margin-left: auto;
  color: #fff;
  padding: 5px 14px;
  border-radius: 20px;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  white-space: nowrap;
}
.track-msg {
  color: var(--text-mid);
  font-size: .92rem;
  line-height: 1.6;
  margin-bottom: 10px;
}
.track-notes {
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  border-radius: 6px;
  padding: 10px 14px;
  font-size: .86rem;
  color: #166534;
  margin-bottom: 10px;
}
.track-notes-red {
  background: #fef2f2;
  border-color: #fecaca;
  color: #991b1b;
}
.track-date {
  font-size: .78rem;
  color: var(--text-light);
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-top: 8px;
}
.track-error {
  color: var(--error);
  text-align: center;
  padding: 12px;
}

/* ══ SUBJECT ENROLMENT & TEACHER ASSIGNMENTS ════════════════ */
.admin-result-entry {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px 24px;
  margin-bottom: 24px;
}
.email-results-wrap {
  padding: 4px;
}
.email-results-controls {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: flex-end;
  background: var(--navy-pale);
  padding: 18px 20px;
  border-radius: var(--radius);
  margin-bottom: 24px;
}

/* ══ IMAGE REPLACEMENTS FOR SVGs ════════════════════════════ */
/* Hero background image — fills the entire hero section */
.hero-bg-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
  opacity: 0.35;
}
.about-img-crest {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  top: 0; left: 0;
  border-radius: var(--radius);
}
.footer-logo {
  width: 48px;
  height: 48px;
  object-fit: contain;
  border-radius: 50%;
}
