/* =====================================================================
   SARHAD LAW SCHOOL — Theme Stylesheet
   Palette: deep maroon + gold, ivory backgrounds, serif display type
   ===================================================================== */

:root{
  --maroon:#7b1113;
  --maroon-dark:#5c0c0e;
  --maroon-light:#9a2326;
  --gold:#c9a227;
  --gold-light:#e3c75a;
  --ink:#1f1b1b;
  --muted:#6b6361;
  --ivory:#fbf8f3;
  --cream:#f4eee3;
  --line:#e7ded0;
  --white:#ffffff;
  --shadow:0 10px 30px rgba(40,20,20,.08);
  --shadow-lg:0 20px 50px rgba(40,20,20,.14);
  --radius:14px;
  --maxw:1180px;
  --t:.28s cubic-bezier(.4,0,.2,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,sans-serif;
  color:var(--ink);
  background:var(--ivory);
  line-height:1.65;
  font-size:16px;
  overflow-x:hidden;
}
h1,h2,h3,h4,h5{font-family:'Playfair Display',Georgia,serif;line-height:1.2;color:var(--ink);font-weight:700}
a{color:inherit;text-decoration:none;transition:color var(--t)}
img{max-width:100%;display:block}
ul{list-style:none}
.container{width:min(var(--maxw),92%);margin-inline:auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.85rem 1.6rem;border-radius:50px;font-weight:600;font-size:.95rem;
  cursor:pointer;border:2px solid transparent;transition:all var(--t);
}
.btn-primary{background:var(--gold);color:var(--maroon-dark)}
.btn-primary:hover{background:var(--gold-light);transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-outline{border-color:#fff;color:#fff}
.btn-outline:hover{background:#fff;color:var(--maroon)}
.btn-maroon{background:var(--maroon);color:#fff}
.btn-maroon:hover{background:var(--maroon-dark);transform:translateY(-2px);box-shadow:var(--shadow)}

/* ---------- Top bar ---------- */
.topbar{background:var(--maroon-dark);color:#f3e7d8;font-size:.85rem}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;flex-wrap:wrap;gap:.5rem}
.topbar a{color:#f3e7d8;margin-right:1.2rem}
.topbar a:hover{color:var(--gold-light)}
.topbar i{color:var(--gold)}
.topbar-social a{margin:0 0 0 .9rem}
.topbar-social .login-link{padding:.2rem .8rem;border:1px solid var(--gold);border-radius:50px;color:var(--gold-light)}
.topbar-social .login-link:hover{background:var(--gold);color:var(--maroon-dark)}
.topbar-social .student-login{padding:.22rem .9rem;border-radius:50px;background:var(--gold);color:var(--maroon-dark)!important;font-weight:600}
.topbar-social .student-login i{color:var(--maroon-dark)}
.topbar-social .student-login:hover{background:var(--gold-light);color:var(--maroon-dark)!important}

/* ---------- Header / Nav ---------- */
.site-header{background:var(--white);box-shadow:0 2px 14px rgba(0,0,0,.06);position:sticky;top:0;z-index:1000;transition:all var(--t)}
.site-header.scrolled{box-shadow:0 6px 24px rgba(0,0,0,.12)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:.7rem 0;gap:1rem}
.brand{display:flex;align-items:center;gap:.8rem}
.brand-mark{
  width:48px;height:48px;display:grid;place-items:center;border-radius:12px;
  background:linear-gradient(135deg,var(--maroon),var(--maroon-light));color:var(--gold);font-size:1.3rem;
  box-shadow:var(--shadow);flex-shrink:0;
}
.brand-logo{height:52px;width:auto;max-width:270px;object-fit:contain}
.site-footer .brand-logo{height:54px;max-width:240px}
.brand-text strong{display:block;font-family:'Playfair Display',serif;font-size:1.05rem;color:var(--maroon);line-height:1.1;white-space:nowrap}
.brand-text small{display:block;color:var(--muted);font-size:.72rem;letter-spacing:.3px}

.main-nav > ul{display:flex;align-items:center;gap:.1rem}
.main-nav a{display:block;padding:.55rem .62rem;border-radius:8px;font-weight:500;font-size:.9rem;color:var(--ink);position:relative;white-space:nowrap}
.main-nav a:hover,.main-nav a.active{color:var(--maroon)}
.main-nav > ul > li > a.active::after{content:"";position:absolute;left:.62rem;right:.62rem;bottom:.28rem;height:2px;background:var(--gold)}
.btn-nav{background:var(--maroon);color:#fff!important;border-radius:50px!important;padding:.6rem 1.3rem!important}
.btn-nav:hover{background:var(--maroon-dark)}
.btn-nav.active::after{display:none}

.has-sub{position:relative}
.has-sub > a i{font-size:.65rem;margin-left:.2rem}
.submenu{
  position:absolute;top:100%;left:0;min-width:220px;background:#fff;border-radius:10px;
  box-shadow:var(--shadow-lg);padding:.5rem;display:block;opacity:0;visibility:hidden;
  transform:translateY(10px);transition:all var(--t);border-top:3px solid var(--gold);
}
.has-sub:hover .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.submenu li a{display:block;padding:.55rem .8rem;font-size:.88rem}
.submenu li a:hover{background:var(--cream);color:var(--maroon)}
.nav-toggle{display:none;background:none;border:none;font-size:1.5rem;color:var(--maroon);cursor:pointer;padding:.3rem .5rem;line-height:1}
.nav-close{display:none}
body.nav-locked{overflow:hidden}

/* ---------- Hero ---------- */
.hero{
  position:relative;color:#fff;padding:6rem 0 7rem;overflow:hidden;
  background:
    linear-gradient(120deg,rgba(92,12,14,.94),rgba(123,17,19,.82)),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cpath d='M0 0h60v60H0z' fill='%235c0c0e'/%3E%3Cpath d='M30 8l4 12h-8zM30 52l-4-12h8z' fill='%23ffffff' opacity='.03'/%3E%3C/svg%3E");
  background-size:cover;
}
.hero::after{
  content:"\f24e";font-family:"Font Awesome 6 Free";font-weight:900;
  position:absolute;right:-3rem;bottom:-3rem;font-size:24rem;color:rgba(255,255,255,.04);
}
.hero-inner{max-width:680px;position:relative;z-index:2}
.badge{
  display:inline-flex;align-items:center;gap:.5rem;background:rgba(201,162,39,.18);
  border:1px solid var(--gold);color:var(--gold-light);padding:.4rem 1rem;border-radius:50px;
  font-size:.82rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;margin-bottom:1.4rem;
}
.hero h1{font-size:clamp(2.2rem,5vw,3.6rem);color:#fff;margin-bottom:1.2rem}
.hero h1 span{color:var(--gold-light)}
.hero p{font-size:1.12rem;color:#f3e7d8;margin-bottom:2rem;max-width:560px}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero-stats{display:flex;gap:2.5rem;margin-top:3rem;flex-wrap:wrap}
.hero-stats .stat strong{font-family:'Playfair Display',serif;font-size:1.9rem;color:var(--gold-light);display:block}
.hero-stats .stat span{font-size:.85rem;color:#e6d4c2}

/* ---------- Home hero image slider (clean, no overlay) ---------- */
.hero-slider{position:relative;width:100%;overflow:hidden;background:#161616}
.hs-track{display:flex;transition:transform .6s cubic-bezier(.4,0,.2,1)}
.hs-slide{min-width:100%}
.hs-slide img{display:block;width:100%;height:clamp(260px,42vw,620px);object-fit:cover}
.hs-arrow{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border:none;border-radius:50%;background:rgba(255,255,255,.85);color:var(--maroon);font-size:1rem;cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow);transition:all var(--t);z-index:3}
.hs-arrow:hover{background:#fff;transform:translateY(-50%) scale(1.06)}
.hs-prev{left:1rem}.hs-next{right:1rem}
.hs-dots{position:absolute;left:0;right:0;bottom:1rem;display:flex;gap:.5rem;justify-content:center;z-index:3}
.hs-dot{width:11px;height:11px;border-radius:50%;border:2px solid #fff;background:transparent;cursor:pointer;padding:0;transition:all var(--t)}
.hs-dot.active{background:var(--gold);border-color:var(--gold);width:26px;border-radius:10px}
.hero-fallback{display:grid;place-items:center;height:clamp(220px,32vw,420px);background:linear-gradient(120deg,var(--maroon),var(--maroon-dark));color:var(--gold);font-size:5rem}

/* ---------- Home intro (details below the slider) ---------- */
.home-intro{text-align:center;padding:3.4rem 0 2.4rem;position:relative;overflow:hidden}
.home-intro::before{content:"";position:absolute;top:-120px;left:50%;transform:translateX(-50%);width:760px;height:340px;background:radial-gradient(ellipse at center,rgba(201,162,39,.14),transparent 70%);pointer-events:none}
.home-intro .container{position:relative;z-index:1}
.home-intro .badge-maroon{background:var(--cream);border-color:var(--gold);color:var(--maroon)}
.home-intro .badge-maroon i{color:var(--gold)}
.home-intro h1{font-size:clamp(2rem,4.6vw,3.4rem);color:var(--maroon);margin:1.2rem auto .2rem;max-width:18ch;line-height:1.12}
.home-intro h1 span{color:var(--gold);position:relative}
.head-accent{display:block;width:84px;height:4px;border-radius:4px;margin:1.1rem auto 1.3rem;background:linear-gradient(90deg,var(--gold),var(--maroon))}
.home-intro p{color:var(--muted);max-width:660px;margin:0 auto 1.9rem;font-size:1.08rem}
.home-intro .hero-actions{justify-content:center}

/* ---------- Stats band (maroon) ---------- */
.stats-band{background:linear-gradient(125deg,var(--maroon-dark),var(--maroon) 55%,var(--maroon-light));position:relative;overflow:hidden;padding:2.6rem 0 5.2rem}
.stats-band::after{content:"\f24e";font-family:"Font Awesome 6 Free";font-weight:900;position:absolute;right:-2rem;top:-3rem;font-size:13rem;color:rgba(255,255,255,.05);pointer-events:none}
.stats-band-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;position:relative;z-index:1}
.sb-stat{text-align:center;color:#fff;padding:.4rem 1rem;position:relative}
.sb-stat+.sb-stat::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);height:54px;width:1px;background:rgba(255,255,255,.16)}
.sb-ico{display:inline-grid;place-items:center;width:50px;height:50px;border-radius:14px;background:rgba(255,255,255,.1);color:var(--gold-light);font-size:1.3rem;margin-bottom:.7rem;border:1px solid rgba(201,162,39,.35)}
.sb-stat strong{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,3vw,2.2rem);color:#fff;display:block;line-height:1}
.sb-stat span{font-size:.84rem;color:#f1ddc4;display:block;margin-top:.3rem}

/* ---------- Section scaffolding ---------- */
.section{padding:5rem 0}
.section.alt{background:var(--cream)}
.section-head{text-align:center;max-width:680px;margin:0 auto 3rem}
.section-head .eyebrow{
  color:var(--gold);font-weight:700;text-transform:uppercase;letter-spacing:2px;font-size:.8rem;
  display:inline-block;margin-bottom:.6rem;
}
.section-head h2{font-size:clamp(1.8rem,3.5vw,2.5rem);color:var(--maroon)}
.section-head h2::after{content:"";display:block;width:64px;height:3px;border-radius:3px;margin:.9rem auto 0;background:linear-gradient(90deg,var(--gold),var(--maroon))}
.section-head p{color:var(--muted);margin-top:.8rem}
.section-head.left{text-align:left;margin-inline:0}
.section-head.left h2::after{margin-left:0;margin-right:auto}

/* ---------- Highlight strip (floats up over the stats band) ---------- */
.highlights-section{padding:0 0 1rem;position:relative;z-index:5}
.highlights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;background:#fff;border-radius:18px;box-shadow:var(--shadow-lg);padding:2rem;border-top:4px solid var(--gold);margin-top:-3.4rem}
.highlight{display:flex;gap:1rem;align-items:center;padding:.4rem;border-radius:12px;transition:background var(--t)}
.highlight:hover{background:var(--ivory)}
.highlight i{font-size:1.6rem;color:var(--gold);background:linear-gradient(135deg,var(--maroon),var(--maroon-light));width:58px;height:58px;display:grid;place-items:center;border-radius:14px;flex-shrink:0}
.highlight strong{display:block;font-family:'Playfair Display',serif;color:var(--ink);font-size:1.05rem}
.highlight span{color:var(--muted);font-size:.88rem}

/* ---------- About visual (designed placeholder) ---------- */
.about-visual{position:relative;display:grid;place-items:center;background:linear-gradient(140deg,var(--maroon),var(--maroon-dark));color:var(--gold-light)}
.about-visual > i{font-size:6rem;opacity:.9;position:relative;z-index:1}
.about-visual .av-ring{position:absolute;width:230px;height:230px;border:2px dashed rgba(201,162,39,.4);border-radius:50%;animation:avspin 26s linear infinite}
.about-visual .av-ring::before{content:"";position:absolute;inset:26px;border:1px solid rgba(255,255,255,.12);border-radius:50%}
@keyframes avspin{to{transform:rotate(360deg)}}
.av-badge{position:absolute;right:1.2rem;bottom:3.4rem;z-index:2;display:flex;align-items:center;gap:.7rem;background:#fff;color:var(--ink);padding:.7rem .95rem;border-radius:14px;box-shadow:var(--shadow-lg)}
.av-badge-ico{width:44px;height:44px;border-radius:11px;background:var(--cream);color:var(--maroon);display:grid;place-items:center;flex-shrink:0}
.av-badge-ico i{font-size:1.25rem!important;line-height:1}
.av-badge strong{display:block;font-family:'Playfair Display',serif;color:var(--maroon);font-size:.98rem;line-height:1.1}
.av-badge span{font-size:.76rem;color:var(--muted)}

/* ---------- Cards grid ---------- */
.grid{display:grid;gap:1.6rem}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-1-center{grid-template-columns:minmax(0,420px);justify-content:center}

.card{
  background:#fff;border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow);
  border:1px solid var(--line);transition:transform var(--t),box-shadow var(--t);position:relative;overflow:hidden;
}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--maroon));transform:scaleX(0);transform-origin:left;transition:transform var(--t)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--gold)}
.card:hover::before{transform:scaleX(1)}
.card .card-icon{
  width:62px;height:62px;border-radius:14px;display:grid;place-items:center;font-size:1.5rem;
  background:linear-gradient(135deg,var(--maroon),var(--maroon-light));color:var(--gold);margin-bottom:1.2rem;
  transition:transform var(--t);
}
.card:hover .card-icon{transform:scale(1.06) rotate(-3deg)}
.card h3{font-size:1.25rem;color:var(--maroon);margin-bottom:.6rem}
.card p{color:var(--muted);font-size:.94rem}

/* ---------- Programme cards ---------- */
.prog-card .prog-meta{list-style:none;margin:1.1rem 0;border-top:1px dashed var(--line);padding-top:1rem}
.prog-card .prog-meta li{display:flex;justify-content:space-between;font-size:.9rem;padding:.3rem 0;color:var(--ink)}
.prog-card .prog-meta li span:first-child{color:var(--muted)}
.prog-card .prog-meta li span:last-child{font-weight:600;text-align:right}

/* ---------- About split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.split .media{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg);min-height:340px;
  background:linear-gradient(135deg,var(--maroon),var(--maroon-dark));display:grid;place-items:center;color:var(--gold);position:relative}
.split .media > i{font-size:6rem;opacity:.85}
.split .media .media-cap{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.35);color:#fff;padding:1rem 1.4rem;font-size:.9rem}
.lead{font-size:1.05rem;color:var(--muted);margin-bottom:1.2rem}
.tick{margin:1.2rem 0}
.tick li{display:flex;gap:.7rem;align-items:flex-start;margin-bottom:.7rem;color:var(--ink)}
.tick li i{color:var(--gold);margin-top:.25rem}

/* ---------- Desk / message cards ---------- */
.desk{display:flex;gap:1.5rem;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:2rem;border-left:4px solid var(--gold)}
.desk .avatar{width:90px;height:90px;border-radius:50%;background:linear-gradient(135deg,var(--maroon),var(--maroon-light));color:var(--gold);display:grid;place-items:center;font-size:2rem;flex-shrink:0}
.desk h3{color:var(--maroon);margin-bottom:.2rem}
.desk .role{color:var(--gold);font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:.8rem}
.desk p{color:var(--muted);font-style:italic}

/* ---------- Trustee / Principal desk layout ---------- */
.desk-layout{display:grid;grid-template-columns:360px 1fr;gap:2.5rem;align-items:start}
.desk-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:2.2rem;text-align:center;border-top:4px solid var(--gold);position:sticky;top:110px}
.desk-photo{width:230px;height:260px;border-radius:16px;margin:0 auto 1.3rem;display:grid;place-items:center;font-size:4.5rem;overflow:hidden;
  background:linear-gradient(135deg,var(--maroon),var(--maroon-light));color:var(--gold);box-shadow:var(--shadow)}
@media(max-width:520px){.desk-photo{width:200px;height:230px}}
.desk-card h3{color:var(--maroon);font-size:1.35rem;margin-bottom:.2rem}
.desk-card .role{color:var(--gold);font-weight:600;font-size:.82rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:1.2rem}
.desk-chips{display:flex;flex-direction:column;gap:.6rem}
.desk-chips span{background:var(--cream);color:var(--maroon);font-size:.85rem;font-weight:600;padding:.5rem .9rem;border-radius:50px}
.desk-chips i{color:var(--gold);margin-right:.4rem}
.desk-message{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:2.5rem;position:relative;border-left:4px solid var(--gold)}
.desk-message .quote-mark{font-size:2rem;color:var(--cream)}
.desk-message h2{color:var(--maroon);font-size:1.7rem;margin:.3rem 0 .2rem}
.desk-message .msg-sub{color:var(--gold);font-weight:600;font-size:.9rem;margin-bottom:1.4rem}
.desk-message p{color:var(--muted);margin-bottom:1rem;line-height:1.8}
.desk-message .sign{color:var(--maroon);font-weight:600;font-style:italic;margin-top:1.4rem}
@media(max-width:860px){.desk-layout{grid-template-columns:1fr}.desk-card{position:static}}

/* ---------- News list ---------- */
.news-item{display:flex;gap:1.2rem;background:#fff;border-radius:12px;padding:1.2rem 1.4rem;box-shadow:var(--shadow);border:1px solid var(--line);transition:all var(--t)}
.news-item:hover{transform:translateX(4px);border-color:var(--gold)}
.news-date{background:var(--maroon);color:#fff;border-radius:10px;min-width:70px;text-align:center;padding:.6rem;align-self:flex-start}
.news-date .d{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:700;line-height:1}
.news-date .m{font-size:.72rem;text-transform:uppercase;letter-spacing:1px}
.news-item h4{color:var(--maroon);font-size:1.05rem;margin-bottom:.25rem}
.news-item .tag{display:inline-block;background:var(--cream);color:var(--maroon);font-size:.7rem;font-weight:700;text-transform:uppercase;padding:.15rem .6rem;border-radius:50px;letter-spacing:.5px;margin-bottom:.3rem}
.news-item p{color:var(--muted);font-size:.9rem}

/* ---------- Testimonials ---------- */
.testi{background:#fff;border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow);border:1px solid var(--line)}
.testi .stars{color:var(--gold);margin-bottom:.8rem}
.testi blockquote{font-style:italic;color:var(--ink);margin-bottom:1.2rem;position:relative}
.testi blockquote::before{content:"\201C";font-family:'Playfair Display',serif;font-size:3rem;color:var(--cream);position:absolute;top:-1.5rem;left:-.5rem;z-index:0}
.testi .who{display:flex;align-items:center;gap:.8rem}
.testi .who .avatar{width:46px;height:46px;border-radius:50%;background:var(--maroon);color:var(--gold);display:grid;place-items:center;font-weight:700}
.testi .who strong{display:block;color:var(--maroon)}
.testi .who span{color:var(--muted);font-size:.83rem}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(120deg,var(--maroon),var(--maroon-dark));color:#fff;border-radius:20px;padding:3.4rem 3rem;text-align:center;position:relative;overflow:hidden;border:1px solid rgba(201,162,39,.3)}
.cta-band::before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M20 4l3 9h-6z' fill='%23ffffff' opacity='.04'/%3E%3C/svg%3E");pointer-events:none}
.cta-band::after{content:"\f24e";font-family:"Font Awesome 6 Free";font-weight:900;position:absolute;left:-2rem;bottom:-3rem;font-size:12rem;color:rgba(201,162,39,.08);pointer-events:none}
.cta-band > *{position:relative;z-index:1}
.cta-band h2{color:#fff;font-size:2rem;margin-bottom:.6rem}
.cta-band h2::after{display:none}
.cta-band p{color:#f3e7d8;margin-bottom:1.6rem;max-width:540px;margin-inline:auto}

/* ---------- Page banner (inner pages) ---------- */
.page-banner{
  background:linear-gradient(120deg,rgba(92,12,14,.95),rgba(123,17,19,.86));
  color:#fff;padding:3.5rem 0;text-align:center;position:relative;
}
.page-banner h1{color:#fff;font-size:clamp(1.8rem,4vw,2.8rem)}
.breadcrumb{margin-top:.7rem;color:#e6d4c2;font-size:.9rem}
.breadcrumb a{color:var(--gold-light)}

/* ---------- Forms ---------- */
.form-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:2.5rem;border-top:4px solid var(--gold)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.field{margin-bottom:1.2rem}
.field label{display:block;font-weight:600;font-size:.88rem;margin-bottom:.4rem;color:var(--ink)}
.field input,.field select,.field textarea{
  width:100%;padding:.8rem 1rem;border:1.5px solid var(--line);border-radius:10px;font-family:inherit;font-size:.95rem;
  background:var(--ivory);transition:border var(--t),box-shadow var(--t);
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,39,.15);background:#fff}
.field textarea{min-height:130px;resize:vertical}
.req{color:var(--maroon)}

.alert{padding:1rem 1.3rem;border-radius:10px;margin-bottom:1.5rem;font-weight:500;display:flex;gap:.6rem;align-items:center}
.alert-success{background:#e8f6ec;color:#1e6b39;border:1px solid #bfe3c9}
.alert-error{background:#fbeaea;color:#9a2326;border:1px solid #f0c9c9}

/* ---------- Info / table ---------- */
.info-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.info-table th,.info-table td{padding:1rem 1.3rem;text-align:left;border-bottom:1px solid var(--line)}
.info-table th{background:var(--maroon);color:#fff;font-family:'Playfair Display',serif;font-weight:600}
.info-table tr:last-child td{border-bottom:none}
.info-table tr:nth-child(even) td{background:var(--ivory)}

/* ---------- Gallery ---------- */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.gallery-item{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);position:relative;aspect-ratio:4/3;
  background:linear-gradient(135deg,var(--maroon),var(--maroon-dark));display:grid;place-items:center;color:var(--gold);transition:all var(--t)}
.gallery-item:hover{transform:scale(1.02);box-shadow:var(--shadow-lg)}
.gallery-item i{font-size:3rem;opacity:.6}
.gallery-item .cap{position:absolute;inset:auto 0 0 0;background:linear-gradient(transparent,rgba(0,0,0,.6));color:#fff;padding:1.4rem 1rem .9rem;font-weight:600;font-size:.95rem}
.gallery-item .tag{position:absolute;top:.8rem;left:.8rem;background:var(--gold);color:var(--maroon-dark);font-size:.7rem;font-weight:700;padding:.2rem .7rem;border-radius:50px}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:2.5rem;align-items:start}
.contact-info .ci-item{display:flex;gap:1rem;margin-bottom:1.5rem}
.contact-info .ci-item i{width:50px;height:50px;border-radius:12px;background:var(--maroon);color:var(--gold);display:grid;place-items:center;font-size:1.2rem;flex-shrink:0}
.contact-info .ci-item strong{display:block;color:var(--maroon)}
.contact-info .ci-item span{color:var(--muted);font-size:.92rem}
.map-embed{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);margin-top:1.5rem;border:0;width:100%;height:260px}

/* ---------- Footer ---------- */
.site-footer{background:var(--maroon-dark);color:#e7d8c6;padding-top:4rem;margin-top:2rem}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:2.5rem;padding-bottom:3rem}
.brand-footer .brand-text strong{color:#fff}
.brand-footer .brand-text small{color:var(--gold-light)}
.footer-about{margin:1rem 0;font-size:.9rem;color:#cdb9a4;line-height:1.7}
.footer-col h4{color:#fff;font-size:1.05rem;margin-bottom:1.2rem;position:relative;padding-bottom:.6rem}
.footer-col h4::after{content:"";position:absolute;left:0;bottom:0;width:40px;height:2px;background:var(--gold)}
.footer-links li,.footer-contact li{margin-bottom:.7rem;font-size:.9rem}
.footer-links a:hover{color:var(--gold-light);padding-left:5px}
.footer-contact li{display:flex;gap:.7rem;color:#cdb9a4}
.footer-contact i{color:var(--gold)}
.footer-social{display:flex;gap:.7rem;margin-top:1.2rem}
.footer-social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);display:grid;place-items:center;color:#fff}
.footer-social a:hover{background:var(--gold);color:var(--maroon-dark)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:1.4rem 0}
.footer-bottom .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem;font-size:.83rem;color:#bfa890}

/* ---------- Promotional popup ---------- */
.site-popup{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.65);display:none;align-items:center;justify-content:center;padding:1.2rem;opacity:0;transition:opacity .3s ease}
.site-popup.show{display:flex;opacity:1}
.popup-box{position:relative;max-width:min(560px,92vw);max-height:90vh;animation:popIn .35s cubic-bezier(.4,0,.2,1)}
@keyframes popIn{from{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}
.popup-box img{display:block;width:100%;height:auto;max-height:90vh;object-fit:contain;border-radius:12px;box-shadow:var(--shadow-lg)}
.popup-close{position:absolute;top:-14px;right:-14px;width:38px;height:38px;border-radius:50%;border:none;background:var(--maroon);color:#fff;font-size:1.5rem;line-height:1;cursor:pointer;box-shadow:var(--shadow-lg);display:grid;place-items:center;transition:background var(--t)}
.popup-close:hover{background:var(--maroon-dark)}
@media(max-width:520px){.popup-close{top:-8px;right:-8px;width:34px;height:34px;font-size:1.3rem}}

/* ---------- Preloader ---------- */
.preloader{position:fixed;inset:0;z-index:99999;display:grid;place-items:center;background:#fff;transition:opacity .5s ease,visibility .5s ease}
.preloader.loaded{opacity:0;visibility:hidden}
.pl-inner{display:grid;place-items:center;padding:1rem}
.pl-media{max-width:min(280px,62vw);max-height:min(280px,40vh);width:auto;height:auto;object-fit:contain}
.preloader video.pl-media{max-width:min(440px,82vw);max-height:min(60vh,440px)}
.pl-spinner{width:58px;height:58px;border-radius:50%;border:5px solid var(--cream);border-top-color:var(--maroon);border-right-color:var(--gold);animation:plSpin .8s linear infinite}
@keyframes plSpin{to{transform:rotate(360deg)}}

/* ---------- Floating WhatsApp / Call buttons ---------- */
.float-actions{position:fixed;left:1.2rem;bottom:1.2rem;display:flex;flex-direction:column;gap:.65rem;z-index:900}
.float-btn{width:52px;height:52px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:1.4rem;box-shadow:var(--shadow-lg);transition:transform var(--t);position:relative}
.float-btn:hover{transform:scale(1.09);color:#fff}
.float-wa{background:#25d366}
.float-call{background:var(--maroon)}
.float-call i{font-size:1.25rem}
.float-wa::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid #25d366;animation:floatPulse 2s ease-out infinite}
@keyframes floatPulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.6);opacity:0}}
@media(max-width:620px){.float-actions{left:1rem;bottom:1rem}.float-btn{width:48px;height:48px;font-size:1.25rem}}

/* ---------- Back to top ---------- */
.back-to-top{position:fixed;right:1.5rem;bottom:1.5rem;width:46px;height:46px;border-radius:50%;background:var(--maroon);color:var(--gold);display:grid;place-items:center;box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(15px);transition:all var(--t);z-index:900}
.back-to-top.show{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top:hover{background:var(--maroon-dark)}

/* ===== Highlighted table row (e.g. caution money) ===== */
.info-table tr.hl td{background:var(--cream)!important;font-weight:700;color:var(--ink)}

/* ===== Step / timeline cards (ABC ID process) ===== */
.steps-grid{display:grid;gap:1.2rem;grid-template-columns:repeat(auto-fit,minmax(235px,1fr));margin-top:1.5rem}
.step{position:relative;background:#fff;border:1px solid var(--line);border-radius:12px;padding:1.4rem 1.4rem 1.4rem 1.6rem;box-shadow:var(--shadow);overflow:hidden;transition:transform var(--t),box-shadow var(--t)}
.step:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.step::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--gold)}
.step .step-num{display:inline-flex;align-items:center;gap:.4rem;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--maroon);background:var(--cream);padding:.3rem .8rem;border-radius:50px;margin-bottom:.9rem}
.step .step-num i{color:var(--gold)}
.step h4{color:var(--maroon);font-size:1.05rem;margin-bottom:.4rem}
.step p{color:var(--muted);font-size:.88rem;line-height:1.6}

/* ===== Document / committee download card ===== */
.doc-card{display:flex;flex-direction:column}
.doc-card .doc-foot{margin-top:auto;padding-top:1rem;display:flex;align-items:center;justify-content:space-between;gap:.6rem;border-top:1px dashed var(--line);flex-wrap:wrap}
.doc-card .doc-pill{display:inline-flex;align-items:center;gap:.4rem;font-size:.74rem;font-weight:700;color:var(--maroon);background:var(--cream);padding:.35rem .7rem;border-radius:50px}
.doc-card .doc-pill i{color:var(--gold)}
.btn-sm{padding:.55rem 1.1rem;font-size:.85rem}

/* ===== Syllabus / curriculum (year + semester) ===== */
.syl-year{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);margin-bottom:1.4rem}
.syl-year-head{background:linear-gradient(135deg,var(--maroon),var(--maroon-dark));color:#fff;padding:.95rem 1.4rem;font-family:'Playfair Display',serif;font-weight:700;font-size:1.15rem;display:flex;align-items:center;gap:.7rem;letter-spacing:.3px}
.syl-year-head i{color:var(--gold)}
.syl-sem-grid{display:grid;gap:1.2rem;padding:1.2rem}
@media(min-width:900px){.syl-sem-grid{grid-template-columns:1fr 1fr}}
.syl-sem{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--ivory)}
.syl-sem h4{background:var(--cream);color:var(--maroon);padding:.7rem 1rem;font-family:'Playfair Display',serif;font-size:1rem;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:.5rem}
.syl-sem h4 i{color:var(--gold);font-size:.85rem}
.syl-list{padding:.9rem;display:flex;flex-direction:column;gap:.45rem}
.syl-item{display:flex;gap:.6rem;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:8px;padding:.55rem .75rem;font-size:.88rem;color:var(--ink);line-height:1.4}
.syl-item > i{color:var(--gold);margin-top:4px;font-size:.6rem;flex:0 0 auto}
.syl-item .syl-name{flex:1;min-width:0}
.syl-item .syl-code{color:var(--maroon);font-size:.72rem;font-weight:700;white-space:nowrap;background:var(--cream);padding:.15rem .5rem;border-radius:50px;align-self:flex-start}
.syl-group{text-align:center;font-weight:700;color:var(--maroon);font-size:.78rem;background:var(--cream);border:1px dashed var(--gold);border-radius:8px;padding:.5rem;margin-top:.35rem;text-transform:uppercase;letter-spacing:.4px;line-height:1.4}

/* ===== Library tabbed section ===== */
.lib{position:relative}
.lib input[type=radio]{position:absolute;opacity:0;pointer-events:none}
.lib-snapshot{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem}
.lib-snap{display:flex;gap:1rem;align-items:center;background:linear-gradient(135deg,var(--maroon),var(--maroon-dark));color:#fff;border-radius:var(--radius);padding:1.2rem 1.4rem;box-shadow:var(--shadow)}
.lib-snap > i{font-size:1.7rem;color:var(--gold)}
.lib-snap b{display:block;font-family:'Playfair Display',serif;font-size:1.6rem;line-height:1.1}
.lib-snap span{font-size:.82rem;color:#e6d4c2}
.lib-grid{display:grid;gap:1.5rem}
@media(min-width:980px){.lib-grid{grid-template-columns:300px 1fr;align-items:start}}
.lib-nav{display:flex;flex-direction:column;gap:.5rem}
@media(min-width:980px){.lib-nav{position:sticky;top:110px}}
.lib-tab{display:flex;gap:.8rem;align-items:flex-start;padding:.85rem;border-radius:12px;border:1px solid var(--line);background:#fff;box-shadow:var(--shadow);cursor:pointer;transition:all var(--t)}
.lib-tab:hover{border-color:var(--gold);transform:translateY(-2px)}
.lib-tab > i{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:var(--cream);color:var(--maroon);flex:0 0 auto}
.lib-tab b{display:block;font-size:.9rem;color:var(--ink);line-height:1.3}
.lib-tab small{display:block;font-size:.76rem;color:var(--muted);margin-top:2px;line-height:1.4}
.lib-panel{display:none;animation:slsFade .25s ease}
@keyframes slsFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.lib-phead{display:flex;gap:1rem;align-items:flex-start;justify-content:space-between;padding-bottom:1.2rem;margin-bottom:1.4rem;border-bottom:2px solid var(--line);flex-wrap:wrap}
.lib-phead .lib-pm{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--maroon),var(--maroon-light));color:var(--gold);display:grid;place-items:center;font-size:1.25rem;flex:0 0 auto}
.lib-phead .lib-pt{display:flex;gap:.9rem;align-items:flex-start;flex:1;min-width:0}
.lib-phead h2{color:var(--maroon);font-size:1.4rem;line-height:1.2}
.lib-phead .lib-psub{color:var(--muted);font-size:.9rem;margin-top:.25rem}
.lib-ptag{display:inline-flex;align-items:center;gap:.4rem;background:var(--maroon);color:#fff;border-radius:50px;padding:.45rem .95rem;font-size:.72rem;font-weight:700;white-space:nowrap;text-transform:uppercase;letter-spacing:.5px}
.lib-ptag i{color:var(--gold)}
.lib-panel > p{color:var(--muted);line-height:1.85;font-size:.95rem}
.lib-panel > p + p{margin-top:.9rem}
.lib-box{border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:var(--shadow);background:#fff}
.lib-box-top{padding:.75rem 1rem;background:var(--cream);font-weight:700;font-size:.9rem;color:var(--maroon);display:flex;gap:.5rem;align-items:center;border-bottom:1px solid var(--line)}
.lib-box-top i{color:var(--gold)}
.lib-box-in{padding:1rem 1.2rem}
.lib-box-in > p{color:var(--muted);line-height:1.8;font-size:.92rem}
.lib-list{list-style:none}
.lib-li{display:flex;gap:.7rem;padding:.65rem 0;border-top:1px solid var(--line)}
.lib-li:first-child{border-top:none;padding-top:0}
.lib-li > i{color:var(--gold);margin-top:3px;flex:0 0 auto;width:20px;text-align:center}
.lib-li b{display:block;font-size:.88rem;color:var(--ink)}
.lib-li span{display:block;font-size:.82rem;color:var(--muted);margin-top:2px;line-height:1.5}
.lib-2col{display:grid;gap:1.2rem;margin-top:1.4rem}
@media(min-width:880px){.lib-2col{grid-template-columns:1fr 1fr;align-items:start}}
.lib-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.3rem}
.lib-chip{display:inline-flex;gap:.4rem;align-items:center;padding:.45rem .9rem;border-radius:50px;border:1px solid var(--line);background:#fff;font-size:.78rem;font-weight:600;color:var(--maroon);box-shadow:var(--shadow)}
.lib-chip i{color:var(--gold)}
.lib-table-wrap{margin-top:1.3rem;border:1px solid var(--line);border-radius:12px;overflow-x:auto;box-shadow:var(--shadow)}
.lib-table{width:100%;border-collapse:collapse;min-width:460px}
.lib-table th{text-align:left;font-size:.72rem;text-transform:uppercase;letter-spacing:.6px;padding:.85rem 1rem;background:var(--maroon);color:#fff;font-family:'Playfair Display',serif}
.lib-table td{padding:.75rem 1rem;border-top:1px solid var(--line);font-size:.88rem;color:var(--muted)}
.lib-table tbody tr:nth-child(even) td{background:var(--ivory)}
.lib-table tbody tr:hover td{background:var(--cream)}
.lib-table td b{color:var(--ink)}
/* Active tab + visible panel (explicit for broad browser support) */
#lib1:checked~.lib-grid .lib-content #p1,#lib2:checked~.lib-grid .lib-content #p2,
#lib3:checked~.lib-grid .lib-content #p3,#lib4:checked~.lib-grid .lib-content #p4,
#lib5:checked~.lib-grid .lib-content #p5,#lib6:checked~.lib-grid .lib-content #p6,
#lib7:checked~.lib-grid .lib-content #p7{display:block}
#lib1:checked~.lib-grid .lib-nav label[for=lib1],#lib2:checked~.lib-grid .lib-nav label[for=lib2],
#lib3:checked~.lib-grid .lib-nav label[for=lib3],#lib4:checked~.lib-grid .lib-nav label[for=lib4],
#lib5:checked~.lib-grid .lib-nav label[for=lib5],#lib6:checked~.lib-grid .lib-nav label[for=lib6],
#lib7:checked~.lib-grid .lib-nav label[for=lib7]{background:var(--maroon);border-color:var(--maroon)}
#lib1:checked~.lib-grid .lib-nav label[for=lib1] b,#lib2:checked~.lib-grid .lib-nav label[for=lib2] b,
#lib3:checked~.lib-grid .lib-nav label[for=lib3] b,#lib4:checked~.lib-grid .lib-nav label[for=lib4] b,
#lib5:checked~.lib-grid .lib-nav label[for=lib5] b,#lib6:checked~.lib-grid .lib-nav label[for=lib6] b,
#lib7:checked~.lib-grid .lib-nav label[for=lib7] b{color:#fff}
#lib1:checked~.lib-grid .lib-nav label[for=lib1] small,#lib2:checked~.lib-grid .lib-nav label[for=lib2] small,
#lib3:checked~.lib-grid .lib-nav label[for=lib3] small,#lib4:checked~.lib-grid .lib-nav label[for=lib4] small,
#lib5:checked~.lib-grid .lib-nav label[for=lib5] small,#lib6:checked~.lib-grid .lib-nav label[for=lib6] small,
#lib7:checked~.lib-grid .lib-nav label[for=lib7] small{color:#e6d4c2}
#lib1:checked~.lib-grid .lib-nav label[for=lib1]>i,#lib2:checked~.lib-grid .lib-nav label[for=lib2]>i,
#lib3:checked~.lib-grid .lib-nav label[for=lib3]>i,#lib4:checked~.lib-grid .lib-nav label[for=lib4]>i,
#lib5:checked~.lib-grid .lib-nav label[for=lib5]>i,#lib6:checked~.lib-grid .lib-nav label[for=lib6]>i,
#lib7:checked~.lib-grid .lib-nav label[for=lib7]>i{background:var(--gold);color:var(--maroon-dark)}
@media(max-width:620px){.lib-snapshot{grid-template-columns:1fr}}
@media(max-width:979px){
  .lib-nav{flex-direction:row;overflow-x:auto;padding-bottom:.6rem;-webkit-overflow-scrolling:touch}
  .lib-tab{min-width:240px;flex:0 0 auto}
}

/* ---------- Document repository (NAAC / IQAC) ---------- */
.repo-grid{display:grid;gap:1.4rem}
@media(min-width:820px){.repo-grid{grid-template-columns:1fr 1fr}}
.repo-sec{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.repo-sec-head{background:linear-gradient(135deg,var(--maroon),var(--maroon-dark));color:#fff;padding:.9rem 1.3rem;font-family:'Playfair Display',serif;font-weight:700;font-size:1.05rem;display:flex;align-items:center;gap:.6rem}
.repo-sec-head i{color:var(--gold)}
.repo-sec-body{padding:.8rem 1.1rem}
.repo-doc{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.7rem 0;border-top:1px solid var(--line)}
.repo-doc:first-child{border-top:none}
.repo-doc-name{display:flex;align-items:center;gap:.6rem;font-size:.92rem;color:var(--ink);font-weight:500}
.repo-doc-name i{color:var(--maroon)}
.repo-empty{color:var(--muted);font-size:.88rem;padding:.4rem 0}
.repo-empty i{color:var(--gold);margin-right:.3rem}

/* ---------- Achievements grid ---------- */
.achv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.6rem}
.achv-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.8rem 1.4rem 1.6rem;text-align:center;transition:transform var(--t),box-shadow var(--t)}
.achv-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.achv-photo-wrap{position:relative;width:124px;margin:0 auto 1rem}
.achv-photo{width:124px;height:124px;border-radius:50%;object-fit:cover;border:4px solid var(--cream);box-shadow:var(--shadow);display:block}
.achv-photo-ph{display:grid;place-items:center;font-size:2.8rem;color:var(--gold);background:linear-gradient(135deg,var(--maroon),var(--maroon-dark))}
.achv-badge{position:absolute;bottom:2px;right:2px;width:38px;height:38px;border-radius:50%;background:var(--gold);color:var(--maroon-dark);display:grid;place-items:center;border:3px solid #fff;font-size:.9rem}
.achv-card h3{color:var(--maroon);font-size:1.15rem;margin-bottom:.25rem}
.achv-role{display:inline-block;background:var(--cream);color:var(--maroon);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:.2rem .8rem;border-radius:50px;margin-bottom:.7rem}
.achv-card p{color:var(--muted);font-size:.9rem;line-height:1.6;margin:0}

/* ---------- Our Team grid ---------- */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.6rem}
.team-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;text-align:center;transition:transform var(--t),box-shadow var(--t)}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.team-photo{width:100%;aspect-ratio:1/1;object-fit:cover;display:block}
.team-photo-ph{display:grid;place-items:center;font-size:3.5rem;color:var(--gold);background:linear-gradient(135deg,var(--maroon),var(--maroon-dark))}
.team-info{padding:1.1rem 1rem 1.3rem;border-top:3px solid var(--gold)}
.team-info h3{color:var(--maroon);font-size:1.12rem;margin-bottom:.2rem}
.team-info span{color:var(--muted);font-size:.85rem;font-weight:600;display:block}

/* ---------- Sub-page tab navigation ---------- */
.subnav{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-bottom:2.8rem}
.subnav a{
  padding:.55rem 1.25rem;border-radius:50px;background:#fff;box-shadow:var(--shadow);
  font-weight:600;font-size:.9rem;color:var(--maroon);border:1px solid var(--line);transition:all var(--t);
}
.subnav a.active,.subnav a:hover{background:var(--maroon);color:#fff;border-color:var(--maroon);transform:translateY(-2px)}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
  .split,.contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .highlights-grid{grid-template-columns:1fr;gap:1rem;margin-top:-3rem}
  .stats-band{padding-bottom:4.4rem}
  .stats-band-grid{grid-template-columns:repeat(2,1fr);gap:1.8rem 1rem}
  .sb-stat+.sb-stat::before{display:none}
  .about-visual{min-height:300px}
  .av-badge{right:1rem;bottom:1rem}
}
@media(max-width:1024px){
  .nav-toggle{display:block}
  .main-nav{position:fixed;inset:0;background:#fff;z-index:2000;
    padding:4.6rem 1.3rem 2rem;overflow-y:auto;
    opacity:0;visibility:hidden;pointer-events:none;transition:opacity .25s ease}
  .main-nav.open{opacity:1;visibility:visible;pointer-events:auto}
  .nav-close{display:grid;place-items:center;position:absolute;top:.9rem;right:1rem;width:40px;height:40px;border-radius:50%;border:none;background:var(--cream);color:var(--maroon);font-size:1.9rem;line-height:1;cursor:pointer;z-index:2}
  .nav-close:hover{background:var(--gold);color:#fff}
  .main-nav ul{flex-direction:column;align-items:stretch;gap:.2rem}
  .main-nav a{padding:.85rem 1rem;border-radius:10px}
  .main-nav a.active::after{display:none}
  .main-nav a.active{background:var(--cream)}
  .submenu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;padding-left:1rem;display:none}
  .has-sub.open .submenu{display:block}
  .btn-nav{display:inline-block;text-align:center;margin-top:.5rem}
  .nav-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.4);opacity:0;visibility:hidden;transition:all var(--t);z-index:1050}
  .nav-backdrop.show{opacity:1;visibility:visible}
}
@media(max-width:620px){
  .grid-3,.grid-4,.grid-2,.form-row{grid-template-columns:1fr}
  .footer-grid,.gallery-grid{grid-template-columns:1fr}
  .section{padding:3.2rem 0}
  .hero{padding:4rem 0 5rem}
  .desk{flex-direction:column;text-align:center;align-items:center}
  .form-card{padding:1.5rem}
}

/* ============ Advance Course (Academic) ============ */
.adv-course{
  position:relative;overflow:hidden;
  background:#fff;border:1px solid var(--line);border-radius:28px;
  padding:clamp(1.8rem,4vw,3.5rem);margin-bottom:2.5rem;
  box-shadow:var(--shadow);
}
.adv-course::before{content:'';position:absolute;width:360px;height:360px;background:rgba(201,162,39,.10);border-radius:50%;top:-150px;right:-110px;pointer-events:none}
.adv-course::after{content:'';position:absolute;width:240px;height:240px;background:rgba(123,17,19,.05);border-radius:50%;bottom:-110px;left:-90px;pointer-events:none}
.adv-course > *{position:relative;z-index:2}
.adv-tag{
  display:inline-block;background:var(--maroon);color:#fff;
  padding:.7rem 1.4rem;border-radius:50px;font-size:.82rem;font-weight:700;
  letter-spacing:1px;text-transform:uppercase;margin-bottom:1.4rem;
}
.adv-title{
  font-size:clamp(1.9rem,4.5vw,3rem);line-height:1.18;color:var(--maroon-dark);
  margin:0 0 1.4rem;max-width:900px;font-weight:800;
}
.adv-register{margin-bottom:1.8rem}
.adv-subtitle p{font-size:1.05rem;line-height:1.9;color:var(--muted);max-width:920px;margin:0 0 1rem}
.adv-features{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
  gap:1.5rem;margin:2rem 0;
}
.adv-feature{
  background:#fff;border:1px solid var(--line);border-radius:20px;
  padding:2rem 1.6rem;transition:.35s ease;position:relative;overflow:hidden;
}
.adv-feature::before{content:'';position:absolute;top:0;left:0;width:100%;height:5px;background:linear-gradient(90deg,var(--gold),var(--maroon))}
.adv-feature:hover{transform:translateY(-6px);border-color:var(--gold);box-shadow:var(--shadow-lg)}
.adv-feature-icon{
  width:62px;height:62px;border-radius:16px;background:var(--cream);color:var(--maroon);
  display:grid;place-items:center;font-size:1.5rem;margin-bottom:1.1rem;
}
.adv-feature h3{font-size:1.2rem;color:var(--ink);margin:0 0 .6rem;font-weight:700}
.adv-feature p{color:var(--muted);line-height:1.7;font-size:.95rem;margin:0}
.adv-quote{
  background:var(--maroon-dark);color:#f6ecdd;border:0;border-radius:22px;
  padding:2.2rem 2.4rem;font-size:1.25rem;line-height:1.8;font-style:italic;
  margin:2rem 0;position:relative;overflow:hidden;font-family:'Playfair Display',Georgia,serif;
}
.adv-quote::before{content:'\201C';position:absolute;top:-1.4rem;left:1rem;font-size:7rem;color:rgba(201,162,39,.22);font-family:Georgia,serif}
.adv-details{margin-top:.4rem}
@media(max-width:600px){
  .adv-register,.adv-details{display:flex;width:100%;justify-content:center}
  .adv-quote{font-size:1.05rem;padding:1.6rem}
}

/* Advance Course — compact home-page variant */
.adv-home-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-top:1.8rem}
.adv-home-feat{display:flex;gap:1rem;align-items:flex-start}
.adv-home-chip{flex:0 0 auto;width:54px;height:54px;border-radius:15px;display:grid;place-items:center;font-size:1.5rem;color:var(--gold);background:linear-gradient(135deg,var(--maroon),var(--maroon-light));box-shadow:0 6px 16px rgba(123,17,19,.22)}
.adv-home-feat > div{padding-top:.15rem}
.adv-home-feat b{color:var(--ink);display:block;font-size:1.02rem;margin-bottom:.15rem}
.adv-home-feat > div > span{color:var(--muted);font-size:.9rem;line-height:1.5;display:block}
