/* ALFA CONVENT SCHOOL & COLLEGE - premium redesign */
:root {
  --ink:#111827;
  --ink-soft:#334155;
  --muted:#64748b;
  --line:#e5e7eb;
  --paper:#ffffff;
  --cloud:#f7f9fc;
  --cream:#fffaf0;
  --red:#8f1024;
  --red-d:#520815;
  --maroon:var(--red);
  --maroon-dark:var(--red-d);
  --blue:#0f4c81;
  --blue-d:#082f57;
  --green:#137a52;
  --gold:#d8a31f;
  --gold-l:#ffe6a3;
  --font:"Manrope","Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --head:"Cormorant Garamond",Georgia,serif;
  --r:8px;
  --rl:14px;
  --sh1:0 10px 30px rgba(15,23,42,.08);
  --sh2:0 18px 50px rgba(15,23,42,.13);
  --sh3:0 28px 80px rgba(15,23,42,.2);
  --t:all .25s ease;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;font-family:var(--font);color:var(--ink);background:var(--paper);line-height:1.68;overflow-x:hidden;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;}
img{max-width:100%;height:auto;}
a{text-decoration:none;transition:var(--t);}
p{color:var(--muted);margin-bottom:1rem;}
ul{list-style:none;padding:0;margin:0;}
h1,h2,h3,h4,h5,h6{font-family:var(--head);font-weight:800;color:var(--red-d);line-height:1.08;letter-spacing:0;}
::selection{background:var(--gold-l);color:var(--red-d);}
::-webkit-scrollbar{width:9px;}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--red),var(--blue));border-radius:999px;}

#admissionBanner{position:relative;z-index:10000;background:linear-gradient(90deg,var(--red-d),var(--red),var(--blue-d));border-bottom:1px solid rgba(255,255,255,.16);}
.adm-inner{min-height:42px;display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;padding:6px 18px;}
.blink-dot{width:9px;height:9px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 8px rgba(216,163,31,.15);animation:bpulse 1.2s ease-in-out infinite;}
@keyframes bpulse{50%{opacity:.35;transform:scale(.72);}}
.banner-txt{font-size:.83rem;font-weight:800;color:#fff;letter-spacing:.2px;}
.banner-txt i{color:var(--gold-l);}
.adm-btn{display:inline-flex;align-items:center;gap:7px;background:#fff;color:var(--red-d)!important;font-size:.74rem;font-weight:900;padding:6px 16px;border-radius:999px;box-shadow:0 8px 20px rgba(0,0,0,.16);}
.adm-btn:hover{background:var(--gold-l);transform:translateY(-1px);}
.adm-close{width:26px;height:26px;border:1px solid rgba(255,255,255,.28);background:rgba(255,255,255,.11);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;}

.topbar{background:#09111f;padding:8px 0;font-size:.78rem;}
.topbar a,.topbar span{color:rgba(255,255,255,.76);}
.topbar a:hover{color:var(--gold-l);}
.topbar i{color:var(--gold);margin-right:6px;}
.social-icons a{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.14);border-radius:50%;color:#fff!important;margin-left:5px;background:rgba(255,255,255,.04);}
.social-icons a:hover{background:var(--gold);color:#111!important;border-color:var(--gold);}

.site-header{position:sticky;top:0;z-index:9000;background:rgba(255,255,255,.95);backdrop-filter:blur(18px);border-bottom:1px solid rgba(15,23,42,.08);box-shadow:0 8px 26px rgba(15,23,42,.06);}
.site-header.scrolled{box-shadow:0 18px 45px rgba(15,23,42,.12);}
.navbar .container-fluid{height:82px!important;}
.navbar-brand{min-width:260px;}
.logo-img-wrap{width:68px;height:68px;border-radius:50%;padding:3px;background:#fff;border:1px solid rgba(143,16,36,.18);box-shadow:0 10px 26px rgba(143,16,36,.14);overflow:hidden;flex-shrink:0;}
.logo-img-wrap img{width:100%;height:100%;object-fit:contain;border-radius:50%;}
.logo-name{display:block;font-family:var(--head);font-size:1.15rem;font-weight:900;color:var(--red-d);line-height:1.02;}
.logo-college{color:var(--blue);}
.logo-tag{display:block;margin-top:5px;font-size:.69rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--green);}
.navbar-nav .nav-link{position:relative;font-size:.75rem;font-weight:900;color:var(--ink)!important;text-transform:uppercase;letter-spacing:.04em;padding:10px 10px!important;border-radius:999px;white-space:nowrap;}
.navbar-nav .nav-link:hover,.navbar-nav .active>.nav-link{color:var(--red)!important;background:rgba(143,16,36,.07);}
.navbar-nav .active>.nav-link::after{content:"";position:absolute;left:18px;right:18px;bottom:4px;height:2px;background:var(--gold);border-radius:99px;}
.dropdown-menu{border:1px solid rgba(15,23,42,.08);border-top:3px solid var(--gold);border-radius:0 0 var(--rl) var(--rl);box-shadow:var(--sh3);padding:9px;min-width:235px;margin-top:0!important;}
.dropdown-item{border-radius:8px;font-size:.84rem;font-weight:800;color:var(--ink-soft)!important;padding:10px 12px;}
.dropdown-item:hover{background:rgba(15,76,129,.08)!important;color:var(--blue)!important;}
.dropdown-item i{width:20px;color:var(--red);margin-right:7px;}
.navbar-toggler{border:1px solid rgba(143,16,36,.35);border-radius:8px;padding:8px 10px;}
.hdr-dl,.hdr-apply,.btn-red,.btn-blue,.btn-green,.btn-gold,.btn-or,.btn-ow,.btn-dl,.f-dl-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:999px;font-family:var(--font);font-weight:900;line-height:1.1;transition:var(--t);}
.hdr-dl{font-size:.74rem;color:var(--blue)!important;border:1px solid rgba(15,76,129,.28);padding:9px 14px;background:#fff;}
.hdr-dl:hover{background:var(--blue);color:#fff!important;}
.hdr-apply{font-size:.76rem;color:#fff!important;background:linear-gradient(135deg,var(--red),var(--red-d));padding:11px 18px;box-shadow:0 14px 30px rgba(143,16,36,.28);}
.hdr-apply:hover,.btn-red:hover,.btn-blue:hover,.btn-green:hover,.btn-gold:hover,.btn-or:hover,.btn-ow:hover,.btn-dl:hover{transform:translateY(-2px);}

#heroSlider .carousel-item{height:640px;background-size:cover!important;background-position:center!important;position:relative;}
.ci-1,.ci-2,.ci-3{background:linear-gradient(135deg,#09111f 0%,var(--blue-d) 48%,var(--red-d) 100%);}
.slide-overlay{position:absolute;inset:0;background:radial-gradient(circle at 76% 20%,rgba(255,230,163,.24),transparent 28%),linear-gradient(90deg,rgba(8,18,33,.94) 0%,rgba(82,8,21,.72) 50%,rgba(8,47,87,.26) 100%);}
.has-img .slide-overlay{background:linear-gradient(90deg,rgba(8,18,33,.95) 0%,rgba(82,8,21,.72) 50%,rgba(8,47,87,.18) 100%);}
.caption-wrap{position:absolute;inset:0;display:flex;align-items:center;z-index:5;padding:0 28px;}
.slide-badge{display:inline-flex;align-items:center;gap:9px;margin-bottom:18px;padding:8px 16px;border:1px solid rgba(255,230,163,.5);border-radius:999px;background:rgba(255,255,255,.1);color:var(--gold-l);font-size:.73rem;font-weight:900;letter-spacing:.13em;text-transform:uppercase;backdrop-filter:blur(10px);}
.slide-title{max-width:880px;color:#fff;font-size:clamp(2.4rem,5.2vw,5.7rem);line-height:.96;margin-bottom:18px;text-shadow:0 18px 48px rgba(0,0,0,.45);}
.slide-title span{color:var(--gold-l);}
.slide-desc{max-width:650px;color:rgba(255,255,255,.84);font-size:1.08rem;font-weight:500;margin-bottom:30px;}
.carousel-control-prev,.carousel-control-next{width:48px;height:48px;top:50%;transform:translateY(-50%);border-radius:50%;border:1px solid rgba(255,255,255,.35);background:rgba(255,255,255,.12);backdrop-filter:blur(12px);opacity:1;}
.carousel-control-prev{left:18px;}
.carousel-control-next{right:18px;}
.carousel-control-prev:hover,.carousel-control-next:hover{background:var(--gold);border-color:var(--gold);}
.carousel-indicators [data-bs-target]{width:9px;height:9px;border-radius:50%;border:0;background:rgba(255,255,255,.48);}
.carousel-indicators .active{width:30px;border-radius:999px;background:var(--gold-l);}

.stats-bar{position:relative;background:#fff;padding:0;box-shadow:0 -18px 35px rgba(15,23,42,.08);}
.stats-bar .container{transform:translateY(-34px);background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:var(--rl);box-shadow:var(--sh2);overflow:hidden;}
.stat-item{padding:24px 18px;text-align:center;border-right:1px solid var(--line);background:linear-gradient(180deg,#fff,var(--cloud));}
.stat-item:last-child{border-right:0;}
.stat-num{font-family:var(--head);font-size:2.65rem;font-weight:900;color:var(--red-d);line-height:1;}
.stat-lbl{margin-top:6px;font-size:.73rem;font-weight:900;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;}
.ticker-bar{margin-top:-18px;background:var(--blue-d);padding:10px 0;overflow:hidden;position:relative;z-index:2;}
.ticker-label{background:var(--gold-l);color:var(--red-d);font-size:.73rem;font-weight:900;padding:6px 18px;border-radius:0 999px 999px 0;text-transform:uppercase;}
.ticker-wrap{overflow:hidden;flex:1;}
.ticker-move{display:flex;gap:54px;white-space:nowrap;animation:tick 35s linear infinite;}
.ticker-move span{color:rgba(255,255,255,.86);font-size:.84rem;font-weight:700;}
.ticker-move span::before{content:"* ";color:var(--gold-l);}
@keyframes tick{to{transform:translateX(-50%);}}

.page-hero{position:relative;padding:74px 0;text-align:center;background:linear-gradient(135deg,var(--blue-d),var(--red-d));overflow:hidden;}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 10%,rgba(255,230,163,.22),transparent 30%),linear-gradient(90deg,rgba(255,255,255,.06),transparent);}
.page-hero .container{position:relative;}
.page-hero h1{font-size:clamp(2.2rem,4.5vw,4.2rem);color:#fff;margin-bottom:12px;}
.breadcrumb{justify-content:center;background:none;padding:0;margin:0;}
.breadcrumb-item a{color:var(--gold-l);font-weight:800;}
.breadcrumb-item.active{color:rgba(255,255,255,.72);}
.breadcrumb-item+.breadcrumb-item::before{color:rgba(255,255,255,.42);}

section{position:relative;}
.bg-light{background:var(--cloud)!important;}
.sec-label{display:inline-flex;align-items:center;gap:8px;margin-bottom:13px;padding:7px 15px;border-radius:999px;background:rgba(15,76,129,.08);border:1px solid rgba(15,76,129,.12);color:var(--blue);font-size:.72rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase;}
.sec-title{font-size:clamp(2rem,3.2vw,3.25rem);margin-bottom:16px;}
.sec-title span{color:var(--blue);}
.btn-red{background:linear-gradient(135deg,var(--red),var(--red-d));color:#fff!important;border:0;padding:12px 26px;box-shadow:0 14px 30px rgba(143,16,36,.22);}
.btn-blue{background:linear-gradient(135deg,var(--blue),var(--blue-d));color:#fff!important;border:0;padding:12px 26px;}
.btn-green{background:linear-gradient(135deg,var(--green),#07543a);color:#fff!important;border:0;padding:12px 26px;}
.btn-gold{background:linear-gradient(135deg,var(--gold-l),var(--gold));color:#2b1600!important;border:0;padding:12px 26px;box-shadow:0 14px 32px rgba(216,163,31,.24);}
.btn-or{background:#fff;color:var(--red)!important;border:1px solid rgba(143,16,36,.28);padding:10px 22px;}
.btn-or:hover{background:var(--red);color:#fff!important;}
.btn-ow{background:rgba(255,255,255,.12);color:#fff!important;border:1px solid rgba(255,255,255,.38);padding:10px 22px;backdrop-filter:blur(10px);}
.btn-ow:hover{background:#fff;color:var(--blue-d)!important;}
.btn-dl{background:#fff;color:var(--green)!important;border:1px solid rgba(19,122,82,.26);padding:10px 20px;}
.btn-dl:hover{background:var(--green);color:#fff!important;}

.about-img{width:100%;height:500px;object-fit:cover;border-radius:var(--rl);box-shadow:var(--sh3);}
.years-badge{position:absolute;right:24px;bottom:24px;padding:18px 22px;border-radius:var(--rl);background:linear-gradient(135deg,var(--gold-l),var(--gold));box-shadow:var(--sh2);text-align:center;color:#2b1600;}
.years-badge .n{display:block;font-family:var(--head);font-size:3rem;font-weight:900;line-height:.9;}
.years-badge .t{display:block;margin-top:5px;font-size:.68rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em;}
.ck-list li{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line);font-weight:800;color:var(--ink-soft);}
.ck-list li i{color:var(--green);}

.ach-section{padding:92px 0;background:linear-gradient(135deg,#07111f 0%,#250814 46%,#081f37 100%);overflow:hidden;}
.ach-section::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 10% 20%,rgba(216,163,31,.18),transparent 28%),radial-gradient(circle at 86% 14%,rgba(15,76,129,.22),transparent 30%);}
.ach-card,.ev-card,.fac-card,.msg-card,.r-modal,.r-mini-card{border-radius:var(--rl);transition:var(--t);}
.ach-card{height:100%;padding:22px 14px;text-align:center;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.13);backdrop-filter:blur(16px);}
.ach-card:hover{transform:translateY(-7px);background:rgba(255,255,255,.12);border-color:rgba(255,230,163,.42);box-shadow:0 22px 55px rgba(0,0,0,.28);}
.ach-avatar,.ach-placeholder{width:88px;height:88px;border-radius:50%;margin:0 auto 14px;border:3px solid var(--gold-l);box-shadow:0 0 0 6px rgba(255,230,163,.08);}
.ach-avatar{object-fit:cover;}
.ach-placeholder{display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.08);}
.ach-placeholder i{font-size:2rem;color:var(--gold-l);}
.ach-name{font-family:var(--head);font-size:1.08rem;font-weight:900;color:#fff;}
.ach-cls{font-size:.72rem;color:rgba(255,255,255,.56);font-weight:800;text-transform:uppercase;letter-spacing:.08em;}
.ach-pct{font-family:var(--head);font-size:2.25rem;font-weight:900;color:var(--gold-l);line-height:1;margin:12px 0 8px;}
.ach-badge{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:5px 12px;background:rgba(255,230,163,.12);border:1px solid rgba(255,230,163,.25);color:var(--gold-l);font-size:.65rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em;}

.ev-card{height:100%;overflow:hidden;background:#fff;border:1px solid rgba(15,23,42,.08);box-shadow:var(--sh1);}
.ev-card:hover,.fac-card:hover,.msg-card:hover{transform:translateY(-7px);box-shadow:var(--sh2);}
.ev-img{width:100%;height:225px;object-fit:cover;display:block;}
.ev-cat{position:absolute;top:14px;left:14px;border-radius:999px;background:var(--red);color:#fff;font-size:.67rem;font-weight:900;padding:6px 12px;text-transform:uppercase;}
.ev-date{display:flex;align-items:center;gap:8px;color:var(--blue);font-size:.78rem;font-weight:900;margin-bottom:9px;}

.gal-item{position:relative;height:250px;border-radius:var(--rl);overflow:hidden;cursor:pointer;box-shadow:var(--sh1);background:#ddd;}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .55s ease;}
.gal-item:hover img{transform:scale(1.08);}
.gal-overlay{position:absolute;inset:0;display:flex;align-items:flex-end;padding:18px;background:linear-gradient(0deg,rgba(8,18,33,.84),transparent 62%);opacity:0;transition:var(--t);}
.gal-item:hover .gal-overlay{opacity:1;}
.gal-overlay span{color:#fff;font-weight:900;}

.fac-card{height:100%;padding:30px 22px;text-align:center;background:#fff;border:1px solid rgba(15,23,42,.08);box-shadow:var(--sh1);}
.fac-icon{width:70px;height:70px;margin:0 auto 16px;border-radius:18px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(143,16,36,.1),rgba(15,76,129,.1));}
.fac-icon i{font-size:1.55rem;color:var(--red);}
.fac-card h4{font-family:var(--font);font-size:1.02rem;font-weight:900;color:var(--ink);margin-bottom:7px;}
.fac-card p{font-size:.86rem;margin:0;}

.dl-section{padding:58px 0;background:linear-gradient(135deg,var(--green),var(--blue-d));}
.dl-card{height:100%;display:flex;align-items:center;gap:16px;padding:24px;border:1px solid rgba(255,255,255,.18);border-radius:var(--rl);background:rgba(255,255,255,.1);color:#fff;backdrop-filter:blur(14px);}
.dl-card:hover{background:rgba(255,255,255,.16);transform:translateY(-4px);color:#fff;}
.dl-card i{font-size:2rem;color:var(--gold-l);}
.dl-card h5{font-family:var(--font);font-size:.94rem;font-weight:900;color:#fff;margin-bottom:3px;}
.dl-card p{font-size:.78rem;color:rgba(255,255,255,.74);margin:0;}

.msg-card{height:100%;overflow:hidden;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(16px);}
.msg-top{padding:24px;text-align:center;background:rgba(0,0,0,.16);}
.msg-top h4{font-size:1.2rem;color:#fff;}
.msg-top p{color:rgba(255,255,255,.64);font-size:.8rem;margin:0;}
.msg-ava{width:80px;height:80px;margin:0 auto 13px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(255,230,163,.13);border:2px solid rgba(255,230,163,.45);}
.msg-ava i{font-size:1.8rem;color:var(--gold-l);}
.msg-body{padding:22px;}
.msg-body blockquote{margin:0 0 14px;padding-left:14px;border-left:3px solid var(--gold-l);color:rgba(255,255,255,.78);font-size:.87rem;font-style:italic;}

.page-tab-nav{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:38px;padding:8px;border:1px solid var(--line);border-radius:var(--rl);background:#fff;box-shadow:var(--sh1);}
.ptab{flex:1;min-width:160px;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border:0;border-radius:8px;background:transparent;color:var(--muted);font-size:.81rem;font-weight:900;}
.ptab:hover{background:rgba(15,76,129,.08);color:var(--blue);}
.ptab.active{background:linear-gradient(135deg,var(--red),var(--red-d));color:#fff;box-shadow:0 12px 26px rgba(143,16,36,.22);}
.tab-pane{display:none!important;}
.tab-pane.active{display:block!important;}

.fee-table{width:100%;border-collapse:separate;border-spacing:0;overflow:hidden;border-radius:var(--rl);box-shadow:var(--sh1);}
.fee-table thead tr{background:linear-gradient(135deg,var(--red),var(--red-d));}
.fee-table th{color:#fff;padding:14px 16px;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;}
.fee-table td{padding:14px 16px;border-bottom:1px solid var(--line);font-size:.89rem;}
.fee-table tbody tr:nth-child(even) td{background:var(--cloud);}
.fee-table td:first-child{font-weight:900;color:var(--red-d);}
.fee-table td:last-child{font-weight:900;color:var(--green);}

.form-label{font-size:.75rem;font-weight:900;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.08em;}
.form-control,.form-select{border:1px solid #d7dde7;border-radius:8px;background:#fff;font-size:.9rem;padding:12px 14px;box-shadow:0 1px 0 rgba(15,23,42,.03);}
.form-control:focus,.form-select:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(15,76,129,.1);}
.form-success{border:1px solid rgba(19,122,82,.24);border-radius:8px;background:rgba(19,122,82,.1);color:#07543a;padding:14px 18px;font-weight:800;}
.upload-area{padding:46px;text-align:center;border:2px dashed rgba(15,76,129,.28);border-radius:var(--rl);background:var(--cloud);cursor:pointer;}
.upload-area:hover{border-color:var(--blue);background:#fff;}
.upload-area i{display:block;margin-bottom:12px;font-size:2.8rem;color:var(--blue);}

#lightbox{position:fixed;inset:0;z-index:99999;display:none;align-items:center;justify-content:center;background:rgba(3,7,18,.94);padding:20px;}
#lightbox.open{display:flex;}
#lightbox img{max-width:92vw;max-height:90vh;border-radius:var(--r);}
#lightboxClose{position:absolute;top:18px;right:22px;width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.26);background:rgba(255,255,255,.12);color:#fff;}

#resultPopup{position:fixed;inset:0;z-index:99998;display:flex;align-items:center;justify-content:center;background:rgba(3,7,18,.72);padding:20px;backdrop-filter:blur(8px);}
#resultPopup.hidden{display:none!important;}
.r-modal{max-width:760px;width:100%;max-height:88vh;overflow:auto;background:#fff;box-shadow:var(--sh3);}
.r-modal-head{display:flex;align-items:center;justify-content:space-between;padding:23px 26px;border-radius:var(--rl) var(--rl) 0 0;background:linear-gradient(135deg,var(--red),var(--blue-d));color:#fff;}
.r-modal-head h4{color:#fff;margin:0;font-size:1.45rem;}
.r-close{width:36px;height:36px;border:1px solid rgba(255,255,255,.25);border-radius:50%;background:rgba(255,255,255,.13);color:#fff;}
.r-mini-card{padding:17px 11px;text-align:center;background:var(--cloud);border:1px solid var(--line);}
.r-mini-avatar,.r-mini-placeholder{width:72px;height:72px;border-radius:50%;margin:0 auto 10px;border:3px solid var(--gold);}
.r-mini-avatar{object-fit:cover;}
.r-mini-placeholder{display:flex;align-items:center;justify-content:center;background:#fff;}
.r-name{font-family:var(--head);font-weight:900;color:var(--red-d);}
.r-pct{font-family:var(--head);font-size:1.8rem;font-weight:900;color:var(--green);}

.site-footer{background:#07111f;color:#fff;}
.footer-top{padding:62px 0 40px;background:radial-gradient(circle at 18% 0,rgba(216,163,31,.12),transparent 28%);}
.footer-logo-img{width:58px;height:58px;border-radius:50%;object-fit:contain;background:#fff;padding:3px;border:2px solid var(--gold);}
.f-name{font-family:var(--head);font-size:1.12rem;font-weight:900;color:#fff;line-height:1.02;}
.f-tag{font-size:.69rem;color:rgba(255,255,255,.48);font-weight:800;letter-spacing:.08em;text-transform:uppercase;}
.f-about{color:rgba(255,255,255,.62);font-size:.86rem;}
.f-social a{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.08);color:#fff!important;margin-right:6px;}
.f-social a:hover{background:var(--gold);color:#111!important;}
.f-head{font-family:var(--font);font-size:.86rem;font-weight:900;color:#fff;text-transform:uppercase;letter-spacing:.11em;margin-bottom:16px;padding-bottom:11px;border-bottom:1px solid rgba(255,255,255,.12);}
.f-links li{margin-bottom:8px;}
.f-links a,.f-contact-item,.f-contact-item a{color:rgba(255,255,255,.62);font-size:.84rem;}
.f-links a:hover,.f-contact-item a:hover{color:var(--gold-l);}
.f-links a i,.f-contact-item i{color:var(--gold);margin-right:7px;}
.f-contact-item{display:flex;gap:10px;margin-bottom:12px;}
.f-contact-item i{margin-top:5px;}
.f-dl-btn{padding:8px 14px;margin-right:6px;margin-bottom:8px;border:1px solid rgba(255,230,163,.28);background:rgba(255,230,163,.1);color:var(--gold-l)!important;font-size:.75rem;}
.f-dl-btn:hover{background:var(--gold-l);color:#111!important;}
.footer-bottom{padding:15px 0;border-top:1px solid rgba(255,255,255,.08);background:rgba(0,0,0,.22);}
.footer-bottom p{margin:0;color:rgba(255,255,255,.5);font-size:.78rem;}
.footer-bottom a{color:rgba(255,255,255,.45);}
.footer-bottom a:hover{color:var(--gold-l);}

#backToTop{position:fixed;right:24px;bottom:24px;z-index:8000;width:46px;height:46px;border:0;border-radius:50%;background:linear-gradient(135deg,var(--red),var(--blue));color:#fff;box-shadow:0 16px 38px rgba(15,23,42,.24);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:var(--t);}
#backToTop.visible{opacity:1;visibility:visible;}
.fu{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease;}
.fu.visible{opacity:1;transform:translateY(0);}

@media (max-width:1199px){
  .navbar .container-fluid{height:auto!important;min-height:78px;}
  .navbar-brand{min-width:auto;}
  .navbar-collapse{background:#fff;margin-top:10px;padding:16px;border-radius:0 0 var(--rl) var(--rl);box-shadow:var(--sh2);border-top:1px solid var(--line);}
}
@media (max-width:991px){
  #heroSlider .carousel-item{height:540px;}
  .caption-wrap{padding:0 20px;}
  .about-img{height:390px;}
  .stats-bar .container{transform:none;border-radius:0;}
  .ticker-bar{margin-top:0;}
}
@media (max-width:767px){
  .topbar{display:none!important;}
  .adm-inner{justify-content:flex-start;}
  .banner-txt{font-size:.76rem;}
  .logo-img-wrap{width:56px;height:56px;}
  .logo-name{font-size:.95rem;}
  .logo-tag{font-size:.58rem;}
  #heroSlider .carousel-item{height:470px;}
  .slide-desc{font-size:.95rem;}
  .stat-item{border-right:0;border-bottom:1px solid var(--line);}
  .page-hero{padding:58px 0;}
  .gal-item{height:220px;}
}
@media (max-width:480px){
  .navbar-brand{gap:8px!important;}
  .slide-title{font-size:2.2rem;}
  .btn-red,.btn-blue,.btn-green,.btn-gold,.btn-or,.btn-ow,.btn-dl{width:100%;}
  .years-badge{right:14px;bottom:14px;}
  .upload-area{padding:30px 18px;}
}

/* ── EXTRA UTILITY CLASSES ── */
.py-section { padding: 80px 0; }
.bg-white { background: #fff !important; }
.bg-light  { background: #F8F9FA !important; }

/* Ensure carousel-item background-image shows correctly */
#heroSlider .carousel-item[style*="background-image"] {
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
}

/* ev-card-body (was missing) */
.ev-card-body { padding: 20px; }
.ev-card-body h4 { font-size: 1rem; color: var(--red-d, #5C0000); margin-bottom: 7px; }
.ev-card-body p  { font-size: .84rem; margin: 0; }

/* r-mini-card (result popup) */
.r-mini-card { background: #FAFAFA; border: 1px solid #E5E7EB; border-radius: 10px; padding: 16px 10px; text-align: center; transition: all .3s; }
.r-mini-card:hover { border-color: #C8A800; box-shadow: 0 2px 10px rgba(0,0,0,.08); }
.r-mini-avatar { width: 68px; height: 68px; border-radius: 50%; border: 3px solid #FFD700; margin: 0 auto 10px; object-fit: cover; display: block; }
.r-mini-placeholder { width: 68px; height: 68px; border-radius: 50%; border: 3px solid #FFD700; margin: 0 auto 10px; background: rgba(21,101,192,.07); display: flex; align-items: center; justify-content: center; }
.r-mini-placeholder i { font-size: 1.6rem; color: var(--blue, #1565C0); }
.r-name { font-family: var(--head, 'Playfair Display',serif); font-size: .88rem; color: var(--red-d, #5C0000); margin-bottom: 2px; }
.r-pct  { font-family: var(--head, 'Playfair Display',serif); font-size: 1.55rem; font-weight: 800; color: #2E7D32; }

/* r-modal */
.r-modal-head { background: linear-gradient(90deg,#5C0000,#8B0000); padding: 20px 24px; display: flex; align-items: center; justify-content: space-between; border-radius: 16px 16px 0 0; }
.r-modal-head h4 { color: #fff; font-size: 1.2rem; margin: 0; }
.r-close { background: rgba(255,255,255,.18); border: none; color: #fff; width: 34px; height: 34px; border-radius: 50%; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all .3s; }
.r-close:hover { background: rgba(255,255,255,.35); }

/* dl-section */
.dl-section { background: linear-gradient(90deg,#1E8449,#27AE60); padding: 48px 0; }
.dl-card { background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2); border-radius: 16px; padding: 20px; display: flex; align-items: center; gap: 14px; transition: all .3s; color: #fff; text-decoration: none; height: 100%; }
.dl-card:hover { background: rgba(255,255,255,.18); transform: translateY(-3px); color: #fff; }
.dl-card i { font-size: 1.7rem; color: #FFD700; flex-shrink: 0; }
.dl-card h5 { font-size: .88rem; font-weight: 700; color: #fff; margin-bottom: 2px; }
.dl-card p  { font-size: .75rem; color: rgba(255,255,255,.72); margin: 0; }

/* btn-outline */
.btn-outline { display: inline-flex; align-items: center; gap: 8px; background: transparent; color: var(--blue, #1565C0) !important; border: 2px solid var(--blue, #1565C0); border-radius: 999px; font-weight: 700; font-size: .85rem; padding: 9px 22px; transition: all .3s; }
.btn-outline:hover { background: var(--blue, #1565C0); color: #fff !important; }

/* Additional utility */
.py-section { padding: 80px 0 !important; }
.ach-section { background: #0F1828; background-image: linear-gradient(135deg,#0F1828 0%,#1a3a6b 50%,#0F1828 100%); padding: 80px 0; }

/* ── MESSAGE PAGE (director.php / principal.php / founder.php) ── */
.message-page { padding: 70px 0; background: #f6f7fb; }
.message-layout {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 36px;
  align-items: start;
}
@media (max-width: 991px) {
  .message-layout { grid-template-columns: 1fr; }
}

/* Sidebar card */
.message-profile {
  border-radius: 18px;
  padding: 32px 24px 28px;
  text-align: center;
  color: #fff;
  box-shadow: 0 16px 48px rgba(0,0,0,.22);
  position: sticky;
  top: 100px;
}

/* ── PROFILE PHOTO — professional constrained size ── */
.profile-photo {
  width: 160px;
  height: 160px;
  border-radius: 50%;
  margin: 0 auto 18px;
  overflow: hidden;
  border: 4px solid rgba(255,230,163,.55);
  box-shadow: 0 8px 28px rgba(0,0,0,.28);
  background: rgba(255,255,255,.1);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.profile-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}
.profile-photo i { font-size: 3rem; color: rgba(255,230,163,.8); }

.message-profile h3 { font-size: 1.25rem; font-weight: 800; margin: 0 0 4px; color: #fff; }
.message-profile .title { font-size: .82rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,230,163,.85); margin-bottom: 4px; }
.message-profile .qualification { font-size: .78rem; color: rgba(255,255,255,.68); }
.profile-divider { height: 1px; background: rgba(255,255,255,.18); margin: 18px 0; }
.profile-stat { font-size: .8rem; color: rgba(255,255,255,.72); line-height: 1.5; }

/* Content area */
.message-content-wrap {
  background: #fff;
  border-radius: 18px;
  padding: 38px 40px;
  box-shadow: 0 4px 24px rgba(0,0,0,.06);
}
@media (max-width: 575px) { .message-content-wrap { padding: 26px 20px; } }

.message-content-wrap .section-label {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 6px 14px; border-radius: 999px;
  background: rgba(15,76,129,.08); border: 1px solid rgba(15,76,129,.12);
  color: var(--blue); font-size: .7rem; font-weight: 900;
  letter-spacing: .13em; text-transform: uppercase; margin-bottom: 10px;
}
.message-content-wrap h2 { font-size: 1.9rem; color: var(--maroon-dark, #5c0000); margin-bottom: 4px; }
.message-content-wrap .lead {
  border-left: 4px solid var(--gold, #d8a31f);
  padding: 14px 18px;
  background: rgba(216,163,31,.07);
  border-radius: 0 8px 8px 0;
  font-style: italic;
  color: var(--maroon-dark, #5c0000);
  font-size: .97rem;
  margin: 20px 0 22px;
}
.message-content-wrap p { font-size: .95rem; line-height: 1.8; color: #374151; margin-bottom: 14px; }

.message-signature {
  margin-top: 28px;
  padding-top: 22px;
  border-top: 1px solid #e5e7eb;
  display: flex;
  align-items: center;
  gap: 18px;
}
.signature-line { font-size: .82rem; color: #6b7280; margin-top: 3px; }

/* ── HOME PAGE LEADERS — larger, more professional images ── */
.msg-ava {
  width: 100px !important;
  height: 100px !important;
  margin: 0 auto 14px !important;
  border-radius: 50% !important;
  border: 3px solid rgba(255,230,163,.55) !important;
  box-shadow: 0 6px 20px rgba(0,0,0,.22) !important;
}
.msg-ava i { font-size: 2.4rem !important; }
.msg-top img.leader-img {
  width: 110px !important;
  height: 110px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  object-position: center top !important;
  border: 3px solid rgba(255,215,0,.6) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,.28) !important;
  margin: 0 auto 14px !important;
  display: block !important;
}
