/* =========================================================
   Mom's Blessing — Homepage Styles
   Author: Senior UI/UX · Animation · Front-End
   ========================================================= */

/* ---------- 1. Tokens — DARK BOLD PRIMARY COLOR THEME ---------- */
:root{
  /* Primary bold palette */
  --blue:#1E6BDD;
  --red:#E03131;
  --yellow:#FAB005;
  --green:#2F9E44;

  /* Darker variants */
  --navy:#0B1428;
  --deep-blue:#1849A9;
  --deep-red:#C92A2A;
  --deep-green:#1F6E31;
  --deep-yellow:#D9930A;

  /* Secondary accents */
  --pink:#E64980;
  --purple:#7048E8;
  --mint:#12B886;
  --tangerine:#FD7E14;

  /* Dark surfaces */
  --dark-bg:#0B1428;
  --dark-surface:#14213D;
  --dark-card:#1B2B4A;
  --dark-text:#C5D0E1;
  --dark-muted:#8A99B3;

  /* Soft pastels (kept for light sections) */
  --cream:#FFF9ED;
  --baby-blue:#DCEAFB;
  --rose-mist:#FFDDE7;
  --lilac-mist:#E5DFFC;
  --peach:#FFDDC9;
  --mint-mist:#C8F4E0;

  /* Neutrals — unified single dark text color */
  --ink:#0B1428;
  --slate:#0B1428;
  --muted:#0B1428;
  --hairline:#E0E5EF;
  --paper:#FFFFFF;

  /* Gradients — bolder, darker */
  --grad-hero: linear-gradient(135deg,#0B1428 0%,#14213D 50%,#1849A9 100%);
  --grad-soft: linear-gradient(180deg,#FFFBF0 0%,#DCEAFB 100%);
  --grad-candy: linear-gradient(135deg,#E03131 0%,#1E6BDD 100%);
  --grad-sky:  linear-gradient(135deg,#1E6BDD 0%,#2F9E44 100%);

  /* Space */
  --space-4:16px; --space-5:24px; --space-6:32px;
  --space-7:48px; --space-8:64px; --space-9:96px;

  /* Radius */
  --r-sm:8px; --r-md:16px; --r-lg:24px; --r-xl:32px; --r-full:9999px;

  /* Shadows */
  --shadow-sm:0 2px 8px rgba(31,29,54,.06);
  --shadow-md:0 8px 24px rgba(31,29,54,.08);
  --shadow-lg:0 20px 50px rgba(31,29,54,.12);
  --shadow-pink:0 20px 40px rgba(255,107,157,.25);
  --shadow-yellow:0 16px 32px rgba(255,217,61,.35);

  /* Fonts */
  --font-display:'Baloo 2','Poppins',system-ui,sans-serif;
  --font-heading:'Poppins',system-ui,sans-serif;
  --font-body:'Nunito',system-ui,sans-serif;
  --font-accent:'Caveat',cursive;

  --header-h:58px;
}

/* ---------- 2. Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.65;
  color:var(--slate);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);line-height:1.2;margin:0 0 .5em}
h1{font-weight:800}
h2,h3{font-weight:700}
p{margin:0 0 1em}
a{color:var(--blue);text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none;padding:0;margin:0}

.skip-link{position:absolute;left:-9999px;top:8px;padding:10px 16px;background:var(--ink);color:#fff;border-radius:8px;z-index:9999}
.skip-link:focus{left:8px}

/* ---------- 3. Utilities ---------- */
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 24px}
.section{padding:var(--space-9) 0;position:relative}
.gradient-text{color:var(--red)}
.eyebrow{
  display:inline-block;font-family:var(--font-heading);font-weight:700;
  font-size:.875rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--red);margin-bottom:.75rem;
}
.section-head{text-align:center;max-width:720px;margin:0 auto var(--space-7)}
.section-head h2{font-size:clamp(2rem,4vw,3rem)}
.section-sub{color:var(--slate);font-size:1.05rem}

/* ---------- 4. Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;justify-content:center;
  padding:14px 28px;border-radius:var(--r-full);font-family:var(--font-heading);
  font-weight:600;font-size:1rem;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);
  white-space:nowrap;border:2px solid transparent;line-height:1;
}
.btn-sm{padding:8px 14px;font-size:.82rem}
.btn-lg{padding:16px 32px;font-size:1.05rem}
.btn-primary{background:var(--yellow);color:var(--ink);box-shadow:0 16px 32px rgba(250,176,5,.4)}
.btn-primary:hover{transform:translateY(-3px) scale(1.03);background:var(--deep-yellow);box-shadow:0 24px 44px rgba(250,176,5,.55)}
.btn-primary:active{transform:translateY(-1px) scale(.98)}
.btn-secondary{background:var(--red);color:#fff;box-shadow:0 16px 32px rgba(224,49,49,.35)}
.btn-secondary:hover{transform:translateY(-3px) scale(1.03);background:var(--deep-red)}
.btn-outline{background:var(--green);color:#fff;border-color:var(--green);box-shadow:0 8px 18px rgba(47,158,68,.3)}
.btn-outline:hover{background:var(--deep-green);color:#fff;border-color:var(--deep-green);transform:translateY(-3px);box-shadow:0 12px 24px rgba(47,158,68,.45)}
.btn-white{background:#fff;color:var(--pink)}
.btn-white:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 20px 40px rgba(0,0,0,.15)}
.btn-outline-white{background:transparent;color:#fff;border-color:#fff}
.btn-outline-white:hover{background:#fff;color:var(--pink)}
.btn-whatsapp{background:#25D366;color:#fff;box-shadow:0 12px 24px rgba(37,211,102,.35)}
.btn-whatsapp:hover{transform:translateY(-3px) scale(1.03);background:#1fbb5a}

/* ---------- 5. Header — PRO theme ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(180%) blur(22px);-webkit-backdrop-filter:saturate(180%) blur(22px);
  border-bottom:1px solid rgba(11,20,40,.06);
  transition:background .3s ease,box-shadow .3s ease,border-color .3s ease,height .3s ease;
}
.site-header::after{
  content:'';position:absolute;left:0;right:0;bottom:0;height:2px;
  background:linear-gradient(90deg,transparent 0%,var(--yellow) 20%,var(--red) 45%,var(--pink) 60%,var(--blue) 80%,transparent 100%);
  opacity:.35;transition:opacity .3s ease;pointer-events:none;
}
.site-header.scrolled{background:rgba(255,255,255,.96);box-shadow:0 10px 30px rgba(11,20,40,.08);border-bottom-color:transparent}
.site-header.scrolled::after{opacity:.7}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);gap:1.5rem}

/* Brand / Logo */
.logo{display:flex;align-items:center;gap:.75rem;font-family:var(--font-display);font-weight:800;font-size:1.18rem;color:var(--ink);letter-spacing:-.01em;text-decoration:none;position:relative;padding:4px 0}
.logo-mark{
  display:inline-grid;place-items:center;flex-shrink:0;
  width:54px;height:54px;border-radius:16px;
  background:#fff;padding:3px;
  box-shadow:0 8px 20px rgba(11,20,40,.10),0 2px 6px rgba(11,20,40,.06),inset 0 0 0 1px rgba(11,20,40,.04);
  transition:transform .45s cubic-bezier(.34,1.56,.64,1),box-shadow .35s ease;
  position:relative;overflow:hidden;
}
.logo-mark::before{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:conic-gradient(from 180deg,transparent 0deg,rgba(250,176,5,.35) 90deg,transparent 180deg,rgba(224,49,49,.25) 270deg,transparent 360deg);
  opacity:0;transition:opacity .4s ease;mix-blend-mode:multiply;
}
.logo-mark img{width:100%;height:100%;object-fit:contain;border-radius:12px;display:block}
.logo:hover .logo-mark{transform:rotate(-6deg) scale(1.06);box-shadow:0 14px 30px rgba(224,49,49,.18),0 4px 10px rgba(11,20,40,.08)}
.logo:hover .logo-mark::before{opacity:1}
.logo-text{display:flex;flex-direction:column;line-height:1.05}
.logo-text span{color:var(--red);display:inline}
.logo-tag{
  font-family:var(--font-heading);font-weight:700;
  font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink);opacity:.55;margin-top:3px;display:block;
}

/* Compact header on scroll */
.site-header.scrolled .logo-mark{width:46px;height:46px;border-radius:13px}
.site-header.scrolled .logo{font-size:1.08rem}
.main-nav ul{display:flex;gap:1.1rem;align-items:center}
.main-nav a{position:relative;color:var(--ink);font-weight:600;font-size:.84rem;padding:.3rem 0;transition:color .2s}
.main-nav a::after{content:'';position:absolute;left:0;bottom:-2px;width:0;height:3px;border-radius:3px;background:var(--red);transition:width .3s cubic-bezier(.4,0,.2,1)}
.main-nav a:hover,.main-nav a.active{color:var(--red)}

/* Dropdown menu — Programs */
.has-dropdown{position:relative}
.nav-has-arrow{display:inline-flex;align-items:center;gap:.3rem}
.dd-arrow{transition:transform .3s cubic-bezier(.4,0,.2,1)}
.has-dropdown:hover .dd-arrow,
.has-dropdown.open .dd-arrow{transform:rotate(180deg)}

.dropdown{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(-6px);
  min-width:240px;padding:.5rem;margin:0;list-style:none;
  background:#fff;border-radius:16px;box-shadow:0 24px 48px rgba(11,20,40,.16),0 6px 16px rgba(11,20,40,.06);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .25s ease,transform .3s cubic-bezier(.4,0,.2,1),visibility .25s;
  z-index:1002;border:1px solid rgba(11,20,40,.05);
}
.dropdown::before{
  content:'';position:absolute;top:-14px;left:0;right:0;height:14px;
}
.dropdown::after{
  content:'';position:absolute;top:-7px;left:50%;transform:translateX(-50%) rotate(45deg);
  width:14px;height:14px;background:#fff;border-top:1px solid rgba(11,20,40,.05);
  border-left:1px solid rgba(11,20,40,.05);border-radius:2px;
}
.has-dropdown:hover .dropdown,.has-dropdown.open .dropdown{
  opacity:1;visibility:visible;pointer-events:auto;
  transform:translateX(-50%) translateY(0);
}
.has-dropdown:hover > .nav-has-arrow,.has-dropdown.open > .nav-has-arrow{color:var(--red)}
.has-dropdown:hover > .nav-has-arrow::after,.has-dropdown.open > .nav-has-arrow::after{width:100%}

.dropdown{display:flex;flex-direction:column;gap:3px;min-width:290px;padding:.6rem}
.dropdown li{width:100%;margin:0;display:block;--item:var(--red)}
.dropdown li:nth-child(1){--item:#D9930A}
.dropdown li:nth-child(2){--item:var(--red)}
.dropdown li:nth-child(3){--item:var(--blue)}
.dropdown li:nth-child(4){--item:var(--green)}
.dropdown li:nth-child(5){--item:var(--red)}

.dropdown a{
  display:flex!important;align-items:center;gap:.85rem;
  padding:.7rem .85rem!important;font-size:.9rem!important;
  color:var(--ink)!important;border-radius:12px;font-weight:600;
  white-space:nowrap;transition:background .3s ease,transform .3s ease;
  position:relative;border-left:3px solid transparent;
}
.dropdown a::after{display:none!important}

.dd-emoji{
  font-size:1.35rem;flex-shrink:0;width:42px;height:42px;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:12px;color:#fff;
  transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s;
  box-shadow:0 4px 10px color-mix(in srgb,var(--item) 40%,transparent);
}
.dd-info{display:flex;flex-direction:column;line-height:1.2;flex:1}
.dd-info strong{font-size:.95rem;color:var(--item);font-weight:800;letter-spacing:-.005em;transition:color .2s}
.dd-info small{font-size:.74rem;color:var(--ink);opacity:.62;margin-top:3px;font-weight:500}
.dd-arrow-r{
  font-size:1.05rem;color:var(--item);opacity:0;transform:translateX(-8px);
  transition:all .3s ease;flex-shrink:0;font-weight:700;
}

.dropdown a:hover{
  background:color-mix(in srgb,var(--item) 12%,white);
  transform:translateX(3px);
  border-left-color:var(--item);
}
.dropdown a:hover .dd-emoji{
  transform:rotate(-10deg) scale(1.1);
  box-shadow:0 8px 18px color-mix(in srgb,var(--item) 55%,transparent);
}
.dropdown a:hover .dd-arrow-r{opacity:1;transform:translateX(0)}
.dropdown a:hover .dd-info small{opacity:.85}

/* Solid bold emoji badge backgrounds (4-color palette only) */
.dropdown li:nth-child(1) .dd-emoji{background:#D9930A}
.dropdown li:nth-child(2) .dd-emoji{background:var(--red)}
.dropdown li:nth-child(3) .dd-emoji{background:var(--blue)}
.dropdown li:nth-child(4) .dd-emoji{background:var(--green)}
.dropdown li:nth-child(5) .dd-emoji{background:var(--red)}

/* ===== Unified header action pills — same style, different colors ===== */
.main-nav a.nav-cta,
.main-nav a.nav-special{
  display:inline-flex;align-items:center;justify-content:center;gap:.35rem;
  padding:8px 16px;border-radius:999px;
  font-family:var(--font-heading);font-weight:700;font-size:.82rem;
  letter-spacing:.01em;line-height:1;text-decoration:none;
  border:2px solid transparent;
  transition:all .25s ease;
}
.main-nav a.nav-cta::before,.main-nav a.nav-cta::after,
.main-nav a.nav-special::before,.main-nav a.nav-special::after{display:none}
.main-nav a.nav-special .ns-emoji{display:none}

/* Fee Structure — GREEN */
.main-nav a.nav-cta{
  background:var(--green);color:#fff;
  box-shadow:0 6px 14px rgba(47,158,68,.35);
}
.main-nav a.nav-cta:hover{
  background:var(--deep-green);color:#fff;
  transform:translateY(-2px);
  box-shadow:0 10px 20px rgba(47,158,68,.5);
}

/* Franchise — RED */
.main-nav a.nav-special{
  background:var(--red);color:#fff!important;
  box-shadow:0 6px 14px rgba(224,49,49,.35);
}
.main-nav a.nav-special:hover{
  background:var(--deep-red);color:#fff!important;
  transform:translateY(-2px);
  box-shadow:0 10px 20px rgba(224,49,49,.5);
}

/* Enquire Now (btn-primary btn-sm) — YELLOW — match style */
.btn.btn-primary.btn-sm{
  padding:8px 16px;font-size:.82rem;font-weight:700;
  letter-spacing:.01em;line-height:1;
  box-shadow:0 6px 14px rgba(250,176,5,.4);
}
.btn.btn-primary.btn-sm:hover{
  transform:translateY(-2px) scale(1);
  background:var(--deep-yellow);
  box-shadow:0 10px 20px rgba(250,176,5,.55);
}
.main-nav a:hover::after,.main-nav a.active::after{width:100%}
.header-cta{display:flex;align-items:center;gap:.75rem}
.phone-link{width:34px;height:34px;border-radius:var(--r-full);background:var(--mint-mist);color:var(--mint);display:inline-flex;align-items:center;justify-content:center;transition:.25s}
.phone-link svg{width:16px;height:16px}
.phone-link:hover{background:var(--mint);color:#fff;transform:scale(1.08) rotate(12deg)}

.hamburger{display:none;flex-direction:column;gap:5px;padding:10px;cursor:pointer}
.hamburger span{width:24px;height:3px;background:var(--ink);border-radius:3px;transition:.3s}
.hamburger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ---------- 6. Hero — LIGHT BG ---------- */
.hero{position:relative;min-height:100vh;padding-top:calc(var(--header-h) + 40px);padding-bottom:80px;background:var(--grad-soft);overflow:hidden;color:var(--ink)}
.hero-inner{display:grid;grid-template-columns:1.1fr 1fr;gap:3rem;align-items:center;position:relative;z-index:2}
.hero-title{color:var(--ink)}
.hero-sub{color:var(--ink);opacity:.85}
.hero-content .badge{display:inline-flex;align-items:center;gap:.5rem;padding:8px 16px;background:#fff;border-radius:var(--r-full);font-weight:700;font-size:.85rem;color:var(--red);box-shadow:var(--shadow-sm);margin-bottom:1.5rem}
.badge-dot{width:8px;height:8px;background:var(--pink);border-radius:50%;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 0 0 rgba(255,107,157,.6)}50%{box-shadow:0 0 0 8px rgba(255,107,157,0)}}
.hero-title{font-size:clamp(2.4rem,5.5vw,4.5rem);font-weight:800;line-height:1.05;margin-bottom:1.25rem;letter-spacing:-.02em}
.wave{display:inline-block;transform-origin:70% 70%;animation:wave 2.5s infinite}
@keyframes wave{0%,50%,100%{transform:rotate(0)}10%,30%{transform:rotate(-20deg)}20%{transform:rotate(14deg)}40%{transform:rotate(-4deg)}}
.hero-sub{font-size:1.15rem;color:var(--ink);opacity:.8;max-width:520px;margin-bottom:2rem}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2rem}
.hero-trust{display:flex;align-items:center;gap:1rem}
.trust-avatars{display:flex}
.trust-avatars img{width:40px;height:40px;border-radius:50%;border:3px solid #fff;margin-left:-10px;box-shadow:var(--shadow-sm);object-fit:cover}
.trust-avatars img:first-child{margin-left:0}
.trust-text{font-size:.92rem;color:var(--ink)}
.hero-trust strong{color:var(--ink)}
.stars{color:var(--yellow);letter-spacing:.1em;font-size:.95rem}

/* Hero art (new photo layout) */
.hero-art{position:relative;display:flex;align-items:center;justify-content:center;min-height:520px}
.hero-photo-main{
  width:min(460px,90%);aspect-ratio:4/5;position:relative;overflow:hidden;
  border-radius:40% 60% 55% 45% / 50% 40% 60% 50%;
  box-shadow:var(--shadow-lg);
  animation:blob-morph 14s ease-in-out infinite;
  border:6px solid #fff;
}
@keyframes blob-morph{
  0%,100%{border-radius:40% 60% 55% 45% / 50% 40% 60% 50%}
  33%{border-radius:55% 45% 40% 60% / 60% 55% 45% 40%}
  66%{border-radius:48% 52% 55% 45% / 40% 60% 40% 60%}
}
.hero-photo-main .hero-img{width:100%;height:100%;object-fit:cover}
.hero-photo-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,217,61,.15),rgba(167,139,250,.15));pointer-events:none}
.hero-photo-sm{
  position:absolute;width:130px;height:130px;border-radius:26px;
  overflow:hidden;box-shadow:var(--shadow-lg);border:5px solid #fff;z-index:2;
  animation:float-y 5s ease-in-out infinite;
}
.hero-photo-sm img{width:100%;height:100%;object-fit:cover}
.hero-photo-top{top:2%;right:-2%;transform:rotate(6deg);animation-delay:.6s}
.hero-photo-bottom{bottom:5%;left:-4%;transform:rotate(-8deg);animation-delay:1.8s}

.hero-badge{position:absolute;background:#fff;padding:12px 18px;border-radius:var(--r-lg);display:flex;align-items:center;gap:.75rem;box-shadow:var(--shadow-md);font-size:.88rem;z-index:3;animation:float-y 4s ease-in-out infinite}
.hero-badge-1{top:18%;left:-8%;animation-delay:0s}
.hero-badge-2{bottom:18%;right:-8%;animation-delay:2s}
.hb-icon{font-size:1.5rem}
.hero-badge strong{color:var(--ink);font-family:var(--font-heading);display:block}
.hero-badge small{color:var(--muted);font-size:.78rem}
@keyframes float-y{0%,100%{transform:translateY(0) rotate(var(--r,0deg))}50%{transform:translateY(-12px) rotate(var(--r,0deg))}}
.hero-photo-top{--r:6deg}
.hero-photo-bottom{--r:-8deg}

/* Floaters */
.floaters{position:absolute;inset:0;pointer-events:none;z-index:1}
.floaters .cloud,.floaters .balloon,.floaters .star{position:absolute;font-size:2rem;opacity:.85;filter:drop-shadow(0 4px 8px rgba(0,0,0,.08))}
.cloud-1{top:12%;left:8%;font-size:3rem;animation:drift 28s linear infinite}
.cloud-2{top:30%;right:10%;font-size:2.4rem;animation:drift 35s linear infinite reverse;animation-delay:-5s}
.cloud-3{bottom:25%;left:15%;font-size:2.6rem;animation:drift 40s linear infinite;animation-delay:-10s}
@keyframes drift{0%{transform:translateX(0)}50%{transform:translateX(60px)}100%{transform:translateX(0)}}
.balloon-1{top:20%;right:18%;font-size:2.5rem;animation:float-lg 6s ease-in-out infinite}
.balloon-2{bottom:18%;left:8%;font-size:2rem;animation:float-lg 7s ease-in-out infinite reverse}
@keyframes float-lg{0%,100%{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-22px) rotate(4deg)}}
.star-1{top:18%;left:45%;font-size:1.5rem;animation:twinkle 3s ease-in-out infinite}
.star-2{bottom:22%;right:12%;font-size:1.8rem;animation:twinkle 2.5s ease-in-out infinite;animation-delay:.8s}
.star-3{top:55%;left:3%;font-size:1.4rem;animation:twinkle 3.5s ease-in-out infinite;animation-delay:1.5s}
@keyframes twinkle{0%,100%{opacity:.3;transform:scale(.9)}50%{opacity:1;transform:scale(1.15)}}

.shape{position:absolute;border-radius:50%;filter:blur(70px);opacity:.3}
.shape-1{width:340px;height:340px;background:var(--yellow);top:-80px;right:10%}
.shape-2{width:280px;height:280px;background:var(--red);bottom:-60px;left:20%;opacity:.22}
.shape-3{width:220px;height:220px;background:var(--blue);top:40%;left:-60px;opacity:.22}

.scroll-indicator{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3}
.mouse{width:26px;height:42px;border:2.5px solid var(--ink);border-radius:16px;display:flex;justify-content:center;padding-top:6px}
.wheel{width:4px;height:8px;background:var(--ink);border-radius:2px;animation:scroll-wheel 2s infinite}
@keyframes scroll-wheel{0%{opacity:1;transform:translateY(0)}100%{opacity:0;transform:translateY(14px)}}

/* ---------- 7. Feature (Highlights) Cards — professional design ---------- */
.cards-grid{display:grid;gap:1.75rem}
.cards-4{grid-template-columns:repeat(4,1fr)}
.feature-card{
  background:var(--accent);border-radius:24px;overflow:hidden;
  box-shadow:0 12px 28px rgba(11,20,40,.1);
  transition:transform .4s cubic-bezier(.4,0,.2,1),box-shadow .4s ease;
  display:flex;flex-direction:column;color:#fff;
  position:relative;isolation:isolate;--accent:var(--yellow);
}
.feature-card:hover{
  transform:translateY(-10px);
  box-shadow:0 30px 50px -10px var(--accent),0 20px 40px rgba(11,20,40,.14);
}
.feature-card:hover .feature-icon{transform:scale(1.08) rotate(-6deg)}
.feature-card:hover .feature-photo img{transform:scale(1.08)}
.feature-card:hover .fc-link{gap:.75rem}
.feature-card:hover .fc-link span{transform:translateX(3px)}

.feature-photo{position:relative;aspect-ratio:16/11;overflow:hidden;z-index:1}
.feature-photo img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.4,0,.2,1)}
/* Smooth gradient fade from photo into colored body */
.feature-photo::after{
  content:'';position:absolute;bottom:-1px;left:0;right:0;height:55%;z-index:2;pointer-events:none;
  background:linear-gradient(to bottom,transparent 0%,color-mix(in srgb,var(--accent) 40%,transparent) 55%,var(--accent) 100%);
}

.feature-card .feature-icon{
  position:absolute;left:20px;bottom:20px;z-index:3;
  width:60px;height:60px;border-radius:16px;display:flex;align-items:center;justify-content:center;
  font-size:1.75rem;box-shadow:0 10px 24px rgba(11,20,40,.25);
  background:#fff;
  transition:transform .4s cubic-bezier(.34,1.56,.64,1);
}

/* Legacy icon classes (kept for other sections) */
.icon-mint{background:var(--mint-mist);color:var(--mint)}
.icon-pink{background:var(--rose-mist);color:var(--pink)}
.icon-yellow{background:#FFF4C2;color:var(--tangerine)}
.icon-purple{background:var(--lilac-mist);color:var(--purple)}
.icon-blue{background:var(--baby-blue);color:var(--blue)}

.feature-body{padding:1.25rem 1.5rem 1.5rem;display:flex;flex-direction:column;flex:1;position:relative;z-index:2}
.feature-card h3{
  font-size:1.3rem;font-weight:700;margin:0 0 .5rem;color:#fff;line-height:1.25;
}
.feature-card p{color:rgba(255,255,255,.92);font-size:.94rem;line-height:1.55;margin:0 0 1.1rem;flex:1}
.fc-link{
  display:inline-flex;align-items:center;gap:.4rem;
  padding-top:.85rem;border-top:1px solid rgba(255,255,255,.22);
  color:#fff;font-weight:600;font-size:.88rem;text-decoration:none;
  transition:gap .3s ease;letter-spacing:.01em;
}
.fc-link span{display:inline-block;transition:transform .3s ease;font-size:1.1em}

/* Yellow card — dark text override for readability */
.cards-grid .feature-card:nth-child(4n+1) h3{color:var(--navy)}
.cards-grid .feature-card:nth-child(4n+1) p{color:var(--navy);opacity:.78}
.cards-grid .feature-card:nth-child(4n+1) .fc-link{color:var(--navy);border-top-color:rgba(11,20,40,.18)}

/* 4-color rotation: Yellow → Blue → Green → Red */
.cards-grid .feature-card:nth-child(4n+1){--accent:var(--yellow);--accent-tint:#FFF4C2}
.cards-grid .feature-card:nth-child(4n+2){--accent:var(--blue);--accent-tint:#DCEAFB}
.cards-grid .feature-card:nth-child(4n+3){--accent:var(--green);--accent-tint:#D4F4DE}
.cards-grid .feature-card:nth-child(4n+4){--accent:var(--red);--accent-tint:#FFDDE0}
.cards-grid .feature-card:nth-child(4n+1) .feature-icon{color:var(--navy)}

/* Yellow card needs darker glow */
.cards-grid .feature-card:nth-child(4n+1):hover{box-shadow:0 30px 50px -12px rgba(250,176,5,.5),0 20px 40px rgba(11,20,40,.12)}
.cards-grid .feature-card:nth-child(4n+2):hover{box-shadow:0 30px 50px -12px rgba(30,107,221,.45),0 20px 40px rgba(11,20,40,.12)}
.cards-grid .feature-card:nth-child(4n+3):hover{box-shadow:0 30px 50px -12px rgba(47,158,68,.45),0 20px 40px rgba(11,20,40,.12)}
.cards-grid .feature-card:nth-child(4n+4):hover{box-shadow:0 30px 50px -12px rgba(224,49,49,.5),0 20px 40px rgba(11,20,40,.12)}

.highlights{background:var(--grad-soft)}

/* ---------- 8. About ---------- */
.about-inner{display:grid;grid-template-columns:1fr 1.1fr;gap:4rem;align-items:center}
.about-art{position:relative;padding:20px 30px 40px 20px}

/* Layered stacked-card background */
.about-art::before{
  content:'';position:absolute;top:40px;right:10px;bottom:-10px;left:40px;
  border-radius:28px;z-index:0;
  background:color-mix(in srgb,var(--blue) 8%,transparent);
  border:1px solid color-mix(in srgb,var(--blue) 25%,transparent);
  transform:rotate(3deg);
}
.about-art::after{
  content:'';position:absolute;top:30px;right:20px;bottom:-5px;left:30px;
  border-radius:28px;z-index:0;
  background:color-mix(in srgb,var(--blue) 4%,transparent);
  border:1px solid color-mix(in srgb,var(--blue) 18%,transparent);
  transform:rotate(-2deg);
}

.about-image-wrap{
  position:relative;z-index:2;border-radius:24px;
}
.about-main-img{
  width:100%;aspect-ratio:4/3.2;object-fit:cover;
  border-radius:24px;display:block;
  box-shadow:0 25px 55px rgba(11,20,40,.25);
}

/* Stat badges */
.about-badge{
  position:absolute;z-index:4;border-radius:14px;
  transition:transform .4s cubic-bezier(.34,1.56,.64,1);
}
.about-badge:hover{transform:translateY(-4px) scale(1.04)}

/* Top-right YELLOW */
.about-badge-top{
  top:-20px;right:-14px;
  background:var(--yellow);
  padding:14px 22px;text-align:center;
  box-shadow:0 14px 30px rgba(250,176,5,.4);
}
.about-badge-top strong{
  font-family:var(--font-display);font-size:1.9rem;font-weight:800;color:var(--ink);
  line-height:1;display:block;letter-spacing:-.02em;
}
.about-badge-top strong sup{font-size:.7em;color:var(--red)}
.about-badge-top span{
  font-size:.68rem;letter-spacing:.14em;color:var(--ink);
  font-weight:800;display:block;margin-top:5px;text-transform:uppercase;
}

/* Bottom-left DARK */
.about-badge-bottom{
  bottom:-18px;left:-14px;
  background:var(--navy);
  padding:12px 22px 12px 14px;
  display:flex;align-items:center;gap:12px;
  box-shadow:0 18px 38px rgba(11,20,40,.35);
  color:#fff;
  border:1px solid rgba(255,255,255,.08);
}
.ab-icon{
  width:40px;height:40px;border-radius:11px;background:var(--yellow);
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;flex-shrink:0;
}
.ab-icon-blue{background:var(--blue)}
.about-badge-bottom .ab-text strong{
  font-family:var(--font-display);font-size:1.5rem;font-weight:800;color:#fff;
  line-height:1;display:block;letter-spacing:-.02em;
}
.about-badge-bottom .ab-text strong sup{font-size:.7em;color:var(--yellow)}
.about-badge-bottom .ab-text span{
  font-size:.64rem;letter-spacing:.14em;color:rgba(255,255,255,.75);
  font-weight:700;display:block;margin-top:3px;text-transform:uppercase;
}

/* Right-middle BLUE floating */
.about-badge-side{
  top:45%;right:-30px;transform:translateY(-50%);
  background:#fff;
  padding:12px 18px 12px 12px;
  display:flex;align-items:center;gap:10px;
  box-shadow:0 14px 32px rgba(11,20,40,.18);
  border:1px solid rgba(11,20,40,.05);
  animation:float-y 5s ease-in-out infinite;
}
.about-badge-side:hover{transform:translateY(-50%) translateY(-4px) scale(1.04)}
.about-badge-side .ab-text strong{
  font-family:var(--font-display);font-size:1.3rem;font-weight:800;color:var(--ink);
  line-height:1;display:block;letter-spacing:-.02em;
}
.about-badge-side .ab-text strong sup{font-size:.7em;color:var(--blue)}
.about-badge-side .ab-text span{
  font-size:.62rem;letter-spacing:.12em;color:var(--ink);opacity:.7;
  font-weight:700;display:block;margin-top:3px;text-transform:uppercase;
}

/* Decorative blurred shapes */
.about-shape{position:absolute;border-radius:50%;filter:blur(60px);z-index:0}
.about-shape.shape-a{width:180px;height:180px;background:var(--yellow);top:-30px;right:-20px;opacity:.25}
.about-shape.shape-b{width:220px;height:220px;background:var(--blue);bottom:-40px;left:-30px;opacity:.2}
.about-content h2{font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:1rem}
.check-list{margin:1.5rem 0 1.5rem;display:grid;gap:.75rem}
.check-list li{display:flex;align-items:center;gap:.75rem;font-weight:500;color:var(--ink)}
.check{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:var(--mint);color:#fff;font-weight:800;font-size:.9rem;flex-shrink:0}

.about-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:1.25rem;background:var(--cream);border-radius:var(--r-lg);margin-bottom:1.75rem}
.stat{text-align:center}
.stat strong{display:block;font-family:var(--font-display);font-size:clamp(1.4rem,2.5vw,1.85rem);font-weight:800;color:var(--ink);line-height:1}
.stat span{font-size:.78rem;color:var(--slate);font-weight:600;text-transform:uppercase;letter-spacing:.04em}

/* ---------- 9. Programs ---------- */
.programs{background:var(--lilac-mist);position:relative;overflow:hidden}
.programs::before,.programs::after{content:'';position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;pointer-events:none}
.programs::before{width:300px;height:300px;background:var(--pink);top:-100px;right:-50px}
.programs::after{width:350px;height:350px;background:var(--blue);bottom:-150px;left:-100px}
.programs-grid{position:relative;z-index:1;padding:2rem 0 2.5rem}

/* Polaroid / magazine tilt — floating photos with peeking tags */
.program-card{
  position:relative;display:flex;flex-direction:column;
  background:transparent;padding:0;border:none;border-radius:0;
  box-shadow:none;overflow:visible;isolation:isolate;
  transition:transform .5s cubic-bezier(.34,1.56,.64,1);
}
.program-card::before,.program-card::after{display:none}

/* Staggered rotations + lifts — alternating, middle pair raised */
.programs-grid .program-card:nth-child(1){transform:rotate(-2.5deg)}
.programs-grid .program-card:nth-child(2){transform:rotate(1.8deg) translateY(-22px)}
.programs-grid .program-card:nth-child(3){transform:rotate(-1.8deg) translateY(-12px)}
.programs-grid .program-card:nth-child(4){transform:rotate(2.5deg)}

.program-card:hover{transform:rotate(0) translateY(-24px);z-index:10}

/* Photo with colored shadow glow */
.program-photo{
  position:relative;aspect-ratio:3/4;border-radius:10px;overflow:hidden;
  margin:0 0 1.1rem;z-index:1;background:#fff;
  box-shadow:0 18px 36px -6px color-mix(in srgb,var(--card-color) 35%,rgba(11,20,40,.2));
  transition:box-shadow .4s;
}
.program-card:hover .program-photo{box-shadow:0 28px 50px -8px color-mix(in srgb,var(--card-color) 55%,rgba(11,20,40,.25))}
.program-photo img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.4,0,.2,1)}
.program-card:hover .program-photo img{transform:scale(1.06)}
.program-photo::after{display:none}

/* Emoji hidden in this style */
.program-emoji{display:none}

/* Tag peeking UP from body top — straddles photo-body boundary */
.program-age{
  position:absolute;left:14px;top:-16px;z-index:3;
  padding:7px 16px;border-radius:6px;
  background:color-mix(in srgb,var(--card-color) 18%,white);
  color:var(--card-color);
  font-family:var(--font-accent);font-style:italic;font-weight:700;font-size:1.05rem;
  letter-spacing:0;text-transform:none;
  box-shadow:0 8px 18px rgba(11,20,40,.12);
  white-space:nowrap;
}
.program-card[style*="#FAB005"] .program-age{color:var(--deep-yellow)}

/* Body — clean plain text below photo with top padding for tag */
.program-body{
  position:relative;z-index:1;flex:1;display:flex;flex-direction:column;
  padding:1.75rem .25rem 0;margin:0;background:transparent;border-radius:0;
}
.program-body::before{display:none}

.program-card h3{
  font-size:1.1rem;font-weight:600;color:var(--ink);
  margin:0 0 .5rem;line-height:1.35;letter-spacing:-.005em;
}
.program-card[style*="#FAB005"] h3{color:var(--ink)}

.program-card p{
  font-size:.84rem;line-height:1.5;color:var(--ink);
  opacity:.72;margin:0 0 .75rem;flex:1;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}

/* Learn more — simple arrow link */
.program-link{
  align-self:flex-start;display:inline-flex;align-items:center;gap:.35rem;
  padding:0;background:transparent;color:var(--card-color);
  border-radius:0;font-weight:600;font-size:.82rem;letter-spacing:.01em;
  text-decoration:none;box-shadow:none;transition:gap .3s;
}
.program-card[style*="#FAB005"] .program-link{color:var(--deep-yellow)}
.program-card:hover .program-link{gap:.6rem}
.program-link:hover{color:var(--card-color)}
.program-card[style*="#FAB005"] .program-link:hover{color:var(--deep-yellow)}

@media (max-width:1024px){
  .programs-grid .program-card:nth-child(n){transform:rotate(0)!important;translate:0 0!important}
  .program-card:hover{transform:translateY(-10px)!important}
}

/* ---------- 10. Faculty ---------- */
.faculty{background:var(--grad-soft)}
.faculty-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.25rem}
.faculty-card{
  margin:0;background:#fff;border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:.35s cubic-bezier(.34,1.56,.64,1);
  text-align:center;--star-color:var(--red);position:relative;
}
.faculty-card::after{
  content:'';position:absolute;inset:0;border-radius:var(--r-lg);pointer-events:none;
  border:3px solid transparent;transition:border-color .3s;
}
.faculty-card:hover{transform:translateY(-10px) rotate(1deg);box-shadow:0 24px 48px -8px var(--star-color)}
.faculty-card:hover::after{border-color:var(--star-color)}
.faculty-card:hover .faculty-photo img{transform:scale(1.08)}
.faculty-photo{aspect-ratio:1/1;overflow:hidden;position:relative}
.faculty-photo img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.faculty-card figcaption{
  padding:1.1rem .85rem 1.25rem;
  background:var(--star-color);color:#fff;position:relative;
}
.faculty-card figcaption::before{
  content:'';position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  width:0;height:0;border-left:12px solid transparent;border-right:12px solid transparent;
  border-bottom:12px solid var(--star-color);
}

/* Star color rotation for happy stars */
.faculty-grid .faculty-card:nth-child(5n+1){--star-color:var(--red)}
.faculty-grid .faculty-card:nth-child(5n+2){--star-color:var(--blue)}
.faculty-grid .faculty-card:nth-child(5n+3){--star-color:var(--green)}
.faculty-grid .faculty-card:nth-child(5n+4){--star-color:var(--deep-yellow)}
.faculty-grid .faculty-card:nth-child(5n+5){--star-color:var(--red)}
.faculty-card strong{display:block;color:#fff;font-family:var(--font-heading);font-size:1.05rem;margin-bottom:.2rem}
.faculty-card figcaption span{display:block;color:rgba(255,255,255,.85);font-size:.82rem;font-weight:600;margin-bottom:.3rem}
.faculty-card figcaption small{color:rgba(255,255,255,.9);font-size:.82rem;font-weight:500}

/* ---------- 11. Facilities ---------- */
.facilities{background:#fff}
.facilities-inner{display:grid;grid-template-columns:1fr 1.1fr;gap:4rem;align-items:center}
.facilities-collage{
  display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,200px);gap:12px;
  position:relative;
}
.fc{overflow:hidden;border-radius:var(--r-lg);box-shadow:var(--shadow-md);transition:.4s}
.fc img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.fc:hover img{transform:scale(1.08)}
.fc-1{grid-column:1/2;grid-row:1/3;border-radius:32% 40% 38% 42%/40% 35% 45% 40%}
.fc-2{transform:rotate(2deg)}
.fc-3{transform:rotate(-2deg)}
.fc-4{grid-column:2/3;grid-row:2/3}
.fc:hover{transform:rotate(0) scale(1.03)}

.facilities-content h2{font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:.75rem}
.facilities-content > p{color:var(--slate);margin-bottom:1.5rem}
.facilities-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.9rem;margin-top:1rem}
.facility-item{display:flex;flex-direction:column;align-items:center;gap:.6rem;padding:1.25rem .5rem;background:var(--cream);border-radius:var(--r-md);text-align:center;transition:.3s}
.facility-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.facility-item:hover .facility-icon{animation:wobble .5s ease-in-out}
.facility-icon{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.55rem;box-shadow:0 4px 10px rgba(0,0,0,.08)}
.facility-item span{font-weight:700;color:var(--ink);font-size:.85rem}

/* 8 unique colors — each facility box distinct */
.facilities-grid .facility-item:nth-child(1){background:#FFF4C2}
.facilities-grid .facility-item:nth-child(1) .facility-icon{background:var(--yellow)}

.facilities-grid .facility-item:nth-child(2){background:#DCEAFB}
.facilities-grid .facility-item:nth-child(2) .facility-icon{background:var(--blue)}

.facilities-grid .facility-item:nth-child(3){background:#D4F4DE}
.facilities-grid .facility-item:nth-child(3) .facility-icon{background:var(--green)}

.facilities-grid .facility-item:nth-child(4){background:#FFDDE0}
.facilities-grid .facility-item:nth-child(4) .facility-icon{background:var(--red)}

.facilities-grid .facility-item:nth-child(5){background:#FFE4CF}
.facilities-grid .facility-item:nth-child(5) .facility-icon{background:var(--tangerine)}

.facilities-grid .facility-item:nth-child(6){background:#E5DFFC}
.facilities-grid .facility-item:nth-child(6) .facility-icon{background:var(--purple)}

.facilities-grid .facility-item:nth-child(7){background:#FFDCE7}
.facilities-grid .facility-item:nth-child(7) .facility-icon{background:var(--pink)}

.facilities-grid .facility-item:nth-child(8){background:#C8F4E0}
.facilities-grid .facility-item:nth-child(8) .facility-icon{background:var(--mint)}
@keyframes wobble{0%,100%{transform:rotate(0)}25%{transform:rotate(-12deg) scale(1.1)}75%{transform:rotate(12deg) scale(1.1)}}

/* ---------- 12. Gallery ---------- */
.gallery{background:var(--cream)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:160px;gap:1rem;grid-auto-flow:dense}
.g-item{position:relative;overflow:hidden;border-radius:var(--r-lg);display:block;box-shadow:var(--shadow-sm);transition:.3s}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.g-item:hover img{transform:scale(1.1)}
.g-1{grid-column:span 2;grid-row:span 2}
.g-2{grid-column:span 1;grid-row:span 1}
.g-3{grid-column:span 1;grid-row:span 1}
.g-4{grid-column:span 1;grid-row:span 1}
.g-5{grid-column:span 2;grid-row:span 1}
.g-6{grid-column:span 1;grid-row:span 1}
.g-7{grid-column:span 1;grid-row:span 1}
.g-8{grid-column:span 1;grid-row:span 1}
.g-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(31,29,54,.75),transparent 60%);display:flex;align-items:flex-end;padding:1rem 1.25rem;opacity:0;transition:.3s;color:#fff;font-weight:700}
.g-item:hover .g-overlay{opacity:1}
.gallery-cta{text-align:center;margin-top:2rem}

/* ---------- 13. Testimonials — DARK ---------- */
.testimonials{background:var(--dark-bg);position:relative;overflow:hidden;color:#fff}
.testimonials .section-head h2{color:#fff}
.testimonials::before{content:'"';position:absolute;top:-60px;left:5%;font-size:24rem;color:rgba(250,176,5,.1);font-family:Georgia,serif;line-height:1;pointer-events:none}
.testimonials::after{content:'';position:absolute;width:400px;height:400px;background:var(--blue);filter:blur(120px);opacity:.2;bottom:-150px;right:-100px;border-radius:50%;pointer-events:none}
.testimonials-swiper{padding:20px 0 60px;position:relative;z-index:1}
.testimonial-card{background:var(--dark-card);border-radius:var(--r-xl);padding:2.5rem 2rem;height:100%;box-shadow:0 20px 50px rgba(0,0,0,.4);position:relative;border:1px solid rgba(255,255,255,.06)}
.quote-mark{position:absolute;top:-10px;left:20px;font-size:5rem;font-family:Georgia,serif;color:var(--yellow);line-height:1;opacity:.4}
.testimonial-card .stars{font-size:1.05rem;margin-bottom:.75rem}
.testimonial-card p{font-family:var(--font-body);font-size:1.02rem;color:var(--dark-text);line-height:1.7;margin-bottom:1.5rem;font-style:italic}
.author{display:flex;align-items:center;gap:.9rem}
.author img{width:52px;height:52px;border-radius:50%;object-fit:cover;border:3px solid var(--yellow)}
.author strong{display:block;color:#fff;font-family:var(--font-heading);font-size:1rem}
.author span{color:var(--dark-muted);font-size:.85rem}
.swiper-pagination-bullet{background:var(--yellow);opacity:.4}
.swiper-pagination-bullet-active{background:var(--yellow);opacity:1;width:28px;border-radius:6px}
.swiper-button-prev,.swiper-button-next{color:var(--yellow)}
.swiper-button-prev::after,.swiper-button-next::after{font-size:1.5rem;font-weight:900}

/* ---------- 14. CTA Banner ---------- */
.cta-banner{position:relative;overflow:hidden;padding:var(--space-8) 0;color:#fff;text-align:center;isolation:isolate}
.cta-bg{position:absolute;inset:0;z-index:-2}
.cta-bg img{width:100%;height:100%;object-fit:cover}
.cta-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,217,61,.92) 0%,rgba(255,107,157,.92) 50%,rgba(167,139,250,.92) 100%);z-index:1}
.cta-banner h2{color:#fff;font-size:clamp(2rem,4.5vw,3rem);margin-bottom:1rem}
.cta-banner p{color:rgba(255,255,255,.96);font-size:1.15rem;margin-bottom:2rem;max-width:600px;margin-left:auto;margin-right:auto}
.cta-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.cta-banner .btn-white{animation:btn-pulse 2.5s infinite}
@keyframes btn-pulse{0%,100%{box-shadow:0 0 0 0 rgba(255,255,255,.5)}50%{box-shadow:0 0 0 16px rgba(255,255,255,0)}}
.cta-decor{position:absolute;inset:0;pointer-events:none;z-index:1}
.cd{position:absolute;font-size:2.5rem;opacity:.85;filter:drop-shadow(0 4px 10px rgba(0,0,0,.15))}
.cd-1{top:15%;left:6%;animation:float-lg 6s ease-in-out infinite}
.cd-2{top:20%;right:8%;font-size:2rem;animation:twinkle 3s ease-in-out infinite}
.cd-3{bottom:20%;left:15%;font-size:1.8rem;animation:twinkle 2.5s ease-in-out infinite;animation-delay:.5s}
.cd-4{bottom:25%;right:12%;animation:float-lg 7s ease-in-out infinite reverse}
.cd-5{top:50%;right:25%;font-size:1.8rem;animation:twinkle 3.5s ease-in-out infinite;animation-delay:1s}
.cd-6{bottom:10%;left:45%;font-size:2.2rem;animation:float-lg 5s ease-in-out infinite}
.cta-inner{position:relative;z-index:2}

/* ---------- 15. FAQ ---------- */
.faq{background:var(--cream)}
.faq-inner{display:grid;grid-template-columns:1fr 1.2fr;gap:4rem;align-items:center}
.faq-visual{position:relative;aspect-ratio:1/1;max-width:460px;margin:0 auto;width:100%}
.faq-visual img{width:100%;height:100%;object-fit:cover;border-radius:48% 52% 40% 60% / 55% 45% 55% 45%;box-shadow:var(--shadow-lg);animation:blob-morph 16s ease-in-out infinite}
.faq-floating{position:absolute;font-size:2rem;background:#fff;width:62px;height:62px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);animation:float-y 4.5s ease-in-out infinite}
.faq-float-1{top:10%;left:-6%;animation-delay:0s}
.faq-float-2{top:45%;right:-8%;animation-delay:1s}
.faq-float-3{bottom:8%;left:6%;font-size:1.6rem;animation-delay:2s}

.faq-content h2{font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:1.5rem}
.faq-list{display:grid;gap:.9rem}
.faq-item{background:#fff;border-radius:var(--r-lg);padding:0;box-shadow:var(--shadow-sm);transition:.3s;overflow:hidden;border:2px solid transparent}
.faq-item[open]{border-color:var(--pink);box-shadow:var(--shadow-md)}
.faq-item summary{list-style:none;padding:1.15rem 1.4rem;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1rem;font-family:var(--font-heading);font-weight:600;font-size:1rem;color:var(--ink);transition:color .2s}
.faq-item[open] summary{color:var(--red)}
.faq-item:hover summary{color:var(--blue)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-icon{width:30px;height:30px;flex-shrink:0;border-radius:50%;background:var(--rose-mist);color:var(--pink);display:inline-flex;align-items:center;justify-content:center;font-size:1.3rem;font-weight:700;transition:transform .3s}
.faq-item[open] .faq-icon{transform:rotate(45deg);background:var(--pink);color:#fff}
.faq-answer{padding:0 1.4rem 1.15rem}
.faq-answer p{color:var(--slate);margin:0;font-size:.95rem}

/* ---------- 16. Contact ---------- */
.contact{background:#fff}
.contact-inner{display:grid;grid-template-columns:1fr 1.2fr;gap:3rem;align-items:start}
.contact-info h2{font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:.75rem}
.contact-photo{border-radius:var(--r-lg);overflow:hidden;margin:1.5rem 0;aspect-ratio:16/10;box-shadow:var(--shadow-md)}
.contact-photo img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.contact-photo:hover img{transform:scale(1.05)}
.contact-list{display:grid;gap:1rem;margin:1.5rem 0}
.contact-list li{display:flex;align-items:flex-start;gap:1rem}
.contact-icon{width:48px;height:48px;flex-shrink:0;border-radius:var(--r-md);display:inline-flex;align-items:center;justify-content:center;font-size:1.3rem}
.contact-list strong{display:block;color:var(--blue);font-family:var(--font-heading);margin-bottom:.15rem}
.contact-list li:nth-child(1) strong{color:var(--red)}
.contact-list li:nth-child(2) strong{color:var(--deep-yellow)}
.contact-list li:nth-child(3) strong{color:var(--blue)}
.contact-list li:nth-child(4) strong{color:var(--green)}
.contact-list a,.contact-list span{color:var(--slate)}
.contact-list a:hover{color:var(--pink)}
.contact-map{aspect-ratio:4/3;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-lg);border:6px solid #fff;position:sticky;top:100px}

/* ---------- 17. Footer — PRO ---------- */
.site-footer{
  position:relative;background:#0B1428;color:#C5C5D1;
  padding:var(--space-8) 0 0;overflow:hidden;
  background-image:
    radial-gradient(ellipse 80% 50% at 0% 0%,rgba(224,49,49,.12),transparent 60%),
    radial-gradient(ellipse 70% 60% at 100% 0%,rgba(250,176,5,.10),transparent 60%),
    radial-gradient(ellipse 60% 40% at 50% 100%,rgba(34,139,230,.08),transparent 70%);
}
.site-footer::before{
  content:'';position:absolute;left:0;right:0;top:0;height:3px;
  background:linear-gradient(90deg,var(--yellow),var(--red),var(--pink),var(--blue),var(--green));
  opacity:.85;
}
.site-footer .container{position:relative;z-index:1}

/* Pre-footer CTA band */
.footer-cta-band{
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;
  padding:1.75rem 2rem;margin-bottom:3rem;border-radius:22px;
  background:linear-gradient(135deg,rgba(250,176,5,.16),rgba(224,49,49,.14));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 20px 40px rgba(0,0,0,.25),inset 0 1px 0 rgba(255,255,255,.05);
}
.footer-cta-band .fcb-text h3{
  margin:0 0 .25rem;color:#fff;font-family:var(--font-display);
  font-size:clamp(1.1rem,2vw,1.5rem);font-weight:800;letter-spacing:-.01em;
}
.footer-cta-band .fcb-text p{margin:0;color:rgba(255,255,255,.75);font-size:.95rem}
.footer-cta-band .fcb-actions{display:flex;gap:.75rem;flex-wrap:wrap}
.footer-cta-band .btn{margin:0}

.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:3rem;padding-bottom:var(--space-7)}

/* Footer logo */
.footer-about .logo{color:#fff;margin-bottom:1.1rem}
.footer-about .logo-mark{
  width:60px;height:60px;border-radius:18px;padding:4px;
  background:#fff;box-shadow:0 10px 26px rgba(0,0,0,.35),inset 0 0 0 1px rgba(255,255,255,.06);
}
.footer-about .logo-mark img{border-radius:14px}
.footer-about .logo-text{color:#fff}
.footer-about .logo-text span{color:var(--yellow)}
.footer-about .logo-tag{color:rgba(255,255,255,.55)}
.footer-about p{color:rgba(255,255,255,.65);margin:0 0 1.25rem;font-size:.95rem;line-height:1.65;max-width:380px}

/* Footer trust badges */
.footer-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0 1.25rem}
.footer-badges .fb{
  display:inline-flex;align-items:center;gap:.35rem;
  padding:.35rem .75rem;border-radius:999px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  font-size:.72rem;font-weight:600;color:rgba(255,255,255,.75);
}
.footer-badges .fb-ico{font-size:.85rem}

.footer-mini-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:1.25rem;border-radius:12px;overflow:hidden}
.footer-mini-gallery img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:8px;transition:transform .45s cubic-bezier(.16,1,.3,1),filter .3s ease;cursor:pointer}
.footer-mini-gallery img:hover{transform:scale(1.08);filter:brightness(1.2) saturate(1.1)}

.socials{display:flex;gap:.6rem}
.social-link{
  width:42px;height:42px;border-radius:12px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);
  color:#fff;display:inline-flex;align-items:center;justify-content:center;
  transition:transform .3s cubic-bezier(.34,1.56,.64,1),background .3s ease,border-color .3s ease,box-shadow .3s ease;
}
.social-link:hover{background:var(--yellow);border-color:var(--yellow);color:var(--ink);transform:translateY(-4px) rotate(-4deg);box-shadow:0 10px 24px rgba(250,176,5,.35)}

/* Footer columns */
.footer-col h4{
  color:#fff;font-family:var(--font-heading);font-size:1.05rem;margin:0 0 1.25rem;
  position:relative;padding-bottom:.75rem;font-weight:700;letter-spacing:.01em;
}
.footer-col h4::after{
  content:'';position:absolute;left:0;bottom:0;width:32px;height:3px;border-radius:3px;
  background:linear-gradient(90deg,var(--yellow),var(--red));
}
.footer-col ul{display:grid;gap:.75rem;list-style:none;padding:0;margin:0}
.footer-col a{
  color:rgba(255,255,255,.62);transition:color .2s ease,transform .25s ease,padding-left .25s ease;
  font-size:.93rem;display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;
}
.footer-col a::before{
  content:'›';color:var(--yellow);opacity:0;transform:translateX(-6px);
  transition:opacity .25s ease,transform .25s ease;font-weight:800;
}
.footer-col a:hover{color:#fff;padding-left:2px}
.footer-col a:hover::before{opacity:1;transform:translateX(0)}

.contact-mini li{font-size:.9rem;color:rgba(255,255,255,.7);display:flex;gap:.6rem;align-items:flex-start;line-height:1.5}
.contact-mini li a{color:rgba(255,255,255,.7);transition:color .2s ease}
.contact-mini li a:hover{color:var(--yellow)}

/* Footer bottom */
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding:1.5rem 0;margin-top:1.5rem}
.footer-bottom .container{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:rgba(255,255,255,.55)}
.legal{display:inline-flex;gap:1rem;align-items:center}
.legal a{color:rgba(255,255,255,.55);text-decoration:none;transition:color .2s ease;margin:0}
.legal a:hover{color:var(--yellow)}

@media (max-width:960px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .footer-about{grid-column:1 / -1}
  .footer-cta-band{padding:1.25rem 1.25rem;text-align:center;justify-content:center}
  .footer-cta-band .fcb-text{width:100%}
}
@media (max-width:560px){
  .footer-grid{grid-template-columns:1fr;gap:2.25rem}
  .footer-bottom .container{justify-content:center;text-align:center}
}

/* ---------- 18. Floating buttons ---------- */
.whatsapp-float{position:fixed;bottom:24px;right:24px;width:60px;height:60px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 28px rgba(37,211,102,.45);z-index:999;transition:.3s}
.whatsapp-float:hover{transform:scale(1.1) rotate(8deg)}
.wa-pulse{position:absolute;inset:0;border-radius:50%;border:3px solid #25D366;animation:wa-ring 2s infinite}
@keyframes wa-ring{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.6);opacity:0}}

/* Live social-proof popup */
.live-popup{
  position:fixed;bottom:24px;left:24px;z-index:997;
  display:flex;align-items:center;gap:.75rem;
  background:#fff;padding:10px 42px 10px 10px;
  border-radius:100px;box-shadow:0 14px 38px rgba(11,20,40,.18);
  max-width:340px;border:1px solid rgba(11,20,40,.05);
  transform:translateY(30px) scale(.95);opacity:0;pointer-events:none;
  transition:transform .5s cubic-bezier(.34,1.56,.64,1),opacity .4s ease;
}
.live-popup.show{transform:translateY(0) scale(1);opacity:1;pointer-events:auto}
.lp-avatar{
  width:48px;height:48px;border-radius:50%;object-fit:cover;flex-shrink:0;
  border:3px solid var(--yellow);
}
.lp-content{display:flex;flex-direction:column;line-height:1.35;min-width:0;flex:1}
.lp-title{font-size:.82rem;color:var(--ink)}
.lp-title strong{font-weight:700}
.lp-title span{color:var(--ink);opacity:.85}
.lp-detail{font-size:.72rem;color:var(--ink);opacity:.6;margin-top:1px}
.lp-close{
  position:absolute;top:50%;right:10px;transform:translateY(-50%);
  width:26px;height:26px;border-radius:50%;background:rgba(11,20,40,.06);
  color:var(--ink);font-size:1.1rem;font-weight:600;line-height:1;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:.2s;
}
.lp-close:hover{background:rgba(11,20,40,.12);transform:translateY(-50%) scale(1.08)}
@media (max-width:640px){
  .live-popup{bottom:90px;left:12px;right:12px;max-width:none}
}

.scroll-top{position:fixed;bottom:96px;right:28px;width:44px;height:44px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);z-index:998;opacity:0;pointer-events:none;transform:translateY(10px);transition:.3s}
.scroll-top.show{opacity:1;pointer-events:auto;transform:translateY(0)}
.scroll-top:hover{background:var(--pink);transform:translateY(-3px)}

/* ---------- 18.5 Curriculum (bold solid blocks, Footprints-style) ---------- */
.curriculum{background:#fff;position:relative}
.rainbow-heading{
  font-family:var(--font-display);font-size:clamp(2rem,4.5vw,3.2rem);font-weight:800;
  display:flex;gap:.45em;justify-content:center;flex-wrap:wrap;
  margin:0 0 1rem;letter-spacing:-.01em;line-height:1.1;
}
.rainbow-heading .rh-red{color:var(--red);position:relative;display:inline-block;padding-bottom:.15em}
.rainbow-heading .rh-dark{color:var(--ink)}
.rainbow-heading .rh-teal{color:var(--blue)}
.rainbow-heading .underlined::after{
  content:'';position:absolute;left:-4%;right:-4%;bottom:-6px;height:14px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 14' preserveAspectRatio='none'%3E%3Cpath d='M2 10 Q 20 2 40 8 T 80 8 T 118 8' stroke='%23FFD93D' stroke-width='4' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-size:100% 100%;
}

.curriculum-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem;
}
.cur-card{
  padding:2.5rem 2rem;border-radius:24px;text-align:center;color:#fff;
  min-height:260px;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:1.25rem;position:relative;overflow:hidden;
  transition:transform .4s cubic-bezier(.4,0,.2,1),box-shadow .4s;
  box-shadow:0 10px 30px rgba(31,29,54,.08);
}
.cur-card::before{
  content:'';position:absolute;top:-40%;right:-20%;width:60%;height:140%;
  background:radial-gradient(circle,rgba(255,255,255,.22),transparent 65%);
  pointer-events:none;transition:transform .6s ease;
}
.cur-card::after{
  content:'';position:absolute;bottom:-30%;left:-15%;width:50%;height:100%;
  background:radial-gradient(circle,rgba(255,255,255,.12),transparent 60%);
  pointer-events:none;
}
.cur-card:hover{transform:translateY(-10px) scale(1.02);box-shadow:0 30px 60px rgba(31,29,54,.22)}
.cur-card:hover::before{transform:translate(-20px,20px)}
.cur-card:hover .cur-icon{transform:rotate(-8deg) scale(1.1)}
.cur-icon{
  width:86px;height:86px;border-radius:22px;background:rgba(255,255,255,.2);
  display:flex;align-items:center;justify-content:center;color:#fff;
  transition:transform .45s cubic-bezier(.34,1.56,.64,1);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  border:2px solid rgba(255,255,255,.25);position:relative;z-index:1;
}
.cur-icon svg{width:44px;height:44px;stroke-width:1.6}
.cur-card p{
  margin:0;font-size:1rem;line-height:1.55;font-weight:500;
  max-width:92%;position:relative;z-index:1;
}
.cur-card p strong{font-weight:800}

/* Bold PRIMARY color palette — blue / red / yellow / green + dark variants */
.bg-blue{background:var(--blue)}
.bg-red{background:var(--red)}
.bg-yellow{background:var(--yellow);color:var(--navy)}
.bg-yellow .cur-icon{background:rgba(11,20,40,.12);border-color:rgba(11,20,40,.18);color:var(--navy)}
.bg-yellow p strong{color:var(--navy)}
.bg-green{background:var(--green)}
.bg-navy{background:var(--navy);border:1px solid rgba(255,255,255,.06)}
.bg-deep-red{background:var(--deep-red)}

@media (max-width:1024px){
  .curriculum-grid{grid-template-columns:repeat(2,1fr)}
  .rainbow-heading{font-size:2.2rem}
}
@media (max-width:640px){
  .curriculum-grid{grid-template-columns:1fr;gap:1rem}
  .cur-card{min-height:200px;padding:2rem 1.5rem}
  .cur-icon{width:72px;height:72px}
  .cur-icon svg{width:36px;height:36px}
  .rainbow-heading{gap:.3em;font-size:1.9rem}
}

/* ---------- Inner pages (about, programs, etc.) ---------- */
.page-hero{
  position:relative;padding:calc(var(--header-h) + 5rem) 0 4rem;
  background:var(--grad-soft);text-align:center;overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;
  background:var(--yellow);opacity:.2;border-radius:50%;filter:blur(80px);pointer-events:none;
}
.page-hero::after{
  content:'';position:absolute;bottom:-150px;left:-100px;width:400px;height:400px;
  background:var(--blue);opacity:.18;border-radius:50%;filter:blur(80px);pointer-events:none;
}
.page-hero .container{position:relative;z-index:1}
.page-hero .breadcrumb{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:6px 14px;background:#fff;border-radius:999px;
  font-size:.8rem;font-weight:600;color:var(--ink);
  box-shadow:var(--shadow-sm);margin-bottom:1.25rem;
}
.page-hero .breadcrumb a{color:var(--ink);opacity:.7;text-decoration:none}
.page-hero .breadcrumb a:hover{color:var(--red);opacity:1}
.page-hero .breadcrumb .sep{opacity:.4}
.page-hero h1{
  font-family:var(--font-display);font-size:clamp(2.2rem,5vw,3.8rem);
  font-weight:800;color:var(--ink);line-height:1.1;margin:0 0 1rem;letter-spacing:-.02em;
}
.page-hero .tagline{
  max-width:680px;margin:0 auto;font-size:1.1rem;
  color:var(--ink);opacity:.75;line-height:1.6;
}

/* Two-column content block */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}
.two-col.reverse{direction:rtl}
.two-col.reverse > *{direction:ltr}
.two-col img{width:100%;border-radius:var(--r-lg);box-shadow:var(--shadow-lg)}
@media (max-width:768px){.two-col{grid-template-columns:1fr;gap:2rem}}

/* Info cards grid */
.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem}
.info-card{
  background:#fff;padding:2rem 1.5rem;border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm);border:1px solid rgba(11,20,40,.06);
  transition:transform .3s ease,box-shadow .3s ease;
}
.info-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.info-card .info-icon{
  width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  font-size:1.8rem;margin-bottom:1rem;color:#fff;
}
.info-card h3{font-size:1.2rem;margin-bottom:.5rem;color:var(--ink)}
.info-card p{font-size:.94rem;line-height:1.55;color:var(--ink);opacity:.75;margin:0}

/* Fee table */
.fee-table{
  width:100%;border-collapse:separate;border-spacing:0;border-radius:16px;overflow:hidden;
  box-shadow:var(--shadow-md);background:#fff;
}
.fee-table th{
  background:var(--ink);color:#fff;padding:1rem;text-align:left;font-weight:700;
  font-family:var(--font-heading);font-size:.92rem;letter-spacing:.02em;
}
.fee-table td{padding:1rem;border-bottom:1px solid rgba(11,20,40,.06);font-size:.92rem}
.fee-table tr:last-child td{border-bottom:none}
.fee-table tr:nth-child(even) td{background:rgba(11,20,40,.02)}
.fee-price{font-weight:800;color:var(--red);font-family:var(--font-display)}
@media (max-width:640px){.fee-table{font-size:.85rem}.fee-table th,.fee-table td{padding:.75rem}}

/* Form */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;max-width:700px;margin:0 auto}
.form-grid .full{grid-column:1/-1}
.form-field{display:flex;flex-direction:column;gap:.35rem}
.form-field label{font-size:.85rem;font-weight:700;color:var(--ink)}
.form-field input,.form-field select,.form-field textarea{
  padding:.75rem 1rem;border:1.5px solid rgba(11,20,40,.12);border-radius:10px;
  font-family:inherit;font-size:.95rem;color:var(--ink);background:#fff;
  transition:border-color .2s,box-shadow .2s;
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{
  outline:none;border-color:var(--blue);box-shadow:0 0 0 4px rgba(30,107,221,.12);
}
.form-field textarea{min-height:120px;resize:vertical}
@media (max-width:640px){.form-grid{grid-template-columns:1fr}}

/* ---------- 19. Scroll reveal ---------- */
[data-reveal]{opacity:0;transform:translateY(40px);transition:opacity .7s ease-out,transform .7s cubic-bezier(.4,0,.2,1)}
[data-reveal].in{opacity:1;transform:translateY(0)}

/* ---------- 20. Responsive ---------- */
@media (max-width:1024px){
  .cards-4{grid-template-columns:repeat(2,1fr)}
  .faculty-grid{grid-template-columns:repeat(3,1fr)}
  .facilities-grid{grid-template-columns:repeat(4,1fr);gap:.75rem}
  .hero-inner{gap:2rem}
  .gallery-grid{grid-template-columns:repeat(3,1fr);grid-auto-flow:dense}
  .g-1{grid-column:span 2;grid-row:span 2}
  .g-5{grid-column:span 2}
}

/* ============ MOBILE (≤ 768px) ============ */
@media (max-width:768px){
  :root{--header-h:56px}
  .section{padding:3rem 0}
  .container{padding:0 18px}
  h2{font-size:1.75rem!important}

  /* Header + nav — slide-down dropdown panel */
  .main-nav{
    position:fixed!important;
    top:var(--header-h)!important;
    left:0!important;
    right:0!important;
    bottom:auto!important;
    width:100%!important;
    max-height:calc(100vh - var(--header-h) - 20px)!important;
    max-height:calc(100dvh - var(--header-h) - 20px)!important;
    background:#ffffff!important;
    background-color:#ffffff!important;
    padding:.75rem .9rem 1.5rem!important;
    transform:translateY(-20px);
    opacity:0;visibility:hidden;pointer-events:none;
    transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s ease,visibility .3s;
    box-shadow:0 24px 50px rgba(11,20,40,.18),0 6px 16px rgba(11,20,40,.08);
    z-index:9999!important;
    isolation:isolate;
    overflow-y:auto!important;
    overflow-x:hidden!important;
    -webkit-overflow-scrolling:touch;
    border-radius:0 0 20px 20px;
    border-top:1px solid rgba(11,20,40,.06);
  }
  .main-nav.open{
    transform:translateY(0)!important;
    opacity:1!important;visibility:visible!important;pointer-events:auto!important;
  }

  /* Top-level nav list */
  .main-nav > ul{
    display:flex!important;flex-direction:column;gap:.4rem;
    align-items:stretch;width:100%;padding:0;margin:0;list-style:none;
  }
  .main-nav > ul > li{width:100%;list-style:none;--item:var(--blue)}

  /* Top-level nav item cards */
  .main-nav > ul > li > a{
    display:flex!important;align-items:center;gap:.85rem;
    padding:.7rem .85rem!important;
    font-size:.95rem!important;font-weight:700;
    color:var(--ink)!important;text-decoration:none!important;
    background:#fff!important;border-radius:14px!important;
    border:1px solid rgba(11,20,40,.08)!important;
    transition:all .25s ease;position:relative;
  }

  /* Default right arrow */
  .main-nav > ul > li > a::after{
    content:'→';display:block;margin-left:auto;
    color:var(--item);font-size:1.05rem;font-weight:700;opacity:.5;
    transition:transform .25s,opacity .25s;
    position:static;width:auto;height:auto;background:transparent;
  }
  .main-nav > ul > li > a:hover,
  .main-nav > ul > li > a:active,
  .main-nav > ul > li > a.active{
    background:color-mix(in srgb,var(--item) 15%,white)!important;
    border-color:var(--item)!important;
    transform:translateX(3px);
  }
  .main-nav > ul > li > a:hover::after,
  .main-nav > ul > li > a:active::after,
  .main-nav > ul > li > a.active::after{opacity:1;transform:translateX(4px)}

  /* Dropdown sub-item hover — strong colored tint */
  .main-nav .dropdown li > a:hover,
  .main-nav .dropdown li > a:active{
    background:color-mix(in srgb,var(--item) 15%,white)!important;
    border-color:var(--item)!important;
    transform:translateX(3px);
  }

  /* Icon badge before name */
  .main-nav > ul > li > a::before{
    display:inline-flex;align-items:center;justify-content:center;
    width:40px;height:40px;border-radius:11px;flex-shrink:0;
    font-size:1.2rem;color:#fff;background:var(--item);
    box-shadow:0 4px 10px color-mix(in srgb,var(--item) 40%,transparent);
    line-height:1;
  }

  /* Per-item icon + color */
  .main-nav > ul > li:nth-child(1){--item:var(--blue)}
  .main-nav > ul > li:nth-child(1) > a::before{content:'🏠'}
  .main-nav > ul > li:nth-child(2){--item:var(--red)}
  .main-nav > ul > li:nth-child(2) > a::before{content:'💝'}
  .main-nav > ul > li:nth-child(3){--item:#D9930A}
  .main-nav > ul > li:nth-child(3) > a::before{content:'📚'}
  .main-nav > ul > li:nth-child(4){--item:var(--green)}
  .main-nav > ul > li:nth-child(4) > a::before{content:'🖼️'}
  .main-nav > ul > li:nth-child(5){--item:var(--blue)}
  .main-nav > ul > li:nth-child(5) > a::before{content:'🏢'}
  .main-nav > ul > li:nth-child(6){--item:var(--red)}
  .main-nav > ul > li:nth-child(6) > a::before{content:'✉️'}
  .main-nav > ul > li:nth-child(7){--item:var(--red)}
  .main-nav > ul > li:nth-child(7) > a::before{content:'💼'}
  .main-nav > ul > li:nth-child(8){--item:var(--green)}
  .main-nav > ul > li:nth-child(8) > a::before{content:'💰'}

  /* CTA pills reset to card style on mobile */
  .main-nav > ul > li > a.nav-cta,
  .main-nav > ul > li > a.nav-special{
    background:#fff!important;color:var(--ink)!important;
    padding:.7rem .85rem!important;margin-top:0!important;
    text-align:left!important;justify-content:flex-start!important;
    border:1px solid rgba(11,20,40,.08)!important;
    box-shadow:none!important;gap:.85rem!important;overflow:visible!important;
  }
  .main-nav > ul > li > a.nav-special .ns-emoji{display:none!important}
  .main-nav > ul > li > a.nav-special::before{content:'💼'!important}
  .main-nav > ul > li > a.nav-cta::before{content:'💰'!important}
  .main-nav > ul > li > a.nav-special::before,
  .main-nav > ul > li > a.nav-cta::before{display:inline-flex!important}

  /* Programs has chevron instead of → */
  .main-nav > ul > li.has-dropdown > a::after{display:none!important}
  .main-nav > ul > li.has-dropdown > a .dd-arrow{
    margin-left:auto;color:var(--item);opacity:.8;width:16px;height:16px;
  }
  .main-nav > ul > li.has-dropdown.open > a{
    background:color-mix(in srgb,var(--item) 10%,white)!important;
    border-color:var(--item)!important;
  }

  /* Dropdown on mobile — expanded accordion with cards */
  .has-dropdown .dropdown{
    position:static!important;transform:none!important;
    opacity:1!important;visibility:visible!important;pointer-events:auto!important;
    background:transparent!important;box-shadow:none!important;border:none!important;
    padding:0!important;margin:0!important;min-width:0!important;
    max-height:0;overflow:hidden!important;
    transition:max-height .4s ease,margin .25s ease,padding .25s ease;
    display:flex!important;flex-direction:column;gap:4px;
  }
  .has-dropdown .dropdown::before,
  .has-dropdown .dropdown::after{display:none!important}
  .has-dropdown.open .dropdown{
    max-height:600px;
    margin:.5rem 0 .25rem 1rem!important;
    padding:.25rem 0 .25rem .75rem!important;
    border-left:3px solid var(--item)!important;
  }

  /* Dropdown sub-item cards (Playgroup, Nursery, etc.) */
  .main-nav .dropdown li > a{
    display:flex!important;align-items:center;gap:.75rem!important;
    padding:.6rem .75rem!important;
    font-size:.88rem!important;
    background:#fff!important;
    border:1px solid rgba(11,20,40,.06)!important;
    border-radius:11px!important;
    margin:0!important;
    border-left:3px solid var(--item)!important;
  }
  .main-nav .dropdown li > a::before,
  .main-nav .dropdown li > a::after{display:none!important}
  .main-nav .dropdown .dd-emoji{display:inline-flex!important;width:36px;height:36px;font-size:1.15rem}
  .main-nav .dropdown .dd-info{display:flex;flex-direction:column;flex:1}
  .main-nav .dropdown .dd-info strong{font-size:.9rem}
  .main-nav .dropdown .dd-info small{font-size:.7rem}
  .main-nav .dropdown .dd-arrow-r{display:inline-flex!important;opacity:1;transform:none;color:var(--item);font-size:1rem}

  /* Dropdown becomes inline accordion on mobile */
  .has-dropdown .dropdown{
    position:static;transform:none!important;
    opacity:1;visibility:visible;pointer-events:auto;
    box-shadow:none;border:none;background:transparent;padding:0;
    max-height:0;overflow:hidden;min-width:0;margin:0;
    transition:max-height .35s ease,margin .25s ease;
  }
  .has-dropdown .dropdown::before,
  .has-dropdown .dropdown::after{display:none}
  .has-dropdown.open .dropdown{
    max-height:400px;margin:.25rem 0 .75rem;
    padding:.25rem 0 .25rem .75rem;
    border-left:3px solid var(--red);
  }
  .has-dropdown:hover .dropdown{max-height:0}  /* hover disabled on mobile */
  .has-dropdown.open:hover .dropdown{max-height:400px}
  .dropdown a{padding:.6rem .75rem!important;font-size:.92rem!important;border-bottom:1px solid rgba(11,20,40,.05)!important}
  .nav-has-arrow{justify-content:space-between;width:100%}

  .hamburger{display:flex}
  .header-cta .btn{display:none}
  .phone-link{width:36px;height:36px}

  /* Hero */
  .hero{padding-top:calc(var(--header-h) + 20px);padding-bottom:40px;min-height:auto}
  .hero-inner{grid-template-columns:1fr;gap:2.5rem;text-align:center}
  .hero-title{font-size:clamp(1.9rem,7vw,2.4rem)!important;line-height:1.1}
  .hero-sub{font-size:1rem;margin-left:auto;margin-right:auto}
  .hero-content .badge{margin-left:auto;margin-right:auto}
  .hero-ctas{justify-content:center;flex-direction:column;gap:.75rem}
  .hero-ctas .btn{width:100%;max-width:320px;margin:0 auto}
  .hero-trust{justify-content:center;flex-wrap:wrap;flex-direction:column;gap:.75rem}
  .trust-avatars{justify-content:center}
  .hero-art{min-height:auto;margin-top:1rem}
  .hero-photo-main{max-width:280px;width:80%;margin:0 auto}
  .hero-photo-sm{width:90px;height:90px;border-width:4px}
  .hero-photo-top{top:-5%;right:0}
  .hero-photo-bottom{bottom:0;left:0}
  .hero-badge{padding:8px 12px;font-size:.8rem}
  .hero-badge-1{left:-2%;top:10%}
  .hero-badge-2{right:-2%;bottom:12%}
  .hero-badge strong{font-size:.9rem}
  .hero-badge small{font-size:.7rem}
  .hb-icon{font-size:1.2rem}
  .scroll-indicator{display:none}
  .floaters .cloud,.floaters .balloon,.floaters .star{font-size:1.5rem!important}

  /* Universal grids stack */
  .cards-4,.curriculum-grid,.programs-grid,.faculty-grid,
  .about-inner,.contact-inner,.facilities-inner,.faq-inner{
    grid-template-columns:1fr!important;gap:1.25rem;
  }

  /* Highlights cards */
  .feature-card::before{font-size:1.1rem;top:10px;right:10px}
  .feature-card::after{width:100px;height:100px}
  .feature-card h3{font-size:1.15rem;margin:1rem 1.25rem .4rem}
  .feature-card p{margin:0 1.25rem 1rem;font-size:.9rem}
  .feature-body{padding:1rem 1.25rem 1.25rem}
  .fc-link{font-size:.82rem}
  .feature-icon{width:52px;height:52px;font-size:1.5rem;left:14px;bottom:14px}

  /* About — stat badges */
  .about-art{padding:20px 14px 30px 14px}
  .about-art::before,.about-art::after{left:20px;right:5px}
  .about-main-img{aspect-ratio:4/3}
  .about-badge-top{padding:10px 16px;top:-14px;right:-8px}
  .about-badge-top strong{font-size:1.4rem}
  .about-badge-top span{font-size:.6rem}
  .about-badge-bottom{padding:10px 16px 10px 10px;bottom:-14px;left:-8px;gap:10px}
  .about-badge-bottom .ab-text strong{font-size:1.2rem}
  .about-badge-bottom .ab-text span{font-size:.58rem}
  .ab-icon{width:34px;height:34px;font-size:1rem}
  .about-badge-side{display:none}
  .about-content h2,.facilities-content h2,.faq-content h2,.contact-info h2{font-size:1.6rem}

  /* Programs — disable tilts on mobile */
  .programs-grid{padding:1rem 0}
  .programs-grid .program-card{transform:none!important;margin-bottom:.5rem}
  .program-card:hover{transform:translateY(-6px)!important}
  .program-photo{aspect-ratio:4/3}
  .program-card h3{font-size:1.15rem}

  /* Curriculum blocks */
  .cur-card{min-height:200px;padding:2rem 1.5rem;gap:1rem}
  .cur-icon{width:68px;height:68px}
  .cur-icon svg{width:36px;height:36px}
  .cur-card p{font-size:.95rem}
  .rainbow-heading{font-size:1.75rem;gap:.25em}

  /* Happy Stars */
  .faculty-grid{grid-template-columns:repeat(2,1fr)!important;gap:1rem}
  .faculty-card figcaption{padding:.85rem .6rem 1rem}
  .faculty-card strong{font-size:.95rem}

  /* Facilities — stack image collage above grid */
  .facilities-collage{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,140px);gap:10px}
  .facilities-grid{grid-template-columns:repeat(2,1fr)!important;gap:.8rem}
  .facility-item{padding:1rem .5rem}
  .facility-icon{width:46px;height:46px;font-size:1.35rem}
  .facility-item span{font-size:.78rem}

  /* Gallery — uniform 2×4 grid (no gaps) */
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px;gap:.6rem;grid-auto-flow:dense}
  .gallery-grid .g-item{grid-column:span 1!important;grid-row:span 1!important}
  .g-overlay{padding:.75rem;font-size:.82rem}

  /* Testimonials — single per view */
  .testimonial-card{padding:2rem 1.5rem}
  .testimonial-card p{font-size:.95rem}

  /* CTA Banner */
  .cta-banner{padding:3rem 0}
  .cta-banner h2{font-size:1.75rem}
  .cta-banner p{font-size:1rem}
  .cta-buttons{flex-direction:column;gap:.75rem}
  .cta-buttons .btn{width:100%;max-width:320px;margin:0 auto}
  .cd{font-size:1.5rem!important}

  /* FAQ */
  .faq-visual{max-width:320px}
  .faq-floating{width:46px;height:46px;font-size:1.4rem}
  .faq-item summary{padding:1rem 1.1rem;font-size:.95rem}
  .faq-answer p{font-size:.9rem}

  /* Contact */
  .contact-photo{aspect-ratio:16/10}
  .contact-list{gap:.9rem}
  .contact-icon{width:44px;height:44px;font-size:1.2rem}
  .contact-map{position:static;aspect-ratio:4/3}

  /* Footer */
  .footer-grid{grid-template-columns:1fr 1fr;gap:1.75rem}
  .footer-about{grid-column:1/-1}
  .footer-bottom .container{flex-direction:column;text-align:center;gap:.5rem}

  /* Floating UI */
  .whatsapp-float{width:52px;height:52px;bottom:18px;right:18px}
  .whatsapp-float svg{width:26px;height:26px}
  .scroll-top{bottom:80px;right:22px;width:40px;height:40px}
  .live-popup{bottom:auto;top:calc(var(--header-h) + 10px);left:10px;right:10px;max-width:none}
  .lp-avatar{width:42px;height:42px}
  .lp-title{font-size:.78rem}
  .lp-detail{font-size:.68rem}
}

/* ============ SMALL PHONES (≤ 480px) ============ */
@media (max-width:480px){
  .container{padding:0 14px}
  .section{padding:2.5rem 0}
  h2{font-size:1.5rem!important}

  .hero-title{font-size:1.85rem!important}
  .hero-sub{font-size:.95rem}
  .hero-photo-main{max-width:240px}
  .hero-photo-sm{width:72px;height:72px;border-width:3px}
  .hero-badge{padding:6px 10px;font-size:.75rem}
  .hero-badge strong{font-size:.82rem}
  .hero-badge small{font-size:.65rem}

  .btn-lg{padding:13px 22px;font-size:.95rem}

  .feature-card h3{font-size:1.08rem}
  .program-card h3{font-size:1.08rem}
  .cur-card{min-height:180px;padding:1.75rem 1.25rem}
  .cur-icon{width:60px;height:60px}
  .cur-icon svg{width:32px;height:32px}

  .facilities-grid{grid-template-columns:repeat(2,1fr)!important}
  .footer-grid{grid-template-columns:1fr;gap:1.5rem}
  .footer-about{grid-column:auto}

  /* About badges — keep but smaller */
  .about-badge-top{padding:8px 12px;top:-10px;right:-4px}
  .about-badge-top strong{font-size:1.2rem}
  .about-badge-top span{font-size:.56rem}
  .about-badge-bottom{padding:8px 12px 8px 8px;gap:8px;bottom:-10px;left:-4px}
  .about-badge-bottom .ab-text strong{font-size:1.05rem}
  .ab-icon{width:30px;height:30px;font-size:.9rem}

  /* About stats */
  .about-stats{grid-template-columns:repeat(2,1fr);gap:.5rem;padding:1rem}

  .cta-banner h2{font-size:1.55rem}
  .hero-trust{flex-direction:column}

  /* Logo + header text smaller */
  .logo{font-size:.95rem}
  .logo-mark{font-size:1.25rem}

  /* Gallery simpler */
  .gallery-grid{grid-auto-rows:110px}

  /* Testimonials padding */
  .testimonial-card{padding:1.75rem 1.25rem}
}

/* Tap target minimum 44px on touch devices */
@media (hover:none) and (pointer:coarse){
  a,button,.btn,.facility-item,.program-link,.fc-link{min-height:44px}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  [data-reveal]{opacity:1;transform:none}
}

/* ---------- Responsive Logo ---------- */
@media (max-width:768px){
  .logo{gap:.6rem;font-size:1.02rem}
  .logo-mark{width:44px;height:44px;border-radius:13px;padding:2px}
  .logo-mark img{border-radius:10px}
  .logo-tag{font-size:.55rem;letter-spacing:.18em;margin-top:2px}
  .site-header.scrolled .logo-mark{width:40px;height:40px}
  .footer-about .logo-mark{width:52px;height:52px}
}
@media (max-width:420px){
  .logo-tag{display:none}
}

/* ---------- PRO Gallery v2 — enhancements ---------- */
.gph-filters{
  display:flex;flex-wrap:wrap;justify-content:center;gap:.55rem;
  margin:0 0 2rem;padding:0;list-style:none;
}
.gph-chip{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.55rem 1.1rem;background:rgba(255,255,255,.75);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1.5px solid rgba(11,20,40,.08);border-radius:999px;
  font-family:var(--font-heading);font-weight:700;font-size:.82rem;
  color:var(--ink);cursor:pointer;user-select:none;
  transition:background .25s ease,border-color .25s ease,color .25s ease,transform .25s ease,box-shadow .25s ease;
}
.gph-chip .chip-dot{width:7px;height:7px;border-radius:50%;background:currentColor;opacity:.55}
.gph-chip:hover{transform:translateY(-2px);box-shadow:0 8px 18px rgba(11,20,40,.08);color:var(--red)}
.gph-chip.is-active{
  background:linear-gradient(135deg,var(--red),var(--pink));
  color:#fff;border-color:transparent;
  box-shadow:0 10px 22px rgba(224,49,49,.28);
}
.gph-chip.is-active .chip-dot{background:#fff;opacity:1}

/* Ken-burns subtle animation for tiles */
@keyframes gphKenBurns{
  0%{transform:scale(1.02)}
  50%{transform:scale(1.08)}
  100%{transform:scale(1.02)}
}
.gph-tile img{animation:gphKenBurns 18s ease-in-out infinite}
.gph-tile:nth-child(2n) img{animation-delay:-6s}
.gph-tile:nth-child(3n) img{animation-delay:-12s}
.gph-tile:hover img{animation-play-state:paused}

/* Tile reveal ring */
.gph-tile::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  box-shadow:inset 0 0 0 0 var(--yellow);
  transition:box-shadow .35s ease;pointer-events:none;z-index:2;
}
.gph-tile:hover::before{box-shadow:inset 0 0 0 3px var(--yellow)}

/* Hide state for filter */
.gph-tile.is-hidden{display:none}

/* Gallery marquee strip (bonus) */
.gph-strip{
  margin-top:2.5rem;padding:1rem 0;border-radius:16px;
  background:rgba(255,255,255,.55);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.7);overflow:hidden;position:relative;
}
.gph-strip::before,.gph-strip::after{
  content:'';position:absolute;top:0;bottom:0;width:60px;z-index:2;pointer-events:none;
}
.gph-strip::before{left:0;background:linear-gradient(to right,rgba(255,249,237,.95),transparent)}
.gph-strip::after{right:0;background:linear-gradient(to left,rgba(255,221,231,.95),transparent)}
.gph-strip-track{
  display:flex;gap:.8rem;animation:gphMarquee 30s linear infinite;width:max-content;
}
.gph-strip:hover .gph-strip-track{animation-play-state:paused}
.gph-strip-track img{
  width:110px;height:110px;object-fit:cover;border-radius:12px;flex-shrink:0;
  box-shadow:0 6px 14px rgba(11,20,40,.1);
  transition:transform .3s ease;
}
.gph-strip-track img:hover{transform:translateY(-4px) scale(1.04)}
@keyframes gphMarquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

@media (prefers-reduced-motion:reduce){
  .gph-tile img,.gph-strip-track{animation:none!important}
}
