/*
Theme Name: Chari International School
Theme URI: https://chariinternationalschool.edu.gh
Author: Chari International School
Description: Official WordPress theme for Chari International School — Grace • Wisdom • Possibility. East Legon Hills, ECG Estate, Accra, Ghana. EST 2024.
Version: 2.0
License: GNU General Public License v2 or later
Text Domain: chari-school
*/

/* ===========================
   CSS VARIABLES
=========================== */
:root {
  --orange:       #FC7B03;
  --orange-dark:  #d96600;
  --orange-light: #fd9534;
  --orange-pale:  #fff4e8;
  --orange-glow:  rgba(252,123,3,0.20);
  --blue:         #007BFF;
  --blue-dark:    #0062cc;
  --blue-light:   #e8f3ff;
  --blue-pale:    #f0f7ff;
  --dark:         #05111f;
  --dark-mid:     #0d2035;
  --dark-3:       #112840;
  --white:        #ffffff;
  --off-white:    #f8fafd;
  --text-dark:    #0a1929;
  --text-mid:     #3a5068;
  --text-light:   #7a95aa;
  --font-head:    'Plus Jakarta Sans', sans-serif;
  --font-body:    'Inter', sans-serif;
  --nav-h:        82px;
  --tr:           0.3s cubic-bezier(0.4,0,0.2,1);
  --radius:       6px;
  --shadow-sm:    0 2px 16px rgba(0,123,255,0.07);
  --shadow-md:    0 8px 40px rgba(0,123,255,0.12);
  --shadow-lg:    0 20px 60px rgba(0,123,255,0.16);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--text-dark);background:var(--white);overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}

/* ===========================
   UTILITY
=========================== */
.container{max-width:1240px;margin:0 auto;padding:0 36px}

.label{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-head);font-size:11px;font-weight:700;
  letter-spacing:4px;text-transform:uppercase;color:var(--orange);margin-bottom:16px;
}
.label::before{content:'';display:block;width:28px;height:3px;background:var(--orange);border-radius:2px}
.label.blue{color:var(--blue)}.label.blue::before{background:var(--blue)}
.label.white{color:rgba(255,255,255,.85)}.label.white::before{background:var(--orange)}

.section-title{
  font-family:var(--font-head);font-size:clamp(1.9rem,3.5vw,3rem);
  font-weight:800;line-height:1.14;color:var(--text-dark);
  margin-bottom:20px;letter-spacing:-.4px;
}
.section-title .o{color:var(--orange)}
.section-title .b{color:var(--blue)}
.section-title.white{color:#fff}

.section-sub{font-size:15px;line-height:1.8;color:var(--text-mid);max-width:620px}

/* BUTTONS */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-head);font-size:12px;font-weight:700;
  letter-spacing:1px;text-transform:uppercase;
  padding:13px 28px;cursor:pointer;
  transition:var(--tr);border:2px solid transparent;border-radius:var(--radius);
}
.btn svg{width:15px;height:15px;transition:transform var(--tr)}
.btn:hover svg{transform:translateX(5px)}
.btn-orange{background:var(--orange);color:#fff;border-color:var(--orange)}
.btn-orange:hover{background:var(--orange-dark);border-color:var(--orange-dark);box-shadow:0 8px 24px var(--orange-glow);transform:translateY(-2px)}
.btn-blue{background:var(--blue);color:#fff;border-color:var(--blue)}
.btn-blue:hover{background:var(--blue-dark);box-shadow:0 8px 24px rgba(0,123,255,.3);transform:translateY(-2px)}
.btn-out-orange{background:transparent;color:var(--orange);border-color:var(--orange)}
.btn-out-orange:hover{background:var(--orange);color:#fff}
.btn-out-white{background:transparent;color:#fff;border-color:rgba(255,255,255,.65)}
.btn-out-white:hover{background:#fff;color:var(--blue)}
.btn-out-blue{background:transparent;color:var(--blue);border-color:var(--blue)}
.btn-out-blue:hover{background:var(--blue);color:#fff}
.btn-sm{padding:9px 20px;font-size:11px}

/* FADE ANIMATIONS */
.fade-up{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.fade-up.v{opacity:1;transform:translateY(0)}
.fade-left{opacity:0;transform:translateX(-30px);transition:opacity .7s ease,transform .7s ease}
.fade-left.v{opacity:1;transform:translateX(0)}
.fade-right{opacity:0;transform:translateX(30px);transition:opacity .7s ease,transform .7s ease}
.fade-right.v{opacity:1;transform:translateX(0)}

/* ===========================
   TOP BAR
=========================== */
.topbar{
  background:var(--dark-mid);color:rgba(255,255,255,.7);
  font-size:12px;font-weight:500;padding:9px 0;
  border-bottom:3px solid var(--orange);
}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;gap:16px}
.topbar-left{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.topbar-left span{display:flex;align-items:center;gap:6px}
.topbar-left a{color:rgba(255,255,255,.7);transition:color var(--tr)}
.topbar-left a:hover{color:var(--orange)}
.topbar-sep{color:rgba(255,255,255,.2)}
.topbar-right{display:flex;gap:8px;flex-shrink:0}
.topbar-right a{
  padding:4px 14px;font-size:11px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;border-radius:3px;transition:var(--tr);
}
.tb-portal{background:transparent;border:1px solid rgba(255,255,255,.25);color:rgba(255,255,255,.7)}
.tb-portal:hover{border-color:var(--blue);color:var(--blue)}
.tb-apply{background:var(--orange);color:#fff}
.tb-apply:hover{background:var(--blue)}

/* ===========================
   NAVIGATION
=========================== */
nav.site-nav{
  position:sticky;top:0;z-index:999;
  background:#fff;height:var(--nav-h);
  box-shadow:0 1px 0 rgba(0,0,0,.07),0 4px 24px rgba(0,123,255,.06);
}
.nav-inner{height:100%;display:flex;align-items:center;justify-content:space-between;gap:20px}

/* Logo */
.nav-logo{display:flex;align-items:center;gap:12px;flex-shrink:0}
.nav-logo img{
  height:58px;width:58px;object-fit:contain;
  /* transparent PNG — no background needed */
  background:transparent;
}
.nav-logo-name{font-family:var(--font-head);font-size:15px;font-weight:800;color:var(--blue);letter-spacing:-.2px;line-height:1.2}
.nav-logo-motto{font-size:10px;font-weight:600;color:var(--orange);letter-spacing:1px}

/* Menu */
.nav-menu{display:flex;align-items:center}
.nav-menu>li{position:relative}
.nav-menu>li>a{
  display:flex;align-items:center;gap:5px;
  font-family:var(--font-head);font-size:13px;font-weight:600;
  color:var(--text-dark);padding:0 13px;height:var(--nav-h);transition:color var(--tr);
}
.nav-menu>li>a:hover,.nav-menu>li:hover>a{color:var(--orange)}
.nav-menu>li>a .ch{width:10px;height:10px;opacity:.35;transition:transform var(--tr)}
.nav-menu>li:hover>a .ch{transform:rotate(180deg)}

.dropdown{
  position:absolute;top:100%;left:0;min-width:220px;background:#fff;
  border-radius:0 0 var(--radius) var(--radius);
  box-shadow:0 12px 40px rgba(0,123,255,.13);border-top:3px solid var(--orange);
  opacity:0;visibility:hidden;transform:translateY(-6px);transition:var(--tr);padding:8px 0;
}
.nav-menu>li:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown li a{
  display:block;padding:10px 20px;font-size:13px;color:var(--text-mid);
  border-left:3px solid transparent;transition:var(--tr);
}
.dropdown li a:hover{color:var(--orange);background:var(--orange-pale);border-left-color:var(--orange)}

.nav-cta{display:flex;gap:10px;flex-shrink:0}
.nav-cta a{
  font-family:var(--font-head);font-size:12px;font-weight:700;
  letter-spacing:.8px;text-transform:uppercase;padding:10px 18px;border-radius:var(--radius);transition:var(--tr);
}
.nav-enq{color:var(--blue);border:2px solid var(--blue)}
.nav-enq:hover{background:var(--blue);color:#fff}
.nav-app{background:var(--orange);color:#fff;border:2px solid var(--orange)}
.nav-app:hover{background:var(--orange-dark);border-color:var(--orange-dark)}

.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
.hamburger span{display:block;width:24px;height:2px;background:var(--blue);transition:var(--tr)}

/* ===========================
   HERO SLIDER (5 slides)
=========================== */
.hero{
  position:relative;height:calc(100vh - var(--nav-h) - 43px);
  min-height:620px;overflow:hidden;background:var(--dark);
}
.hero-slides{position:relative;width:100%;height:100%}
.hero-slide{
  position:absolute;inset:0;display:flex;align-items:center;
  opacity:0;transition:opacity 1.1s ease;
}
.hero-slide.active{opacity:1}
.hero-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transform:scale(1.06);transition:transform 8s ease;
}
.hero-slide.active .hero-bg{transform:scale(1)}

/* Each slide gets a slightly different overlay for variety */
.hero-slide:nth-child(1) .hero-overlay{background:linear-gradient(110deg,rgba(5,17,31,.88) 0%,rgba(0,62,130,.60) 55%,rgba(252,123,3,.18) 100%)}
.hero-slide:nth-child(2) .hero-overlay{background:linear-gradient(100deg,rgba(5,17,31,.85) 0%,rgba(13,32,53,.65) 50%,rgba(0,123,255,.15) 100%)}
.hero-slide:nth-child(3) .hero-overlay{background:linear-gradient(115deg,rgba(13,32,53,.90) 0%,rgba(0,40,100,.60) 50%,rgba(252,123,3,.12) 100%)}
.hero-slide:nth-child(4) .hero-overlay{background:linear-gradient(105deg,rgba(5,17,31,.87) 0%,rgba(0,60,120,.62) 55%,rgba(252,123,3,.20) 100%)}
.hero-slide:nth-child(5) .hero-overlay{background:linear-gradient(110deg,rgba(13,32,53,.88) 0%,rgba(0,50,110,.60) 55%,rgba(0,123,255,.18) 100%)}
.hero-overlay{position:absolute;inset:0}

/* Right accent stripe */
.hero-stripe{position:absolute;top:0;right:0;bottom:0;width:5px;background:linear-gradient(180deg,var(--orange),var(--blue));z-index:2}

/* Watermark crest */
.hero-crest{
  position:absolute;right:6%;top:50%;transform:translateY(-50%);
  width:360px;height:360px;z-index:2;
  opacity:.06;
  background:url('images/logo.png') center/contain no-repeat;
}

.hero-content{position:relative;z-index:3;max-width:700px;color:#fff;padding:0 72px}

.hero-badge{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(252,123,3,.15);border:1px solid rgba(252,123,3,.35);
  border-radius:100px;padding:7px 18px;margin-bottom:24px;
  font-family:var(--font-head);font-size:11px;font-weight:700;
  letter-spacing:3px;text-transform:uppercase;color:var(--orange);
  opacity:0;animation:fadeUp .7s .2s forwards;
}
.hero-badge .dot{width:6px;height:6px;border-radius:50%;background:var(--orange);animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.5)}}

.hero-title{
  font-family:var(--font-head);font-weight:900;
  font-size:clamp(2.4rem,5vw,4.6rem);
  line-height:1.06;letter-spacing:-1.5px;margin-bottom:18px;
  opacity:0;animation:fadeUp .7s .4s forwards;
}
.hero-title .hl{color:var(--orange)}

.hero-motto{
  font-size:13px;font-weight:600;color:rgba(255,255,255,.55);
  letter-spacing:4px;margin-bottom:18px;
  opacity:0;animation:fadeUp .7s .55s forwards;
}
.hero-desc{
  font-size:15px;line-height:1.82;color:rgba(255,255,255,.78);
  margin-bottom:38px;max-width:530px;
  opacity:0;animation:fadeUp .7s .7s forwards;
}
.hero-buttons{
  display:flex;gap:14px;flex-wrap:wrap;
  opacity:0;animation:fadeUp .7s .9s forwards;
}

@keyframes fadeUp{
  from{opacity:0;transform:translateY(22px)}
  to{opacity:1;transform:translateY(0)}
}

/* Location tag */
.hero-location{
  position:absolute;bottom:44px;left:72px;z-index:3;
  display:flex;align-items:center;gap:8px;
  font-size:12px;font-weight:500;color:rgba(255,255,255,.5);letter-spacing:.5px;
}
.hero-location svg{width:13px;height:13px;color:var(--orange);flex-shrink:0}

/* Slide counter */
.hero-counter{
  position:absolute;bottom:44px;right:72px;z-index:3;
  font-family:var(--font-head);font-size:13px;font-weight:700;color:rgba(255,255,255,.4);
  letter-spacing:2px;
}
.hero-counter .cur{color:var(--orange);font-size:22px;font-weight:900}

/* Dots + arrows */
.hero-nav{
  position:absolute;bottom:0;left:0;right:0;z-index:3;
  display:flex;align-items:center;justify-content:center;
  gap:8px;padding-bottom:16px;
}
.hero-dot{
  width:28px;height:3px;border-radius:2px;
  background:rgba(255,255,255,.25);cursor:pointer;transition:var(--tr);
}
.hero-dot.active{background:var(--orange);width:48px}

.hero-arrows-wrap{position:absolute;top:50%;right:20px;transform:translateY(-50%);z-index:3;display:flex;flex-direction:column;gap:8px}
.hero-arr{
  width:42px;height:42px;background:rgba(255,255,255,.08);
  border:1.5px solid rgba(255,255,255,.25);border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  color:#fff;cursor:pointer;transition:var(--tr);
}
.hero-arr:hover{background:var(--orange);border-color:var(--orange)}

/* Progress bar */
.hero-progress{
  position:absolute;bottom:0;left:0;height:3px;
  background:var(--orange);z-index:4;width:0;
  transition:none;
}
.hero-progress.animating{transition:width 5.5s linear}

/* ===========================
   MOTTO BAND
=========================== */
.motto-band{background:var(--orange)}
.motto-inner{display:flex;align-items:stretch}
.motto-item{
  flex:1;padding:26px 28px;text-align:center;
  border-right:1px solid rgba(255,255,255,.2);
  display:flex;flex-direction:column;align-items:center;gap:6px;
  transition:background var(--tr);cursor:default;
}
.motto-item:last-child{border-right:none}
.motto-item:hover{background:rgba(0,0,0,.08)}
.motto-icon{font-size:1.5rem}
.motto-word{font-family:var(--font-head);font-size:1.25rem;font-weight:900;color:#fff}
.motto-sub{font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.7)}

/* ===========================
   STATS BAR
=========================== */
.stats-bar{background:var(--blue);position:relative;overflow:hidden}
.stats-bar::after{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(90deg,transparent,transparent 100px,rgba(255,255,255,.03) 100px,rgba(255,255,255,.03) 101px);
}
.stats-inner{display:grid;grid-template-columns:repeat(4,1fr);position:relative;z-index:1}
.stat-item{
  padding:34px 24px;text-align:center;
  border-right:1px solid rgba(255,255,255,.12);transition:background var(--tr);
}
.stat-item:last-child{border-right:none}
.stat-item:hover{background:rgba(255,255,255,.06)}
.stat-num{font-family:var(--font-head);font-size:2.6rem;font-weight:900;color:var(--orange);line-height:1;margin-bottom:6px;letter-spacing:-1px}
.stat-lbl{font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.55)}

/* ===========================
   ABOUT SECTION (homepage)
=========================== */
.about-section{padding:120px 0;background:#fff}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}

.about-visual{position:relative;padding:20px 20px 56px 0}
.about-img-main{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow-lg)}
.about-img-small{
  position:absolute;bottom:0;right:-16px;width:54%;aspect-ratio:1;
  object-fit:cover;border-radius:var(--radius);
  border:5px solid #fff;box-shadow:var(--shadow-md);
}
.about-logo-badge{
  position:absolute;top:-10px;left:-16px;background:transparent;
  border-radius:50%;padding:0;width:90px;height:90px;
  display:flex;align-items:center;justify-content:center;
  filter:drop-shadow(0 4px 16px rgba(0,123,255,.25));
}
.about-logo-badge img{width:90px;height:90px;object-fit:contain;background:transparent}
.about-est-badge{
  position:absolute;bottom:8px;left:16px;background:var(--blue);color:#fff;
  border-radius:var(--radius);padding:16px 20px;box-shadow:0 8px 24px rgba(0,123,255,.3);text-align:center;
}
.about-est-badge .est-year{font-family:var(--font-head);font-size:2rem;font-weight:900;line-height:1;display:block}
.about-est-badge .est-label{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;opacity:.8}

.about-text p{font-size:15px;line-height:1.88;color:var(--text-mid);margin-bottom:16px}
.tagline{
  font-family:var(--font-head);font-size:1.05rem;font-weight:700;
  color:var(--orange);border-left:4px solid var(--orange);
  padding-left:16px;margin:24px 0;line-height:1.6;
}
.about-grid-mini{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:24px 0}
.mini-card{background:var(--blue-pale);border-radius:var(--radius);padding:16px 18px;border-left:3px solid var(--blue)}
.mini-card-title{font-family:var(--font-head);font-size:13px;font-weight:700;color:var(--blue);margin-bottom:4px}
.mini-card-text{font-size:12px;color:var(--text-mid);line-height:1.55}

/* ===========================
   FEATURES GRID
=========================== */
.features-section{padding:120px 0;background:var(--off-white)}
.features-header{text-align:center;margin-bottom:64px}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.feature-card{
  background:#fff;padding:38px 32px;border-radius:var(--radius);
  border:2px solid transparent;box-shadow:var(--shadow-sm);
  transition:var(--tr);cursor:pointer;position:relative;overflow:hidden;
}
.feature-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--orange),var(--blue));
  transform:scaleX(0);transform-origin:left;transition:var(--tr);
}
.feature-card:hover::before{transform:scaleX(1)}
.feature-card:hover{border-color:rgba(252,123,3,.15);box-shadow:var(--shadow-md);transform:translateY(-6px)}
.feature-num{font-family:var(--font-head);font-size:3.2rem;font-weight:900;color:rgba(0,123,255,.05);line-height:1;margin-bottom:6px;transition:color var(--tr)}
.feature-card:hover .feature-num{color:rgba(252,123,3,.10)}
.feature-icon{width:52px;height:52px;border-radius:var(--radius);background:var(--blue-light);display:flex;align-items:center;justify-content:center;margin-bottom:18px;color:var(--blue);transition:var(--tr)}
.feature-card:hover .feature-icon{background:var(--orange);color:#fff}
.feature-icon svg{width:24px;height:24px}
.feature-title{font-family:var(--font-head);font-size:1.05rem;font-weight:700;color:var(--text-dark);margin-bottom:10px}
.feature-text{font-size:14px;line-height:1.75;color:var(--text-mid);margin-bottom:18px}
.feature-link{font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--orange);display:flex;align-items:center;gap:8px;transition:gap var(--tr)}
.feature-card:hover .feature-link{gap:14px}

/* ===========================
   CURRICULUM TABS
=========================== */
.curriculum-section{padding:120px 0;background:#fff}
.curriculum-tabs{display:flex;border-bottom:2px solid #e5edf5}
.curriculum-tab{
  padding:14px 28px;font-family:var(--font-head);font-size:12px;font-weight:700;
  letter-spacing:1px;text-transform:uppercase;color:var(--text-light);
  cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:var(--tr);
}
.curriculum-tab.active{color:var(--blue);border-bottom-color:var(--orange)}
.curriculum-tab:hover{color:var(--blue)}
.curriculum-panel{display:none}
.curriculum-panel.active{display:grid;grid-template-columns:1fr 1fr}
.curriculum-image{position:relative;overflow:hidden;min-height:500px}
.curriculum-image img{width:100%;height:100%;object-fit:cover}
.curriculum-age{
  position:absolute;top:0;left:0;background:var(--orange);color:#fff;
  font-family:var(--font-head);font-size:11px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;padding:10px 20px;
}
.curriculum-content{
  background:var(--dark-mid);color:#fff;
  padding:68px 56px;display:flex;flex-direction:column;justify-content:center;
  position:relative;overflow:hidden;
}
.curriculum-content::before{
  content:'';position:absolute;bottom:-60px;right:-60px;width:240px;height:240px;
  border-radius:50%;background:rgba(252,123,3,.10);
}
.curriculum-content::after{
  content:'';position:absolute;top:-40px;left:30px;width:100px;height:100px;
  border-radius:50%;background:rgba(0,123,255,.12);
}
.curriculum-content h3{font-family:var(--font-head);font-size:2rem;font-weight:800;margin-bottom:16px;line-height:1.2;position:relative;z-index:1}
.curriculum-content p{font-size:14px;line-height:1.85;color:rgba(255,255,255,.78);margin-bottom:30px;position:relative;z-index:1}
.curriculum-content .label{position:relative;z-index:1}

/* ===========================
   TESTIMONIALS
=========================== */
.testimonials-section{padding:120px 0;background:var(--dark);position:relative;overflow:hidden}
.testimonials-section::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--orange),var(--blue),var(--orange))}
.testimonials-header{text-align:center;margin-bottom:60px}
.testimonials-header p{color:rgba(255,255,255,.55);font-size:15px;line-height:1.8;max-width:540px;margin:0 auto}
.t-track-wrap{overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.t-track{display:flex;gap:22px;animation:scrollT 36s linear infinite;width:max-content}
.t-track:hover{animation-play-state:paused}
@keyframes scrollT{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.t-card{
  width:370px;flex-shrink:0;background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);border-radius:var(--radius);padding:34px 30px;transition:var(--tr);
}
.t-card:hover{background:rgba(252,123,3,.07);border-color:rgba(252,123,3,.3)}
.t-stars{display:flex;gap:3px;margin-bottom:14px}
.t-stars span{color:var(--orange);font-size:13px}
.t-text{font-size:14px;line-height:1.8;color:rgba(255,255,255,.82);margin-bottom:22px;font-style:italic}
.t-author{display:flex;align-items:center;gap:13px}
.t-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid var(--orange);background:rgba(252,123,3,.2)}
.t-name{font-family:var(--font-head);font-size:13px;font-weight:700;color:#fff}
.t-role{font-size:11px;color:var(--orange);letter-spacing:.5px}

/* ===========================
   NEWS
=========================== */
.news-section{padding:120px 0;background:var(--off-white)}
.news-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:52px}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.news-card{background:#fff;overflow:hidden;border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:var(--tr)}
.news-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.news-img-wrap{aspect-ratio:16/10;overflow:hidden;position:relative}
.news-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.news-card:hover .news-img-wrap img{transform:scale(1.07)}
.news-cat{position:absolute;top:14px;left:14px;background:var(--orange);color:#fff;font-family:var(--font-head);font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:5px 12px;border-radius:3px}
.news-body{padding:24px}
.news-date{font-size:11px;font-weight:700;letter-spacing:2px;color:var(--blue);margin-bottom:10px;text-transform:uppercase}
.news-title{font-family:var(--font-head);font-size:1rem;font-weight:700;color:var(--text-dark);margin-bottom:10px;line-height:1.4}
.news-excerpt{font-size:13px;line-height:1.72;color:var(--text-mid);margin-bottom:16px}
.news-link{font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--orange);display:flex;align-items:center;gap:8px;transition:gap var(--tr)}
.news-card:hover .news-link{gap:14px}

/* ===========================
   CTA BAND
=========================== */
.cta-band{
  padding:100px 0;
  background:linear-gradient(135deg,var(--dark-mid) 0%,#003580 60%,#001a6e 100%);
  position:relative;overflow:hidden;
}
.cta-band::before{content:'';position:absolute;top:-80px;right:-80px;width:400px;height:400px;border-radius:50%;background:rgba(252,123,3,.11)}
.cta-band::after{content:'';position:absolute;bottom:-60px;left:20%;width:260px;height:260px;border-radius:50%;background:rgba(0,123,255,.14)}
.cta-inner{display:flex;justify-content:space-between;align-items:center;gap:48px;position:relative;z-index:1;flex-wrap:wrap}
.cta-brand{display:flex;align-items:center;gap:18px;flex-shrink:0}
.cta-brand img{width:76px;height:76px;object-fit:contain;background:transparent;filter:drop-shadow(0 4px 16px rgba(252,123,3,.4))}
.cta-brand-name{font-family:var(--font-head);font-size:1.2rem;font-weight:900;color:#fff}
.cta-brand-motto{font-size:11px;font-weight:600;color:var(--orange);letter-spacing:1.5px}
.cta-divider{width:1px;height:72px;background:rgba(255,255,255,.15);flex-shrink:0}
.cta-text h2{font-family:var(--font-head);font-size:2.2rem;font-weight:900;color:#fff;margin-bottom:12px;letter-spacing:-.4px;line-height:1.15}
.cta-text h2 span{color:var(--orange)}
.cta-text p{font-size:15px;color:rgba(255,255,255,.65);max-width:420px}
.cta-buttons{display:flex;gap:12px;flex-shrink:0}

/* ===========================
   FOOTER
=========================== */
footer.site-footer{
  background:var(--dark);color:rgba(255,255,255,.65);
  padding:100px 0 0;position:relative;
}
footer.site-footer::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--orange),var(--blue))}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.6fr;gap:52px;margin-bottom:60px}
.footer-brand-top{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.footer-brand-top img{width:56px;height:56px;object-fit:contain;background:transparent}
.footer-brand-name{font-family:var(--font-head);font-size:15px;font-weight:800;color:#fff}
.footer-brand-motto{font-size:10px;font-weight:600;color:var(--orange);letter-spacing:1px}
.footer-brand p{font-size:13px;line-height:1.82;margin-bottom:22px}
.footer-socials{display:flex;gap:10px}
.footer-social{
  width:38px;height:38px;border-radius:var(--radius);
  border:1.5px solid rgba(255,255,255,.14);
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;color:rgba(255,255,255,.4);transition:var(--tr);
}
.footer-social:hover{background:var(--orange);border-color:var(--orange);color:#fff}
.footer-col h4{font-family:var(--font-head);font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--orange);margin-bottom:20px}
.footer-col ul li{margin-bottom:9px}
.footer-col ul li a{font-size:13px;color:rgba(255,255,255,.5);transition:color var(--tr);display:flex;align-items:center;gap:7px}
.footer-col ul li a::before{content:'';display:block;width:4px;height:4px;border-radius:50%;background:var(--blue);flex-shrink:0;transition:background var(--tr)}
.footer-col ul li a:hover{color:var(--orange)}
.footer-col ul li a:hover::before{background:var(--orange)}
.foot-contact-item{display:flex;gap:12px;margin-bottom:14px;align-items:flex-start}
.foot-contact-item svg{width:14px;height:14px;color:var(--orange);flex-shrink:0;margin-top:2px}
.foot-contact-item span,.foot-contact-item a{font-size:13px;line-height:1.65;color:rgba(255,255,255,.5);transition:color var(--tr)}
.foot-contact-item a:hover{color:var(--orange)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding:24px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
.footer-bottom p{font-size:12px;color:rgba(255,255,255,.28)}
.footer-bottom-links{display:flex;gap:20px}
.footer-bottom-links a{font-size:12px;color:rgba(255,255,255,.28);transition:color var(--tr)}
.footer-bottom-links a:hover{color:var(--orange)}

/* ===========================
   INNER PAGE HERO (all sub-pages)
=========================== */
.page-hero{
  position:relative;height:380px;overflow:hidden;
  background:var(--dark-mid);
  display:flex;align-items:center;
}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.3}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(110deg,rgba(5,17,31,.92) 0%,rgba(0,62,130,.70) 60%,rgba(252,123,3,.15) 100%)}
.page-hero-stripe{position:absolute;top:0;right:0;bottom:0;width:5px;background:linear-gradient(180deg,var(--orange),var(--blue))}
.page-hero-content{position:relative;z-index:2;color:#fff;padding:0 0;max-width:700px}
.page-hero-content .breadcrumb{
  display:flex;align-items:center;gap:8px;margin-bottom:16px;
  font-size:12px;font-weight:600;letter-spacing:1px;
  color:rgba(255,255,255,.5);text-transform:uppercase;
}
.page-hero-content .breadcrumb a{color:rgba(255,255,255,.5);transition:color var(--tr)}
.page-hero-content .breadcrumb a:hover{color:var(--orange)}
.page-hero-content .breadcrumb span{color:var(--orange)}
.page-hero-title{
  font-family:var(--font-head);font-size:clamp(2rem,4vw,3.4rem);
  font-weight:900;line-height:1.1;letter-spacing:-.5px;margin-bottom:14px;
}
.page-hero-title .hl{color:var(--orange)}
.page-hero-sub{font-size:15px;color:rgba(255,255,255,.7);line-height:1.7;max-width:560px}

/* ===========================
   BREADCRUMB NAV STRIP
=========================== */
.breadcrumb-strip{
  background:#fff;border-bottom:1px solid rgba(0,123,255,.1);
  padding:12px 0;
}
.breadcrumb-strip .bc{
  display:flex;align-items:center;gap:8px;
  font-size:12px;font-weight:600;color:var(--text-light);letter-spacing:.5px;
}
.breadcrumb-strip .bc a{color:var(--text-light);transition:color var(--tr)}
.breadcrumb-strip .bc a:hover{color:var(--orange)}
.breadcrumb-strip .bc .sep{color:rgba(0,0,0,.2)}
.breadcrumb-strip .bc .cur{color:var(--blue)}

/* ===========================
   ABOUT PAGE
=========================== */
.about-intro{padding:100px 0;background:#fff}
.about-intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-intro-img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg)}
.about-intro-img img{width:100%;aspect-ratio:4/3;object-fit:cover}

.values-section{padding:100px 0;background:var(--off-white)}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:56px}
.value-card{
  background:#fff;border-radius:var(--radius);padding:40px 32px;
  box-shadow:var(--shadow-sm);text-align:center;transition:var(--tr);
  border-top:4px solid transparent;
}
.value-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-top-color:var(--orange)}
.value-icon-wrap{
  width:70px;height:70px;border-radius:50%;background:var(--orange-pale);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;font-size:1.8rem;transition:var(--tr);
}
.value-card:hover .value-icon-wrap{background:var(--orange)}
.value-title{font-family:var(--font-head);font-size:1.1rem;font-weight:800;color:var(--text-dark);margin-bottom:10px}
.value-text{font-size:14px;line-height:1.75;color:var(--text-mid)}

.leadership-section{padding:100px 0;background:#fff}
.leadership-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:56px}
.leader-card{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:var(--tr)}
.leader-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.leader-img{aspect-ratio:3/4;overflow:hidden}
.leader-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.leader-card:hover .leader-img img{transform:scale(1.05)}
.leader-info{padding:22px 24px;background:#fff}
.leader-name{font-family:var(--font-head);font-size:1.05rem;font-weight:700;color:var(--text-dark);margin-bottom:4px}
.leader-role{font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--orange)}
.leader-bio{font-size:13px;line-height:1.7;color:var(--text-mid);margin-top:10px}

.history-section{padding:100px 0;background:var(--dark-mid);position:relative;overflow:hidden}
.history-section::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--orange),var(--blue))}
.history-timeline{display:flex;flex-direction:column;gap:0;margin-top:60px;position:relative}
.history-timeline::before{content:'';position:absolute;left:50%;top:0;bottom:0;width:2px;background:rgba(255,255,255,.1);transform:translateX(-50%)}
.timeline-item{
  display:grid;grid-template-columns:1fr 60px 1fr;gap:0;align-items:center;
  margin-bottom:48px;
}
.timeline-content{
  background:rgba(255,255,255,.05);border-radius:var(--radius);padding:28px 32px;
  border:1px solid rgba(255,255,255,.08);color:#fff;
}
.timeline-content.right{grid-column:3}
.timeline-content.left{grid-column:1;text-align:right}
.timeline-dot{
  grid-column:2;display:flex;align-items:center;justify-content:center;
}
.timeline-dot-inner{
  width:16px;height:16px;border-radius:50%;background:var(--orange);
  border:3px solid var(--dark-mid);box-shadow:0 0 0 3px rgba(252,123,3,.3);
  position:relative;z-index:1;
}
.timeline-year{font-family:var(--font-head);font-size:1.4rem;font-weight:900;color:var(--orange);margin-bottom:6px}
.timeline-title{font-family:var(--font-head);font-size:1rem;font-weight:700;color:#fff;margin-bottom:8px}
.timeline-text{font-size:13px;line-height:1.75;color:rgba(255,255,255,.6)}

/* ===========================
   ACADEMICS PAGE
=========================== */
.academics-intro{padding:100px 0;background:#fff}
.academics-intro-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:72px;align-items:center}
.academics-intro-text p{font-size:15px;line-height:1.88;color:var(--text-mid);margin-bottom:16px}

.level-section{padding:100px 0}
.level-section:nth-child(even){background:var(--off-white)}
.level-section:nth-child(odd){background:#fff}
.level-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.level-grid.reverse{direction:rtl}
.level-grid.reverse > *{direction:ltr}
.level-image{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg)}
.level-image img{width:100%;aspect-ratio:16/11;object-fit:cover}
.level-age-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--orange);color:#fff;
  font-family:var(--font-head);font-size:11px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  padding:7px 16px;border-radius:3px;margin-bottom:16px;
}
.level-content p{font-size:15px;line-height:1.88;color:var(--text-mid);margin-bottom:16px}
.subjects-list{
  display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:20px 0 28px;
}
.subject-item{
  display:flex;align-items:center;gap:8px;
  font-size:13px;font-weight:500;color:var(--text-mid);
}
.subject-item::before{
  content:'';display:block;width:6px;height:6px;
  border-radius:50%;background:var(--blue);flex-shrink:0;
}

.cca-section{padding:100px 0;background:var(--blue)}
.cca-section .section-title.white{margin-bottom:12px}
.cca-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:52px}
.cca-card{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius);padding:28px 24px;text-align:center;transition:var(--tr);
}
.cca-card:hover{background:rgba(255,255,255,.14);transform:translateY(-4px)}
.cca-icon{font-size:2rem;margin-bottom:12px}
.cca-title{font-family:var(--font-head);font-size:14px;font-weight:700;color:#fff;margin-bottom:6px}
.cca-text{font-size:12px;color:rgba(255,255,255,.6);line-height:1.6}

/* ===========================
   ADMISSIONS PAGE
=========================== */
.admissions-process{padding:100px 0;background:#fff}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:60px;position:relative}
.process-steps::before{
  content:'';position:absolute;top:36px;left:12%;right:12%;height:2px;
  background:linear-gradient(90deg,var(--orange),var(--blue));z-index:0;
}
.process-step{text-align:center;padding:0 16px;position:relative;z-index:1}
.step-num{
  width:72px;height:72px;border-radius:50%;
  background:#fff;border:3px solid var(--orange);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;
  font-family:var(--font-head);font-size:1.4rem;font-weight:900;color:var(--orange);
  box-shadow:0 4px 20px var(--orange-glow);
}
.step-title{font-family:var(--font-head);font-size:1rem;font-weight:700;color:var(--text-dark);margin-bottom:10px}
.step-text{font-size:13px;line-height:1.75;color:var(--text-mid)}

.fees-section{padding:100px 0;background:var(--off-white)}
.fees-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:56px}
.fee-card{
  background:#fff;border-radius:var(--radius);padding:40px 32px;
  box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:var(--tr);
}
.fee-card.featured{
  background:var(--blue);color:#fff;
  box-shadow:0 16px 48px rgba(0,123,255,.3);transform:scale(1.03);
}
.fee-card:not(.featured):hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.fee-level{font-family:var(--font-head);font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--orange);margin-bottom:12px}
.fee-card.featured .fee-level{color:rgba(255,255,255,.7)}
.fee-name{font-family:var(--font-head);font-size:1.3rem;font-weight:800;color:var(--text-dark);margin-bottom:6px}
.fee-card.featured .fee-name{color:#fff}
.fee-range{font-family:var(--font-head);font-size:2rem;font-weight:900;color:var(--blue);margin-bottom:4px}
.fee-card.featured .fee-range{color:var(--orange)}
.fee-period{font-size:12px;color:var(--text-light);margin-bottom:24px}
.fee-card.featured .fee-period{color:rgba(255,255,255,.6)}
.fee-includes{font-size:13px;line-height:1.8;color:var(--text-mid)}
.fee-card.featured .fee-includes{color:rgba(255,255,255,.75)}
.fee-badge{
  position:absolute;top:20px;right:20px;
  background:var(--orange);color:#fff;
  font-family:var(--font-head);font-size:9px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;padding:5px 12px;border-radius:3px;
}

.faq-section{padding:100px 0;background:#fff}
.faq-list{margin-top:52px;display:flex;flex-direction:column;gap:12px;max-width:800px;margin-left:auto;margin-right:auto}
.faq-item{
  background:var(--off-white);border-radius:var(--radius);
  border:1px solid rgba(0,123,255,.1);overflow:hidden;
}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;
  padding:20px 24px;cursor:pointer;
  font-family:var(--font-head);font-size:15px;font-weight:700;color:var(--text-dark);
  transition:var(--tr);
}
.faq-q:hover{color:var(--blue)}
.faq-q .faq-icon{
  width:28px;height:28px;border-radius:50%;
  background:var(--blue-light);color:var(--blue);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;font-size:18px;font-weight:400;transition:var(--tr);
}
.faq-item.open .faq-q{color:var(--blue)}
.faq-item.open .faq-icon{background:var(--orange);color:#fff;transform:rotate(45deg)}
.faq-a{
  max-height:0;overflow:hidden;transition:max-height .4s ease;
}
.faq-item.open .faq-a{max-height:300px}
.faq-a-inner{padding:0 24px 20px;font-size:14px;line-height:1.8;color:var(--text-mid)}

/* ===========================
   CONTACT PAGE
=========================== */
.contact-section{padding:100px 0;background:#fff}
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:72px}
.contact-info h3{font-family:var(--font-head);font-size:1.5rem;font-weight:800;color:var(--text-dark);margin-bottom:20px}
.contact-info p{font-size:15px;line-height:1.85;color:var(--text-mid);margin-bottom:32px}
.contact-detail{display:flex;gap:14px;margin-bottom:20px;align-items:flex-start}
.contact-detail-icon{
  width:44px;height:44px;border-radius:var(--radius);
  background:var(--orange-pale);border:2px solid rgba(252,123,3,.2);
  display:flex;align-items:center;justify-content:center;
  color:var(--orange);flex-shrink:0;
}
.contact-detail-icon svg{width:18px;height:18px}
.contact-detail-text .cdl{font-family:var(--font-head);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text-light);margin-bottom:4px}
.contact-detail-text .cdv{font-size:14px;font-weight:500;color:var(--text-dark)}
.contact-detail-text .cdv a{color:var(--blue);transition:color var(--tr)}
.contact-detail-text .cdv a:hover{color:var(--orange)}
.map-embed{
  border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-md);margin-top:32px;
  border:2px solid rgba(0,123,255,.1);
}
.map-embed iframe{width:100%;height:300px;display:block;border:none}
.map-placeholder{
  width:100%;height:300px;background:var(--blue-pale);
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:12px;color:var(--blue);
}
.map-placeholder svg{width:48px;height:48px;opacity:.4}
.map-placeholder p{font-family:var(--font-head);font-size:13px;font-weight:600;color:var(--text-light)}

/* Contact form */
.contact-form-wrap{background:var(--off-white);border-radius:var(--radius);padding:40px;border:1px solid rgba(0,123,255,.08)}
.contact-form-wrap h3{font-family:var(--font-head);font-size:1.4rem;font-weight:800;color:var(--text-dark);margin-bottom:8px}
.contact-form-wrap .form-sub{font-size:14px;color:var(--text-mid);margin-bottom:28px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.form-group{margin-bottom:16px}
.form-label{display:block;font-family:var(--font-head);font-size:12px;font-weight:700;letter-spacing:.5px;color:var(--text-dark);margin-bottom:8px}
.form-input, .form-select, .form-textarea{
  width:100%;padding:13px 16px;
  border:2px solid rgba(0,123,255,.15);
  border-radius:var(--radius);font-family:var(--font-body);
  font-size:14px;color:var(--text-dark);
  background:#fff;transition:border-color var(--tr);outline:none;
}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--blue)}
.form-textarea{resize:vertical;min-height:130px}
.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none' stroke='%23007BFF' stroke-width='2'%3E%3Cpath d='M1 1l5 6 5-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.form-submit{width:100%}

/* ===========================
   NEWS PAGE
=========================== */
.news-filters{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:40px}
.news-filter-btn{
  font-family:var(--font-head);font-size:11px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;
  padding:8px 20px;border-radius:100px;
  border:2px solid rgba(0,123,255,.2);color:var(--text-mid);
  cursor:pointer;transition:var(--tr);
}
.news-filter-btn.active,.news-filter-btn:hover{background:var(--orange);border-color:var(--orange);color:#fff}
.news-grid-full{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.news-featured{
  display:grid;grid-template-columns:1.5fr 1fr;gap:22px;margin-bottom:22px;
}
.news-card-featured{
  background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:var(--tr);
}
.news-card-featured:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.news-card-featured .news-img-wrap{aspect-ratio:16/9}
.news-card-featured .news-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.news-card-featured:hover .news-img-wrap img{transform:scale(1.05)}
.news-card-featured .news-body{padding:28px}

.news-sidebar-stack{display:flex;flex-direction:column;gap:16px}
.news-card-sm{
  display:grid;grid-template-columns:100px 1fr;gap:16px;
  background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:var(--tr);align-items:center;
}
.news-card-sm:hover{transform:translateX(4px);box-shadow:var(--shadow-md)}
.news-card-sm .news-img-sm{width:100px;height:80px;object-fit:cover}
.news-card-sm .news-body-sm{padding:12px 16px 12px 0}
.news-card-sm .news-title-sm{font-family:var(--font-head);font-size:13px;font-weight:700;color:var(--text-dark);margin-bottom:6px;line-height:1.4}
.news-card-sm .news-date-sm{font-size:11px;font-weight:600;letter-spacing:1.5px;color:var(--orange);text-transform:uppercase}

/* ===========================
   COMMUNITY PAGE
=========================== */
.community-section{padding:100px 0;background:#fff}
.community-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.community-photos{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.community-photo{border-radius:var(--radius);overflow:hidden;aspect-ratio:1;box-shadow:var(--shadow-sm)}
.community-photo:first-child{aspect-ratio:auto;grid-row:span 2}
.community-photo img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.community-photo:hover img{transform:scale(1.05)}
.community-text p{font-size:15px;line-height:1.88;color:var(--text-mid);margin-bottom:16px}

.gallery-section{padding:100px 0;background:var(--off-white)}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:200px;
  gap:12px;margin-top:52px;
}
.gallery-item{border-radius:var(--radius);overflow:hidden;position:relative;cursor:pointer}
.gallery-item.wide{grid-column:span 2}
.gallery-item.tall{grid-row:span 2}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery-item:hover img{transform:scale(1.08)}
.gallery-item-overlay{
  position:absolute;inset:0;
  background:rgba(0,0,0,.45);
  opacity:0;transition:opacity var(--tr);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:2rem;
}
.gallery-item:hover .gallery-item-overlay{opacity:1}

/* ===========================
   RESPONSIVE
=========================== */
@media(max-width:1024px){
  .features-grid,.values-grid,.cca-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid,.leadership-grid{grid-template-columns:1fr 1fr}
  .topbar{display:none}
  .about-img-small{display:none}
  .cta-brand,.cta-divider{display:none}
  .process-steps{grid-template-columns:repeat(2,1fr)}
  .process-steps::before{display:none}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .fees-grid{grid-template-columns:1fr}
  .fees-grid .fee-card.featured{transform:none}
}
@media(max-width:768px){
  :root{--nav-h:64px}
  .nav-menu,.nav-cta{display:none}
  .hamburger{display:flex}
  .hero-content{padding:0 24px}
  .hero-location{left:24px}
  .hero-arrows-wrap{display:none}
  .stats-inner,.motto-inner{flex-wrap:wrap}
  .stat-item{width:50%;border-bottom:1px solid rgba(255,255,255,.1)}
  .motto-item{width:50%;border-bottom:1px solid rgba(255,255,255,.2)}
  .about-grid,.curriculum-panel.active,
  .about-intro-grid,.academics-intro-grid,
  .level-grid,.contact-grid,.community-grid{grid-template-columns:1fr}
  .about-visual,.about-intro-img{display:none}
  .features-grid,.news-grid,.news-grid-full,.values-grid,.leadership-grid,.cca-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .cta-inner{flex-direction:column;text-align:center}
  .news-header{flex-direction:column;align-items:flex-start;gap:16px}
  .news-featured{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .history-timeline::before{left:24px}
  .timeline-item{grid-template-columns:40px 1fr}
  .timeline-content.left{grid-column:2;text-align:left}
  .timeline-content.right{grid-column:2}
  .timeline-dot{grid-column:1}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-item.wide,.gallery-item.tall{grid-column:auto;grid-row:auto}
  .page-hero{height:280px}
  .container{padding:0 20px}
}
