/* ══════════════════════════════════════════════════════════════════
   style.css  |  PESIMSR — Design system based on research.pes.edu
   ══════════════════════════════════════════════════════════════════ */

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

/* ── Design Tokens (research.pes.edu) ── */
:root {
  --blue-dark:         #00338d;
  --blue-mid:          #00377b;
  --orange:            #FF6C00;
  --orange-dark:       #e05c00;
  --tan:               #c9c9bc;
  --grey-bg:           #F0F0ED;

  --brand-navy:        #00377B;
  --brand-orange:      #FF6C00;
  --brand-blue-light:  #61B9F0;
  --brand-pale-blue:   #F2F8FD;
  --brand-soft-blue:   #E4F3FD;
  --primary-gradient:  linear-gradient(135deg,#00377B 0%,#0055B3 100%);
  --accent-gradient:   linear-gradient(135deg,#FF6C00 0%,#FF9240 100%);

  --bg-primary:        #ffffff;
  --bg-secondary:      #F0F0ED;
  --text-primary:      #0D1B2A;
  --text-secondary:    #2E4A6B;
  --text-tertiary:     #7B9BBF;
  --border-color:      #D3E4F2;

  --shadow-sm:  0 2px 8px  rgba(0,55,123,.06);
  --shadow-md:  0 8px 24px rgba(0,55,123,.10);
  --shadow-lg:  0 16px 48px rgba(0,55,123,.14);
  --shadow-xl:  0 24px 64px rgba(0,55,123,.18);

  --font-title: 'Merriweather', serif;
  --font-body:  'Noto Sans', sans-serif;
  --radius-sm:  10px;
  --radius-md:  16px;
  --radius-lg:  20px;
  --blur-amount: 20px;
  --transition: all .3s ease;
}

/* ── Reset ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:var(--font-body); color:var(--text-primary); background:var(--bg-secondary); overflow-x:clip; line-height:1.7; }
h1,h2,h3,h4,h5,h6 { font-family:var(--font-title); }
a { text-decoration:none; color:inherit; }
img { max-width:100%; display:block; }

/* ══════════════════════════════════════
   TOP BAR
══════════════════════════════════════ */
.top-bar {
  background: var(--brand-navy);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.top-bar-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: .42rem 2rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
/* Left label */
.top-bar-left-label {
  color: rgba(255,255,255,.8);
  font-family: var(--font-body);
  font-size: .76rem;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  text-decoration: none;
  transition: color .2s;
}
.top-bar-left-label:hover { color: #fff; }
/* Right group */
.top-bar-right {
  display: flex;
  align-items: center;
  gap: 1.1rem;
}
.top-bar-right .top-bar-link {
  color: rgba(255,255,255,.72);
  font-family: var(--font-body);
  font-size: .76rem;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: .28rem;
  text-decoration: none;
  transition: color .2s;
}
.top-bar-right .top-bar-link:hover { color: #fff; }
/* Apply Now pill */
.top-bar-apply-btn {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  background: var(--orange);
  color: #fff;
  font-family: var(--font-body);
  font-size: .76rem;
  font-weight: 700;
  padding: 6px 22px;
  border-radius: 50px;
  text-decoration: none;
  white-space: nowrap;
  transition: background .2s;
}
.top-bar-apply-btn:hover { background: #e05a00; color: #fff; }
.nav-apply-btn {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  background: var(--orange);
  color: #fff;
  font-family: var(--font-body);
  font-size: .82rem;
  font-weight: 700;
  padding: .52rem 1.15rem;
  border-radius: 8px;
  text-decoration: none;
  white-space: nowrap;
  margin-left: .6rem;
  flex-shrink: 0;
  transition: background .2s, transform .15s;
}
.nav-apply-btn:hover { background: var(--orange-dark); color: #fff; transform: translateY(-1px); }

/* ══════════════════════════════════════
   MAIN HEADER
══════════════════════════════════════ */
.main-header {
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(var(--blur-amount));
  -webkit-backdrop-filter: blur(var(--blur-amount));
  border-bottom: 1px solid var(--border-color);
  box-shadow: var(--shadow-sm);
  position: sticky;
  top: 0;
  z-index: 1000;
  overflow: visible;
  transition: box-shadow .3s;
}
.main-header.scrolled { box-shadow: var(--shadow-md); }
.header-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 80px;
}
.logo { display: flex; align-items: center; gap: 12px; }
.logo img { height: 40px; width: auto; transition: transform .3s; }
.logo img:hover { transform: scale(1.03); }

/* ── Nav ── */
.main-nav { display: flex; align-items: center; }
.main-nav > ul { display: flex; list-style: none; position: static; gap: .2rem; }
.main-nav > ul > li { position: relative; }
.main-nav > ul > li > a {
  display: block;
  padding: .65rem .75rem;
  font-family: var(--font-body);
  font-size: .85rem;
  font-weight: 600;
  color: var(--text-secondary);
  border-radius: var(--radius-sm);
  transition: var(--transition);
  white-space: nowrap;
  letter-spacing: .02em;
  position: relative;
}
.main-nav > ul > li > a::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--primary-gradient);
  border-radius: var(--radius-sm);
  opacity: 0;
  transition: opacity .3s;
}
.main-nav > ul > li > a span { position: relative; z-index: 2; }
.main-nav > ul > li:hover > a,
.main-nav > ul > li > a.active { color: #fff; }
.main-nav > ul > li:hover > a::before,
.main-nav > ul > li > a.active::before { opacity: 1; }

/* ── Mega Menu ── */
.main-nav > ul > li > .mega-menu {
  position: fixed;
  margin-top: -47px;
  left: 0;
  width: 100%;
  background: #fff;
  border-bottom: 3px solid #c2bdb6;
  box-shadow: 0 10px 40px rgba(0,55,123,.13);
  z-index: 9999;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-8px);
  transition: opacity .22s ease, transform .22s ease, visibility .22s;
}
.main-nav > ul > li.mega-open > .mega-menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
}

.mega-menu-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 28px 2rem 32px;
}

.mega-label {
  font-family: var(--font-body);
  font-size: .65rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  color: #8fa3bc;
  padding-bottom: 10px; margin-bottom: 18px;
  border-bottom: 1px solid #e4dfd9;
}

.mega-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px 12px;
}

.mega-item {
  display: flex; align-items: center; gap: 13px;
  padding: 12px 14px; border-radius: 10px;
  text-decoration: none;
  transition: background .15s;
}
.mega-item:hover { background: #f0f6ff; }

.mega-icon {
  width: 42px; height: 42px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; font-size: 18px;
}

.mega-item-name {
  font-family: var(--font-body);
  font-size: .9rem; font-weight: 600;
  color: var(--brand-navy); line-height: 1.3;
}

.mega-item-desc {
  font-family: var(--font-body);
  font-size: .74rem; color: #7a90a8;
  line-height: 1.4; margin-top: 2px;
}

/* ══════════════════════════════════════
   HOME HERO
══════════════════════════════════════ */
.home-hero {
  background: #002766;
  position: relative; overflow: hidden;
  border-bottom: 3px solid var(--orange);
}
.hh-bg-slide {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  opacity: 0; z-index: 0;
  animation: hhFade 20s infinite;
}
.hh-bg-slide:nth-child(1) { animation-delay: 0s; }
.hh-bg-slide:nth-child(2) { animation-delay: 5s; }
.hh-bg-slide:nth-child(3) { animation-delay: 10s; }
.hh-bg-slide:nth-child(4) { animation-delay: 15s; }
.hh-bg-overlay {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(135deg, rgba(0,39,102,.62) 0%, rgba(0,55,123,.55) 50%, rgba(0,85,179,.48) 100%);
}
.home-hero-inner {
  max-width: 1400px; margin: 0 auto;
  padding: 84px 2rem 64px;
  display: flex; align-items: center; justify-content: space-between; gap: 2rem;
  position: relative; z-index: 2;
}
.home-hero-text { flex: 1; min-width: 0; max-width: 640px; }
.home-hero-chip {
  display: inline-flex; align-items: center; gap: .45rem;
  background: rgba(0,0,0,.28); border: 1px solid rgba(255,255,255,.22);
  color: rgba(255,255,255,.88); font-size: .78rem; font-weight: 600;
  padding: .35rem .95rem; border-radius: 30px; margin-bottom: 20px;
  font-family: var(--font-body); letter-spacing: .04em;
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
}
.home-hero-h1 {
  font-family: var(--font-title);
  font-size: clamp(2.2rem, 4.8vw, 3.6rem);
  font-weight: 700; color: #fff; line-height: 1.1; margin-bottom: 18px;
}
.home-hero-h1 em { font-style: normal; color: var(--orange); }
.home-hero-sub {
  font-family: var(--font-body); font-size: 1rem;
  color: rgba(255,255,255,.72); line-height: 1.75;
  margin-bottom: 18px; max-width: 530px;
}
.home-hero-accent { width: 54px; height: 4px; background: var(--orange); border-radius: 3px; margin-bottom: 32px; }
.home-hero-btns { display: flex; gap: 14px; flex-wrap: wrap; }
.home-hero-btn-primary {
  display: inline-flex; align-items: center; gap: .45rem;
  background: var(--orange); color: #fff;
  font-family: var(--font-body); font-size: .9rem; font-weight: 700;
  padding: .78rem 1.8rem; border-radius: 8px; text-decoration: none;
  transition: background .2s, transform .15s;
}
.home-hero-btn-primary:hover { background: #d96b00; color: #fff; transform: translateY(-2px); }
.home-hero-btn-secondary {
  display: inline-flex; align-items: center; gap: .45rem;
  background: rgba(255,255,255,.10); border: 1.5px solid rgba(255,255,255,.38);
  color: #fff; font-family: var(--font-body); font-size: .9rem; font-weight: 600;
  padding: .78rem 1.8rem; border-radius: 8px; text-decoration: none;
  transition: background .2s, transform .15s; backdrop-filter: blur(4px);
}
.home-hero-btn-secondary:hover { background: rgba(255,255,255,.2); color: #fff; transform: translateY(-2px); }

/* Hero image slideshow */
.home-hero-imgbox {
  position: relative;
  width: 460px; height: 320px;
  border-radius: 16px; overflow: hidden; flex-shrink: 0;
  box-shadow: 0 12px 48px rgba(0,0,0,.4), 0 0 0 3px rgba(255,255,255,.12);
}
.hh-slide {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  opacity: 0;
  animation: hhFade 20s infinite;
}
.hh-slide:nth-child(1) { animation-delay: 0s; }
.hh-slide:nth-child(2) { animation-delay: 5s; }
.hh-slide:nth-child(3) { animation-delay: 10s; }
.hh-slide:nth-child(4) { animation-delay: 15s; }
@keyframes hhFade {
  0%   { opacity: 0; }
  5%   { opacity: 1; }
  22%  { opacity: 1; }
  27%  { opacity: 0; }
  100% { opacity: 0; }
}
.hh-overlay {
  position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(to top, rgba(0,30,80,.45) 0%, transparent 55%);
}
.hh-dots {
  position: absolute; bottom: 14px; left: 50%; transform: translateX(-50%);
  display: flex; gap: 6px; z-index: 2;
}
.hh-dot {
  height: 6px; border-radius: 3px; background: rgba(255,255,255,.4);
  animation: hhDot 20s infinite;
}
.hh-dot:nth-child(1) { animation-delay: 0s; }
.hh-dot:nth-child(2) { animation-delay: 5s; }
.hh-dot:nth-child(3) { animation-delay: 10s; }
.hh-dot:nth-child(4) { animation-delay: 15s; }
@keyframes hhDot {
  0%   { width: 6px;  background: rgba(255,255,255,.4); }
  5%   { width: 20px; background: #fff; }
  22%  { width: 20px; background: #fff; }
  27%  { width: 6px;  background: rgba(255,255,255,.4); }
  100% { width: 6px;  background: rgba(255,255,255,.4); }
}

/* Stats bar */
.home-hero-stats { background: rgba(0,0,0,.22); border-top: 1px solid rgba(255,255,255,.1); position: relative; z-index: 2; }
.home-hero-stats-inner {
  max-width: 1400px; margin: 0 auto; padding: 0 2rem;
  display: flex; align-items: stretch;
}
.home-hero-stat {
  flex: 1; padding: 22px 16px; border-right: 1px solid rgba(255,255,255,.1);
  text-align: center;
}
.home-hero-stat:last-child { border-right: none; }
.home-hero-stat-num { font-family: var(--font-title); font-size: 2rem; font-weight: 700; color: #fff; line-height: 1; margin-bottom: 5px; }
.home-hero-stat-num sup { font-size: 1.1rem; color: var(--orange); }
.home-hero-stat-label { font-family: var(--font-body); font-size: .68rem; font-weight: 700; color: rgba(255,255,255,.58); letter-spacing: .1em; text-transform: uppercase; }

/* ══════════════════════════════════════
   HERO SLIDER (kept for reference)
══════════════════════════════════════ */
.hero-slider { position:relative; overflow:hidden; height:520px; }
.slide { position:absolute; inset:0; overflow:hidden; }
.slider-nav { position:absolute; right:20px; top:50%; transform:translateY(-50%); z-index:100; display:flex; flex-direction:column; gap:8px; }
.slider-dot { width:5px; height:30px; background:rgba(255,255,255,.4); border-radius:3px; cursor:pointer; transition:background .3s,height .3s; }
.slider-dot.active { background:#fff; height:50px; }

@keyframes s1TextDrop { 0%{transform:translateY(-80px);opacity:0;} 100%{transform:translateY(0);opacity:1;} }
@keyframes s1TextRise { 0%{transform:translateY(0);opacity:1;} 100%{transform:translateY(-80px);opacity:0;} }
@keyframes panRightLeft { 0%{transform:translateX(6%) scale(1.05);} 100%{transform:translateX(-3%) scale(1.05);} }
@keyframes exitLeft { 0%{transform:translateX(0);opacity:1;} 100%{transform:translateX(-80px);opacity:0;} }
@keyframes enterFromRight { 0%{transform:translateY(-52%) translateX(120px);opacity:0;} 100%{transform:translateY(-52%) translateX(0);opacity:1;} }
@keyframes exitToLeft { 0%{transform:translateY(-52%) translateX(0);opacity:1;} 100%{transform:translateY(-52%) translateX(-120px);opacity:0;} }
@keyframes riseFromBottom { 0%{transform:translateX(-50%) translateY(120px);opacity:0;} 100%{transform:translateX(-50%) translateY(0);opacity:1;} }
@keyframes fallToBottom { 0%{transform:translateX(-50%) translateY(0);opacity:1;} 100%{transform:translateX(-50%) translateY(120px);opacity:0;} }
@keyframes popUp { 0%{transform:scale(.85);opacity:0;} 60%{transform:scale(1.03);opacity:1;} 100%{transform:scale(1);opacity:1;} }
@keyframes bgZoomIn { 0%{transform:scale(1.12);opacity:0;} 100%{transform:scale(1);opacity:1;} }
@keyframes popOut { 0%{transform:scale(1);opacity:1;} 100%{transform:scale(.88);opacity:0;} }
@keyframes dropFromTop { 0%{transform:translateY(calc(-50% - 80px));opacity:0;} 100%{transform:translateY(-50%);opacity:1;} }
@keyframes riseToTop { 0%{transform:translateY(-50%);opacity:1;} 100%{transform:translateY(calc(-50% - 80px));opacity:0;} }
@keyframes riseUp { 0%{transform:translateY(calc(-50% + 80px));opacity:0;} 100%{transform:translateY(-50%);opacity:1;} }
@keyframes fallDown { 0%{transform:translateY(-50%);opacity:1;} 100%{transform:translateY(calc(-50% + 80px));opacity:0;} }
@keyframes popUpLeft { 0%{transform:translateY(-50%) scale(.82);opacity:0;} 60%{transform:translateY(-50%) scale(1.03);opacity:1;} 100%{transform:translateY(-50%) scale(1);opacity:1;} }
@keyframes btnPop { 0%{transform:translateX(-50%) scale(.7);opacity:0;} 70%{transform:translateX(-50%) scale(1.06);opacity:1;} 100%{transform:translateX(-50%) scale(1);opacity:1;} }

/* Slide 1 */
.slide-1 { background:linear-gradient(135deg,#0a1f5c 0%,#1a3a8a 50%,#0d2d6b 100%); }
.s1-bg { position:absolute; inset:0; background:url('https://pes.edu/wp-content/uploads/revslider/slider-1/PESSAT2024Bannerbg1.jpg') center/cover no-repeat; opacity:0; transform-origin:center; }
.s1-text { position:absolute; top:8%; left:0; right:0; z-index:3; text-align:center; opacity:0; transform:translateY(-80px); }
.s1-headline { font-family:var(--font-title); font-size:clamp(58px,6.5vw,94px); font-weight:900; color:var(--orange); line-height:.94; letter-spacing:-1px; text-shadow:0 2px 20px rgba(0,0,0,.3); }
.s1-student { position:absolute; bottom:0; left:50%; transform:translateX(-50%) translateY(120px); height:92%; width:auto; object-fit:contain; z-index:4; opacity:0; }
.s1-btn { display:inline-flex; align-items:center; gap:10px; background:var(--orange); color:#fff; font-family:var(--font-title); font-size:15px; font-weight:700; padding:14px 44px; border-radius:var(--radius-sm); position:absolute; bottom:12%; left:50%; transform:translateX(-50%) scale(.7); white-space:nowrap; z-index:5; opacity:0; letter-spacing:1px; transition:background .2s; }
.s1-btn:hover { background:#e05a00; color:#fff; }
.slide-1.active .s1-bg      { animation:panRightLeft 8s ease-out forwards; opacity:1; }
.slide-1.active .s1-text    { animation:s1TextDrop .75s .2s cubic-bezier(.22,1,.36,1) forwards; }
.slide-1.active .s1-student { animation:riseFromBottom .85s .5s cubic-bezier(.22,1,.36,1) forwards; }
.slide-1.active .s1-btn     { animation:btnPop .6s .9s cubic-bezier(.22,1,.36,1) forwards; }
.slide-1.exiting .s1-text    { animation:s1TextRise .45s ease-in forwards; }
.slide-1.exiting .s1-student { animation:fallToBottom .5s .08s ease-in forwards; }
.slide-1.exiting .s1-btn     { animation:popOut .4s ease-in forwards; }
.slide-1.exiting .s1-bg      { animation:exitLeft .55s ease-in forwards; }

/* Slide 2 */
.s2-bg { position:absolute; inset:0; background:url('https://pes.edu/wp-content/uploads/revslider/slider-1/mdes-slider.jpg') center/cover no-repeat; transform:scale(1.1); opacity:0; }
.s2-overlay { position:absolute; inset:0; background:rgba(0,0,0,.2); z-index:1; opacity:0; }
.s2-content { position:absolute; top:33%; left:5%; z-index:2; text-align:left; max-width:500px; transform:scale(.85); opacity:0; }
.s2-tag { font-family:var(--font-body); font-size:13px; font-weight:700; color:rgba(255,255,255,.9); letter-spacing:5px; text-transform:uppercase; margin-bottom:10px; display:block; }
.s2-title { font-family:var(--font-title); font-size:clamp(24px,3vw,36px); font-weight:900; color:#fff; line-height:1.15; margin-bottom:14px; }
.s2-sub { font-family:var(--font-body); font-size:15px; font-style:italic; color:#fff; background:var(--orange); padding:10px 16px; display:block; margin-bottom:20px; line-height:1.55; max-width:380px; }
.s2-btn { display:inline-flex; align-items:center; gap:8px; color:#fff; font-family:var(--font-body); font-size:13px; font-weight:700; letter-spacing:2px; text-transform:uppercase; padding:6px 12px; border:2px solid rgba(255,255,255,.7); transition:background .2s,color .2s; }
.s2-btn:hover { background:var(--orange); border-color:var(--orange); color:#fff; }
.slide-2.active .s2-bg      { animation:bgZoomIn .9s 0s cubic-bezier(.22,1,.36,1) forwards; }
.slide-2.active .s2-overlay { animation:popUp .5s .2s ease forwards; }
.slide-2.active .s2-content { animation:popUp .75s .3s cubic-bezier(.22,1,.36,1) forwards; }
.slide-2.exiting .s2-content { animation:popOut .45s ease-in forwards; }
.slide-2.exiting .s2-bg      { animation:popOut .5s .05s ease-in forwards; }

/* Slide 3 */
.s3-bg { position:absolute; inset:0; background:url('https://pes.edu/wp-content/uploads/revslider/slider-1/PESSAT2024Bannerbg1.jpg') center/cover no-repeat; transform:translateX(6%) scale(1.04); opacity:0; }
.s3-overlay { position:absolute; inset:0; background:rgba(0,25,80,.58); z-index:1; opacity:0; }
.s3-badge { position:absolute; left:26%; top:50%; transform:translateY(calc(-50% + 80px)); width:230px; height:auto; z-index:3; opacity:0; }
.s3-text { position:absolute; top:50%; left:48%; transform:translateY(calc(-50% - 80px)); z-index:3; opacity:0; max-width:480px; }
.s3-headline { font-family:var(--font-title); font-size:clamp(32px,4vw,54px); font-weight:900; color:#fff; line-height:1.1; text-transform:uppercase; }
.s3-headline span { color:var(--orange); }
.slide-3.active .s3-bg      { animation:panRightLeft 8s ease-out forwards; opacity:1; }
.slide-3.active .s3-overlay { animation:popUp .4s .1s ease forwards; }
.slide-3.active .s3-text    { animation:dropFromTop .7s .3s cubic-bezier(.22,1,.36,1) forwards; }
.slide-3.active .s3-badge   { animation:riseUp .8s .5s cubic-bezier(.22,1,.36,1) forwards; }
.slide-3.exiting .s3-text  { animation:riseToTop .5s ease-in forwards; }
.slide-3.exiting .s3-badge { animation:fallDown .5s .08s ease-in forwards; }
.slide-3.exiting .s3-bg    { animation:exitLeft .55s ease-in forwards; }

/* ── Unified Slide Caption ── */
.slide-caption { position:absolute; bottom:15%; left:8%; max-width:600px; opacity:0; z-index:5; }
.slide-headline { display:block; font-family:var(--font-title); font-size:clamp(22px,3vw,44px); font-weight:700; color:#fff; background:#002060; padding:8px 16px; line-height:1.4; margin:0 0 8px; width:fit-content; }
.slide-subtitle { display:block; font-family:var(--font-body); font-size:clamp(13px,1.5vw,18px); font-weight:400; color:#fff; background:var(--orange); padding:8px 16px; line-height:1.5; width:fit-content; margin:0; }
@keyframes captionEnter { 0%{transform:translateY(30px);opacity:0;} 100%{transform:translateY(0);opacity:1;} }
@keyframes captionExit  { 0%{transform:translateY(0);opacity:1;} 100%{transform:translateY(-20px);opacity:0;} }
.slide.active  .slide-caption { animation:captionEnter .7s .3s cubic-bezier(.22,1,.36,1) forwards; }
.slide.exiting .slide-caption { animation:captionExit .4s ease-in forwards; }

/* ══════════════════════════════════════
   INFO CARDS
══════════════════════════════════════ */
.info-cards-section { padding: 56px 0 48px; background: var(--bg-secondary); }
.info-cards-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.info-card {
  background: #fff; border: 1px solid #a8d4f5;
  border-radius: 14px; padding: 30px 28px 32px;
  box-shadow: 0 2px 12px rgba(0,55,123,.07);
  transition: transform .2s, box-shadow .2s;
  display: flex; flex-direction: column;
}
.info-card:hover { transform: translateY(-4px); box-shadow: 0 8px 28px rgba(0,55,123,.13); }
.info-card-icon {
  width: 50px; height: 50px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; color: #fff; margin-bottom: 18px; flex-shrink: 0;
}
.info-card-title {
  font-family: var(--font-title); font-size: 1.1rem; font-weight: 700;
  color: var(--brand-navy); margin-bottom: 10px;
}
.info-card-text {
  font-family: var(--font-body); font-size: .9rem;
  color: #4a5568; line-height: 1.75; margin-bottom: 18px; flex: 1;
}
.info-card-links { display: flex; flex-direction: column; gap: 6px; margin-top: auto; border-top: 1px solid #e4eaf3; padding-top: 14px; }
.info-card-links a {
  display: flex; align-items: center; gap: 4px;
  font-family: var(--font-body); font-size: .875rem; font-weight: 600;
  color: var(--brand-navy); text-decoration: none;
  transition: color .15s, gap .15s;
}
.info-card-links a i { font-size: 1.1rem; color: var(--orange); }
.info-card-links a:hover { color: var(--orange); gap: 8px; }

/* ══════════════════════════════════════
   VIDEO SECTION
══════════════════════════════════════ */
.video-section { padding:70px 0; background:var(--bg-primary); }
.video-wrap { position:relative; padding-bottom:56.25%; height:0; overflow:hidden; border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); }
.video-wrap iframe { position:absolute; top:0; left:0; width:100%; height:100%; border-radius:var(--radius-lg); }

/* ══════════════════════════════════════
   ABOUT + ANNOUNCEMENTS
══════════════════════════════════════ */
.about-announce-section {
  background: linear-gradient(to right, #eef4fb 60%, var(--brand-navy) 60%);
}
.about-announce-section .container { max-width: 1400px; padding: 0; }
.about-announce-grid { display:grid; grid-template-columns:3fr 2fr; min-height:460px; }
.about-panel { background: transparent; display:flex; align-items:center; }
.about-panel-inner { padding: 60px 2rem; width: 100%; box-sizing: border-box; }
.about-label { font-family:var(--font-body); font-size:11px; font-weight:700; letter-spacing:3px; color:var(--orange); text-transform:uppercase; display:block; margin-bottom:12px; }
.about-heading { font-family:var(--font-title); font-size:30px; font-weight:700; color:var(--brand-navy); margin:0 0 16px; }
.about-accent { width:50px; height:4px; background:var(--accent-gradient); border-radius:2px; margin-bottom:24px; }
.about-text { font-family:var(--font-body); font-size:15px; color:var(--text-secondary); line-height:1.9; margin-bottom:28px; }
.about-readmore { display:inline-flex; align-items:center; gap:10px; font-family:var(--font-body); font-size:14px; font-weight:700; color:var(--brand-navy); border-bottom:2px solid var(--brand-navy); padding-bottom:3px; transition:color .2s,border-color .2s; }
.about-readmore:hover { color:var(--orange); border-color:var(--orange); }
.announce-panel { background: transparent; display:flex; align-items:center; padding: 60px 4rem; }
.announce-panel-inner { padding:60px 2rem; width:100%; box-sizing:border-box; text-align:center; }
.announce-heading { font-family:var(--font-title); font-size:20px; font-weight:700; color:#fff; margin:0 0 30px; display:flex; align-items:center; justify-content:center; gap:12px; }
.announce-heading i { color:var(--orange); font-size:18px; }
.announce-list { list-style:none; padding:0; margin:0; }
.announce-list li { border-bottom:1px solid rgba(255,255,255,.1); }
.announce-list li:last-child { border-bottom:none; }
.announce-list li a { display:block; font-family:var(--font-body); font-size:13px; font-weight:600; color:var(--orange); padding:15px 0; letter-spacing:.5px; text-transform:uppercase; transition:color .2s; text-align:center; }
.announce-list li a:hover { color:#fff; }

/* ══════════════════════════════════════
   CTA BANNER
══════════════════════════════════════ */
.cta-banner { display:flex; }
.cta-left { flex:1; background:var(--orange); display:flex; align-items:center; justify-content:center; padding:30px 50px; }
.cta-left span { font-family:var(--font-title); font-size:18px; font-weight:700; color:#fff; text-align:center; letter-spacing:1px; }
.cta-right { flex:0 0 320px; background:var(--brand-navy); display:flex; align-items:center; justify-content:center; padding:30px 40px; }
.cta-apply { display:flex; align-items:center; gap:14px; font-family:var(--font-title); font-size:20px; font-weight:700; color:#fff; transition:opacity .2s; }
.cta-apply:hover { opacity:.8; }
.cta-logo { width:40px; height:40px; border-radius:50%; background:#fff; padding:2px; }

/* ══════════════════════════════════════
   COMMON
══════════════════════════════════════ */
.section { padding:70px 0; }
.container { max-width:1400px; margin:0 auto; padding:0 2rem; }
.section-title { font-size:2rem; font-weight:700; color:var(--brand-navy); font-family:var(--font-title); margin-bottom:6px; }
.section-subtitle { font-size:1.3rem; font-weight:300; color:var(--text-secondary); font-family:var(--font-title); margin-bottom:0; }

/* ══════════════════════════════════════
   CAMPUSES — 3-D AUTO CAROUSEL
══════════════════════════════════════ */

/* Stage: regular section, no sticky magic */
.campuses-section { background: transparent; }
.campuses-stage {
  background: linear-gradient(160deg, #0d1a2e 0%, #080f1c 100%);
  padding: 56px 0 52px;
  position: relative; overflow: hidden;
}
.campuses-stage::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 90% 55% at 50% -10%, rgba(0,55,123,.32) 0%, transparent 68%);
  pointer-events: none; z-index: 0;
}

/* Header text */
.campuses-section .section-eyebrow  { color: rgba(255,255,255,.48); }
.campuses-section .section-title    { color: #fff; }
.campuses-section .section-subtitle { color: rgba(255,255,255,.4); }

.campuses-header {
  margin-bottom: 40px;
  display: flex; align-items: flex-end; justify-content: space-between;
  position: relative; z-index: 2;
}

/* ── Arrow buttons ── */
.campus-track-wrap { position: relative; }
.campus-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  z-index: 10; width: 42px; height: 42px; border-radius: 50%;
  background: rgba(255,255,255,.15); backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.22); color: #fff;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  font-size: 1rem; transition: background .2s, border-color .2s;
}
.campus-nav:hover { background: var(--orange); border-color: var(--orange); }
.campus-prev { left: .75rem; }
.campus-next { right: .75rem; }

/* Horizontal scroll row */
.campus-h-track {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding: 0 4rem 4px;
  scroll-padding-left: 4rem;
  position: relative; z-index: 1;
  scrollbar-width: none;
}
.campus-h-track::-webkit-scrollbar { display: none; }

/* ── Card shell — 4 visible at once ── */
.campus-card {
  flex: 0 0 calc((100% - 48px) / 4);
  aspect-ratio: 1 / 1;
  border-radius: 14px; overflow: hidden;
  position: relative; cursor: pointer;
  scroll-snap-align: start;
  scroll-snap-stop: always;
  box-shadow: 0 8px 28px rgba(0,0,0,.5);
  transition: transform .25s, box-shadow .25s;
}
.campus-card:hover { box-shadow: 0 18px 48px rgba(0,0,0,.65); transform: translateY(-3px); }

/* ── Full-bleed image ── */
.campus-card > a { display: block; position: absolute; inset: 0; text-decoration: none; color: #fff; }
.campus-card-bg  { position: absolute; inset: 0; overflow: hidden; }
.campus-card-bg img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .6s ease; display: block;
}
.campus-card:hover .campus-card-bg img { transform: scale(1.07); }

/* ── Gradient overlay ── */
.campus-card-body {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,6,20,.97) 0%, rgba(0,6,20,.5) 42%, transparent 68%);
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 16px;
  transition: background .35s ease;
}
.campus-card:hover .campus-card-body {
  background: linear-gradient(to top, rgba(0,6,20,.99) 0%, rgba(0,6,20,.8) 55%, rgba(0,6,20,.22) 100%);
}

/* ── City badge ── */
.campus-card-tag {
  position: absolute; top: 10px; left: 10px;
  display: inline-flex; align-items: center; gap: 4px;
  background: rgba(255,255,255,.1);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,.18);
  color: rgba(255,255,255,.88);
  font-family: var(--font-body); font-size: .55rem; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
  padding: .2rem .6rem; border-radius: 20px; z-index: 3;
}
.campus-card-tag.tag--here { background: rgba(255,108,0,.78); border-color: var(--orange); color: #fff; }

/* ── Card info text ── */
.campus-card-info { min-width: 0; }
.campus-card-info h3 {
  font-family: var(--font-title); font-size: .95rem; font-weight: 700;
  color: #fff; margin-bottom: 3px; line-height: 1.3;
}
.campus-card-info p {
  font-family: var(--font-body); font-size: .63rem;
  color: rgba(255,255,255,.5);
  display: flex; align-items: center; gap: 3px;
  margin: 0;
}
.campus-card-info p i { font-size: .6rem; color: var(--orange); }

/* ── Visit link ── */
.campus-card-visit {
  display: inline-flex; align-items: center; gap: 5px;
  color: var(--orange); font-family: var(--font-body);
  font-size: .7rem; font-weight: 700; margin-top: 8px;
  transition: gap .2s ease;
}
.campus-card:hover .campus-card-visit { gap: 8px; }

/* ── Mobile — 1 card ── */
@media (max-width: 767px) {
  .campuses-stage { padding: 36px 0 44px; }
  .campus-h-track { gap: 12px; padding: 0 3rem 4px; scroll-padding-left: 3rem; }
  .campus-card    { flex: 0 0 85%; aspect-ratio: 1 / 1; }
  .campus-nav     { width: 34px; height: 34px; font-size: .85rem; }
  .campus-prev    { left: .4rem; }
  .campus-next    { right: .4rem; }
}

/* ══════════════════════════════════════
   ACADEMICS / PROMO CARDS
══════════════════════════════════════ */
.academics-section { background:var(--bg-secondary); padding:70px 0; position:relative; }
.academics-bg { position:absolute; inset:0; background-size:cover; background-position:center; opacity:.15; }
.academics-inner { position:relative; z-index:1; }
.academics-intro { margin-bottom:40px; }
.subtext { font-size:1.2rem; color:var(--brand-navy); font-family:var(--font-title); line-height:1.9; max-width:300px; }
.promo-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:30px; margin-bottom:50px; align-items:stretch; height:600px; }
.promo-card { background:var(--bg-primary); border:2px solid var(--border-color); border-radius:var(--radius-lg); box-shadow:var(--shadow-sm); overflow:hidden; display:flex; flex-direction:column; position:relative; transition:var(--transition); }
.promo-card::before { content:''; position:absolute; top:0; left:0; right:0; height:4px; background:var(--primary-gradient); transform:scaleX(0); transform-origin:left; transition:transform .4s; }
.promo-card:hover { box-shadow:var(--shadow-md); transform:translateY(-4px); }
.promo-card:hover::before { transform:scaleX(1); }
.promo-card img { width:100%; object-fit:cover; flex-shrink:0; }
.promo-card-body { padding:24px 24px 0; display:flex; flex-direction:column; flex:1; }
.promo-card-body h3 { font-size:18px; color:var(--brand-navy); font-family:var(--font-title); font-weight:700; margin-bottom:10px; }
.promo-card-body p { font-size:15px; color:var(--text-secondary); font-family:var(--font-body); line-height:1.8; flex:1; }
.promo-card-body .arrow-link { display:inline-block; color:var(--brand-navy); font-size:17px; margin-top:12px; transition:transform .2s; padding-bottom:24px; }
.promo-card-body .arrow-link:hover { transform:translateX(6px); color:var(--orange); }

/* FACULTY */
.faculty-title { font-size:2rem; font-weight:700; color:var(--brand-navy); font-family:var(--font-title); margin-bottom:24px; }
.faculty-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:30px; margin-bottom:40px; align-items:stretch; }
.faculty-card { border-radius:var(--radius-lg); overflow:hidden; display:flex; flex-direction:column; border:2px solid var(--border-color); box-shadow:var(--shadow-sm); transition:var(--transition); }
.faculty-card:hover { box-shadow:var(--shadow-md); transform:translateY(-4px); }
.faculty-photo-wrap { position:relative; overflow:hidden; height:260px; flex-shrink:0; }
.faculty-photo-wrap img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .3s ease; }
.faculty-card:hover .faculty-photo-wrap img { transform:scale(1.03); }
.faculty-play-icon { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:60px; height:60px; background:rgba(255,255,255,.88); border-radius:50%; display:flex; align-items:center; justify-content:center; pointer-events:none; transition:background .2s,transform .2s; }
.faculty-card:hover .faculty-play-icon { background:rgba(255,108,0,.92); transform:translate(-50%,-50%) scale(1.1); }
.faculty-play-icon i { color:var(--brand-navy); font-size:22px; margin-left:4px; }
.faculty-card:hover .faculty-play-icon i { color:#fff; }
.faculty-card-body { background:var(--brand-navy); padding:22px 22px 16px; box-shadow:none; display:flex; flex-direction:column; flex:1; }
.faculty-card-body h3 { font-size:17px; color:#fff; font-family:var(--font-title); font-weight:700; margin-bottom:8px; }
.faculty-card-body p { font-size:13px; color:rgba(255,255,255,.9); font-family:var(--font-body); line-height:1.7; flex:1; }
.faculty-card-body .arrow-link { display:inline-block; color:#fff; font-size:17px; margin-top:12px; transition:transform .2s; }
.faculty-card-body .arrow-link:hover { transform:translateX(6px); color:var(--orange); }

/* RANKINGS */
.rankings-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.ranking-card { background:var(--bg-primary); border:2px solid var(--border-color); border-radius:var(--radius-md); padding:24px 16px; text-align:center; box-shadow:var(--shadow-sm); transition:var(--transition); }
.ranking-card:hover { box-shadow:var(--shadow-md); transform:translateY(-4px); }
.ranking-card img { width:60px; margin:0 auto 16px; }
.ranking-card h5 { font-size:16px; color:var(--brand-navy); font-family:var(--font-title); font-weight:700; margin-bottom:8px; }
.ranking-card p { font-size:13px; color:var(--text-secondary); font-family:var(--font-body); line-height:1.7; }

/* ══════════════════════════════════════
   PLACEMENTS
══════════════════════════════════════ */
.placements-section { position:relative; overflow:hidden; min-height:600px; background-size:cover; background-position:center; }
.placements-inner { display:grid; grid-template-columns:1fr 1fr; min-height:600px; }
.placements-left { position:relative; display:flex; align-items:flex-end; padding:40px 100px 60px; }
.placements-left-bg { position:absolute; inset:0; background-size:cover; background-position:center; }
.placements-card { position:relative; z-index:2; background:var(--bg-primary); border-top:4px solid var(--orange); border-radius:var(--radius-md); padding:28px; max-width:340px; box-shadow:var(--shadow-lg); }
.placements-card h1 { font-size:24px; color:var(--brand-navy); font-family:var(--font-title); font-weight:700; margin-bottom:10px; }
.placements-card p { font-size:14px; color:var(--text-secondary); font-family:var(--font-body); line-height:1.7; }
.placements-right { padding:100px 120px 80px 80px; display:flex; flex-direction:column; }
.placements-right-title { font-size:2rem; font-weight:700; color:var(--brand-navy); font-family:var(--font-title); margin-bottom:6px; }
.placements-right-sub { font-size:1.3rem; font-weight:300; color:var(--text-secondary); font-family:var(--font-title); margin-bottom:40px; }
.placements-logos { max-width:100%; }

/* ══════════════════════════════════════
   RESEARCH
══════════════════════════════════════ */
.research-section { padding:70px 0; background:var(--bg-primary); position:relative; }
.research-bg { position:absolute; inset:0; background-size:cover; background-position:center; opacity:.1; }
.research-inner { position:relative; z-index:1; }
.research-intro { margin-bottom:40px; }
.research-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:30px; align-items:stretch; }
.research-card { border-radius:var(--radius-lg); border:2px solid var(--border-color); background:var(--bg-primary); box-shadow:var(--shadow-sm); overflow:hidden; display:flex; flex-direction:column; position:relative; transition:var(--transition); }
.research-card::before { content:''; position:absolute; top:0; left:0; right:0; height:4px; background:var(--accent-gradient); transform:scaleX(0); transform-origin:left; transition:transform .4s; }
.research-card:hover { box-shadow:var(--shadow-md); transform:translateY(-4px); }
.research-card:hover::before { transform:scaleX(1); }
.research-card img { width:100%; object-fit:cover; flex-shrink:0; }
.research-card-body { padding:24px 20px 24px; display:flex; flex-direction:column; flex:1; }
.research-card-body p { font-size:15px; color:var(--text-secondary); font-family:var(--font-body); line-height:1.8; flex:1; }
.research-card-body .arrow-link { display:inline-block; color:var(--brand-navy); font-size:17px; margin-top:12px; transition:transform .2s,color .2s; }
.research-card-body .arrow-link:hover { transform:translateX(6px); color:var(--orange); }

/* ══════════════════════════════════════
   CAMPUS LIFE (legacy)
══════════════════════════════════════ */
.campus-life-section { padding:70px 0; background:var(--bg-primary); position:relative; }
.campus-life-bg { position:absolute; inset:0; background-size:cover; background-position:center; opacity:.1; }
.campus-life-inner { position:relative; z-index:1; }
.campus-life-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:20px; }
.campus-life-main { position:relative; min-height:480px; overflow:hidden; border-radius:var(--radius-lg); }
.campus-life-main-bg { position:absolute; inset:0; background-size:cover; background-position:center; }
.campus-life-main-card { position:absolute; bottom:30px; left:50px; right:50px; background:var(--bg-primary); border-top:4px solid var(--orange); border-radius:var(--radius-sm); padding:20px; }
.campus-life-main-card p { font-size:13px; color:var(--brand-navy); font-family:var(--font-body); line-height:1.7; }
.campus-life-main-card .arrow { color:var(--brand-navy); font-size:17px; display:inline-block; margin-top:8px; }
.campus-life-news { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.news-tile { position:relative; overflow:hidden; min-height:220px; border-radius:var(--radius-lg); }
.news-tile-bg { position:absolute; inset:0; background-size:cover; background-position:center; }
.news-tile-card { position:absolute; bottom:12px; left:12px; right:12px; background:var(--bg-primary); border-top:4px solid var(--orange); border-radius:var(--radius-sm); padding:12px 14px; }
.news-tile-card p { font-size:12px; color:var(--brand-navy); font-family:var(--font-body); line-height:1.6; }
.news-tile-card .arrow { color:var(--brand-navy); font-size:15px; display:inline-block; margin-top:6px; }

/* ══════════════════════════════════════
   NEWS & EVENTS
══════════════════════════════════════ */
.news-section { padding:80px 0; background:var(--bg-secondary); }
.news-header { display:flex; align-items:flex-start; gap:24px; margin-bottom:50px; }
.news-header-left { flex-shrink:0; }
.news-title { font-family:var(--font-title); font-size:1.6rem; font-weight:700; color:var(--brand-navy); margin:0 0 8px; letter-spacing:.5px; text-transform:uppercase; }
.news-read-all { font-family:var(--font-body); font-size:13px; color:var(--text-secondary); text-decoration:none; display:block; }
.news-read-all:hover { color:var(--orange); }
.news-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; align-items:stretch; }
.news-card { border:2px solid var(--border-color); border-radius:var(--radius-lg); box-shadow:var(--shadow-sm); overflow:hidden; background:var(--bg-primary); display:flex; flex-direction:column; transition:var(--transition); }
.news-card:hover { box-shadow:var(--shadow-md); transform:translateY(-5px); }
.news-card > a { display:flex; flex-direction:column; flex:1; color:inherit; text-decoration:none; }
.news-card-img { overflow:hidden; height:200px; flex-shrink:0; }
.news-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.news-card:hover .news-card-img img { transform:scale(1.06); }
.news-card-body { padding:22px 22px 16px; display:flex; flex-direction:column; flex:1; }
.news-card-date { font-family:var(--font-body); font-size:11px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--orange); display:block; margin-bottom:8px; }
.news-card-title { font-family:var(--font-title); font-size:16px; font-weight:700; color:var(--brand-navy); line-height:1.55; margin:0; flex:1; }
.news-card-arrow { color:var(--brand-navy); font-size:17px; margin-top:14px; display:block; transition:transform .2s,color .2s; }
.news-card:hover .news-card-arrow { transform:translateX(6px); color:var(--orange); }

/* ALSO INTERESTED */
.also-interested { padding:70px 0; background:var(--bg-primary); }
.also-interested > .container > h3 { font-size:1.3rem; color:var(--brand-navy); font-family:var(--font-title); font-weight:400; margin-bottom:30px; }
.interest-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:30px; align-items:stretch; }
.interest-card { border:2px solid var(--border-color); border-radius:var(--radius-lg); box-shadow:var(--shadow-sm); overflow:hidden; background:var(--bg-primary); display:flex; flex-direction:column; transition:var(--transition); }
.interest-card:hover { box-shadow:var(--shadow-md); transform:translateY(-4px); }
.interest-card img { width:100%; object-fit:cover; flex-shrink:0; }
.interest-card-body { padding:22px 22px 16px; display:flex; flex-direction:column; flex:1; }
.interest-card-body h3 { font-size:18px; color:var(--brand-navy); font-family:var(--font-title); font-weight:700; margin-bottom:10px; }
.interest-card-body p { font-size:15px; color:var(--text-secondary); font-family:var(--font-body); line-height:1.8; flex:1; }
.interest-card-body .arrow-link { display:inline-block; color:var(--brand-navy); font-size:17px; margin-top:12px; transition:transform .2s,color .2s; }
.interest-card-body .arrow-link:hover { transform:translateX(6px); color:var(--orange); }

/* ══════════════════════════════════════
   FOOTER
══════════════════════════════════════ */
footer {
  background: linear-gradient(160deg, #001230 0%, #002060 55%, #001840 100%);
  color: rgba(255,255,255,.72);
  border-top: 3px solid var(--orange);
  font-family: var(--font-body);
  position: relative;
  z-index: 1;
}
.footer-grid {
  max-width: 1400px;
  margin: 0 auto;
  padding: 4rem 2rem 2.5rem;
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr 1fr;
  gap: 3rem;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.footer-col { padding: 0; border-right: none; }
.footer-col h3 {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #fff;
  margin-bottom: 1.1rem;
  padding-bottom: 0;
  border-bottom: none;
  display: flex;
  align-items: center;
  gap: .5rem;
  font-family: var(--font-body);
}
.footer-col h3::before { content: ''; width: 8px; height: 8px; border-radius: 50%; background: var(--orange); flex-shrink: 0; display: inline-block; }
.footer-contact p {
  font-size: .84rem;
  font-family: var(--font-body);
  line-height: 1.9;
  color: #7b96b4;
}
.footer-contact p i { color: var(--orange); margin-right: .4rem; }
.footer-col ul { list-style: none; margin-top: 0; padding: 0; }
.footer-col ul li { margin-bottom: .65rem; display: flex; align-items: baseline; gap: 8px; }
.footer-col ul li::before { content: ''; display: inline-block; width: 6px; height: 6px; background: #7dd3fc; border-radius: 1px; flex-shrink: 0; margin-top: 1px; transition: background .2s; }
.footer-col ul li:hover::before { background: var(--orange); }
.footer-col ul li a {
  display: flex;
  align-items: center;
  gap: .45rem;
  color: #7b96b4;
  font-size: .87rem;
  font-family: var(--font-body);
  transition: color .18s, padding-left .18s;
}
.footer-col ul li a:hover { color: #fff; padding-left: .4rem; }
.footer-bottom {
  background: rgba(0,0,0,.4);
}
.footer-bottom-inner {
  max-width: 1400px;
  padding: 1.1rem 2rem;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.footer-copyright { font-size: .82rem; color: #4a6280; font-family: var(--font-body); }
.footer-copyright a { color: #4a6280; transition: color .18s; }
.footer-copyright a:hover { color: #8aaecb; }
.footer-social { display: flex; gap: .5rem; }
.footer-social a {
  width: 34px;
  height: 34px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #8aaecb;
  font-size: .9rem;
  transition: background .2s, color .2s, transform .2s;
}
.footer-social a:hover { background: var(--orange); color: #fff; border-color: var(--orange); transform: translateY(-3px); }
.footer-social a:hover i { color: #fff !important; }

/* ══════════════════════════════════════
   BACK TO TOP
══════════════════════════════════════ */
.back-to-top { position:fixed; bottom:30px; right:30px; width:44px; height:44px; background:var(--primary-gradient); color:#fff; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:17px; cursor:pointer; opacity:0; transition:opacity .3s,transform .2s; z-index:999; text-decoration:none; box-shadow:var(--shadow-md); }
.back-to-top.visible { opacity:1; }
.back-to-top:hover { transform:translateY(-3px); }

/* ══════════════════════════════════════
   MOBILE HEADER
══════════════════════════════════════ */
.mobile-header {
  display: none;
  background: #fff;
  border-bottom: 2px solid var(--border-color);
  padding: 0 16px;
  align-items: center; justify-content: space-between;
  height: 60px;
  position: sticky; top: 0; z-index: 1000;
  box-shadow: 0 2px 12px rgba(0,0,0,.07);
}
.mobile-logo img { height: 44px; }
.hamburger {
  background: none; border: 2px solid var(--border-color);
  border-radius: 8px; cursor: pointer;
  width: 38px; height: 38px;
  display: flex; align-items: center; justify-content: center;
  font-size: 19px; color: var(--brand-navy);
  transition: border-color .2s, background .2s;
}
.hamburger:hover { border-color: var(--brand-navy); background: var(--brand-pale-blue); }

/* ── Overlay ── */
.mm-overlay {
  display: none;
  position: fixed; inset: 0;
  background: rgba(0,0,0,.46);
  z-index: 9998;
  opacity: 0;
  transition: opacity .3s;
}
.mm-overlay.active { opacity: 1; }

/* ── Drawer (slides from LEFT) ── */
.mobile-menu {
  position: fixed; top: 0; left: 0; bottom: 0;
  width: 300px; max-width: 88vw;
  background: #fff;
  z-index: 9999;
  overflow-y: auto;
  transform: translateX(-100%);
  transition: transform .32s cubic-bezier(.4,0,.2,1);
  display: flex; flex-direction: column;
  box-shadow: 4px 0 32px rgba(0,0,0,.18);
}
.mobile-menu.open { transform: translateX(0); }

/* Drawer header */
.mm-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px;
  background: var(--brand-navy);
  border-bottom: 2px solid rgba(255,255,255,.08);
  flex-shrink: 0;
}
.mm-head-logo { height: 38px; }
.mm-close {
  background: rgba(255,255,255,.12); border: none; color: #fff;
  width: 34px; height: 34px; border-radius: 8px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 17px; transition: background .2s;
}
.mm-close:hover { background: rgba(255,255,255,.24); }

/* Nav area */
.mm-nav { flex: 1; overflow-y: auto; }

/* Item row */
.mm-item { border-bottom: 1px solid #edf1f7; }

.mm-row {
  display: flex; align-items: center;
  width: 100%; padding: 0; background: none; border: none;
  cursor: pointer; text-decoration: none;
  transition: background .15s;
}
.mm-row:hover { background: var(--brand-pale-blue); }

/* Icon badge */
.mm-row-icon {
  width: 44px; height: 50px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; color: var(--brand-navy);
}
.mm-row-label {
  flex: 1; text-align: left;
  font-family: var(--font-body); font-size: .88rem; font-weight: 600;
  color: var(--text-primary); padding: 14px 0;
}
.mm-row-end {
  width: 44px; display: flex; align-items: center; justify-content: center;
  font-size: 13px; color: #b0bec8;
}

/* Accordion chevron rotate */
.mm-item.mm-open > .mm-row .mm-row-end .bi-chevron-down { transform: rotate(180deg); }
.mm-row-end .bi-chevron-down { transition: transform .25s; display: block; }

/* Sub menu */
.mm-sub {
  list-style: none; background: #f7f9fc;
  max-height: 0; overflow: hidden;
  transition: max-height .32s ease;
}
.mm-item.mm-open .mm-sub { max-height: 600px; }
.mm-sub li { border-bottom: 1px solid #edf1f7; }
.mm-sub li:last-child { border-bottom: none; }
.mm-sub li a {
  display: flex; align-items: center; gap: 8px;
  padding: 11px 16px 11px 44px;
  font-family: var(--font-body); font-size: .83rem; font-weight: 500;
  color: var(--text-secondary); text-decoration: none;
  transition: background .15s, color .15s;
}
.mm-sub li a::before {
  content: ''; width: 5px; height: 5px; border-radius: 50%;
  background: var(--border-color); flex-shrink: 0;
}
.mm-sub li a:hover { background: #eef3fb; color: var(--brand-navy); }
.mm-sub li a:hover::before { background: var(--orange); }


/* ══════════════════════════════════════
   MOBILE SECTION DROPDOWN (replaces sidebar)
══════════════════════════════════════ */
.mobile-section-nav { display: none; }
@media (max-width: 768px) {
  aside { display: none; }
  .mobile-section-nav {
    display: block;
    width: 100%;
    position: sticky;
    top: 0;
    z-index: 1001;
  }
}

/* ── Bar (always visible) ── */
.msn-bar {
  display: flex; align-items: center; gap: 14px;
  background: var(--brand-navy); padding: 12px 22px;
  cursor: pointer; border-radius: 0;
  transition: background .15s; user-select: none;
  border: none; width: 100%; text-align: left;
}

/* Orange icon box (left) */
.msn-icon-box {
  width: 40px; height: 40px; border-radius: 8px;
  background: var(--orange);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; font-size: 19px; color: #fff;
}

/* Text block */
.msn-text { flex: 1; min-width: 0; }
.msn-title {
  display: block;
  font-family: var(--font-body); font-size: .9rem; font-weight: 700;
  color: #fff; line-height: 1.3;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.msn-subtitle {
  display: block;
  font-family: var(--font-body); font-size: .6rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  color: rgba(255,255,255,.42); margin-top: 2px;
}

/* Chevron (right) */
.msn-chevron { font-size: 14px; color: rgba(255,255,255,.5); transition: transform .28s; flex-shrink: 0; }
.mobile-section-nav.msn-open .msn-chevron { transform: rotate(180deg); }

/* ── Dropdown list ── */
.msn-list {
  background: #fff;
  border-bottom: 2px solid var(--border-color);
  overflow: hidden; max-height: 0;
  transition: max-height .32s ease;
  box-shadow: 0 6px 20px rgba(0,55,123,.13);
}
.mobile-section-nav.msn-open .msn-list { max-height: 600px; }

.msn-list a {
  display: flex; align-items: center; gap: 12px;
  padding: 13px 16px;
  font-family: var(--font-body); font-size: .875rem; font-weight: 500;
  color: var(--text-secondary); text-decoration: none;
  border-bottom: 1px solid #edf1f7;
  border-left: 3px solid transparent;
  transition: background .15s, color .15s;
}
.msn-list a:last-child { border-bottom: none; }

/* Dot bullet */
.msn-list a::before {
  content: ''; width: 7px; height: 7px; border-radius: 50%;
  background: #ccd8e4; flex-shrink: 0;
  transition: background .15s;
}
.msn-list a:hover { background: var(--brand-pale-blue); color: var(--brand-navy); }
.msn-list a:hover::before { background: var(--brand-navy); }

/* Active item */
.msn-list a.msn-active {
  color: var(--orange); font-weight: 700;
  border-left-color: var(--orange);
  background: #fff8f3;
}
.msn-list a.msn-active::before { background: var(--orange); }

/* ══════════════════════════════════════
   PAGE HERO  (research.pes.edu style)
══════════════════════════════════════ */
.page-hero {
  background: linear-gradient(135deg, #002766 0%, #00377B 45%, #0055B3 100%);
  padding: 54px 0 60px;
  position: relative;
  overflow: hidden;
  border-bottom: 3px solid var(--orange);
}
.page-hero-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 2rem;
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
}
/* Left text block */
.page-hero-text { flex: 1; min-width: 0; }
/* Category chip */
.page-hero-chip {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: rgba(0,0,0,.30);
  border: 1px solid rgba(255,255,255,.24);
  color: rgba(255,255,255,.92);
  font-size: .78rem;
  font-weight: 600;
  padding: .36rem .95rem;
  border-radius: 30px;
  margin-bottom: 16px;
  font-family: var(--font-body);
  letter-spacing: .03em;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.page-hero-chip i { font-size: .88rem; }
/* Page title */
.page-hero h1 {
  font-family: var(--font-title);
  font-size: clamp(2rem, 4.5vw, 3.2rem);
  font-weight: 700;
  color: #fff;
  margin-bottom: 12px;
  line-height: 1.12;
}
/* Subtitle */
.page-hero-sub {
  font-family: var(--font-body);
  font-size: .97rem;
  color: rgba(255,255,255,.72);
  line-height: 1.7;
  margin-bottom: 22px;
  max-width: 580px;
}
/* Orange accent bar */
.page-hero-accent {
  width: 54px;
  height: 4px;
  background: var(--orange);
  border-radius: 3px;
}
/* Right decorative block */
.page-hero-deco {
  position: relative;
  width: 320px;
  height: 220px;
  flex-shrink: 0;
  pointer-events: none;
}
/* Circles */
.deco-card {
  position: absolute;
  border-radius: 50%;
  background: transparent;
}
.deco-card-1 {
  width: 175px; height: 175px;
  top: -20px; right: -20px;
  border: 2px solid rgba(255,108,0,.65);
  box-shadow: 0 0 22px rgba(255,108,0,.18);
}
.deco-card-2 {
  width: 115px; height: 115px;
  top: 115px; left: 0;
  border: 2px solid rgba(97,185,240,.60);
  box-shadow: 0 0 18px rgba(97,185,240,.14);
}
.deco-card-3 {
  width: 80px; height: 80px;
  top: 10px; left: 25px;
  border: 2px solid rgba(97,185,240,.42);
  box-shadow: 0 0 12px rgba(97,185,240,.10);
}
/* Page-specific large background icon */
.deco-icon {
  position: absolute;
  right: 50%;
  top: 50%;
  transform: translate(50%, -50%);
  font-size: 120px;
  color: rgba(255,255,255,.13);
  line-height: 1;
  z-index: 1;
  pointer-events: none;
}
/* Keep old breadcrumb hidden */
.page-hero .breadcrumb { display: none; }
/* Auto-hide duplicate inner title on pages with a preceding hero */
.page-hero + .pes-inner-layout .pes-inner-title,
.page-hero + .pes-inner-layout .pes-inner-rule { display: none; }

/* ══════════════════════════════════════
   SPLIT HERO
══════════════════════════════════════ */
.split-hero { display:grid; grid-template-columns:1fr 1fr; min-height:420px; }
.split-hero-left { background:var(--primary-gradient); display:flex; flex-direction:column; justify-content:center; padding:60px 56px; }
.split-hero-left h1 { font-family:var(--font-title); font-size:2rem; font-weight:700; color:#fff; line-height:1.2; margin-bottom:20px; }
.split-hero-left p { font-family:var(--font-body); font-size:15px; color:rgba(255,255,255,.85); line-height:1.7; max-width:440px; }
.split-hero-right { position:relative; overflow:hidden; }
.split-hero-right img { width:100%; height:100%; object-fit:cover; display:block; }
.split-hero-card { position:absolute; bottom:0; left:0; right:0; background:var(--bg-primary); padding:24px 28px; border-top:4px solid var(--orange); }
.split-hero-card h3 { font-family:var(--font-title); font-size:18px; font-weight:700; color:var(--brand-navy); margin-bottom:12px; line-height:1.35; }
.split-hero-card a.apply-btn { display:inline-flex; align-items:center; gap:8px; border:2px solid var(--brand-navy); color:var(--brand-navy); font-family:var(--font-body); font-size:13px; font-weight:600; padding:8px 18px; border-radius:var(--radius-sm); text-decoration:none; transition:background .2s,color .2s; }
.split-hero-card a.apply-btn:hover { background:var(--brand-navy); color:#fff; }

/* ══════════════════════════════════════
   PAGE CONTENT
══════════════════════════════════════ */
.page-content { padding:60px 0; }
.page-content .container { max-width:1400px; margin:0 auto; padding:0 2rem; }
.content-wrap { max-width:960px; }
.btn-pill {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  background: var(--primary-gradient);
  color: #fff;
  padding: .65rem 1.4rem;
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  transition: var(--transition);
  margin-top: 6px;
  box-shadow: var(--shadow-sm);
}
.btn-pill:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); background: var(--accent-gradient); }

/* ══════════════════════════════════════
   GLOBAL TEXT COLOR
══════════════════════════════════════ */
p { color: var(--text-secondary); font-family: var(--font-body); font-size: 1rem; line-height: 1.8; margin-top: 0; margin-bottom: 1.2rem; }
h3, h4, h5, h6 { color: var(--brand-navy); }
.pes-inner-main ul { padding-left: 22px; margin-bottom: 1.25rem; }
.pes-inner-main ul li { color: var(--text-secondary); font-family: var(--font-body); font-size: 1rem; line-height: 1.8; margin-bottom: 8px; }
.pes-inner-main ul li a { color: var(--text-secondary); text-decoration: none; transition: color .2s; }
.pes-inner-main ul li a:hover { color: var(--orange); }

/* ══════════════════════════════════════
   PES INNER PAGE LAYOUT
══════════════════════════════════════ */
.pes-inner-layout { padding: 60px 0; background: var(--bg-secondary); }
.pes-inner-layout > .container {
  display: grid;
  grid-template-columns: 1fr 240px;
  gap: 60px;
  align-items: start;
}
.pes-inner-main { padding: 0 0 2.5rem 0; min-width: 0; }
.pes-inner-title {
  font-family: var(--font-title);
  font-size: 2rem;
  font-weight: 700;
  color: var(--brand-navy);
  line-height: 1.2;
  margin-bottom: 20px;
}
.pes-inner-lead {
  font-size: 1.1rem;
  font-weight: 300;
  color: var(--text-secondary);
  line-height: 1.7;
  font-family: var(--font-title);
  margin-bottom: 24px;
}
.pes-inner-rule {
  border: none;
  border-top: 3px solid var(--orange);
  margin: 0 0 2rem;
}
/* ── Sidebar Nav ── */
.pes-inner-layout aside {
  align-self: start;
  position: sticky;
  top: 80px;
}
.pes-sidebar-nav {
  background: var(--bg-primary);
  border: 2px solid var(--border-color);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  max-height: calc(100vh - 100px);
  overflow-y: auto;
}
/* Section header */
.pes-sidebar-nav::before {
  content: attr(data-title);
  display: block;
  background: var(--primary-gradient);
  color: #fff;
  font-family: var(--font-body);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 11px 16px 11px 20px;
}
.pes-sidebar-nav ul { list-style: none; padding: 6px 0; }
.pes-sidebar-nav ul li a {
  display: flex;
  align-items: center;
  gap: .65rem;
  font-family: var(--font-body);
  font-size: .875rem;
  font-weight: 500;
  color: var(--text-secondary);
  padding: .62rem 1.1rem .62rem 1.1rem;
  border-radius: 0;
  border: none;
  border-bottom: 1px solid rgba(211,228,242,.6);
  margin: 0;
  transition: color .2s, background .2s, padding-left .2s;
}
.pes-sidebar-nav ul li:last-child a { border-bottom: none; }
/* Dot bullet */
.pes-sidebar-nav ul li a::before {
  content: '';
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--border-color);
  flex-shrink: 0;
  transition: background .2s, transform .2s;
}
.pes-sidebar-nav ul li a:hover {
  background: var(--brand-pale-blue);
  color: var(--brand-navy);
  padding-left: 1.4rem;
  border-color: rgba(211,228,242,.6);
}
.pes-sidebar-nav ul li a:hover::before { background: var(--orange); }
.pes-sidebar-nav ul li a.active {
  background: var(--brand-pale-blue);
  color: var(--brand-navy);
  font-weight: 700;
  border-color: rgba(211,228,242,.6);
}
.pes-sidebar-nav ul li a.active::before { background: var(--orange); transform: scale(1.2); }
/* Sidebar heading override */
.pes-sidebar-heading {
  background: var(--primary-gradient);
  color: #fff;
  font-family: var(--font-body);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 11px 16px 11px 20px;
}
/* Group label inside sidebar */
.pes-sidebar-nav ul li.pes-sidebar-group-label {
  font-family: var(--font-body);
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  padding: 10px 20px 4px;
  pointer-events: none;
}

/* ── Department full-width layout ── */
.dept-layout > .container { grid-template-columns: 1fr; }

/* Zig-zag section row */
.dept-section {
  display: flex;
  align-items: flex-start;
  gap: 48px;
  padding: 40px 0;
  border-bottom: 1px solid var(--border-color);
}
.dept-section:last-child { border-bottom: none; }

/* Odd sections: text left, image right */
.dept-section:nth-child(odd)  { flex-direction: row; }
/* Even sections: image left, text right */
.dept-section:nth-child(even) { flex-direction: row-reverse; }

.dept-sec-text { flex: 1; min-width: 0; }
.dept-sec-img {
  width: 340px;
  height: 260px;
  object-fit: cover;
  border-radius: 14px;
  flex-shrink: 0;
  box-shadow: var(--shadow-md);
  transition: transform .35s, box-shadow .35s;
}
.dept-sec-img:hover { transform: scale(1.03); box-shadow: var(--shadow-lg); }

/* Paragraph-style section headings */
.dept-sec-text h3 {
  font-size: 21px !important;
  font-weight: 700 !important;
  color: var(--brand-navy) !important;
  background: none !important;
  margin: 0 0 10px !important;
  padding: 0 0 10px !important;
  border: none !important;
  border-bottom: 3px solid var(--orange) !important;
  border-radius: 0 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  display: block;
}
/* Hide orange underline divs */
.dept-sec-text > div[style*="border-top:2px solid var(--orange)"] { display: none !important; }

/* Natural paragraph/list flow */
.dept-sec-text p  { margin-bottom: 1rem; color: var(--text-secondary); line-height: 1.8; }
.dept-sec-text ul { list-style: none !important; padding-left: 0 !important; margin: 0; }
.dept-sec-text ul li {
  position: relative;
  padding-left: 22px !important;
  margin-bottom: 9px;
  color: var(--text-secondary);
  line-height: 1.75;
}
.dept-sec-text ul li::before {
  content: '▸';
  color: var(--orange);
  font-weight: 700;
  position: absolute;
  left: 0;
  top: 2px;
}

@media (max-width: 900px) {
  .dept-sec-img { width: 260px; height: 210px; }
}
@media (max-width: 768px) {
  .dept-section,
  .dept-section:nth-child(even) { flex-direction: column !important; gap: 0; padding: 24px 0; }
  .dept-sec-img { display: none; }
  .dept-layout { background: var(--bg-secondary); }
  .pes-inner-layout.dept-layout { padding: 24px 0 40px; }
}

/* Vision / Mission / Goal — three-column card row */
.dept-vmg-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin: 28px 0 36px;
}
.dept-vmg-card,
.dept-vmg-card:nth-child(odd),
.dept-vmg-card:nth-child(even) {
  flex-direction: column !important;
  gap: 0 !important;
  padding: 24px 22px !important;
  background: #f8fafc !important;
  border: 1px solid var(--border-color) !important;
  border-bottom: 1px solid var(--border-color) !important;
  border-radius: 14px !important;
  align-items: stretch !important;
}
.dept-vmg-row .dept-section:last-child { border-bottom: 1px solid var(--border-color) !important; }
@media (max-width: 768px) {
  .dept-vmg-row { grid-template-columns: 1fr; gap: 12px; margin: 16px 0 20px; }
  .dept-vmg-card,
  .dept-vmg-card:nth-child(odd),
  .dept-vmg-card:nth-child(even) { padding: 18px 16px !important; border-radius: 10px !important; }
}
[data-theme="dark"] .dept-vmg-card { background: #1a2740 !important; border-color: #2e3d58 !important; }

/* ── Department category cards grid ── */
.dept-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 24px;
}
@media (max-width: 768px) {
  .dept-cards-grid { grid-template-columns: 1fr; gap: 16px; }
}

/* ── Department faculty table ── */
.dept-faculty-table-wrap { overflow-x: auto; margin: 8px 0 16px; }
.dept-faculty-table {
  width: 100%; border-collapse: collapse;
  font-family: var(--font-body); font-size: .875rem;
}
.dept-faculty-table th {
  background: var(--brand-navy); color: #fff;
  font-weight: 600; text-align: left;
  padding: 11px 16px; font-size: .8rem;
  letter-spacing: .04em; text-transform: uppercase;
}
.dept-faculty-table td {
  padding: 10px 16px;
  border-bottom: 1px solid var(--border-color);
  color: var(--text-secondary);
}
.dept-faculty-table tbody tr:last-child td { border-bottom: none; }
.dept-faculty-table tbody tr:nth-child(even) { background: var(--brand-pale-blue); }

/* ══════════════════════════════════════
   ABOUT PAGE
══════════════════════════════════════ */
.about-intro-grid { display:grid; grid-template-columns:1fr 1fr; gap:40px; margin-bottom:48px; }
.about-promo-band { background:var(--primary-gradient); padding:50px 40px; margin-bottom:48px; display:grid; grid-template-columns:1fr 1fr 1fr; gap:40px; border-radius:var(--radius-lg); }
.about-promo-heading { color:#fcd9b6; font-size:15px; font-weight:700; font-family:var(--font-body); letter-spacing:.5px; text-transform:uppercase; margin-bottom:12px; }
.about-promo-band p { color:rgba(255,255,255,.85); font-size:14px; margin-bottom:16px; }
.about-promo-link { color:var(--orange); font-family:var(--font-body); font-size:13px; font-weight:600; display:inline-flex; align-items:center; gap:8px; transition:opacity .2s; }
.about-promo-link:hover { opacity:.8; }
.about-split { display:grid; grid-template-columns:1fr 1fr; gap:0; margin-bottom:4px; background:var(--bg-secondary); border-radius:var(--radius-lg); overflow:hidden; border:2px solid var(--border-color); }
.about-split-text { padding:50px 48px; display:flex; flex-direction:column; justify-content:center; }
.about-split-text h3 { font-family:var(--font-title); font-size:20px; font-weight:700; color:var(--brand-navy); margin-bottom:20px; }
.about-split-text p { font-size:15px; }
.about-split-img { min-height:320px; background-size:cover; background-position:center; }

/* ══════════════════════════════════════
   LEADERSHIP PAGE
══════════════════════════════════════ */
.leadership-lead { font-family:var(--font-body); font-size:1rem; color:var(--text-secondary); font-weight:400; line-height:1.7; margin-bottom:24px; }
.leadership-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-top:40px; }

/* Card — image always visible, details reveal on hover */
.leadership-card {
  border-radius: var(--radius-lg);
  overflow: hidden;
  height: 300px;
  position: relative;
  box-shadow: var(--shadow-sm);
  transition: box-shadow .4s, transform .4s;
  cursor: pointer;
}
.leadership-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-5px); }
.leadership-card > a { display: block; height: 100%; text-decoration: none; }

/* Image — visible by default */
.leadership-card-img {
  position: absolute;
  inset: 0;
  z-index: 1;
}
.leadership-card-img img { width: 100%; height: 100%; object-fit: cover; object-position: top; transition: transform .5s ease; }
.leadership-card:hover .leadership-card-img img { transform: scale(1.06); }

/* Gradient overlay — subtle default, stronger on hover */
.leadership-card::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(to top, rgba(0,15,50,.75) 30%, transparent 70%);
  transition: background .4s ease;
}
.leadership-card:hover::after {
  background: linear-gradient(to top, rgba(0,15,50,.92) 40%, rgba(0,15,50,.25) 100%);
}

/* Info block — always at bottom */
.leadership-card-info {
  position: absolute;
  z-index: 3;
  left: 0; right: 0;
  bottom: 0;
  padding: 22px 22px 20px;
  text-align: left;
}

/* Name — always visible */
.leadership-card-name {
  font-family: var(--font-title);
  font-size: 17px;
  font-weight: 700;
  color: #fff;
  margin: 0;
  line-height: 1.4;
}

/* Role — hidden by default, slides up on hover */
.leadership-card-role {
  font-family: var(--font-body);
  font-size: 13px;
  color: rgba(255,255,255,.85);
  margin: 0;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transform: translateY(8px);
  transition: max-height .4s ease, opacity .35s .08s, transform .35s .08s;
}
.leadership-card:hover .leadership-card-role {
  max-height: 40px;
  opacity: 1;
  transform: translateY(0);
  margin-top: 6px;
}

/* Arrow — removed */
.leadership-card-arrow { display: none; }

/* ══════════════════════════════════════
   NMC / DEPARTMENT LIST
══════════════════════════════════════ */
.nmc-section { margin-bottom:40px; }
.nmc-section-title { font-family:var(--font-title); font-size:1.2rem; font-weight:700; color:var(--brand-navy); border-left:4px solid var(--brand-navy); padding:4px 0 4px 14px; margin:0 0 16px; }
.nmc-list { list-style:none; padding:0; margin:0; }
.nmc-list li { font-family:var(--font-body); font-size:15px; color:var(--text-secondary); padding:9px 0; border-bottom:1px solid var(--border-color); }
.nmc-list li:last-child { border-bottom:none; }
.nmc-list li a { color:var(--brand-navy); text-decoration:none; transition:color .2s; }
.nmc-list li a:hover { color:var(--orange); }
.nmc-list-grid { columns:2; column-gap:40px; }
.nmc-list-grid-3 { columns:3; column-gap:40px; }

/* ══════════════════════════════════════
   DOCUMENT DOWNLOAD (admissions)
══════════════════════════════════════ */
.doc-quota { margin-bottom:32px; }
.doc-quota-title {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: #fff;
  background: var(--primary-gradient);
  padding: 11px 20px;
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
  margin-bottom: 0;
}
.doc-list-wrap { border: 2px solid var(--border-color); border-top: none; border-radius: 0 0 var(--radius-sm) var(--radius-sm); overflow: hidden; }
.doc-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 20px;
  border-bottom: 1px solid var(--border-color);
  gap: 16px;
}
.doc-item:last-child { border-bottom: none; }
.doc-item:nth-child(even) { background: var(--brand-pale-blue); }
.doc-item-name { display: flex; align-items: center; gap: 12px; font-family: var(--font-body); font-size: 14px; color: var(--text-primary); flex: 1; }
.doc-item-name i { color: #c0392b; font-size: 17px; flex-shrink: 0; }
.doc-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--primary-gradient);
  color: #fff;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 700;
  padding: 6px 14px;
  border-radius: var(--radius-sm);
  white-space: nowrap;
  transition: var(--transition);
  flex-shrink: 0;
  box-shadow: var(--shadow-sm);
}
.doc-btn:hover { background: var(--accent-gradient); color: #fff; box-shadow: var(--shadow-md); }
.doc-btn i { font-size: 11px; }
.admission-intro { margin-bottom: 32px; }
.admission-intro h2 { font-family: var(--font-body); font-size: 1.2rem; font-weight: 700; color: var(--brand-navy); margin-bottom: 10px; }
.admission-contact-box {
  background: var(--brand-pale-blue);
  border-left: 4px solid var(--orange);
  padding: 20px 24px;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  margin-top: 36px;
  border: 2px solid var(--border-color);
  border-left: 4px solid var(--orange);
}
.admission-contact-box h4 { font-family: var(--font-body); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--brand-navy); margin-bottom: 10px; }
.admission-contact-box p { font-size: 14px; margin-bottom: 4px; }
.admission-contact-box a { color: var(--orange); }

/* ══════════════════════════════════════
   HERO MAGAZINE
══════════════════════════════════════ */
.hero-mag {
  position: relative;
  height: 82vh; min-height: 520px;
  overflow: hidden;
  background: #06090f;
  display: flex; align-items: center;
}

/* Full-bleed background per slide */
.hm-bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  opacity: 0;
  will-change: opacity;
}
.hm-bg.active  { opacity: 1; }
.hm-bg.leaving { opacity: 0; transition: opacity .5s ease .1s; }

/* Directional gradient overlay */
.hm-overlay {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(
    to right,
    rgba(3,7,18,.88) 0%,
    rgba(3,7,18,.62) 32%,
    rgba(3,7,18,.2)  60%,
    transparent 82%
  );
  pointer-events: none;
}

/* Left content column */
.hm-left {
  position: relative; z-index: 3;
  padding: 0 0 100px 8%;
  flex: 0 0 54%; min-height: 300px;
}

/* Slide text panels — all absolute, .active one is relative to claim height */
.hm-slide {
  position: absolute; top: 0; left: 0; right: 0;
  opacity: 0;
  transform: translateY(30px);
  transition: opacity .55s ease, transform .55s ease;
  pointer-events: none;
}
.hm-slide.active {
  position: relative;
  opacity: 1; transform: translateY(0); pointer-events: auto;
}
.hm-slide.leaving {
  opacity: 0; transform: translateY(-22px);
  transition: opacity .28s ease, transform .28s ease;
}

.hm-eyebrow {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--font-body); font-size: .72rem; font-weight: 700;
  letter-spacing: .13em; text-transform: uppercase;
  color: var(--orange); margin-bottom: 14px;
}
.hm-eyebrow i { font-size: .88rem; }

.hm-title {
  font-family: var(--font-title);
  font-size: clamp(1.9rem, 3.6vw, 3.2rem);
  font-weight: 900; line-height: 1.0;
  color: #fff; margin-bottom: 18px;
  letter-spacing: -.01em; text-transform: uppercase;
}

.hm-desc {
  font-family: var(--font-body); font-size: .88rem;
  color: rgba(255,255,255,.6);
  max-width: 400px; line-height: 1.78; margin-bottom: 30px;
}

.hm-btns { display: flex; gap: 12px; flex-wrap: wrap; }


.hm-btn-primary {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--orange); color: #fff;
  font-family: var(--font-body); font-size: .82rem; font-weight: 700;
  padding: .72rem 1.6rem; border-radius: 40px; text-decoration: none;
  transition: background .2s, transform .2s;
}
.hm-btn-primary:hover { background: var(--orange-dark); transform: translateY(-2px); color: #fff; }

.hm-btn-ghost {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,.1); color: #fff;
  border: 1.5px solid rgba(255,255,255,.26);
  font-family: var(--font-body); font-size: .82rem; font-weight: 600;
  padding: .72rem 1.4rem; border-radius: 40px; text-decoration: none;
  backdrop-filter: blur(8px);
  transition: background .2s;
}
.hm-btn-ghost:hover { background: rgba(255,255,255,.2); color: #fff; }

/* Preview cards strip — bottom-right */
.hm-cards {
  position: absolute; bottom: 30px; right: 0;
  display: flex; gap: 14px; padding: 0 48px 0 0;
  z-index: 3; overflow: visible;
}

.hm-card {
  flex: 0 0 140px; height: 175px;
  border-radius: 14px; overflow: hidden;
  position: relative; cursor: pointer;
  box-shadow: 0 8px 28px rgba(0,0,0,.48);
  transition: transform .35s ease, box-shadow .35s ease;
}
.hm-card:hover { transform: translateY(-7px) scale(1.03); box-shadow: 0 18px 40px rgba(0,0,0,.6); }

.hm-card-img {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  transition: transform .5s ease;
}
.hm-card:hover .hm-card-img { transform: scale(1.08); }

/* Gradient on card */
.hm-card::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.85) 0%, transparent 55%);
  z-index: 1;
}

.hm-card-body {
  position: absolute; bottom: 13px; left: 13px; right: 13px; z-index: 2;
}
.hm-card-eyebrow {
  display: block;
  font-family: var(--font-body); font-size: .54rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  color: rgba(255,255,255,.55); margin-bottom: 4px;
}
.hm-card-title {
  font-family: var(--font-title); font-size: .72rem; font-weight: 700;
  color: #fff; line-height: 1.25; margin: 0;
}

/* Prev/Next nav */
.hm-nav {
  position: absolute; bottom: 28px; left: 8%;
  display: flex; gap: 10px; z-index: 6;
}
.hm-nav-btn {
  width: 40px; height: 40px; border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,.28);
  background: rgba(255,255,255,.1); backdrop-filter: blur(8px);
  color: #fff; font-size: 14px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: background .2s, border-color .2s, transform .15s;
}
.hm-nav-btn:hover { background: var(--orange); border-color: var(--orange); transform: scale(1.1); }

/* Slide counter */
.hm-counter {
  position: absolute; bottom: 36px; right: 52px; z-index: 6;
  font-family: var(--font-body); font-weight: 800;
  font-size: 1.1rem; color: rgba(255,255,255,.42);
  letter-spacing: .06em;
}

/* Slide dots — mobile only */
.hm-dots {
  position: absolute; bottom: 32px; left: 0; right: 0;
  display: none; justify-content: center; gap: 8px; z-index: 6;
}
.hm-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: rgba(255,255,255,.35); cursor: pointer; flex-shrink: 0;
  transition: background .25s, width .25s, border-radius .25s;
  border: none; padding: 0;
}
.hm-dot.active { background: var(--orange); width: 24px; border-radius: 4px; }

/* Mobile */
@media (max-width: 767px) {
  .hero-mag { align-items: flex-end; }
  .hm-left  { padding: 0 1.5rem 210px; flex: 0 0 100%; }
  .hm-title { font-size: 1.75rem; }
  .hm-overlay {
    background: linear-gradient(to top,
      rgba(3,7,18,.92) 0%, rgba(3,7,18,.55) 42%, rgba(3,7,18,.18) 100%);
  }
  .hm-cards  { bottom: 24px; gap: 10px; padding: 0 16px 0 0; }
  .hm-card   { flex: 0 0 108px; height: 150px; }
  .hm-nav    { display: none; }
  .hm-dots   { display: flex; bottom: 182px; }
  .hm-counter { display: none; }
}

/* ══════════════════════════════════════
   ACCREDITATION BAND
══════════════════════════════════════ */
.accred-band {
  background: #fff;
  border-bottom: 1px solid #e4eaf3;
}
.accred-inner {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}
.accred-item {
  display: flex; align-items: center; gap: 14px;
  padding: 20px 24px;
  border-right: 1px solid #e4eaf3;
  transition: background .15s;
}
.accred-item:last-child { border-right: none; }
.accred-item:hover { background: #f8fafc; }
.accred-icon-wrap {
  width: 44px; height: 44px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; flex-shrink: 0;
}
.accred-name {
  font-family: var(--font-body);
  font-size: .875rem; font-weight: 700;
  color: var(--brand-navy); line-height: 1.3;
}
.accred-sub {
  font-family: var(--font-body);
  font-size: .72rem; color: var(--text-secondary);
  margin-top: 2px; line-height: 1.4;
}

/* ── Info card accent top borders ── */
.info-card--orange { border-top: 3px solid var(--orange); }
.info-card--blue   { border-top: 3px solid #1d4ed8; }
.info-card--teal   { border-top: 3px solid #0d9488; }

/* ══════════════════════════════════════
   VIDEO SECTION — 2-COLUMN LAYOUT
══════════════════════════════════════ */
.video-section { padding: 84px 0; background: var(--bg-secondary); }
.video-layout {
  display: grid;
  grid-template-columns: 1fr 1.7fr;
  gap: 72px;
  align-items: center;
}
.section-eyebrow {
  font-family: var(--font-body);
  font-size: .65rem; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--orange); display: block; margin-bottom: 14px;
}
.video-heading {
  font-family: var(--font-title);
  font-size: clamp(1.9rem, 3vw, 2.6rem);
  font-weight: 700; color: var(--brand-navy);
  line-height: 1.12; margin: 0;
}
.video-accent-bar {
  width: 44px; height: 4px;
  background: var(--orange); border-radius: 2px;
  margin: 22px 0 22px;
}
.video-desc {
  font-family: var(--font-body);
  font-size: .95rem; color: var(--text-secondary);
  line-height: 1.85; margin-bottom: 30px;
}
.video-cta-row { display: flex; gap: 20px; flex-wrap: wrap; align-items: center; }
.video-link {
  display: inline-flex; align-items: center; gap: .45rem;
  font-family: var(--font-body); font-size: .875rem; font-weight: 700;
  color: var(--brand-navy);
  border-bottom: 2px solid var(--brand-navy);
  padding-bottom: 2px;
  transition: color .2s, border-color .2s;
}
.video-link:hover { color: var(--orange); border-color: var(--orange); }
.video-link--ghost {
  color: var(--text-secondary);
  border-bottom-color: var(--border-color);
  font-weight: 600;
}
.video-link--ghost:hover { color: var(--orange); border-color: var(--orange); }
.video-embed-col .video-wrap {
  border-radius: 16px;
  box-shadow: 0 16px 56px rgba(0,55,123,.14);
  overflow: hidden;
}

/* ══════════════════════════════════════
   SECTION CHIP + HEADING PATTERN
══════════════════════════════════════ */
.section-chip {
  display: inline-flex; align-items: center; gap: .45rem;
  background: rgba(234,88,12,.1); color: var(--orange);
  font-family: var(--font-body); font-size: .65rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  padding: .32rem 1rem; border-radius: 20px;
  margin-bottom: 10px;
}
.section-h2 {
  font-family: var(--font-title);
  font-size: clamp(1.5rem, 2.5vw, 1.9rem);
  font-weight: 700; color: var(--brand-navy); margin: 0;
}
.news-section-header {
  display: flex; align-items: flex-end;
  justify-content: space-between; margin-bottom: 44px;
}
.section-more {
  display: inline-flex; align-items: center; gap: .2rem;
  font-family: var(--font-body); font-size: .875rem; font-weight: 600;
  color: var(--text-secondary); white-space: nowrap; margin-bottom: 2px;
  transition: color .2s;
}
.section-more:hover { color: var(--orange); }
.section-more .bi { font-size: 1.1rem; }

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */

/* ── Tablet (≤ 1024px) ── */
@media (max-width: 1024px) {
  .video-layout { grid-template-columns: 1fr; gap: 40px; }
  .promo-cards, .faculty-cards { grid-template-columns: 1fr 1fr; }
  .rankings-grid { grid-template-columns: 1fr 1fr; }
  .news-grid { grid-template-columns: 1fr 1fr; }
  .research-cards { grid-template-columns: 1fr 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; padding: 3rem 1.5rem 2rem; }
  .pes-inner-layout > .container { grid-template-columns: 1fr 200px; gap: 40px; }
  .home-hero-imgbox { width: 380px; height: 270px; }
}

/* ── Mobile (≤ 768px) ── */
@media (max-width: 768px) {
  /* ─ Header ─ */
  .main-header { display: none; }
  .mobile-header { display: flex; }
  .top-bar { display: block; }
  .top-bar-inner { padding: 7px 16px; }
  .top-bar-right .top-bar-link { display: none; }
  .top-bar-right .top-bar-apply-btn { padding: 7px 22px; font-size: .8rem; }

  /* ─ Home Hero ─ */
  .home-hero-inner { flex-direction: column; align-items: flex-start; padding: 44px 1.5rem 40px; }
  .home-hero-imgbox { display: none; }
  .home-hero-sub { max-width: 100%; }

  /* ─ Info cards ─ */
  .info-cards-grid { grid-template-columns: 1fr; }
  .info-cards-section { padding: 36px 0; }

  /* ─ Video ─ */
  .video-section { padding: 40px 0; }

  /* ─ About + announcements ─ */
  .about-announce-section { background: none; }
  .about-announce-grid { grid-template-columns: 1fr; }
  .about-panel { background: #eef4fb; }
  .announce-panel { background: var(--brand-navy); }
  .about-panel-inner { padding: 36px 1.5rem; }
  .announce-panel-inner { padding: 32px 1.5rem; }

  /* ─ Campus section: scroll-driven, no tablet overrides needed ─ */

  /* ─ Accred band ─ */
  .accred-inner { grid-template-columns: 1fr 1fr; }
  .accred-item { padding: 14px 16px; }
  .accred-item:nth-child(2) { border-right: none; }
  .accred-item:nth-child(3) { border-top: 1px solid #e4eaf3; }
  .accred-item:nth-child(4) { border-top: 1px solid #e4eaf3; border-right: none; }

  /* ─ Video layout ─ */
  .video-layout { grid-template-columns: 1fr; gap: 32px; }
  .video-section { padding: 52px 0; }

  /* ─ News ─ */
  .news-section { padding: 44px 0; }
  .news-section-header { flex-direction: column; align-items: flex-start; gap: 12px; margin-bottom: 28px; }
  .news-grid { grid-template-columns: 1fr; }

  /* ─ CTA banner ─ */
  .cta-banner { flex-direction: column; }
  .cta-right { flex: none; }
  .cta-left span { font-size: 15px; }

  /* ─ Hero slider (legacy) ─ */
  .hero-slider { height: 420px; }

  /* ─ Common sections ─ */
  .section { padding: 44px 0; }
  .section-title { font-size: 1.5rem; }
  .section-subtitle { font-size: 1.1rem; }

  /* ─ Promo / faculty / research cards ─ */
  .promo-cards, .faculty-cards { grid-template-columns: 1fr; height: auto; }
  .rankings-grid { grid-template-columns: 1fr 1fr; }
  .research-cards { grid-template-columns: 1fr; }
  .interest-cards { grid-template-columns: 1fr; }
  .campus-life-grid { grid-template-columns: 1fr; }
  .campus-life-news { grid-template-columns: 1fr 1fr; }
  .placements-inner { grid-template-columns: 1fr; }
  .news-tile-card { position: absolute; bottom: 12px; left: 12px; right: 12px; padding: 12px 14px; }

  /* ─ Footer ─ */
  .footer-grid { grid-template-columns: 1fr; padding: 2rem 1.25rem; }
  .footer-bottom-inner { padding: 1rem 1.25rem; flex-direction: column; gap: .75rem; text-align: center; }

  /* ─ Page hero ─ */
  .page-hero { padding: 32px 0 36px; }
  .page-hero h1 { font-size: 1.6rem; }
  .page-hero-deco { display: none; }
  .page-hero-inner { flex-direction: column; align-items: flex-start; }
  .page-hero-text { max-width: 100%; }

  /* ─ Inner page layout ─ */
  .pes-inner-layout { padding: 36px 0; }
  .pes-inner-layout > .container { grid-template-columns: 1fr; padding: 0 1.25rem; }
  .pes-inner-main { padding: 0 0 1.5rem 0; }
  .pes-inner-layout aside { position: static; }
  .pes-sidebar-nav { max-height: none; overflow-y: visible; margin-bottom: 28px; }
  .pes-inner-title { font-size: 1.5rem; }
  .dept-sec-text h3 { font-size: 17px !important; }
  .dept-sec-text p, .dept-sec-text ul li { font-size: .93rem; }

  /* ─ Split hero ─ */
  .split-hero { grid-template-columns: 1fr; }
  .split-hero-right { min-height: 260px; }
  .split-hero-left { padding: 40px 24px; }
  .split-hero-left h1 { font-size: 1.5rem; }

  /* ─ About page ─ */
  .about-intro-grid { grid-template-columns: 1fr; }
  .about-promo-band { grid-template-columns: 1fr; padding: 32px 24px; }
  .about-split { grid-template-columns: 1fr; }
  .about-split-img { min-height: 240px; }
  .about-split-text { padding: 32px 24px; }

  /* ─ Leadership ─ */
  .leadership-grid { grid-template-columns: 1fr 1fr; gap: 16px; }

  /* ─ NMC multi-column lists ─ */
  .nmc-list-grid, .nmc-list-grid-3 { columns: 1; }

  /* ─ Admissions doc items ─ */
  .doc-item { flex-wrap: wrap; }

  /* ─ Govt Approval ─ */
  .ga-intro { padding: 18px 16px; gap: 14px; margin-bottom: 20px; }
  .ga-intro i { font-size: 1.5rem; }
  .ga-intro-desc { font-size: .8rem; }
  .ga-table-wrap { border-radius: 8px; }
}

/* ── Small mobile (≤ 480px) ── */
@media (max-width: 480px) {
  .container { padding: 0 1rem; }
  .header-inner { padding: 0 1rem; }
  .footer-grid { padding: 2rem 1rem; }

  /* Hero buttons stack vertically */
  .home-hero-btns { flex-direction: column; }
  .home-hero-btn-primary,
  .home-hero-btn-secondary { width: 100%; justify-content: center; padding: .72rem 1.4rem; }

  /* Info card compact */
  .info-card { padding: 22px 18px 24px; }
  .info-card-icon { width: 44px; height: 44px; font-size: 18px; }

  /* Leadership single column */
  .leadership-grid { grid-template-columns: 1fr; }

  /* Inner page padding */
  .pes-inner-layout { padding: 28px 0; }
  .about-split-text { padding: 24px 18px; }
}

/* ══════════════════════════════════════
   THEME TOGGLE BUTTON
══════════════════════════════════════ */
.theme-toggle {
  background: none;
  border: 2px solid var(--border-color);
  border-radius: 14px;
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  font-size: 1rem;
  color: var(--brand-navy);
  flex-shrink: 0;
  transition: background .2s, border-color .2s, color .2s;
}
.theme-toggle:hover { background: var(--brand-navy); border-color: var(--brand-navy); color: #fff; }
.theme-toggle-mobile { margin-left: auto; margin-right: 8px; }
/* Show/hide icons based on mode */
.theme-icon-light { display: none; }
.theme-icon-dark  { display: block; }
[data-theme="dark"] .theme-icon-light { display: block; }
[data-theme="dark"] .theme-icon-dark  { display: none; }

/* Logo switching */
.logo-dark         { display: none; }
.logo-light        { display: block; }
[data-theme="dark"] .logo-light { display: none; }
[data-theme="dark"] .logo-dark  { display: block; filter: brightness(0) invert(1); }

/* Footer logo — always white (footer background is always dark) */
.footer-logo-wrap { margin-bottom: 20px; }
.footer-logo-light { display: none; }
.footer-logo-dark  { height: 36px; width: auto; display: block; filter: brightness(0) invert(1); }

/* ══════════════════════════════════════
   DARK MODE  — Rich navy palette
   Base:    #12182b  (page bg)
   Surface: #1a2236  (cards / panels)
   Raised:  #222d42  (elevated elements)
   Border:  #2e3d58  (dividers)
   Text1:   #e8eef6  (headings)
   Text2:   #9aaabb  (body)
   Text3:   #6277a0  (muted)
   Accent:  orange stays (#ff6c00)
══════════════════════════════════════ */
[data-theme="dark"] {
  --bg-primary:      #1a2236;
  --bg-secondary:    #12182b;
  --text-primary:    #e8eef6;
  --text-secondary:  #9aaabb;
  --text-tertiary:   #6277a0;
  --border-color:    #2e3d58;
  --brand-pale-blue: #1e2d47;
  --shadow-sm:  0 1px 4px rgba(0,0,0,.45);
  --shadow-md:  0 4px 18px rgba(0,0,0,.55);
  --shadow-lg:  0 12px 44px rgba(0,0,0,.65);
}

/* ─ Base ─ */
[data-theme="dark"] body { background: #12182b; color: #e8eef6; }
[data-theme="dark"] h1,[data-theme="dark"] h2,[data-theme="dark"] h3,
[data-theme="dark"] h4,[data-theme="dark"] h5,[data-theme="dark"] h6 { color: #e8eef6; }
[data-theme="dark"] p { color: #9aaabb; }

/* ─ Top bar ─ */
[data-theme="dark"] .top-bar { background: #0b1020; border-bottom-color: #1e2d47; }
[data-theme="dark"] .top-bar-right .top-bar-link { color: rgba(232,238,246,.6); }
[data-theme="dark"] .top-bar-right .top-bar-link:hover { color: #e8eef6; }
[data-theme="dark"] .top-bar-left-label { color: rgba(232,238,246,.7); }

/* ─ Header ─ */
[data-theme="dark"] .main-header {
  background: rgba(18,24,43,.96);
  border-bottom-color: #2e3d58;
  box-shadow: 0 2px 16px rgba(0,0,0,.4);
}
[data-theme="dark"] .main-nav > ul > li > a { color: #c8d8e8; }
[data-theme="dark"] .main-nav > ul > li > a:hover,
[data-theme="dark"] .main-nav > ul > li > a.active { color: var(--orange); }
[data-theme="dark"] .theme-toggle { border-color: #2e3d58; color: #e8eef6; background: #1a2236; }
[data-theme="dark"] .theme-toggle:hover { background: #222d42; border-color: var(--orange); }

/* ─ Mobile header ─ */
[data-theme="dark"] .mobile-header { background: #12182b; border-bottom-color: #2e3d58; }
[data-theme="dark"] .hamburger { border-color: #2e3d58; color: #e8eef6; }
[data-theme="dark"] .hamburger:hover { background: #1a2236; border-color: var(--orange); }

/* ─ Mega menu ─ */
[data-theme="dark"] .mega-menu { background: #1a2236 !important; border-color: #2e3d58 !important; box-shadow: 0 8px 32px rgba(0,0,0,.6); }
[data-theme="dark"] .mega-menu-inner { background: #1a2236; }
[data-theme="dark"] .mega-label { color: #6277a0; border-bottom-color: #2e3d58; }
[data-theme="dark"] .mega-item { border-color: #2e3d58 !important; }
[data-theme="dark"] .mega-item:hover { background: #222d42 !important; }
[data-theme="dark"] .mega-item-name { color: #e8eef6 !important; }
[data-theme="dark"] .mega-item-desc { color: #9aaabb !important; }
[data-theme="dark"] .mega-icon { background: #222d42 !important; }

/* ─ Mobile menu drawer ─ */
[data-theme="dark"] .mobile-menu { background: #12182b; border-color: #2e3d58; }
[data-theme="dark"] .mm-head { background: #1a2236; border-bottom-color: #2e3d58; }
[data-theme="dark"] .mm-close { color: #e8eef6; }
[data-theme="dark"] .mm-row { color: #c8d8e8; border-bottom-color: #2e3d58; }
[data-theme="dark"] .mm-row:hover { background: #1a2236; }
[data-theme="dark"] .mm-sub { background: #0f1525; }
[data-theme="dark"] .mm-sub li a { color: #9aaabb; border-bottom-color: #1e2d47; }
[data-theme="dark"] .mm-sub li a:hover { color: var(--orange); }
[data-theme="dark"] .mm-overlay { background: rgba(0,0,0,.7); }

/* ─ Page hero ─ */
[data-theme="dark"] .page-hero {
  background: linear-gradient(135deg, #0e1424 0%, #162040 50%, #1a2d5a 100%);
}
[data-theme="dark"] .page-hero-chip { background: rgba(255,108,0,.15); border-color: rgba(255,108,0,.3); color: var(--orange); }
[data-theme="dark"] .page-hero-text h1 { color: #e8eef6; }
[data-theme="dark"] .page-hero-sub { color: #9aaabb; }
[data-theme="dark"] .deco-card-1 { background: rgba(255,108,0,.12); }
[data-theme="dark"] .deco-card-2 { background: rgba(30,60,100,.4); }
[data-theme="dark"] .deco-card-3 { background: rgba(20,40,80,.35); }

/* ─ Hero slider ─ */
[data-theme="dark"] .home-hero { background: #0b1020; }
[data-theme="dark"] .hero-stat-card { background: rgba(26,34,54,.9); border-color: #2e3d58; }
[data-theme="dark"] .hero-stat-num { color: var(--orange); }
[data-theme="dark"] .hero-stat-label { color: #9aaabb; }

/* ─ Accreditation band ─ */
[data-theme="dark"] .accred-band { background: #1a2236; border-bottom-color: #2e3d58; }
[data-theme="dark"] .accred-item { border-right-color: #2e3d58; }
[data-theme="dark"] .accred-item:hover { background: #222d42; }
[data-theme="dark"] .accred-name { color: #e8eef6; }
[data-theme="dark"] .accred-sub { color: #9aaabb; }

/* ─ Info cards ─ */
[data-theme="dark"] .info-cards-section { background: #1a2236; }
[data-theme="dark"] .info-card { background: #222d42; border-color: #2e3d58; }
[data-theme="dark"] .info-card:hover { border-color: var(--orange); }
[data-theme="dark"] .info-card-title { color: #e8eef6; }
[data-theme="dark"] .info-card-text { color: #9aaabb; }
[data-theme="dark"] .info-card-links { border-top-color: #2e3d58; }
[data-theme="dark"] .info-card-links a { color: #9aaabb; }
[data-theme="dark"] .info-card-links a:hover { color: var(--orange); }

/* ─ About + announcements ─ */
[data-theme="dark"] .about-announce-section { background: linear-gradient(to right, #1a2236 60%, #0e1424 60%) !important; }
[data-theme="dark"] .about-panel { background: #1a2236 !important; }
[data-theme="dark"] .about-heading { color: #e8eef6 !important; }
[data-theme="dark"] .about-text { color: #9aaabb !important; }
[data-theme="dark"] .announce-panel { background: #0e1424 !important; }
[data-theme="dark"] .section-title { color: #e8eef6 !important; }
[data-theme="dark"] .section-subtitle { color: #9aaabb !important; }
[data-theme="dark"] .about-readmore { color: var(--orange); border-color: var(--orange); }

/* ─ Video section ─ */
[data-theme="dark"] .video-section { background: #12182b; }
[data-theme="dark"] .video-text h2 { color: #e8eef6; }

/* ─ Academics / promo cards ─ */
[data-theme="dark"] .academics-section { background: #1a2236; }
[data-theme="dark"] .promo-card { background: #222d42; border-color: #2e3d58; }
[data-theme="dark"] .promo-card:hover { border-color: var(--orange); }
[data-theme="dark"] .promo-card-title { color: #e8eef6; }
[data-theme="dark"] .promo-card-desc { color: #9aaabb; }

/* ─ Rankings ─ */
[data-theme="dark"] .ranking-card { background: #222d42; border-color: #2e3d58; }
[data-theme="dark"] .ranking-card-label { color: #9aaabb; }

/* ─ News section ─ */
[data-theme="dark"] .news-section { background: #12182b; }
[data-theme="dark"] .news-card { background: #1a2236; border-color: #2e3d58; }
[data-theme="dark"] .news-card:hover { border-color: var(--orange); }
[data-theme="dark"] .news-card-title { color: #e8eef6; }
[data-theme="dark"] .news-card-meta { color: #6277a0; }
[data-theme="dark"] .news-card-excerpt { color: #9aaabb; }
[data-theme="dark"] .news-title { color: #e8eef6; }

/* ─ Research section ─ */
[data-theme="dark"] .research-section { background: #1a2236; }
[data-theme="dark"] .research-card { background: #222d42; border-color: #2e3d58; }
[data-theme="dark"] .research-card-title { color: #e8eef6; }

/* ─ Campus / footer top ─ */
[data-theme="dark"] .campuses-stage { background: linear-gradient(160deg, #09111e 0%, #050c14 100%) !important; }

/* ─ Inner page layout ─ */
[data-theme="dark"] .pes-inner-layout { background: #12182b; }
[data-theme="dark"] .pes-inner-main { color: #9aaabb; }
[data-theme="dark"] .pes-inner-main h1,
[data-theme="dark"] .pes-inner-main h2,
[data-theme="dark"] .pes-inner-main h3,
[data-theme="dark"] .pes-inner-main h4 { color: #e8eef6 !important; }
[data-theme="dark"] .pes-inner-rule { border-color: #2e3d58; }

/* ─ Sidebar ─ */
[data-theme="dark"] .pes-sidebar-nav { background: #1a2236; border-color: #2e3d58; box-shadow: none; }
[data-theme="dark"] .pes-sidebar-nav::before { background: linear-gradient(90deg, #1a3660, #1e2d47); }
[data-theme="dark"] .pes-sidebar-nav ul li a { color: #9aaabb; border-bottom-color: #2e3d58; }
[data-theme="dark"] .pes-sidebar-nav ul li a:hover { color: #e8eef6; background: #222d42; padding-left: 1.4rem; }
[data-theme="dark"] .pes-sidebar-nav ul li a.active { color: var(--orange); background: rgba(255,108,0,.08); }
[data-theme="dark"] .pes-sidebar-nav ul li a::before { background: #2e3d58; }
[data-theme="dark"] .pes-sidebar-nav ul li a.active::before { background: var(--orange); }
[data-theme="dark"] .pes-sidebar-group-label { color: #6277a0 !important; }

/* ─ Dept zig-zag pages ─ */
[data-theme="dark"] .dept-section { border-bottom-color: #2e3d58; }
[data-theme="dark"] .dept-sec-text h3 { color: #e8eef6 !important; border-bottom-color: var(--orange) !important; }
[data-theme="dark"] .dept-sec-text p,
[data-theme="dark"] .dept-sec-text ul li { color: #9aaabb; }
[data-theme="dark"] .dept-sec-text ul li::before { color: var(--orange); }

/* ─ Tables ─ */
[data-theme="dark"] .infra-table th,
[data-theme="dark"] .ga-table thead tr,
[data-theme="dark"] .dept-faculty-table th { background: #0e1424 !important; }
[data-theme="dark"] .infra-table td,
[data-theme="dark"] .ga-table td,
[data-theme="dark"] .dept-faculty-table td { border-color: #2e3d58; color: #9aaabb; }
[data-theme="dark"] .infra-table tbody tr:nth-child(even) td,
[data-theme="dark"] .ga-table tbody tr:nth-child(even) td { background: #1a2236; }
[data-theme="dark"] .infra-table tbody tr:hover td,
[data-theme="dark"] .ga-table tbody tr:hover td { background: #222d42; }

/* ─ Footer ─ */
[data-theme="dark"] footer { background: #090e1a; }
[data-theme="dark"] .footer-bottom { background: #060a14; border-top-color: #1e2d47; }
[data-theme="dark"] .footer-copyright { color: #6277a0; }
[data-theme="dark"] footer h3 { color: #e8eef6; }
[data-theme="dark"] footer a { color: #9aaabb; }
[data-theme="dark"] footer a:hover { color: var(--orange); }

/* ─ Back to top ─ */
[data-theme="dark"] .back-to-top { background: #1a2236; border-color: #2e3d58; color: #e8eef6; }

/* ─ Section headings (inner) ─ */
[data-theme="dark"] .dept-sec-text h3 {
  border-bottom-color: var(--orange) !important;
  background: none !important;
  color: #e8eef6 !important;
}

/* ─ Page-specific cards ─ */
[data-theme="dark"] .leadership-card { background: #1a2236; }
[data-theme="dark"] .adm-prog-card,
[data-theme="dark"] .adm-step,
[data-theme="dark"] .adm-link-item,
[data-theme="dark"] .adm-hours-card { background: #1a2236; border-color: #2e3d58; }
[data-theme="dark"] .adm-link-label { color: #e8eef6; }
[data-theme="dark"] .adm-link-sub { color: #9aaabb; }
[data-theme="dark"] .adm-step-label { color: #e8eef6; }
[data-theme="dark"] .adm-step-desc { color: #9aaabb; }
[data-theme="dark"] .adm-hours-row { border-bottom-color: #2e3d58; }
[data-theme="dark"] .adm-hours-heading { color: #e8eef6; }
[data-theme="dark"] .adm-hours-day { color: #e8eef6; }
[data-theme="dark"] .adm-hours-badge { background: rgba(234,88,12,.18); color: var(--orange); }
[data-theme="dark"] .adm-hours-time { color: #6b7e99; }

/* ─ Marb / careers cards ─ */
[data-theme="dark"] .marb-card,
[data-theme="dark"] .car-job,
[data-theme="dark"] .car-why-card { background: #1a2236; border-color: #2e3d58; }
[data-theme="dark"] .car-job-title { color: #e8eef6; }
[data-theme="dark"] .car-dept-tag { background: #222d42; border-color: #2e3d58; color: #9aaabb; }
[data-theme="dark"] .car-why-title { color: #e8eef6; }
[data-theme="dark"] .car-why-desc { color: #9aaabb; }
[data-theme="dark"] .car-why-icon { background: #222d42; }
[data-theme="dark"] .car-intro { background: #1a2236; border-left-color: var(--orange); }
[data-theme="dark"] .car-intro p { color: #9aaabb; }
[data-theme="dark"] .marb-card-title { color: #e8eef6; }
[data-theme="dark"] .marb-card-desc { color: #9aaabb; }
[data-theme="dark"] .marb-card-icon { background: #222d42; color: #9aaabb; }
[data-theme="dark"] .marb-card-btn { border-color: #9aaabb; color: #9aaabb; }
[data-theme="dark"] .marb-card-btn:hover { background: var(--orange); border-color: var(--orange); color: #fff; }
[data-theme="dark"] .marb-card-btn.pdf i { color: #f87171; }
[data-theme="dark"] .marb-card:hover .marb-card-btn.pdf i { color: #fff; }

/* ─ Accordion (Undergraduate / Postgraduate) ─ */
[data-theme="dark"] .acc-item { border-color: #2e3d58; }
[data-theme="dark"] .acc-header { background: #1a2236; color: #e8eef6; }
[data-theme="dark"] .acc-header:hover { background: #222d42; }
[data-theme="dark"] .acc-header.open { background: var(--orange); color: #fff; }
[data-theme="dark"] .acc-body { background: #12182b; border-top-color: #2e3d58; }
[data-theme="dark"] .acc-body p { color: #9aaabb; }

/* ─ Infrastructure cards ─ */
[data-theme="dark"] .hostel-card,
[data-theme="dark"] .apt-card,
[data-theme="dark"] .infra-vm-card,
[data-theme="dark"] .infra-detail-row,
[data-theme="dark"] .infra-info-row { background: #1a2236; border-color: #2e3d58; }
[data-theme="dark"] .hostel-row-label { color: #9aaabb; }
[data-theme="dark"] .hostel-row-val { color: #e8eef6; }
[data-theme="dark"] .apt-card-name { color: #9aaabb; }
[data-theme="dark"] .apt-card-count { color: #e8eef6; }
[data-theme="dark"] .infra-vm-card p,
[data-theme="dark"] .infra-vm-card li { color: #9aaabb; }
[data-theme="dark"] .infra-detail-row span,
[data-theme="dark"] .infra-info-row span { color: #9aaabb; }

/* ─ Vision Mission cards ─ */
[data-theme="dark"] .vm-card { background: #1a2236; border-color: #2e3d58; box-shadow: 0 2px 12px rgba(0,0,0,.25); }
[data-theme="dark"] .vm-card-title { color: #a8c8f0; }
[data-theme="dark"] .vm-card-body { color: #9aaabb; }

/* ─ NMC CBME Timetable cards ─ */
[data-theme="dark"] .tt-card { background: #1a2236; border-color: #2e3d58; }
[data-theme="dark"] .tt-card-icon { background: #1e2d4a; color: #a8c8f0; }
[data-theme="dark"] .tt-card-name { color: #e8eef6; }

/* ─ Dr H R Krishna Rao ─ */
[data-theme="dark"] .kr-profile,
[data-theme="dark"] .kr-card { background: #1a2236; border-color: #2e3d58; }
[data-theme="dark"] .kr-card li,
[data-theme="dark"] .kr-card p { color: #9aaabb; }
[data-theme="dark"] .kr-contact li { color: #9aaabb; }
[data-theme="dark"] .kr-contact a { color: #a8c8f0; }
[data-theme="dark"] .kr-tl-item { background: #1a2236; border-color: #2e3d58; }
[data-theme="dark"] .kr-tl-role { background: #222d42; border-left-color: #2e3d58; }
[data-theme="dark"] .kr-tl-role-name { color: #a8c8f0; }
[data-theme="dark"] .kr-section-title { color: #a8c8f0; }

/* ─ Citizen's Charter ─ */
[data-theme="dark"] .cc-card { background: #1a2236; border-color: #2e3d58; }
[data-theme="dark"] .cc-card li { background: #222d42; color: #9aaabb; }
[data-theme="dark"] .cc-card li:hover { background: #263350; }
[data-theme="dark"] .cc-card p { color: #9aaabb; }
[data-theme="dark"] .cc-content-box { background: #1a2236; }
[data-theme="dark"] .cc-content-box p { color: #9aaabb; }
[data-theme="dark"] .cc-info { background: #1a2236; }
[data-theme="dark"] .cc-info-row span { color: #9aaabb; }
[data-theme="dark"] .cc-info-row i { color: #a8c8f0; }
[data-theme="dark"] .cc-section-title { color: #a8c8f0; }

/* ─ Contact ─ */
[data-theme="dark"] .ct-card,
[data-theme="dark"] .ct-dept-card { background: #1a2236; border-color: #2e3d58; }
[data-theme="dark"] .ct-card-title { color: #e8eef6; }
[data-theme="dark"] .ct-card-desc { color: #9aaabb; }
[data-theme="dark"] .ct-card-value a { color: var(--orange); }
[data-theme="dark"] .ct-dept-name { color: #e8eef6; }
[data-theme="dark"] .ct-dept-row span { color: #9aaabb; }

/* ══════════════════════════════════════
   PAGE-SPECIFIC STYLES
══════════════════════════════════════ */

/* ── Video Tour (Home) ── */
.vt-layout { display:grid; grid-template-columns:1fr 2fr 1fr; gap:14px; align-items:stretch; min-height:460px; }
.vt-img-col { display:flex; flex-direction:column; gap:14px; }
.vt-img-big { flex:2; border-radius:12px; overflow:hidden; min-height:0; box-shadow:0 8px 32px rgba(0,55,123,.18); }
.vt-img-small { flex:1; border-radius:12px; overflow:hidden; min-height:0; box-shadow:0 8px 32px rgba(0,55,123,.18); }
.vt-img-big img, .vt-img-small img { width:100%; height:100%; object-fit:cover; display:block; }
.vt-video-col { display:flex; flex-direction:column; }
.vt-video-wrap { position:relative; width:100%; flex:1; min-height:0; border-radius:14px; overflow:hidden; box-shadow:0 8px 32px rgba(0,55,123,.18); }
.vt-video-wrap iframe { position:absolute; inset:0; width:100%; height:100%; border:none; display:block; }
@media (max-width:900px) {
  .vt-layout { grid-template-columns:1fr; min-height:auto; }
  .vt-img-col { flex-direction:row; height:180px; }
  .vt-img-big, .vt-img-small { flex:1; }
  .vt-video-wrap { padding-top:56.25%; }
}

/* ── Dr H R Krishna Rao ── */
.kr-section-title { font-family:var(--font-title); font-size:1.05rem; font-weight:700; color:#00377b; padding-left:14px; border-left:3px solid #ea580c; margin-bottom:16px; }
.kr-profile { display:grid; grid-template-columns:200px 1fr; gap:36px; background:#fff; border:1px solid #a8d4f5; border-radius:14px; padding:32px; margin-bottom:28px; }
.kr-photo { width:100%; border-radius:10px; object-fit:cover; display:block; }
.kr-name { font-family:var(--font-title); font-size:1.7rem; font-weight:700; color:#00377b; margin-bottom:4px; }
.kr-role { font-size:.97rem; color:#ea580c; font-weight:600; margin-bottom:20px; }
.kr-bar { height:3px; width:56px; background:#ea580c; border:none; border-radius:2px; margin-bottom:22px; }
.kr-contact { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; }
.kr-contact li { display:flex; align-items:center; gap:10px; font-size:.9rem; color:#4a5568; }
.kr-contact li i { color:#00377b; width:18px; font-size:1rem; }
.kr-contact a { color:#00377b; text-decoration:none; }
.kr-contact a:hover { text-decoration:underline; }
.kr-2col { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:28px; }
.kr-card { background:#fff; border:1px solid #a8d4f5; border-radius:12px; padding:24px 26px; }
.kr-card ul { padding-left:18px; margin-bottom:10px; }
.kr-card li { color:#4a5568; font-size:.93rem; line-height:1.75; margin-bottom:4px; }
.kr-card p { color:#4a5568; font-size:.93rem; line-height:1.75; margin:0; }
.kr-timeline { position:relative; padding-left:36px; margin-bottom:32px; }
.kr-timeline::before { content:''; position:absolute; left:13px; top:8px; bottom:8px; width:2px; background:linear-gradient(to bottom,#00377b,#a8d4f5); }
.kr-tl-item { position:relative; margin-bottom:28px; background:#fff; border:1px solid #e2e8f0; border-radius:14px; overflow:hidden; box-shadow:0 2px 8px rgba(0,55,123,.07); transition:box-shadow .25s,transform .25s; }
.kr-tl-item:hover { box-shadow:0 6px 24px rgba(0,55,123,.13); transform:translateX(4px); }
.kr-tl-item::before { content:''; position:absolute; left:-29px; top:22px; width:14px; height:14px; border-radius:50%; background:#ea580c; border:3px solid #fff; box-shadow:0 0 0 2px #00377b; z-index:1; }
.kr-tl-header { display:flex; align-items:center; gap:14px; background:#00377b; padding:14px 20px; border-left:5px solid #ea580c; }
.kr-tl-num { flex-shrink:0; width:28px; height:28px; border-radius:50%; background:#ea580c; color:#fff; font-size:.72rem; font-weight:700; display:flex; align-items:center; justify-content:center; }
.kr-tl-institution { font-size:.9rem; font-weight:700; color:#fff; line-height:1.4; }
.kr-tl-right { padding:14px 20px; display:flex; flex-direction:column; gap:8px; }
.kr-tl-role { display:flex; align-items:center; justify-content:space-between; padding:8px 14px; border-radius:8px; background:#f4f8fd; border-left:3px solid #a8d4f5; gap:12px; }
.kr-tl-role-name { font-size:.88rem; font-weight:600; color:#00377b; }
.kr-tl-period { font-size:.76rem; color:#fff; white-space:nowrap; flex-shrink:0; background:#00377b; padding:3px 10px; border-radius:20px; }
.kr-dark { display:grid; grid-template-columns:1fr 1fr; gap:20px; background:#00377b; border-radius:14px; padding:32px; }
.kr-dark-title { font-family:var(--font-title); font-size:1.05rem; font-weight:700; color:#fff; margin-bottom:14px; padding-left:14px; border-left:3px solid #ea580c; }
.kr-dark ul { padding-left:18px; margin:0; }
.kr-dark li { color:#fff !important; font-size:.9rem; line-height:1.8; margin-bottom:6px; }
.kr-dark p { color:#fff !important; font-size:.93rem; line-height:1.8; margin:0; }
@media (max-width:768px) {
  .kr-profile { grid-template-columns:1fr; }
  .kr-2col { grid-template-columns:1fr; }
  .kr-dark { grid-template-columns:1fr; }
  .kr-photo { max-width:180px; }
}

/* ── Dr M R Doreswamy ── */
.dm-wrap { display:flex; gap:32px; align-items:flex-start; }
.dm-person-col { flex:0 0 220px; display:flex; flex-direction:column; gap:14px; position:relative; }
.dm-photo-card { border-radius:12px; overflow:hidden; border:1px solid #e2e8f0; position:relative; cursor:pointer; }
.dm-photo-card img { width:100%; height:260px; display:block; object-fit:cover; object-position:top; transition:transform .3s; }
.dm-photo-card:hover img { transform:scale(1.04); }
.dm-photo-overlay { position:absolute; top:10px; right:10px; z-index:10; }
.dm-photo-overlay-btn { width:38px; height:38px; background:rgba(255,255,255,.82); border:none; border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; text-decoration:none; box-shadow:0 2px 8px rgba(0,0,0,.18); transition:background .2s; }
.dm-photo-overlay-btn:hover { background:#fff; }
.dm-photo-overlay-btn i { font-size:15px; color:#1a73e8; }
.dm-info-card { background:#fff; border:1px solid #e2e8f0; border-radius:12px; padding:16px 18px 18px; }
.dm-badge { font-size:.7rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:#ea580c; margin-bottom:6px; }
.dm-name { font-family:var(--font-title); font-size:1rem; font-weight:700; color:var(--brand-navy); line-height:1.4; margin-bottom:6px; }
.dm-sub { font-size:.82rem; color:#718096; line-height:1.5; }
.dm-content-col { flex:1; min-width:0; }
.dm-title { font-family:var(--font-title); font-size:1.55rem; font-weight:700; color:var(--brand-navy); margin:0 0 22px; }
.dm-content-col p { font-size:.96rem; color:var(--text-secondary); line-height:1.9; margin-bottom:18px; }
.dm-quote { background:#00377b; border-radius:12px; padding:28px 32px; margin-top:8px; margin-bottom:28px; }
.dm-quote p { color:#fff !important; font-size:.97rem; font-weight:600; line-height:1.85; margin:0; }
@media (max-width:768px) {
  .dm-wrap { flex-direction:column; }
  .dm-person-col { flex:none; width:100%; max-width:240px; }
}

/* ── Vision Mission ── */
.vm-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; padding:32px 0 8px; }
.vm-card { background:#fff; border:1px solid #a8d4f5; border-radius:14px; padding:32px 28px 36px; box-shadow:0 2px 12px rgba(0,55,123,.07); transition:transform .2s,box-shadow .2s; }
.vm-card:hover { transform:translateY(-4px); box-shadow:0 8px 28px rgba(0,55,123,.13); }
.vm-card-icon { width:56px; height:56px; border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:24px; margin-bottom:20px; background:#00377b !important; }
.vm-card-icon i { color:#fff !important; }
.vm-card-title { font-family:var(--font-title); font-size:1.15rem; font-weight:700; color:#00377b; margin-bottom:12px; }
.vm-card-body { font-size:.95rem; color:#4a5568; line-height:1.75; margin:0; }
@media (max-width:768px) { .vm-cards { grid-template-columns:1fr; } }

/* ── NMC CBME Timetable ── */
.tt-section { margin-bottom: 40px; }
.tt-section-title { font-family: var(--font-title); font-size: 1.15rem; font-weight: 700; color: var(--brand-navy); border-left: 4px solid var(--orange); padding: 5px 0 5px 14px; margin: 0 0 20px; }
.tt-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.tt-card { background: #fff; border: 1px solid #dbe8f5; border-radius: 14px; padding: 22px 18px 18px; display: flex; flex-direction: column; align-items: flex-start; gap: 12px; transition: transform .2s, box-shadow .2s; }
.tt-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,55,123,.12); }
.tt-card.tt-card--inactive { opacity: .55; pointer-events: none; }
.tt-card-icon { width: 44px; height: 44px; border-radius: 10px; background: #eef4ff; display: flex; align-items: center; justify-content: center; font-size: 1.2rem; color: var(--brand-navy); flex-shrink: 0; }
.tt-card.tt-card--inactive .tt-card-icon { background: #f1f5f9; color: #94a3b8; }
.tt-card-name { font-family: var(--font-body); font-size: .9rem; font-weight: 600; color: var(--brand-navy); line-height: 1.4; flex: 1; }
.tt-card-btn { display: inline-flex; align-items: center; gap: 6px; font-size: .78rem; font-weight: 600; color: #fff; background: var(--brand-navy); border-radius: 20px; padding: 5px 14px; text-decoration: none; transition: background .2s; }
.tt-card-btn:hover { background: var(--orange); }
.tt-card-coming { font-size: .75rem; color: #94a3b8; font-weight: 500; }
@media (max-width: 900px) { .tt-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 600px) { .tt-grid { grid-template-columns: repeat(2, 1fr); } }

/* ── Citizen's Charter ── */
.cc-section-title { font-family:var(--font-title); font-size:1.05rem; font-weight:700; color:#00377b; padding-left:14px; border-left:3px solid #ea580c; margin-bottom:14px; }
.cc-2col { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:28px; }
.cc-card { background:#fff; border:1px solid #a8d4f5; border-radius:12px; padding:26px 28px; }
.cc-card-accent { font-size:.88rem; color:#ea580c; font-weight:600; margin-bottom:14px; }
.cc-card ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px; }
.cc-card li { display:flex; align-items:flex-start; gap:10px; background:#f4f8fd; border-left:3px solid #ea580c; border-radius:0 8px 8px 0; padding:10px 14px; color:#2d3748; font-size:.9rem; line-height:1.65; transition:background .2s,transform .2s; }
.cc-card li:hover { background:#e8f0fb; transform:translateX(3px); }
.cc-card li::before { content:'\2714'; color:#ea580c; font-size:.85rem; font-weight:700; margin-top:2px; flex-shrink:0; }
.cc-card p { color:#4a5568; font-size:.93rem; line-height:1.8; margin:0; }
.cc-dark { display:grid; grid-template-columns:1fr 1fr; gap:20px; background:#00377b; border-radius:14px; padding:32px; margin-bottom:28px; }
.cc-dark-title { font-family:var(--font-title); font-size:1.05rem; font-weight:700; color:#fff; margin-bottom:12px; padding-left:14px; border-left:3px solid #ea580c; }
.cc-dark p { color:rgba(255,255,255,.85); font-size:.93rem; line-height:1.8; margin-bottom:10px; }
.cc-dark p:last-child { margin-bottom:0; }
.cc-image-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:28px; align-items:stretch; }
.cc-image-box { border-radius:12px; overflow:hidden; min-height:280px; background-size:cover; background-position:center; }
.cc-content-box { background:#f0f6ff; border-radius:12px; padding:28px; }
.cc-content-box p { color:#4a5568; font-size:.93rem; line-height:1.8; margin:0; }
.cc-info { background:#f8fafc; border-radius:14px; padding:28px 32px; display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.cc-info-row { display:flex; gap:11px; margin-bottom:10px; }
.cc-info-row i { color:#00377b; font-size:1rem; margin-top:2px; flex-shrink:0; }
.cc-info-row span { font-size:.9rem; color:#4a5568; line-height:1.7; }
@media (max-width:768px) { .cc-2col,.cc-dark,.cc-image-grid,.cc-info { grid-template-columns:1fr; } }

/* ── MARB ── */
.marb-intro { background:linear-gradient(135deg,var(--brand-navy) 60%,#1e4fa0); border-radius:14px; padding:28px 32px; display:flex; align-items:center; gap:24px; margin-bottom:36px; border-left:6px solid var(--orange); }
.marb-intro-icon { font-size:2.4rem; color:var(--orange); flex-shrink:0; }
.marb-intro-title { font-family:var(--font-title); font-size:1.1rem; font-weight:700; color:#fff; margin:0 0 6px; }
.marb-intro-desc { font-family:var(--font-body); font-size:.87rem; color:rgba(255,255,255,.8); line-height:1.65; margin:0; }
.marb-heading { font-family:var(--font-title); font-size:1.1rem; font-weight:700; color:var(--brand-navy); display:inline-block; padding-bottom:10px; border-bottom:3px solid var(--orange); margin-bottom:24px; }
.marb-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:12px; }
.marb-card { background:#fff; border:1px solid var(--border-color); border-radius:14px; overflow:hidden; box-shadow:0 2px 10px rgba(0,0,0,.06); transition:transform .28s,box-shadow .28s,border-color .28s; display:flex; flex-direction:column; }
.marb-card:hover { transform:translateY(-4px); box-shadow:0 10px 30px rgba(0,0,0,.11); border-color:var(--orange); }
.marb-card-img { height:140px; background-size:cover; background-position:center; position:relative; overflow:hidden; flex-shrink:0; }
.marb-card-img::after { content:''; position:absolute; inset:0; background:linear-gradient(to top,rgba(0,15,50,.65) 0%,transparent 60%); }
.marb-card-num { position:absolute; top:12px; left:14px; z-index:2; background:var(--orange); color:#fff; font-family:var(--font-body); font-size:.7rem; font-weight:700; width:28px; height:28px; border-radius:50%; display:flex; align-items:center; justify-content:center; }
.marb-card-body { padding:20px 20px 16px; flex:1; display:flex; flex-direction:column; }
.marb-card-icon { width:40px; height:40px; border-radius:10px; background:#eff6ff; display:flex; align-items:center; justify-content:center; font-size:1.1rem; color:var(--brand-navy); margin-bottom:12px; transition:background .25s; }
.marb-card:hover .marb-card-icon { background:var(--orange); color:#fff; }
.marb-card-title { font-family:var(--font-body); font-size:.9rem; font-weight:700; color:var(--brand-navy); margin:0 0 8px; line-height:1.4; }
.marb-card-desc { font-family:var(--font-body); font-size:.8rem; color:var(--text-secondary); line-height:1.6; margin:0 0 16px; flex:1; }
.marb-card-btn { display:inline-flex; align-items:center; gap:7px; align-self:flex-start; font-family:var(--font-body); font-size:.78rem; font-weight:700; padding:7px 16px; border-radius:6px; text-decoration:none; border:2px solid var(--brand-navy); color:var(--brand-navy); transition:background .2s,color .2s; }
.marb-card-btn:hover { background:var(--brand-navy); color:#fff; }
.marb-card-btn.pdf i { color:#e53e3e; }
.marb-card:hover .marb-card-btn.pdf i { color:#fff; }
@media (max-width:768px) { .marb-grid { grid-template-columns:1fr; } }

/* ── Govt Approval ── */
.ga-intro { background:linear-gradient(135deg,var(--brand-navy) 60%,#1e4fa0); border-radius:14px; padding:24px 28px; display:flex; align-items:center; gap:20px; margin-bottom:32px; border-left:6px solid var(--orange); }
.ga-intro i { font-size:2rem; color:var(--orange); flex-shrink:0; }
.ga-intro-title { font-family:var(--font-title); font-size:1rem; font-weight:700; color:#fff; margin:0 0 4px; }
.ga-intro-desc { font-family:var(--font-body); font-size:.83rem; color:rgba(255,255,255,.8); line-height:1.6; margin:0; }
.ga-heading { font-family:var(--font-title); font-size:1.1rem; font-weight:700; color:#9aaabb; display:inline-block; padding-bottom:10px; border-bottom:3px solid var(--orange); margin-bottom:22px; }
.ga-table-wrap { overflow-x:auto; border-radius:12px; border:1px solid var(--border-color); box-shadow:0 2px 10px rgba(0,0,0,.06); }
.ga-table { width:100%; min-width:680px; border-collapse:collapse; font-family:var(--font-body); font-size:.84rem; }
.ga-table thead tr { background:var(--brand-navy); }
.ga-table th { padding:13px 14px; text-align:left; color:#fff; font-weight:600; font-size:.78rem; letter-spacing:.04em; text-transform:uppercase; border-right:1px solid rgba(255,255,255,.12); white-space:nowrap; }
.ga-table th:last-child { border-right:none; }
.ga-table td { padding:10px 14px; border-bottom:1px solid var(--border-color); color:var(--text-secondary); vertical-align:middle; line-height:1.55; }
.ga-table tbody tr:last-child td { border-bottom:none; }
.ga-table tbody tr:nth-child(even) td { background:#f8fafc; }
.ga-table tbody tr:hover td { background:#f1f5f9; }
.ga-table td:first-child { font-weight:700; color:#9aaabb; text-align:center; width:48px; }
.ga-table td:nth-child(2) { font-weight:600; color:#9aaabb; }
.ga-table td:nth-child(3) { font-size:.8rem; }
.ga-table a { display:inline-flex; align-items:center; gap:4px; background:#f1f5f9; color:#9aaabb; font-size:.75rem; font-weight:600; padding:3px 10px; border-radius:20px; text-decoration:none; margin:2px 3px 2px 0; border:1px solid #cbd5e1; transition:background .2s,color .2s; white-space:nowrap; }
.ga-table a:hover { background:var(--orange); color:#fff; border-color:var(--orange); }
.ga-table a::before { content:'\f1c1'; font-family:FontAwesome; font-size:.7rem; }

/* ── Careers ── */
.car-intro { font-size:1rem; color:var(--text-secondary); line-height:1.85; margin-bottom:40px; padding:24px 28px; background:#eff6ff; border-left:5px solid var(--brand-navy); border-radius:0 10px 10px 0; }
.car-heading { font-family:var(--font-title); font-size:1.15rem; font-weight:700; color:var(--brand-navy); display:inline-block; padding-bottom:10px; border-bottom:3px solid var(--orange); margin-bottom:24px; }
.car-jobs { display:flex; flex-direction:column; gap:18px; margin-bottom:44px; }
.car-job { background:#fff; border:1px solid var(--border-color); border-radius:14px; padding:0; overflow:hidden; box-shadow:0 2px 10px rgba(0,0,0,.06); transition:transform .25s,box-shadow .25s,border-color .25s; }
.car-job:hover { transform:translateY(-3px); box-shadow:0 8px 28px rgba(0,0,0,.1); border-color:var(--orange); }
.car-job-head { display:flex; align-items:center; justify-content:space-between; padding:18px 22px; border-bottom:1px solid var(--border-color); gap:16px; }
.car-job-title-wrap { display:flex; align-items:center; gap:14px; }
.car-job-icon { width:44px; height:44px; border-radius:10px; background:#eff6ff; display:flex; align-items:center; justify-content:center; font-size:1.2rem; color:var(--brand-navy); flex-shrink:0; }
.car-job-title { font-family:var(--font-body); font-size:.98rem; font-weight:700; color:var(--brand-navy); margin:0; }
.car-job-badge { font-family:var(--font-body); font-size:.68rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; white-space:nowrap; padding:4px 12px; border-radius:20px; flex-shrink:0; }
.badge-faculty { background:#eff6ff; color:#1d4ed8; }
.badge-clinical { background:#fff1f2; color:#be123c; }
.badge-support { background:#f0fdf4; color:#15803d; }
.badge-allied { background:#fef3c7; color:#b45309; }
.car-job-body { padding:16px 22px; }
.car-job-depts { display:flex; flex-wrap:wrap; gap:8px; }
.car-dept-tag { font-family:var(--font-body); font-size:.78rem; color:var(--text-secondary); background:#f8fafc; border:1px solid var(--border-color); padding:4px 12px; border-radius:6px; transition:background .2s,color .2s,border-color .2s; }
.car-job:hover .car-dept-tag { background:#fff7ed; border-color:#fed7aa; color:#c2410c; }
.car-why { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-bottom:44px; }
.car-why-card { background:#fff; border:1px solid var(--border-color); border-radius:14px; padding:24px 20px; text-align:center; box-shadow:0 2px 8px rgba(0,0,0,.05); transition:transform .25s,box-shadow .25s; }
.car-why-card:hover { transform:translateY(-4px); box-shadow:0 8px 24px rgba(0,0,0,.1); }
.car-why-icon { width:52px; height:52px; border-radius:14px; background:#eff6ff; display:flex; align-items:center; justify-content:center; font-size:1.4rem; color:var(--brand-navy); margin:0 auto 14px; }
.car-why-title { font-family:var(--font-body); font-size:.9rem; font-weight:700; color:var(--brand-navy); margin-bottom:8px; }
.car-why-desc { font-family:var(--font-body); font-size:.8rem; color:var(--text-secondary); line-height:1.65; }
.car-apply { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:8px; }
.car-apply-card { background:var(--brand-navy); border-radius:14px; padding:28px 26px; border-left:5px solid var(--orange); }
.car-apply-heading { font-family:var(--font-title); font-size:1rem; font-weight:700; color:#fff; margin:0 0 18px; }
.car-apply-row { display:flex; align-items:flex-start; gap:12px; margin-bottom:14px; }
.car-apply-row:last-child { margin-bottom:0; }
.car-apply-row i { color:var(--orange); font-size:1rem; margin-top:2px; flex-shrink:0; }
.car-apply-row span, .car-apply-row a { font-family:var(--font-body); font-size:.87rem; color:rgba(255,255,255,.85); line-height:1.65; text-decoration:none; }
.car-apply-row a:hover { color:#fff; text-decoration:underline; }
.car-nmc-note { background:#fef3c7; border:1px solid #fcd34d; border-radius:10px; padding:14px 18px; margin-bottom:28px; display:flex; align-items:flex-start; gap:12px; }
.car-nmc-note i { color:#b45309; font-size:1rem; margin-top:2px; flex-shrink:0; }
.car-nmc-note span { font-family:var(--font-body); font-size:.85rem; color:#78350f; line-height:1.6; }
@media (max-width:768px) {
  .car-why { grid-template-columns:1fr 1fr; }
  .car-apply { grid-template-columns:1fr; }
  .car-job-head { flex-direction:column; align-items:flex-start; }
}

/* ── Infrastructure shared (Library / Hostels / Faculty Apartments) ── */
.infra-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-bottom:36px; }
.infra-stat { background:var(--brand-navy); border-radius:14px; padding:22px 18px; text-align:center; border-bottom:4px solid var(--orange); }
.infra-stat-num { font-family:var(--font-title); font-size:1.8rem; font-weight:700; color:#fff; line-height:1.1; }
.infra-stat-label { font-family:var(--font-body); font-size:.75rem; color:rgba(255,255,255,.7); margin-top:6px; text-transform:uppercase; letter-spacing:.06em; }
.infra-section-title { font-family:var(--font-title); font-size:1.1rem; font-weight:700; color:#9aaabb; padding-left:14px; border-left:4px solid var(--orange); margin:32px 0 18px; }
.infra-vm-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-bottom:36px; }
.infra-vm-card { background:#fff; border:1px solid var(--border-color); border-radius:12px; padding:22px 24px; border-top:4px solid var(--orange); box-shadow:0 2px 8px rgba(0,0,0,.05); }
.infra-vm-card h4 { font-family:var(--font-body); font-size:.72rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--orange); margin:0 0 10px; }
.infra-vm-card p, .infra-vm-card li { font-size:.9rem; color:var(--text-secondary); line-height:1.75; margin:0; }
.infra-vm-card ul { padding-left:16px; margin:0; }
.infra-detail-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:32px; }
.infra-detail-row { display:flex; align-items:flex-start; gap:12px; background:#f8fafc; border:1px solid var(--border-color); border-radius:10px; padding:12px 16px; }
.infra-detail-row i { color:var(--orange); font-size:1rem; margin-top:2px; flex-shrink:0; }
.infra-detail-row span { font-size:.87rem; color:var(--text-secondary); line-height:1.65; }
.infra-detail-row strong { color:#9aaabb; }
.infra-table { width:100%; border-collapse:collapse; margin-bottom:28px; font-family:var(--font-body); font-size:.88rem; }
.infra-table th { background:var(--brand-navy); color:#fff; padding:11px 14px; text-align:left; font-weight:600; }
.infra-table td { padding:10px 14px; border-bottom:1px solid var(--border-color); color:var(--text-secondary); }
.infra-table tbody tr:nth-child(even) { background:#f8fafc; }
.infra-table tbody tr:hover { background:#eff6ff; }
.infra-btn { display:inline-flex; align-items:center; gap:8px; background:var(--brand-navy); color:#fff; font-family:var(--font-body); font-size:.88rem; font-weight:600; padding:11px 26px; border-radius:8px; text-decoration:none; border-left:4px solid var(--orange); transition:background .2s; }
.infra-btn:hover { background:#002a5e; }
.hostel-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-bottom:36px; }
.hostel-card { background:#fff; border:1px solid var(--border-color); border-radius:14px; overflow:hidden; box-shadow:0 2px 8px rgba(0,0,0,.05); }
.hostel-card-head { background:var(--brand-navy); padding:14px 18px; display:flex; align-items:center; gap:10px; }
.hostel-card-head i { color:var(--orange); font-size:1.1rem; }
.hostel-card-head span { font-family:var(--font-body); font-size:.88rem; font-weight:700; color:#fff; }
.hostel-card-body { padding:18px; }
.hostel-row { display:flex; justify-content:space-between; align-items:center; padding:8px 0; border-bottom:1px solid #f0f0f0; }
.hostel-row:last-child { border-bottom:none; }
.hostel-row-label { font-family:var(--font-body); font-size:.82rem; color:var(--text-secondary); }
.hostel-row-val { font-family:var(--font-body); font-size:.88rem; font-weight:700; color:#9aaabb; }
.infra-info-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:32px; }
.infra-info-row { display:flex; align-items:flex-start; gap:13px; background:#f8fafc; border:1px solid var(--border-color); border-radius:10px; padding:14px 18px; }
.infra-info-row i { color:var(--orange); font-size:1rem; margin-top:2px; flex-shrink:0; }
.infra-info-row span { font-size:.87rem; color:var(--text-secondary); line-height:1.65; }
.infra-info-row strong { color:#9aaabb; }
.apt-total { display:flex; align-items:center; gap:20px; background:var(--brand-navy); border-radius:14px; padding:24px 28px; margin-bottom:32px; border-left:6px solid var(--orange); }
.apt-total-icon { font-size:2.2rem; color:var(--orange); }
.apt-total-num { font-family:var(--font-title); font-size:2.4rem; font-weight:700; color:#fff; line-height:1; }
.apt-total-label { font-family:var(--font-body); font-size:.82rem; color:rgba(255,255,255,.7); margin-top:4px; text-transform:uppercase; letter-spacing:.06em; }
.apt-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-bottom:36px; }
.apt-card { background:#fff; border:1px solid var(--border-color); border-radius:14px; padding:24px 20px; text-align:center; box-shadow:0 2px 8px rgba(0,0,0,.05); transition:transform .25s,box-shadow .25s,border-color .25s; position:relative; overflow:hidden; }
.apt-card::before { content:''; position:absolute; top:0; left:0; right:0; height:4px; background:var(--orange); }
.apt-card:hover { transform:translateY(-4px); box-shadow:0 8px 24px rgba(0,0,0,.1); border-color:var(--orange); }
.apt-card-icon { font-size:1.8rem; color:var(--brand-navy); margin-bottom:12px; }
.apt-card-name { font-family:var(--font-body); font-size:.82rem; font-weight:700; color:var(--text-secondary); text-transform:uppercase; letter-spacing:.05em; margin-bottom:10px; }
.apt-card-count { font-family:var(--font-title); font-size:2rem; font-weight:700; color:var(--brand-navy); line-height:1; }
.apt-card-unit { font-family:var(--font-body); font-size:.75rem; color:var(--text-secondary); margin-top:4px; }
.apt-card-note { font-family:var(--font-body); font-size:.72rem; color:var(--orange); margin-top:6px; font-style:italic; }
@media (max-width:768px) {
  .infra-stats { grid-template-columns:1fr 1fr; }
  .hostel-cards { grid-template-columns:1fr; }
  .infra-vm-grid,.infra-detail-grid,.infra-info-grid { grid-template-columns:1fr; }
  .apt-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width:480px) { .apt-grid { grid-template-columns:1fr; } }

/* ── Accordion (Undergraduate / Postgraduate) ── */
.acc-wrap { width:100%; font-family:var(--font-body); }
.acc-item { border:1px solid #d8e4f0; border-radius:4px; margin-bottom:10px; overflow:hidden; }
.acc-header { display:flex; align-items:center; justify-content:space-between; padding:20px 32px; cursor:pointer; user-select:none; background:#f0f4f8; font-size:17px; font-weight:700; color:#1a3a6b; transition:background .2s; }
.acc-header:hover { background:#e0eaf5; }
.acc-header.open { background:#3b7dd8; color:#fff; }
.acc-header.open .acc-icon { color:#fff; }
.acc-icon { font-size:24px; font-weight:300; line-height:1; min-width:24px; text-align:right; }
.acc-body { display:none; padding:26px 32px; background:#fff; border-top:1px solid #d8e4f0; }
.acc-body.open { display:block; }
.acc-body p { margin:0 0 10px; font-size:16px; color:#333; line-height:1.7; }
.acc-body p:last-child { margin-bottom:0; }

/* ── NAAC — AQAR / Accreditation Outcomes ── */
.naac-section-title { font-size:35px; font-weight:700; color:#00377b; margin-bottom:18px; font-family:var(--font-title); }
.naac-btn { display:inline-block; background:linear-gradient(135deg,#ff6c00,#e05a00); color:#fff; padding:12px 28px; border-radius:4px; font-family:var(--font-body); font-size:15px; font-weight:600; text-decoration:none; transition:opacity .2s; margin-bottom:28px; }
.naac-btn:hover { opacity:.88; }
.naac-divider { border:none; border-top:2px solid #ff6c00; margin:0 0 40px; }
.naac-item { margin-bottom:0; }

/* ── NAAC IQAC ── */
.iqac-criterion-title { font-size:25px; font-weight:500; color:#00377b; margin-bottom:30px; font-family:var(--font-body); }
.iqac-table-wrap { overflow-y:auto; margin-bottom:40px; }
.iqac-table { min-width:600px; width:100%; border-collapse:collapse; font-family:var(--font-body); font-size:15px; }
.iqac-table th { background:#00337b; color:#fff; padding:12px 16px; text-align:left; font-weight:600; }
.iqac-table th:first-child { width:72px; }
.iqac-table td { padding:12px 16px; border-bottom:1px solid #ddd; vertical-align:top; }
.iqac-table tr:nth-child(even) td { background:#f7f7f7; }
.iqac-table a { color:#00337b; text-decoration:underline; }
.iqac-table a:hover { color:#ff6c00; }
.iqac-breadcrumb { font-family:var(--font-body); font-size:14px; color:#555; padding:10px 0; border-bottom:1px solid #ddd; margin-bottom:30px; }
.iqac-breadcrumb a { color:#00337b; }
.iqac-breadcrumb a:hover { color:#ff6c00; }

/* ── Contact Page ── */
.ct-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:0; background:var(--brand-navy); border-radius:16px; overflow:hidden; margin-bottom:36px; }
.ct-card { padding:44px 36px; display:flex; flex-direction:column; border-right:1px solid rgba(255,255,255,.1); transition:background .2s; }
.ct-card:last-child { border-right:none; }
.ct-card:hover { background:rgba(255,255,255,.04); }
.ct-card-icon { width:56px; height:56px; border-radius:50%; background:rgba(234,88,12,.15); border:2px solid rgba(234,88,12,.4); display:flex; align-items:center; justify-content:center; font-size:1.4rem; color:var(--orange); margin-bottom:22px; }
.ct-card-title { font-family:var(--font-title); font-size:1.6rem; font-weight:700; color:#fff; margin-bottom:14px; letter-spacing:.01em; }
.ct-card-desc { font-family:var(--font-body); font-size:.94rem; color:rgba(255,255,255,.65); line-height:1.7; margin-bottom:18px; flex:1; }
.ct-card-value { font-family:var(--font-body); font-size:.95rem; font-weight:600; color:#fff; line-height:1.75; }
.ct-card-value a { color:#fff; text-decoration:none; }
.ct-card-value a:hover { color:var(--orange); }
.ct-card-link { display:inline-flex; align-items:center; gap:6px; font-family:var(--font-body); font-size:.88rem; font-weight:600; color:var(--orange); text-decoration:none; margin-top:12px; }
.ct-card-link:hover { text-decoration:underline; }
.ct-bottom { display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-bottom:44px; }
.ct-address-card { background:var(--brand-navy); border-radius:14px; padding:34px 30px; display:flex; flex-direction:column; gap:16px; }
.ct-address-title { font-family:var(--font-title); font-size:1.15rem; font-weight:700; color:#fff; margin-bottom:6px; }
.ct-address-row { display:flex; align-items:flex-start; gap:12px; font-family:var(--font-body); font-size:.9rem; color:rgba(255,255,255,.75); line-height:1.6; }
.ct-address-row i { color:var(--orange); font-size:1rem; margin-top:2px; flex-shrink:0; }
.ct-address-row a { color:rgba(255,255,255,.85); text-decoration:none; }
.ct-address-row a:hover { color:var(--orange); }
.ct-map { border-radius:14px; overflow:hidden; min-height:360px; }
.ct-map iframe { width:100%; height:100%; min-height:360px; border:none; display:block; }
.ct-dept-title { font-family:var(--font-title); font-size:1.3rem; font-weight:700; color:var(--brand-navy); margin-bottom:20px; padding-bottom:10px; border-bottom:2px solid var(--orange); display:inline-block; }
.ct-dept-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-bottom:40px; }
.ct-dept-card { background:#fff; border:1px solid var(--border-color); border-radius:12px; padding:22px 20px; display:flex; flex-direction:column; gap:10px; box-shadow:0 2px 10px rgba(0,0,0,.06); transition:box-shadow .2s, transform .2s; }
.ct-dept-card:hover { box-shadow:0 6px 20px rgba(0,0,0,.1); transform:translateY(-2px); }
.ct-dept-name { font-family:var(--font-body); font-size:.95rem; font-weight:700; color:var(--brand-navy); display:flex; align-items:center; margin-bottom:4px; }
.ct-dept-row { display:flex; align-items:center; gap:9px; font-family:var(--font-body); font-size:.86rem; color:var(--text-secondary); }
.ct-dept-row i { color:var(--orange); font-size:.9rem; flex-shrink:0; }
.ct-dept-row a { color:var(--brand-navy); text-decoration:none; }
.ct-dept-row a:hover { color:var(--orange); }
@media (max-width:900px) {
  .ct-cards { grid-template-columns:1fr; }
  .ct-card { border-right:none; border-bottom:1px solid rgba(255,255,255,.1); }
  .ct-card:last-child { border-bottom:none; }
  .ct-bottom { grid-template-columns:1fr; }
  .ct-dept-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width:600px) {
  .ct-dept-grid { grid-template-columns:1fr; }
  .ct-card { padding:32px 24px; }
}

/* ── Admissions Page ── */
.adm-intro { font-family:var(--font-body); font-size:1.02rem; color:var(--text-secondary); line-height:1.8; margin-bottom:10px; }
.adm-programs { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin:28px 0 36px; }
.adm-prog-card { position:relative; border-radius:14px; overflow:hidden; min-height:260px; display:flex; flex-direction:column; justify-content:flex-end; text-decoration:none; box-shadow:0 4px 18px rgba(0,0,0,.18); transition:transform .25s, box-shadow .25s; }
.adm-prog-card:hover { transform:translateY(-4px); box-shadow:0 10px 30px rgba(0,0,0,.25); }
.adm-prog-bg { position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .4s; }
.adm-prog-card:hover .adm-prog-bg { transform:scale(1.04); }
.adm-prog-overlay { position:absolute; inset:0; background:linear-gradient(to top, rgba(0,30,70,.88) 0%, rgba(0,30,70,.3) 60%, transparent 100%); }
.adm-prog-body { position:relative; z-index:1; padding:24px 26px; }
.adm-prog-badge { display:inline-block; font-family:var(--font-body); font-size:.68rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; background:var(--orange); color:#fff; padding:3px 10px; border-radius:20px; margin-bottom:10px; }
.adm-prog-title { font-family:var(--font-title); font-size:1.5rem; font-weight:700; color:#fff; margin:0 0 6px; }
.adm-prog-sub { font-family:var(--font-body); font-size:.88rem; color:rgba(255,255,255,.75); margin:0 0 14px; }
.adm-prog-btn { display:inline-flex; align-items:center; gap:7px; font-family:var(--font-body); font-size:.84rem; font-weight:600; color:#fff; background:rgba(255,255,255,.15); border:1px solid rgba(255,255,255,.3); padding:6px 14px; border-radius:20px; backdrop-filter:blur(4px); transition:background .2s; }
.adm-prog-card:hover .adm-prog-btn { background:var(--orange); border-color:var(--orange); }
.adm-links-title { font-family:var(--font-title); font-size:1.15rem; font-weight:700; color:#9aaabb; margin:0 0 14px; padding-bottom:8px; border-bottom:2px solid var(--orange); display:inline-block; }
.adm-links { display:grid; grid-template-columns:1fr; gap:14px; margin-bottom:0; }
.adm-link-item { display:flex; align-items:center; gap:16px; background:#fff; border:1px solid var(--border-color); border-radius:12px; padding:18px 20px; text-decoration:none; box-shadow:0 2px 8px rgba(0,0,0,.05); transition:box-shadow .2s, transform .2s, border-color .2s; }
.adm-link-item:hover { box-shadow:0 6px 20px rgba(0,0,0,.1); transform:translateY(-2px); border-color:var(--orange); }
.adm-link-icon { width:44px; height:44px; border-radius:10px; background:rgba(234,88,12,.1); display:flex; align-items:center; justify-content:center; font-size:1.2rem; color:var(--orange); flex-shrink:0; }
.adm-link-label { font-family:var(--font-body); font-size:.93rem; font-weight:700; color:#9aaabb; margin-bottom:3px; }
.adm-link-sub { font-family:var(--font-body); font-size:.8rem; color:var(--text-secondary); }
.adm-mid-row { display:grid; grid-template-columns:1fr 1.4fr; gap:28px; align-items:start; margin:32px 0 24px; }
.adm-links-col { display:flex; flex-direction:column; }
.adm-enquiry-wrap { display:flex; flex-direction:column; }
.adm-enquiry-heading { font-family:var(--font-title); font-size:1rem; font-weight:700; color:#9aaabb; display:inline-flex; align-items:center; gap:8px; padding-bottom:10px; border-bottom:2px solid var(--orange); margin-bottom:18px; }
.adm-enquiry-frame { width:100%; height:480px; border:none; border-radius:12px; display:block; box-shadow:0 2px 12px rgba(0,0,0,.08); overflow:hidden; }
@media (max-width:768px) {
  .adm-mid-row { grid-template-columns:1fr; }
  .adm-enquiry-frame { height:495px; }
}
.adm-bottom { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:10px; }
.adm-contact-card { background:var(--brand-navy); border-radius:14px; padding:28px 26px; display:flex; flex-direction:column; gap:14px; }
.adm-contact-heading { font-family:var(--font-title); font-size:1.1rem; font-weight:700; color:#fff; margin-bottom:4px; }
.adm-contact-row { display:flex; align-items:flex-start; gap:12px; font-family:var(--font-body); font-size:.9rem; color:rgba(255,255,255,.78); line-height:1.55; }
.adm-contact-row i { color:var(--orange); font-size:1rem; margin-top:2px; flex-shrink:0; }
.adm-contact-row a { color:rgba(255,255,255,.9); text-decoration:none; }
.adm-contact-row a:hover { color:var(--orange); }
.adm-hours-card { background:#fff; border:1px solid var(--border-color); border-radius:14px; padding:28px 26px; box-shadow:0 2px 10px rgba(0,0,0,.06); }
.adm-hours-heading { font-family:var(--font-title); font-size:1.1rem; font-weight:700; color:#9aaabb; margin-bottom:16px; }
.adm-hours-row { display:flex; justify-content:space-between; align-items:center; padding:10px 0; border-bottom:1px solid var(--border-color); }
.adm-hours-row:last-child { border-bottom:none; }
.adm-hours-day { font-family:var(--font-body); font-size:.9rem; color:#444; }
.adm-hours-badge { font-family:var(--font-body); font-size:.82rem; font-weight:700; background:rgba(234,88,12,.1); color:var(--orange); padding:3px 12px; border-radius:20px; }
.adm-hours-time { font-family:var(--font-body); font-size:.88rem; color:#999; }
@media (max-width:768px) {
  .adm-programs { grid-template-columns:1fr; }
  .adm-bottom { grid-template-columns:1fr; }
}

/* ══════════════════════════════════════
   DEPARTMENT CONTENT PAGE
══════════════════════════════════════ */
.dept-page-wrap { display: flex; flex-direction: column; gap: 0; }

/* Each major section block */
.dept-topic { padding: 32px 0; border-bottom: 1px solid var(--border-color); }
.dept-topic:last-child { border-bottom: none; padding-bottom: 8px; }

/* Section heading */
.dept-topic-title {
  font-family: var(--font-title);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--brand-navy);
  margin: 0 0 6px;
  padding-bottom: 12px;
  border-bottom: 3px solid var(--orange);
  display: inline-block;
}
[data-theme="dark"] .dept-topic-title { color: #e8eef6; }
[data-theme="dark"] .dept-topic-list-intro { color: #9aaabb; }
[data-theme="dark"] .dept-topic-list li { color: #9aaabb; }

/* Vision — quote-style block */
.dept-vision-box {
  background: linear-gradient(135deg, #eff6ff 0%, #f0fdf4 100%);
  border-left: 5px solid var(--brand-navy);
  border-radius: 0 12px 12px 0;
  padding: 20px 24px;
  margin-top: 18px;
  font-family: var(--font-title);
  font-size: 1.05rem;
  font-style: italic;
  color: var(--brand-navy);
  line-height: 1.7;
}
[data-theme="dark"] .dept-vision-box { background: #1a2740; border-left-color: var(--orange); color: #c8d8ee; }

/* Mission / Objectives — styled list */
.dept-topic-list-intro { color: var(--brand-navy); font-family: var(--font-body); font-size: .95rem; margin-bottom: 12px; }
.dept-topic-list { list-style: none; padding: 0; margin: 18px 0 0; display: flex; flex-direction: column; gap: 10px; }
.dept-topic-list li {
  position: relative;
  padding-left: 26px;
  color: var(--brand-navy);
  font-family: var(--font-body);
  font-size: .95rem;
  line-height: 1.75;
}
.dept-topic-list li::before {
  content: '▸';
  color: var(--orange);
  font-weight: 700;
  position: absolute;
  left: 0;
  top: 2px;
}

/* UG / PG Teaching — inner layout */
.dept-teaching-wrap { display: grid; grid-template-columns: 260px 1fr; gap: 24px; margin-top: 20px; align-items: start; }

/* Goal box */
.dept-goal-box {
  background: var(--brand-navy);
  border-radius: 14px;
  padding: 24px 22px;
  color: #fff;
}
.dept-goal-label {
  font-family: var(--font-title);
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--orange);
  margin-bottom: 10px;
  display: block;
}
.dept-goal-text {
  font-family: var(--font-body);
  font-size: .95rem;
  line-height: 1.75;
  color: rgba(255,255,255,.88);
}

/* Objectives box */
.dept-objectives-box { display: flex; flex-direction: column; gap: 0; }
.dept-obj-label {
  font-family: var(--font-title);
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--text-secondary);
  margin-bottom: 6px;
}

@media (max-width: 768px) {
  .dept-teaching-wrap { grid-template-columns: 1fr; gap: 16px; }
  .dept-topic-title { font-size: 1.1rem; }
  .dept-vision-box { font-size: .97rem; padding: 16px 18px; }
}

/* ── Accreditation Outcomes ── */
.ao-doc-list { list-style:none; margin:0; padding:0; display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.ao-doc-item { display:flex; flex-direction:row; align-items:center; gap:12px; background:#fff; border:1px solid var(--border-color); border-radius:12px; padding:14px 16px; box-shadow:0 2px 8px rgba(0,0,0,.05); transition:box-shadow .2s,border-color .2s; }
.ao-doc-item:hover { box-shadow:0 4px 16px rgba(0,0,0,.1); border-color:var(--orange); }
.ao-doc-icon { width:36px; height:36px; border-radius:8px; background:rgba(234,88,12,.08); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.ao-doc-icon i { font-size:1.1rem; color:var(--orange); }
.ao-doc-info { flex:1; min-width:0; }
.ao-doc-label { font-family:var(--font-title); font-size:.82rem; font-weight:600; color:var(--brand-navy); line-height:1.35; }
.ao-doc-link { flex-shrink:0; display:inline-flex; align-items:center; gap:5px; font-family:var(--font-body); font-size:.78rem; font-weight:600; color:#fff !important; background:var(--orange); padding:6px 13px; border-radius:7px; text-decoration:none; transition:background .2s; white-space:nowrap; }
.ao-doc-link:hover { background:var(--brand-navy); color:#fff !important; }
[data-theme="dark"] .ao-doc-item { background:var(--card-bg); border-color:var(--border-color); }
[data-theme="dark"] .ao-doc-label { color:#e8eef6; }
@media (max-width:600px) {
  .ao-doc-list { grid-template-columns:1fr; gap:10px; }
  .ao-doc-item {
    flex-wrap:wrap; align-items:center; gap:10px 12px;
    padding:14px 16px; border-radius:10px;
    border:1px solid var(--border-color);
    border-left:4px solid var(--orange);
    box-shadow:0 2px 10px rgba(0,0,0,.07);
  }
  .ao-doc-icon { width:38px; height:38px; flex-shrink:0; }
  .ao-doc-info { flex:1; min-width:0; }
  .ao-doc-label { font-size:.86rem; }
  .ao-doc-link { flex-basis:100%; width:auto; margin:0 auto; padding:7px 18px; border-radius:8px; font-size:.84rem; justify-content:center; text-align:center; }
}
