/*
 * HCA Design System v2.2 — Himalayan Crown Academy
 * Full override: tokens → typography → hero autofit → components → mobile
 *
 * SELECTOR MAP:
 *   .navbar .nav-menu .top-bar .hero .hero-carousel .hero-notice
 *   .carousel-slide .carousel-overlay .carousel-text-pill
 *   .section .section-alt .section-header .header-line
 *   .facility-card .news-card .voice-card .club-card .pub-card
 *   .hca-staff-card .gallery-item .stat-strip .enroll-band
 *   .footer .btn .page-hero-banner .breadcrumb-trail
 */

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
img,video{max-width:100%;display:block}
button,input,textarea,select{font:inherit}

/* ── DESIGN TOKENS ── */
:root{
  --primary:#C0392B;--primary-dark:#96281B;--primary-light:#E74C3C;
  --accent:#D4850A;--accent-light:#F39C12;--secondary:#7B1A1A;
  --text-main:#1C1917;--text-light:#57534E;--text-muted:#A8A29E;
  --bg-soft:#FAFAF8;--bg-warm:#F5F0E8;--bg-card:#FFFFFF;
  --border:#E7E2D9;--border-strong:#C8C0B4;
  --space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:32px;
  --space-xl:64px;--section-gap:100px;
  --radius-sm:6px;--radius-md:12px;--radius-lg:20px;--radius-pill:999px;
  --shadow-xs:0 1px 3px rgba(0,0,0,.04);
  --shadow-sm:0 2px 8px rgba(0,0,0,.05);
  --shadow-card:0 8px 28px -10px rgba(0,0,0,.10);
  --shadow-md:0 14px 40px -12px rgba(0,0,0,.13);
  --shadow-lg:0 22px 60px -16px rgba(0,0,0,.16);
  --font-head:'Montserrat',system-ui,sans-serif;
  --font-body:'Source Sans 3',system-ui,sans-serif;
  --ease:cubic-bezier(.25,.46,.45,.94);
  --t:.22s var(--ease);
  --max-w:1200px;
}

/* ── GLOBAL TYPOGRAPHY — fluid, no blur, clean ── */
body{
  font-family:var(--font-body);
  font-size:clamp(14.5px,1vw + 10px,16.5px);
  line-height:1.72;
  color:var(--text-main);
  background:var(--bg-soft);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
h1,h2,h3,h4,h5,h6{
  font-family:var(--font-head);font-weight:700;
  line-height:1.2;letter-spacing:-.025em;color:var(--text-main);margin-bottom:0;
}
h1{font-size:clamp(1.65rem,3.8vw + .4rem,2.9rem)}
h2{font-size:clamp(1.35rem,2.8vw + .2rem,2.15rem)}
h3{font-size:clamp(1.1rem,1.8vw + .1rem,1.45rem)}
h4{font-size:clamp(.95rem,1.2vw,1.15rem)}
p{margin-bottom:1.2rem;color:var(--text-light);line-height:1.78;letter-spacing:-.01em}
p:last-child{margin-bottom:0}
a{color:var(--primary);text-decoration:none;transition:color var(--t)}
a:hover{color:var(--primary-dark)}
ul,ol{padding-left:1.4em}
li{margin-bottom:.4em;line-height:1.62}
.entry,.single-content .entry,.content-body{
  font-size:clamp(14.5px,1vw + 9px,16px);
  line-height:1.84;letter-spacing:-.01em;color:var(--text-light);
}
.entry h2,.entry h3,.entry h4{margin:1.8rem 0 .6rem;color:var(--text-main)}

/* ── LAYOUT ── */
.container{max-width:var(--max-w);margin:0 auto;padding:0 clamp(14px,3.5vw,28px)}
.section{padding:var(--section-gap) 0}
.section-alt{background:var(--bg-warm)}
.section-header{text-align:center;margin-bottom:clamp(40px,6vw,72px)}
.section-header h2{color:var(--secondary);margin-bottom:12px;letter-spacing:-.03em}
.section-header p{font-size:clamp(15px,1.15vw,17.5px);color:var(--text-light);max-width:60ch;margin:0 auto;line-height:1.6}
.header-line{width:56px;height:4px;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:var(--radius-pill);margin:18px auto 0}

/* ── TOP BAR ── */
.top-bar{background:var(--secondary);color:rgba(255,255,255,.82);font-size:clamp(11.5px,.9vw,13px);padding:7px 0}
.top-bar a{color:rgba(255,255,255,.82);transition:color var(--t)}
.top-bar a:hover{color:var(--accent-light)}
.top-bar-right a{
  width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;font-size:12px;
  transition:background var(--t),color var(--t);pointer-events:all;cursor:pointer;
}
.top-bar-right a:hover{background:var(--primary);color:#fff;transform:scale(1.1);box-shadow:0 0 10px rgba(192,57,43,.3)}

/* ── NAVBAR ── */
.navbar{background:var(--bg-card);border-bottom:2px solid var(--primary);position:sticky;top:0;z-index:1000;box-shadow:var(--shadow-sm)}
.navbar .container{height:68px}
.nav-brand-text h1{font-size:clamp(15px,1.5vw,19px);color:var(--secondary);letter-spacing:-.02em;line-height:1.1}
.nav-brand-text span{font-size:clamp(11px,1.05vw,12.5px);color:var(--text-muted);font-weight:500;display:block;margin-top:2px}
.nav-menu>li>a{
  font-size:clamp(11.5px,.8vw,13px);font-weight:600;letter-spacing:.01em;
  padding:24px 10px;color:var(--text-main);transition:color var(--t);position:relative;
}
.nav-menu>li>a::after{
  content:'';position:absolute;bottom:0;left:50%;
  transform:translateX(-50%) scaleX(0);width:78%;height:2px;
  background:var(--primary);border-radius:2px;transition:transform var(--t);
}
.nav-menu>li>a:hover::after,
.nav-menu>li.current-menu-item>a::after,
.nav-menu>li.current-menu-ancestor>a::after{transform:translateX(-50%) scaleX(1)}
.nav-menu>li>a:hover,.nav-menu>li.current-menu-item>a{color:var(--primary)}
.nav-menu>li>.sub-menu,.nav-menu>li>ul.sub-menu{
  border-top:2px solid var(--primary);
  border-radius:0 0 var(--radius-md) var(--radius-md);
  box-shadow:var(--shadow-md);padding:6px 0;
}
.nav-menu>li>.sub-menu li a{font-size:13px;font-weight:500;padding:9px 18px;color:var(--text-main);transition:all var(--t)}
.nav-menu>li>.sub-menu li a:hover{color:var(--primary);background:var(--bg-warm);padding-left:24px}

/* ================================================================
   HERO — DEFINITIVE AUTOFIT FOR BOTH DESKTOP AND MOBILE
   Strategy:
   • Desktop: flex row, fixed clamp height, img absolute fills carousel
   • Mobile: flex column, carousel uses padding-bottom ratio trick
             (padding-bottom % on a div = % of its own width, creating
              a fixed-ratio box that img fills with position:absolute)
   ================================================================ */

/* Desktop layout */
.hero{
  display:flex;
  flex-direction:row;
  overflow:hidden;
  background:#1a0808;
  height:clamp(300px,44vw,560px);
  max-height:560px;
  min-height:300px;
}
.hero-carousel{
  flex:0 0 80%;
  position:relative;         /* anchors the absolute slides */
  overflow:hidden;
  height:100%;               /* fills the flex row height */
  min-height:0;
}

/* Every slide covers the carousel pane absolutely */
.carousel-slide{
  position:absolute;
  inset:0;
  width:100%;height:100%;
  opacity:0;
  transition:opacity .85s ease;
  z-index:0;
}
.carousel-slide.active{opacity:1;z-index:1}

/* THE autofit fix — image always fills its parent, no distortion */
.carousel-slide img{
  position:absolute;
  inset:0;
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  object-position:center 30% !important;
  display:block;
  border-radius:0 !important;
  filter:none !important;
  /* no blur, no background-size tricks — pure CSS */
}
.carousel-overlay{
  position:absolute;
  inset:0;
  background:none !important;      /* no full-screen gradient */
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:clamp(12px,3vw,38px) clamp(14px,4vw,46px);
  z-index:3;
}

/* Pill backdrop — translucent rectangle behind text only */
.carousel-text-pill{
  display:inline-flex;
  flex-direction:column;
  gap:5px;
  background:rgba(22,12,8,.76);
  backdrop-filter:blur(3px);
  -webkit-backdrop-filter:blur(3px);
  border-radius:var(--radius-md);
  padding:clamp(10px,1.6vw,18px) clamp(12px,2vw,26px);
  max-width:min(500px,90%);
  border:1px solid rgba(255,255,255,.08);
  width:fit-content;
}
.carousel-text-pill h2{
  font-size:clamp(13.5px,2.1vw,23px);
  font-weight:800;color:#fff;margin:0;
  line-height:1.18;letter-spacing:-.025em;text-shadow:none;
}
.carousel-text-pill p{
  font-size:clamp(11px,1vw,13px);
  color:rgba(255,255,255,.88);margin:0;line-height:1.46;
}
.carousel-cta{display:flex;gap:7px;margin-top:9px;flex-wrap:wrap}
.btn-slide-primary{
  display:inline-flex;align-items:center;gap:5px;
  padding:clamp(6px,.9vw,9px) clamp(12px,1.6vw,20px);
  background:var(--primary);color:#fff;border:none;
  border-radius:var(--radius-pill);font-family:var(--font-head);
  font-size:clamp(10.5px,.85vw,12.5px);font-weight:600;
  cursor:pointer;text-decoration:none;
  transition:background var(--t),transform var(--t);white-space:nowrap;
}
.btn-slide-primary:hover{background:var(--primary-dark);transform:translateY(-1px);color:#fff}
.btn-slide-outline{
  display:inline-flex;align-items:center;gap:5px;
  padding:clamp(5px,.8vw,8px) clamp(10px,1.4vw,18px);
  background:rgba(255,255,255,.12);color:#fff;
  border:1px solid rgba(255,255,255,.4);
  border-radius:var(--radius-pill);font-family:var(--font-head);
  font-size:clamp(10.5px,.85vw,12.5px);font-weight:600;
  cursor:pointer;text-decoration:none;
  transition:background var(--t);white-space:nowrap;
  backdrop-filter:blur(4px);
}
.btn-slide-outline:hover{background:rgba(255,255,255,.22);color:#fff}

/* Dots & arrows */
.carousel-dot{background:rgba(255,255,255,.35);border-radius:50%;transition:background var(--t)}
.carousel-dot.active{background:var(--accent-light)}
.carousel-arrows button{
  width:34px;height:34px;border-radius:50%;
  border:1.5px solid rgba(255,255,255,.4);
  background:rgba(0,0,0,.32);color:#fff;font-size:12px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--t);backdrop-filter:blur(4px);
}
.carousel-arrows button:hover{background:var(--primary);border-color:var(--primary)}

/* Notice panel */
.hero-notice{
  flex:0 0 20%;background:var(--bg-card);
  border-left:3px solid var(--primary);
  display:flex;flex-direction:column;overflow:hidden;
  height:100%;
}
.notice-header{
  background:var(--primary);color:#fff;padding:11px 12px;
  font-family:var(--font-head);font-size:13px;font-weight:700;
  text-align:center;flex-shrink:0;letter-spacing:.01em;
}
.notice-list{flex:1;overflow:hidden;position:relative}
.notice-item{padding:8px 12px;border-bottom:1px dashed var(--border);transition:background var(--t)}
.notice-item:hover{background:var(--bg-warm)}
.notice-item a{display:block;font-size:clamp(11px,.85vw,12.5px);line-height:1.4;color:var(--text-main)}
.notice-item a:hover{color:var(--primary)}
.notice-date{font-size:10px;color:var(--primary);font-weight:600;margin-bottom:2px}

/* ── STAT STRIP ── */
.stat-strip{background:var(--secondary)}
.stat-strip-inner{
  display:grid;grid-template-columns:repeat(4,1fr);
  max-width:var(--max-w);margin:0 auto;
  padding:0 clamp(14px,3.5vw,28px);
}
.stat-item{
  padding:clamp(16px,2.5vw,24px) 12px;
  text-align:center;border-right:1px solid rgba(255,255,255,.1);
}
.stat-item:last-child{border-right:none}
.stat-num{
  font-family:var(--font-head);
  font-size:clamp(1.4rem,2.6vw,2.2rem);
  font-weight:800;color:var(--accent-light);line-height:1;margin-bottom:4px;
}
.stat-label{
  font-size:clamp(10px,.8vw,12px);color:rgba(255,255,255,.7);
  font-weight:600;letter-spacing:.04em;text-transform:uppercase;
}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:10px 24px;font-family:var(--font-head);font-size:13px;
  font-weight:600;letter-spacing:.01em;border-radius:var(--radius-pill);
  border:1.5px solid transparent;cursor:pointer;
  text-decoration:none;transition:all var(--t);white-space:nowrap;
}
.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn-primary:hover{
  background:var(--primary-dark);border-color:var(--primary-dark);color:#fff;
  transform:translateY(-1px);box-shadow:0 5px 18px rgba(192,57,43,.32);
}
.btn-outline{background:transparent;color:var(--primary);border-color:var(--primary)}
.btn-outline:hover{background:var(--primary);color:#fff;transform:translateY(-1px)}

/* Sticky enroll */
.sticky-enroll{
  position:fixed;bottom:24px;right:24px;z-index:900;
  background:var(--primary);color:#fff;border:none;
  border-radius:var(--radius-pill);padding:12px 20px;
  font-family:var(--font-head);font-size:13px;font-weight:700;
  cursor:pointer;text-decoration:none;display:flex;align-items:center;gap:7px;
  box-shadow:0 6px 24px rgba(192,57,43,.44);transition:all var(--t);
  animation:popIn .5s var(--ease) both;
}
.sticky-enroll:hover{background:var(--primary-dark);color:#fff;transform:translateY(-2px);box-shadow:0 10px 32px rgba(192,57,43,.5)}
@keyframes popIn{from{opacity:0;transform:translateY(20px) scale(.92)}to{opacity:1;transform:translateY(0) scale(1)}}

/* ── CARDS ── */
.facility-card,.news-card,.voice-card,.club-card,.pub-card{
  border-radius:var(--radius-md) !important;
  box-shadow:var(--shadow-sm) !important;
  border:1px solid var(--border) !important;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease) !important;
  overflow:hidden;background:var(--bg-card);
}
.facility-card:hover,.news-card:hover,.voice-card:hover,.club-card:hover,.pub-card:hover{
  transform:translateY(-5px) !important;box-shadow:var(--shadow-lg) !important;
}

/* Facility */
.facility-card .card-img-wrap{overflow:hidden}
.facility-card img{height:170px;object-fit:cover;transition:transform .5s var(--ease) !important;border-radius:0 !important}
.facility-card:hover img{transform:scale(1.05) !important}
.facility-card .card-body{padding:14px 16px 18px}
.facility-card .card-body h3{font-size:14.5px;color:var(--secondary);margin-bottom:4px}
.facility-card .card-body p{font-size:13px;line-height:1.52;margin-bottom:10px}
.facility-card .read-more{font-size:12px;font-weight:700;color:var(--primary);display:inline-flex;align-items:center;gap:4px;transition:gap var(--t)}
.facility-card:hover .read-more{gap:8px}

/* News */
.news-card img{height:188px;object-fit:cover;border-radius:0 !important;transition:transform .5s var(--ease) !important}
.news-card:hover img{transform:scale(1.04) !important}
.news-card .news-body{padding:17px 18px 20px}
.news-card .news-body h3{font-size:clamp(14.5px,1.1vw,16.5px);line-height:1.28;color:var(--secondary);margin-bottom:7px}
.news-card .news-body p{font-size:13px;line-height:1.57}

/* Voice */
.voice-card{padding:38px 28px 32px !important}
.voice-card .voice-photo{width:124px;height:124px;border-radius:50%;overflow:hidden;margin:0 auto 18px;border:3px solid var(--primary);box-shadow:0 0 0 5px rgba(192,57,43,.1)}
.voice-card .voice-photo img{width:100%;height:100%;object-fit:cover;border-radius:0 !important}

/* Club */
.club-card img{height:178px;object-fit:cover;border-radius:0 !important;transition:transform .5s var(--ease) !important}
.club-card:hover img{transform:scale(1.05) !important}
.club-card .club-info{padding:14px 16px 18px}
.club-card .club-info h3{font-size:15px;color:var(--secondary);margin-bottom:6px}
.club-card .club-info p{font-size:13px}

/* ── GALLERY — 4-col, no blank cell ── */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:180px;gap:10px}
.gallery-item:nth-child(1){grid-column:span 2;grid-row:span 2}
.gallery-item:nth-child(2),.gallery-item:nth-child(3){grid-column:span 1;grid-row:span 1}
.gallery-item:nth-child(4),.gallery-item:nth-child(5){grid-column:span 1}
.gallery-item:nth-child(6){grid-column:span 2}
.gallery-item:nth-child(7),.gallery-item:nth-child(8){grid-column:span 1}
.gallery-item{border-radius:var(--radius-md);overflow:hidden;cursor:pointer;position:relative}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease);border-radius:0 !important}
.gallery-item:hover img{transform:scale(1.07)}
.gallery-item::after{content:'';position:absolute;inset:0;background:rgba(123,26,26,0);transition:background .3s;border-radius:0}
.gallery-item:hover::after{background:rgba(123,26,26,.22)}

/* ── HCA SYSTEM ── */
.hca-panel{border-radius:var(--radius-md);padding:28px;box-shadow:var(--shadow-card);border:1px solid var(--border);background:var(--bg-card)}
.hca-panel h3{font-size:17px;color:var(--secondary);margin-bottom:18px;padding-bottom:12px;border-bottom:2px solid var(--primary)}
.hca-panel ul li{padding:8px 0;font-size:14px;border-bottom:1px solid #f3f0eb;display:flex;align-items:flex-start;gap:10px;line-height:1.52}
.cocurricular-item{border-radius:var(--radius-sm);font-size:12.5px;font-weight:600;padding:10px 13px;transition:all var(--t)}
.cocurricular-item:hover{background:var(--primary);color:#fff;transform:translateX(4px)}

/* ── ENROLL BAND ── */
.enroll-band{
  background:linear-gradient(135deg,var(--secondary) 0%,var(--primary) 55%,var(--accent) 100%);
  padding:clamp(52px,7vw,90px) 0;position:relative;overflow:hidden;
}
.enroll-band::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23fff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E");
}
.enroll-band .container{position:relative;z-index:1}
.enroll-band-inner{text-align:center}
.enroll-band h2{font-size:clamp(1.5rem,3.2vw,2.4rem);color:#fff;margin-bottom:12px}
.enroll-band p{font-size:clamp(14px,1.2vw,16.5px);color:rgba(255,255,255,.82);max-width:50ch;margin:0 auto 28px;line-height:1.7}
.enroll-band-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn-enroll-primary{
  padding:13px 30px;background:#fff;color:var(--primary);
  border-radius:var(--radius-pill);font-family:var(--font-head);font-size:14px;font-weight:700;
  border:none;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:7px;
  transition:all var(--t);box-shadow:0 4px 18px rgba(0,0,0,.18);
}
.btn-enroll-primary:hover{background:var(--bg-warm);transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.24);color:var(--primary-dark)}
.btn-enroll-outline{
  padding:12px 28px;background:transparent;color:#fff;
  border:1.5px solid rgba(255,255,255,.5);border-radius:var(--radius-pill);
  font-family:var(--font-head);font-size:14px;font-weight:600;
  cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:7px;
  transition:all var(--t);backdrop-filter:blur(4px);
}
.btn-enroll-outline:hover{background:rgba(255,255,255,.16);border-color:#fff;color:#fff}

/* ── STAFF PAGE ── */
.hca-staff-card{
  background:var(--bg-card);border-radius:var(--radius-md);
  padding:26px 16px 20px;box-shadow:var(--shadow-card);
  border:1px solid var(--border);text-align:center;
  transition:transform .28s var(--ease),box-shadow .28s var(--ease);
  position:relative;overflow:hidden;
}
.hca-staff-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--primary),var(--accent));
}
.hca-staff-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.hca-staff-photo{width:108px;height:134px;border-radius:10px;margin:0 auto 14px;position:relative}
.hca-staff-photo::before{content:'';position:absolute;inset:-3px;border-radius:13px;background:linear-gradient(135deg,var(--primary),var(--accent));z-index:0}
.hca-staff-photo::after{content:'';position:absolute;inset:-1px;border-radius:12px;background:var(--bg-card);z-index:1}
.hca-staff-photo img{position:relative;z-index:2;width:100%;height:100%;object-fit:cover;object-position:top;border-radius:10px;display:block;filter:none}
.hca-staff-card.leader .hca-staff-photo{width:128px;height:156px}
.hca-staff-name{font-family:var(--font-head);font-size:13.5px;font-weight:700;color:var(--secondary);margin-bottom:6px;line-height:1.28}
.hca-staff-designation{
  display:inline-block;
  background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;
  font-family:var(--font-head);font-size:10px;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;
  padding:3px 11px;border-radius:var(--radius-pill);margin-bottom:11px;
}
.hca-staff-card.teacher .hca-staff-designation,
.hca-staff-card.admin  .hca-staff-designation{font-size:9.5px;padding:2px 9px}
.hca-staff-contact{display:flex;align-items:center;justify-content:center;gap:5px;font-size:11.5px;color:var(--text-light);margin-top:4px}
.hca-staff-contact a{color:var(--text-light);transition:color var(--t)}
.hca-staff-contact a:hover{color:var(--primary)}
.staff-group{margin-bottom:60px}
.staff-group-header{display:flex;align-items:center;gap:12px;margin-bottom:28px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.staff-group-icon{width:36px;height:36px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;flex-shrink:0;box-shadow:0 4px 12px rgba(192,57,43,.28)}
.staff-group-header h3{font-size:17px;color:var(--secondary);white-space:nowrap}
.staff-group-line{flex:1;height:1.5px;background:linear-gradient(to right,rgba(192,57,43,.28),transparent);border-radius:2px}
.staff-leaders-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;max-width:620px;margin:0 auto}
.staff-vp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:820px;margin:0 auto}
.staff-teachers-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.staff-admin-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.staff-empty{text-align:center;padding:56px 24px;background:var(--bg-card);border-radius:var(--radius-md);border:2px dashed var(--border)}

/* ── SINGLE / INNER ── */
.single-content{padding:clamp(52px,7vw,96px) 0}
.single-content .container{max-width:860px}
.single-content .featured-img{width:100%;border-radius:var(--radius-md);margin-bottom:30px;box-shadow:var(--shadow-md);max-height:460px;object-fit:cover}
.page-hero-banner{background:linear-gradient(135deg,var(--secondary) 0%,#4A1010 100%);padding:clamp(44px,6vw,76px) 0 clamp(32px,4.5vw,56px);position:relative;overflow:hidden}
.page-hero-banner::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23fff' fill-opacity='0.03'%3E%3Ccircle cx='20' cy='20' r='8'/%3E%3C/g%3E%3C/svg%3E")}
.page-hero-banner .container{position:relative;z-index:1}
.page-hero-banner h1{color:#fff;margin-bottom:8px}
.breadcrumb-trail{display:flex;gap:7px;align-items:center;font-size:12.5px;color:rgba(255,255,255,.6);flex-wrap:wrap}
.breadcrumb-trail a{color:var(--accent-light)}
.breadcrumb-trail .sep{color:rgba(255,255,255,.3)}
.notice-archive-item{border-radius:var(--radius-md);box-shadow:var(--shadow-card);border:1px solid var(--border);border-left:4px solid var(--primary);transition:transform var(--t),box-shadow var(--t)}
.notice-archive-item:hover{transform:translateX(4px);box-shadow:var(--shadow-md)}
.notice-attachment-btn{display:inline-flex;align-items:center;gap:6px;background:var(--primary);color:#fff;padding:6px 13px;border-radius:8px;font-family:var(--font-head);font-size:12px;font-weight:600;text-decoration:none;transition:background var(--t);margin-top:8px}
.notice-attachment-btn:hover{background:var(--primary-dark);color:#fff}

/* ── INTRO ── */
.intro-section{padding:clamp(56px,8vw,100px) 0}
.intro-photo img{height:340px;object-fit:cover;border-radius:var(--radius-md);width:100%;box-shadow:var(--shadow-lg)}
.intro-content .subtitle{font-family:var(--font-head);font-size:11.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--primary);margin-bottom:10px;display:block}
.intro-content h2{color:var(--secondary);margin-bottom:14px}
.intro-content p{font-size:15px;line-height:1.8}

/* ── FOOTER ── */
.footer{background:#3D1010;color:rgba(255,255,255,.72)}
.footer-main{padding:clamp(44px,6vw,64px) 0 clamp(28px,4vw,40px)}
.footer h4{font-size:14.5px;color:#fff;margin-bottom:16px;padding-bottom:9px;border-bottom:2px solid var(--primary);display:inline-block}
.footer-about p{font-size:13.5px;line-height:1.7}
.footer-links li a{font-size:13px;transition:all var(--t)}
.footer-links li a:hover{color:var(--accent-light);padding-left:6px}
.footer-contact li{font-size:13px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:16px 0;text-align:center;font-size:12px;color:rgba(255,255,255,.38)}

/* ── PUBLICATIONS ── */
.pub-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pub-card-body{padding:16px 18px 20px;display:flex;flex-direction:column;flex:1}
.pub-type-badge{display:inline-block;background:rgba(192,57,43,.1);color:var(--primary);font-family:var(--font-head);font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 9px;border-radius:6px;margin-bottom:8px}
.pub-card-body h3{font-size:15px;color:var(--secondary);margin-bottom:7px;line-height:1.32}
.pub-card-body p{font-size:13px;flex:1;margin-bottom:12px}
.pub-download-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;background:var(--primary);color:#fff;border-radius:9px;font-family:var(--font-head);font-size:12.5px;font-weight:600;text-decoration:none;transition:background var(--t);margin-top:auto;width:fit-content}
.pub-download-btn:hover{background:var(--primary-dark)}

/* ════════════════════════════════════════════════════════════
   RESPONSIVE — MOBILE FIRST where it matters
   ════════════════════════════════════════════════════════════ */

@media(max-width:1100px){
  .staff-teachers-grid{grid-template-columns:repeat(4,1fr)}
  .staff-admin-grid{grid-template-columns:repeat(3,1fr)}
  .gallery-grid{grid-template-columns:repeat(3,1fr);grid-auto-rows:165px}
  .gallery-item:nth-child(6){grid-column:span 1}
}

/* ── 768 px: hero stacks vertically, padding-bottom ratio trick ── */
@media(max-width:768px){
  .hero{
    flex-direction:column;
    height:auto;max-height:none;min-height:0;
  }

  /*
   * Padding-bottom trick explanation:
   * When height=0, padding-bottom% is calculated from the element's WIDTH.
   * So padding-bottom:56.25% on a full-width div = exactly 16:9 height.
   * The absolutely-positioned children fill this box perfectly.
   * Result: image ALWAYS fills 100% width and correct height with no distortion.
   */
  .hero-carousel{
    flex:none;
    width:100%;
    height:0;
    padding-bottom:56.25%;   /* 16 : 9 — change to 62.5% for 16:10 if preferred */
    position:relative;
    overflow:hidden;
  }

  /* Slides and images must all be positioned inside the padding-bottom box */
  .carousel-slide{
    position:absolute;top:0;left:0;
    width:100%;height:100%;
  }
  .carousel-slide img{
    position:absolute;top:0;left:0;
    width:100% !important;height:100% !important;
    object-fit:cover !important;
    object-position:center center !important;
    border-radius:0 !important;
    filter:none !important;
  }
  .carousel-overlay{
    position:absolute;top:0;left:0;right:0;bottom:0;
    padding:10px 12px;justify-content:flex-end;
  }
  .carousel-text-pill{
    max-width:100%;padding:10px 12px;gap:4px;
    border-radius:10px;
  }
  .carousel-text-pill h2{
    font-size:clamp(12.5px,4.2vw,17px) !important;
    letter-spacing:-.02em;
  }
  .carousel-text-pill p{
    font-size:clamp(10.5px,2.8vw,12.5px) !important;
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  }
  .carousel-cta{margin-top:7px;gap:6px}
  .btn-slide-primary,.btn-slide-outline{padding:6px 13px;font-size:11px}

  /* Notice panel full-width below slider */
  .hero-notice{flex:none;width:100%;height:190px}

  /* Stat strip 2-col on mobile */
  .stat-strip-inner{grid-template-columns:repeat(2,1fr)}
  .stat-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}
  .stat-item:nth-child(2),.stat-item:nth-child(4){border-bottom:none}

  /* Gallery 2-col */
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:130px}
  .gallery-item:nth-child(1){grid-column:span 2;grid-row:span 1}
  .gallery-item:nth-child(6){grid-column:span 2}

  /* Staff */
  .staff-leaders-grid{grid-template-columns:repeat(2,1fr);max-width:100%;gap:16px}
  .staff-vp-grid{grid-template-columns:repeat(2,1fr);max-width:100%}
  .staff-teachers-grid{grid-template-columns:repeat(3,1fr)}
  .staff-admin-grid{grid-template-columns:repeat(2,1fr)}

  /* Other */
  .pub-grid{grid-template-columns:repeat(2,1fr)}
  .enroll-band-btns{flex-direction:column;align-items:center}
  .sticky-enroll{bottom:14px;right:14px;padding:10px 16px;font-size:12px}
  .section{padding:clamp(40px,7vw,64px) 0}
  .intro-section{padding:clamp(40px,7vw,64px) 0}
  .intro-photo img{height:260px}
  .voices-grid{grid-template-columns:1fr;gap:24px}
}

@media(max-width:480px){
  /* Even taller ratio on very narrow phones */
  .hero-carousel{padding-bottom:65%}

  /* Collapse paragraph in pill on very small screens */
  .carousel-text-pill p{display:none}

  /* Gallery */
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:110px}
  .gallery-item:nth-child(6){grid-column:span 1}

  /* Staff */
  .staff-teachers-grid{grid-template-columns:repeat(2,1fr)}

  /* Misc */
  .pub-grid{grid-template-columns:1fr}
  .stat-num{font-size:clamp(1.3rem,5.5vw,1.7rem)}
  .facilities-grid{grid-template-columns:repeat(2,1fr)}
  .nav-brand-text h1{font-size:12.5px}
  .nav-brand-text span{display:none}
  .sticky-enroll span{display:none}
  .sticky-enroll{padding:12px}
}

/* Respect reduced-motion preference */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}
}

/* ================================================================
   v2.2 PATCH — Top bar mobile, Nav font sizing,
                Mobile submenu, Nav toggle button
   ================================================================ */

/* ── TOP BAR — desktop shows all, mobile shows only essentials ── */
.top-bar .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: nowrap;          /* never wrap on any viewport */
    gap: 8px;
    min-height: 34px;
}
.top-bar-left {
    display: flex;
    align-items: center;
    gap: 18px;
    flex: 1;
    min-width: 0;
    overflow: hidden;
}
.tb-item {
    display: flex;
    align-items: center;
    gap: 5px;
    white-space: nowrap;
    font-size: 12.5px;
    color: rgba(255,255,255,.82);
    flex-shrink: 0;
}
.tb-item i { font-size: 11px; color: var(--accent-light); flex-shrink: 0; }
.tb-item a { color: rgba(255,255,255,.82); transition: color var(--t); }
.tb-item a:hover { color: var(--accent-light); }
.top-bar-right {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}
.top-bar-right a {
    width: 28px; height: 28px;
    border-radius: 50%;
    background: rgba(255,255,255,.1);
    color: rgba(255,255,255,.82);
    display: flex; align-items: center; justify-content: center;
    font-size: 12px;
    transition: background var(--t), color var(--t);
    text-decoration: none;
}
.top-bar-right a:hover { background: var(--primary); color: #fff; }

/* Mobile: hide address and email, keep only phone tap-to-call + socials */
@media (max-width: 767px) {
    .top-bar { padding: 5px 0; }
    .tb-addr  { display: none !important; }
    .tb-email { display: none !important; }
    .tb-phone {
        font-size: 11.5px;
        /* Phone shown as a compact tap-to-call link */
    }
    .tb-phone a { color: var(--accent-light); font-weight: 600; }
    .top-bar-left { gap: 0; }
}

/* ── NAVBAR HEIGHT & FONT SIZES ── */
.navbar .container {
    height: 72px;
    gap: 8px;
}
/* Logo image */
.nav-brand img,
.nav-brand .site-logo,
.custom-logo {
    height: 52px !important;
    width:  52px !important;
    max-width: 52px !important;
}
/* Brand text */
.nav-brand-text h1  { font-size: clamp(14px, 1.4vw, 18px); line-height: 1.1; }
.nav-brand-text span { font-size: 11.5px; font-weight: 500; }

/* Desktop nav links — fluid and compact */
.nav-menu { display: flex; align-items: center; gap: 0; flex: 1; justify-content: flex-end; }
.nav-menu > li { position: relative; }
.nav-menu > li > a {
    display: block;
    font-family: var(--font-head);
    font-size: clamp(11px, 0.75vw + 5px, 13px);
    font-weight: 600;
    letter-spacing: 0.01em;
    padding: 20px 9px;
    color: var(--text-main);
    white-space: nowrap;
    text-decoration: none;
    transition: color var(--t);
    position: relative;
}
.nav-menu > li > a::after {
    content: '';
    position: absolute;
    bottom: 0; left: 50%;
    transform: translateX(-50%) scaleX(0);
    width: 75%; height: 2px;
    background: var(--primary);
    border-radius: 2px;
    transition: transform var(--t);
}
.nav-menu > li > a:hover::after,
.nav-menu > li.current-menu-item > a::after,
.nav-menu > li.current-menu-ancestor > a::after { transform: translateX(-50%) scaleX(1); }
.nav-menu > li > a:hover,
.nav-menu > li.current-menu-item > a { color: var(--primary); }

/* Calendar highlight */
.nav-calendar-highlight > a {
    background: var(--primary) !important;
    color: #fff !important;
    border-radius: var(--radius-pill);
    padding: 7px 14px !important;
    margin: 13px 3px !important;
}
.nav-calendar-highlight > a:hover { background: var(--primary-dark) !important; color: #fff !important; }
.nav-calendar-highlight > a::after { display: none; }

/* Desktop dropdown */
.nav-menu > li > .sub-menu,
.nav-menu > li > ul.sub-menu {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 200px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-top: 2px solid var(--primary);
    border-radius: 0 0 var(--radius-md) var(--radius-md);
    box-shadow: var(--shadow-md);
    z-index: 200;
    display: none;
    padding: 6px 0;
    list-style: none;
}
.nav-menu > li:hover > .sub-menu,
.nav-menu > li:focus-within > .sub-menu { display: block; }
.nav-menu > li > .sub-menu li a {
    display: block;
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 500;
    padding: 9px 18px;
    color: var(--text-main);
    text-decoration: none;
    border-bottom: 1px solid #f3f0eb;
    white-space: nowrap;
    transition: all var(--t);
}
.nav-menu > li > .sub-menu li:last-child a { border-bottom: none; }
.nav-menu > li > .sub-menu li a:hover { color: var(--primary); background: var(--bg-warm); padding-left: 24px; }

/* ── NAV TOGGLE BUTTON (hamburger) ── */
.nav-toggle {
    display: none;          /* hidden on desktop */
    flex-direction: column;
    gap: 5px;
    background: none;
    border: 1.5px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 7px 9px;
    cursor: pointer;
    flex-shrink: 0;
    transition: border-color var(--t);
}
.nav-toggle:hover { border-color: var(--primary); }
.nav-toggle .bar {
    display: block;
    width: 20px; height: 2px;
    background: var(--text-main);
    border-radius: 2px;
    transition: all var(--t);
}
/* Animate to X when open */
.nav-toggle[aria-expanded="true"] .bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] .bar:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-toggle[aria-expanded="true"] .bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ── MOBILE NAV DRAWER ── */
.mobile-nav-backdrop {
    display: none;
    position: fixed; inset: 0;
    background: rgba(0,0,0,.45);
    z-index: 1999;
    backdrop-filter: blur(2px);
}
.mobile-nav-backdrop.open { display: block; }

.mobile-nav {
    display: block;          /* always in DOM, off-screen */
    position: fixed;
    top: 0; left: 0;
    width: min(300px, 88vw);
    height: 100dvh;          /* dynamic viewport height */
    background: var(--bg-card);
    z-index: 2000;
    box-shadow: var(--shadow-lg);
    overflow-y: auto;
    transform: translateX(-100%);
    transition: transform 0.28s var(--ease);
    display: flex;
    flex-direction: column;
}
.mobile-nav.open { transform: translateX(0); }

/* Drawer header */
.mob-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 16px 20px;
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
}
.mob-header img,
.mob-header .site-logo {
    width: 38px !important; height: 38px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    border: 2px solid var(--accent) !important;
    flex-shrink: 0;
}
.mob-brand-text {
    display: flex;
    flex-direction: column;
    justify-content: center;
    flex: 1;
    gap: 1px;
}
.mob-school-name {
    font-family: var(--font-head);
    font-weight: 700;
    font-size: 14.5px;
    color: var(--secondary);
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.mob-school-slogan {
    font-size: 10.5px;
    color: var(--text-muted);
    font-weight: 500;
}
.mob-close {
    width: 32px; height: 32px;
    border-radius: 50%;
    border: 1px solid var(--border);
    background: none;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    font-size: 15px;
    color: var(--text-light);
    transition: all var(--t);
    flex-shrink: 0;
    margin-left: auto;
}
.mob-close:hover { background: var(--primary); color: #fff; border-color: var(--primary); }

/* Mobile nav links — the <a> tags rendered by walker */
.mobile-nav > ul,
.mobile-nav ul { list-style: none; padding: 0; margin: 0; }

/* Top-level items */
.mobile-nav > ul > li { border-bottom: 1px solid var(--border); }

/* Parent row (has children) */
.mob-parent-row {
    display: flex;
    align-items: stretch;
    border-bottom: 1px solid var(--border);
}
.mob-parent-link {
    flex: 1;
    display: flex;
    align-items: center;
    padding: 13px 16px;
    font-family: var(--font-head);
    font-size: 14px;
    font-weight: 600;
    color: var(--text-main);
    text-decoration: none;
    transition: color var(--t), background var(--t);
}
.mob-parent-link:hover,
.mob-parent-link:focus { color: var(--primary); background: var(--bg-warm); }

/* Chevron toggle button */
.mob-sub-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    background: none;
    border: none;
    border-left: 1px solid var(--border);
    cursor: pointer;
    color: var(--text-light);
    font-size: 13px;
    transition: color var(--t), background var(--t);
    flex-shrink: 0;
}
.mob-sub-toggle:hover { background: var(--bg-warm); color: var(--primary); }
.mob-sub-toggle i { transition: transform 0.22s var(--ease); }

/* Regular (non-parent) links */
.mobile-nav a:not(.mob-parent-link):not(.mob-contact-link) {
    display: flex;
    align-items: center;
    padding: 14px 18px;
    font-family: var(--font-head);
    font-size: 14px;
    font-weight: 600;
    color: var(--text-main);
    text-decoration: none;
    border-bottom: 1px solid var(--border);
    transition: all var(--t);
}
.mobile-nav a:not(.mob-parent-link):not(.mob-contact-link):hover { color: var(--primary); background: var(--bg-warm); }

/* Submenu (hidden by default, revealed with .open) */
.mob-sub {
    display: none;
    background: var(--bg-warm);
    border-bottom: 1px solid var(--border);
}
.mob-sub.open { display: block; }
.mob-sub a {
    padding-left: 32px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: var(--text-light) !important;
    border-bottom: 1px solid rgba(0,0,0,.05) !important;
}
.mob-sub a:hover { color: var(--primary) !important; background: rgba(192,57,43,.05) !important; }
.mob-sub a:last-child { border-bottom: none !important; }

/* Calendar highlight in mobile */
.mob-calendar-highlight {
    background: var(--primary) !important;
    color: #fff !important;
    margin: 8px 14px !important;
    border-radius: var(--radius-pill) !important;
    justify-content: center !important;
    border: none !important;
    font-weight: 700 !important;
    border-bottom: none !important;
}
.mob-calendar-highlight:hover { background: var(--primary-dark) !important; }

/* Bottom contact strip in mobile nav */
.mob-contact-strip {
    margin-top: auto;
    border-top: 1px solid var(--border);
    padding: 14px 16px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    flex-shrink: 0;
    background: var(--bg-warm);
}
.mob-contact-link {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 600;
    color: var(--text-light);
    text-decoration: none;
    padding: 0 !important;
    border: none !important;
    background: none !important;
    transition: color var(--t);
}
.mob-contact-link:hover { color: var(--primary) !important; background: none !important; }
.mob-contact-link i { color: var(--primary); font-size: 13px; width: 16px; text-align: center; }

/* ── SHOW TOGGLE, HIDE DESKTOP NAV on mobile ── */
@media (max-width: 768px) {
    .nav-toggle { display: flex; }
    .nav-menu   { display: none !important; } /* hide desktop nav */
    .navbar .container { height: 58px; }
    .top-bar .container { flex-direction: row !important; }
}

@media (max-width: 480px) {
    .nav-brand-text span { display: block; font-size: 10px; }
    .nav-brand-text h1   { font-size: 14px; }
    .navbar .container   { height: 60px; }
}
