/* ═══ HEADER WRAPPER ═══ */
.site-header{
  position:relative;
  display:flex;flex-direction:column;
}

/* ═══ TOP HEADER (scrolls away) ═══ */
.top-header{
  background:linear-gradient(to right,#aaff00,#ffff00);
  padding:18px 50px;
  display:flex;align-items:center;justify-content:space-between;
  min-height:130px;
  gap:20px;
}
.brand{display:flex;align-items:center;gap:36px;text-decoration:none}
.brand-logo{
  width:105px;height:105px;border-radius:50%;
  background:#fff;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;flex-shrink:0;
  box-shadow:0 4px 12px rgba(30,30,122,0.2);
}
.brand-logo img{width:100%;height:100%;object-fit:contain}
.brand-logo svg{width:100%;height:100%}
.brand-text{line-height:1;display:flex;align-items:center}
.brand-text img{height:88px;width:auto;display:block}
.brand-text .name{
  font-size:36px;font-weight:800;color:var(--navy);
  letter-spacing:-.5px;line-height:1;
}
.brand-text .name span{color:var(--orange)}
.brand-text .sub{
  font-size:16px;color:var(--navy);font-weight:600;
  letter-spacing:.3px;margin-top:6px;
}

.pillar-nav{display:flex;align-items:center;gap:12px;list-style:none;margin:0;padding:0}
.pillar-nav li{position:relative;list-style:none}
.pillar-nav .navbtn{
  display:block;padding:13px 30px;border-radius:6px;
  font-size:14px;font-weight:700;text-decoration:none;
  letter-spacing:.8px;color:#fff;
  transition:all .18s;cursor:pointer;
}
.pillar-nav .navbtn:hover{opacity:.88;transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,0.2)}
.btn-orange-pill{background:var(--orange)}
.btn-navy-pill{background:var(--navy)}

.top-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}
.top-hamburger span{width:26px;height:3px;background:var(--navy);border-radius:2px;transition:all .2s}

/* ═══ YELLOW STRIP ═══ */
.yellow-strip{
  height:8px;
  background:linear-gradient(to right,#ccff00,#ffff00);
  border-bottom:1px solid rgba(30,30,122,0.1);
  border-top:3px solid #88dd00;
}

/* ═══ SECONDARY MENU NAV (sticky) ═══ */
nav{
  position:sticky;top:0;z-index:999;
  height:64px;padding:0 60px;
  display:flex;align-items:center;justify-content:space-between;
  background:#fff;
  border-bottom:1px solid var(--line);
  box-shadow:0 4px 16px rgba(30,30,122,0.08);
}

.nav-menu{display:flex;gap:4px;list-style:none;align-items:center;margin:0;padding:0}
.nav-menu > li{position:relative;list-style:none}
.nav-menu > li > a,.nav-menu > li > span{
  display:flex;align-items:center;gap:6px;
  font-size:13px;font-weight:700;color:var(--navy);
  padding:10px 18px;border-radius:var(--r4);
  transition:all .2s;cursor:pointer;
  text-transform:uppercase;letter-spacing:.06em;
}
.nav-menu > li > a:hover,.nav-menu > li > span:hover,
.nav-menu > li:hover > a,.nav-menu > li:hover > span{
  background:var(--cream);color:var(--orange);
}
.nav-menu > li > a.active{background:var(--navy);color:#fff}
.nav-menu > li > a.active:hover{background:var(--navy-dark);color:#fff}

.nav-has-dropdown > span::after{
  content:'';
  width:0;height:0;
  border-left:4px solid transparent;
  border-right:4px solid transparent;
  border-top:5px solid currentColor;
  margin-left:2px;
  transition:transform .2s;
}
.nav-has-dropdown:hover > span::after{transform:rotate(180deg)}

.nav-dropdown{
  position:absolute;top:calc(100% + 6px);left:0;
  min-width:180px;
  background:#fff;
  border-radius:var(--r8);
  box-shadow:0 10px 30px rgba(30,30,122,0.15);
  padding:8px;
  list-style:none;
  opacity:0;visibility:hidden;
  transform:translateY(-8px);
  transition:all .25s;
  border:1px solid var(--line);
}
.nav-has-dropdown:hover .nav-dropdown{
  opacity:1;visibility:visible;transform:translateY(0);
}
.nav-dropdown::before{
  content:'';position:absolute;top:-6px;left:0;right:0;height:6px;
}
.nav-dropdown li{list-style:none}
.nav-dropdown a{
  display:block;
  padding:10px 14px;
  font-size:13px;font-weight:600;color:var(--navy);
  border-radius:var(--r4);
  transition:all .2s;text-transform:none;letter-spacing:normal;
}
.nav-dropdown a:hover{background:var(--cream);color:var(--orange);padding-left:18px}

.nav-right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav-login{font-size:12px;color:var(--navy);font-weight:700;padding:8px 12px;text-transform:uppercase;letter-spacing:.04em}
.nav-apply{
  background:var(--orange);color:#fff;
  padding:9px 22px;border-radius:var(--r4);
  font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  box-shadow:0 4px 14px rgba(245,124,46,0.3);
  transition:all .2s;
}
.nav-apply:hover{background:var(--orange-light);transform:translateY(-2px)}

/* Mobile menu toggle */
.nav-toggle{
  display:none;
  background:var(--navy);color:#fff;
  border:none;padding:8px 10px;border-radius:var(--r4);
  cursor:pointer;font-size:16px;
}

/* Mobile slide-out menu */
.mobile-menu{
  position:fixed;top:0;right:-320px;bottom:0;
  width:300px;z-index:1001;
  background:var(--navy);
  padding:80px 24px 32px;
  transition:right .3s ease;
  overflow-y:auto;
  box-shadow:-10px 0 40px rgba(0,0,0,0.3);
}
/* Reset wp_nav_menu ul/li defaults inside mobile menu */
.mobile-menu ul,
.mobile-menu .mobile-nav-menu,
.mobile-menu .sub-menu{
  list-style:none;margin:0;padding:0;
}
.mobile-menu li{
  list-style:none;margin:0;padding:0;
}
.mobile-menu.open{right:0}

/* ─── Main menu items (top level) ─── */
.mobile-menu .mobile-nav-menu > li > a{
  display:block;
  padding:14px 18px;
  color:#fff;font-size:13px;font-weight:700;
  border-radius:var(--r4);
  text-transform:uppercase;letter-spacing:.06em;
  transition:all .2s;
  margin-bottom:2px;
  text-decoration:none;
  border-left:3px solid transparent;
}
.mobile-menu .mobile-nav-menu > li > a:hover,
.mobile-menu .mobile-nav-menu > li.current-menu-item > a{
  background:rgba(255,255,255,.08);
  color:var(--orange-light);
  border-left-color:var(--orange);
}

/* ─── Parent item with sub-menu (visual cue) ─── */
.mobile-menu .mobile-nav-menu > li.menu-item-has-children > a::after{
  content:'';
  display:inline-block;
  width:6px;height:6px;
  border-right:2px solid var(--green-3);
  border-bottom:2px solid var(--green-3);
  transform:rotate(45deg);
  margin-left:8px;
  vertical-align:middle;
  margin-bottom:3px;
  transition:transform .25s ease;
}
/* Rotate chevron upward when sub-menu is open */
.mobile-menu .mobile-nav-menu > li.menu-item-has-children.is-open > a::after{
  transform:rotate(-135deg);
  margin-bottom:-1px;
}

/* ─── Sub-menu container — HIDDEN by default (accordion) ─── */
.mobile-menu .sub-menu{
  margin:0 0 0 12px;
  padding:0 0 0 14px;
  border-left:2px solid rgba(255,255,255,0.15);
  max-height:0;
  overflow:hidden;
  opacity:0;
  transition:max-height .35s ease, opacity .25s ease, padding .25s ease, margin .25s ease;
}
/* Sub-menu shows ONLY when parent has .is-open class */
.mobile-menu .mobile-nav-menu > li.menu-item-has-children.is-open > .sub-menu{
  max-height:600px;     /* large enough to fit all items */
  opacity:1;
  padding:6px 0 8px 14px;
  margin:4px 0 8px 12px;
}

/* ─── Sub-menu items (indented + softer) ─── */
.mobile-menu .sub-menu li a{
  display:block;
  padding:10px 16px;
  color:rgba(255,255,255,0.72);
  font-size:12px;
  font-weight:500;
  text-transform:none;
  letter-spacing:.02em;
  border-radius:var(--r4);
  transition:all .2s;
  text-decoration:none;
  position:relative;
}
.mobile-menu .sub-menu li a::before{
  content:'›';
  color:var(--green-3);
  margin-right:8px;
  font-weight:700;
}
.mobile-menu .sub-menu li a:hover,
.mobile-menu .sub-menu li.current-menu-item a{
  background:rgba(255,255,255,.06);
  color:var(--orange-light);
  padding-left:20px;
}

/* ─── Auth buttons (Log in / Apply Now) ─── */
.mobile-auth{
  display:flex;
  flex-direction:column;
  gap:12px;
  margin-top:28px;
  padding-top:24px;
  border-top:2px solid rgba(255,255,255,0.15);
}
.mobile-auth a{
  display:block;
  padding:14px 24px;
  border-radius:var(--r8);
  text-align:center;
  font-weight:700;
  font-size:13px;
  letter-spacing:.08em;
  text-transform:uppercase;
  text-decoration:none;
  transition:all .25s;
}
.mobile-login{
  background:rgba(255,255,255,0.08);
  color:#fff;
  border:2px solid rgba(255,255,255,0.25);
}
.mobile-login:hover{
  background:#fff;
  color:var(--navy);
  border-color:#fff;
}
.mobile-apply{
  background:var(--orange);
  color:#fff;
  box-shadow:0 6px 18px rgba(245,124,46,0.35);
  border:2px solid var(--orange);
}
.mobile-apply:hover{
  background:var(--orange-light);
  border-color:var(--orange-light);
  transform:translateY(-2px);
}
.mobile-group-title{
  padding:14px 18px 6px;
  color:var(--green-3);
  font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  border-top:1px solid rgba(255,255,255,.08);
  margin-top:6px;
}
.mobile-group:first-of-type .mobile-group-title{border-top:none}

/* ═══ Mobile menu CLOSE button (× in top-right) ═══ */
.mobile-close{
  position:absolute;
  top:18px;right:18px;
  width:42px;height:42px;
  border-radius:50%;
  background:rgba(255,255,255,0.08);
  border:2px solid rgba(255,255,255,0.18);
  cursor:pointer;
  padding:0;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all .25s ease;
  z-index:10;
}
.mobile-close:hover,
.mobile-close:focus{
  background:var(--orange);
  border-color:var(--orange);
  transform:rotate(90deg);
  outline:none;
}
.mobile-close-icon{
  position:relative;
  width:18px;height:18px;
  display:block;
}
.mobile-close-icon span{
  position:absolute;
  top:50%;left:0;
  width:100%;height:2px;
  background:#fff;
  border-radius:2px;
  transition:background .2s;
}
.mobile-close-icon span:nth-child(1){transform:translateY(-50%) rotate(45deg)}
.mobile-close-icon span:nth-child(2){transform:translateY(-50%) rotate(-45deg)}

/* ═══ Backdrop overlay (dim background behind open menu) ═══ */
.mobile-overlay{
  position:fixed;
  inset:0;
  z-index:1000;
  background:rgba(0,0,0,0.55);
  backdrop-filter:blur(2px);
  -webkit-backdrop-filter:blur(2px);
  opacity:0;
  visibility:hidden;
  transition:opacity .3s ease, visibility .3s ease;
  cursor:pointer;
}
.mobile-overlay.open{
  opacity:1;
  visibility:visible;
}

/* ═══ FOOTER (Green gradient matching banner) ═══ */
footer, .site-footer{
  background:linear-gradient(135deg,#3ed337 0%,#6ee81e 40%,#aaf50e 80%,#d9f812 100%);
  padding:0;color:var(--navy);
  position:relative;overflow:hidden;
}
footer::before, .site-footer::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:var(--navy);
}

.footer-main{padding:80px 80px 40px}
.footer-top{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1.3fr;
  gap:56px;margin-bottom:56px;
}

.footer-brand-top{
  display:inline-flex;align-items:center;gap:18px;margin-bottom:14px;
}
.footer-brand-emblem{
  width:92px;height:92px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;overflow:hidden;
}
.footer-brand-emblem img{width:100%;height:100%;object-fit:contain}
.footer-brand-emblem svg{width:100%;height:100%}
.footer-text-logo{
  height:74px;display:flex;align-items:center;
}
.footer-text-logo img{
  height:100%;width:auto;display:block;
}
.footer-brand-tag{
  font-size:16px;line-height:1.6;
  color:var(--navy);opacity:.85;
  margin-bottom:28px;max-width:380px;
  font-weight:500;
  text-align:left;
}

.footer-contact-list{
  display:flex;flex-direction:column;gap:14px;margin-bottom:28px;
}
.footer-contact-item{
  display:flex;align-items:center;gap:14px;
  font-size:16px;color:var(--navy);
  transition:color .2s;font-weight:500;
}
.footer-contact-item a{color:inherit;text-decoration:none;transition:color .2s}
.footer-contact-item a:hover{color:var(--orange);text-decoration:underline}
.footer-contact-icon{
  width:40px;height:40px;border-radius:var(--r8);
  background:var(--navy);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:16px;font-weight:700;
  flex-shrink:0;
}

.footer-social{display:flex;gap:12px}
.footer-social-link{
  width:46px;height:46px;border-radius:var(--r8);
  background:#fff;border:2px solid var(--navy);
  display:flex;align-items:center;justify-content:center;
  color:var(--navy);
  transition:all .25s;
}
.footer-social-link:hover{background:var(--navy);color:#fff;transform:translateY(-3px);box-shadow:0 8px 20px rgba(30,30,122,0.3)}
.footer-social-link svg{width:20px;height:20px}

.footer-col-title{
  font-size:14px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;
  color:var(--navy);margin-bottom:24px;
  display:flex;align-items:center;gap:12px;
}
.footer-col-title::after{
  content:'';flex:1;height:2px;background:rgba(30,30,122,0.25);
}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:14px}
.footer-links a{
  font-size:16px;color:var(--navy);font-weight:500;
  transition:all .2s;
  display:inline-flex;align-items:center;gap:8px;
  text-decoration:none;
}
.footer-links a::before{
  content:'→';color:var(--orange);font-weight:700;
  opacity:0;transform:translateX(-6px);
  transition:all .2s;
}
.footer-links a:hover{color:var(--orange)}
.footer-links a:hover::before{opacity:1;transform:translateX(0)}

.footer-newsletter{
  background:rgba(30,30,122,0.08);
  border:2px solid rgba(30,30,122,0.15);
  border-radius:var(--r12);
  padding:24px;
  margin-top:10px;
}
.footer-newsletter-title{
  font-size:17px;font-weight:800;
  color:var(--navy);margin-bottom:8px;
}
.footer-newsletter-sub{
  font-size:14px;color:var(--navy);opacity:.75;
  margin-bottom:16px;line-height:1.6;font-weight:500;
}
.footer-newsletter-form{
  display:flex;gap:8px;flex-wrap:wrap;
}
.footer-newsletter-input{
  flex:1;min-width:0;
  background:#fff;
  border:2px solid rgba(30,30,122,0.2);
  border-radius:var(--r4);
  padding:12px 16px;
  font-family:var(--sans);font-size:14px;color:var(--navy);
  outline:none;transition:border-color .2s;
  min-width:140px;font-weight:500;
}
.footer-newsletter-input:focus{border-color:var(--navy)}
.footer-newsletter-input::placeholder{color:rgba(30,30,122,.4)}
.footer-newsletter-btn{
  background:var(--navy);color:#fff;
  border:none;padding:12px 24px;border-radius:var(--r4);
  font-size:14px;font-weight:700;cursor:pointer;
  transition:all .2s;
  white-space:nowrap;letter-spacing:.04em;
}
.footer-newsletter-btn:hover{background:var(--orange);transform:translateY(-1px)}

.footer-bottom{
  border-top:2px solid rgba(30,30,122,0.15);
  padding:26px 80px;
  display:flex;justify-content:space-between;align-items:center;
  font-size:15px;flex-wrap:wrap;gap:16px;
  background:rgba(30,30,122,0.05);
}
.footer-bottom-left{color:var(--navy);font-weight:500}
.footer-bottom-left strong{color:var(--navy);font-weight:800}
.footer-bottom-right{display:flex;gap:28px;flex-wrap:wrap}
.footer-bottom-right a{color:var(--navy);font-size:14px;font-weight:500;transition:color .2s;text-decoration:none}
.footer-bottom-right a:hover{color:var(--orange);text-decoration:underline}

/* ═══ RESPONSIVE ═══ */
@media(max-width:1024px){
  .hero-inner{padding:60px 40px 80px}
  .rv-content{grid-template-columns:1fr;gap:40px}
  .foundations-grid{grid-template-columns:1fr 1fr}
  .curr-panel.active{grid-template-columns:1fr 1fr}
  .prog-cards{grid-template-columns:1fr 1fr}
  .islamic{grid-template-columns:1fr;gap:40px}
  .islamic-img{height:450px}
  .registration{grid-template-columns:1fr;gap:40px}
  .message-content{grid-template-columns:1fr;gap:32px}
}
@media(max-width:1100px){
  .nav-menu{display:none}
  .nav-toggle{display:flex}
  nav{padding:0 24px}
  .top-header{padding:0 24px}
  .pillar-nav{gap:6px}
  .pillar-nav .navbtn{padding:8px 16px;font-size:12px}
}
@media(max-width:768px){
  .site-header{position:sticky;top:0;z-index:998;background:#fff;box-shadow:0 4px 16px rgba(30,30,122,0.12)}
  .top-header{padding:14px 16px;min-height:80px;flex-wrap:wrap;gap:10px}
  .pillar-nav{display:none}
  .top-hamburger{display:flex}
  .brand{gap:14px}
  .brand-logo{width:70px;height:70px}
  .brand-text img{height:54px}
  .yellow-strip{height:5px}
  nav{display:none}
  .nav-login{display:none}
  .nav-apply{padding:8px 16px;font-size:11px}
  .hero{min-height:auto}
  .hero-inner{padding:60px 24px 70px;min-height:auto}
  /* Vertical overlay on mobile - top transparent, bottom dark for text */
  .hero-bg-slide::after{
    background:linear-gradient(180deg,
      rgba(30,30,122,0.55) 0%,
      rgba(30,30,122,0.65) 40%,
      rgba(30,30,122,0.85) 75%,
      rgba(30,30,122,0.95) 100%
    );
  }
  .hero-bg-slide img{
    object-position:center 20%;
  }
  .hero-slides{padding:18px 20px}
  .hero-slide{left:20px;right:20px;top:18px;bottom:18px}
  .rationale-video,.curriculum,.programmes,.islamic,.message-section,.registration,.cta{padding:60px 24px}
  .curr-panel.active,.prog-cards{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr;gap:36px}
  .footer-main{padding:50px 24px 28px}
  .footer-bottom{padding:20px 24px;flex-direction:column;text-align:center}
  .footer-brand-top{margin:0 auto 18px;justify-content:center}
  .footer-brand-emblem{width:72px;height:72px}
  .footer-text-logo{height:58px}
  .footer-brand-tag{max-width:100%}
  .footer-newsletter{padding:18px}
  .footer-newsletter-form{flex-direction:column;gap:10px}
  .footer-newsletter-input{width:100%}
  .footer-newsletter-btn{width:100%;padding:13px}
  .reg-right{padding:28px}
  .form-grid{grid-template-columns:1fr}
  .form-full{grid-column:span 1}
  .curr-header{grid-template-columns:1fr}
  .message-content{grid-template-columns:1fr;gap:32px}
  .message-image{height:320px;order:-1}
  .cta-social-grid{grid-template-columns:1fr 1fr;gap:12px;max-width:100%}
  .cta-social-btn{padding:14px 16px;gap:10px}
  .cta-social-btn svg{width:22px;height:22px}
  .cta-social-name{font-size:13px}
  .cta-social-desc{font-size:11px}
  .cta-social-title{margin:32px 0 18px}
}

/* ═══ ANIMATIONS ═══ */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInLeft{from{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}
@keyframes fadeInRight{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(0.92)}to{opacity:1;transform:scale(1)}}
.hero-left>*{animation:fadeUp .8s cubic-bezier(0.34, 1.56, 0.64, 1) both}
.hero-badge{animation-delay:.1s}
.hero-arabic{animation-delay:.2s}
.hero-title{animation-delay:.3s}
.hero-sub{animation-delay:.42s}
.hero-slides{animation-delay:.55s}
.hero-btns{animation-delay:.68s}

/* Scroll Reveal */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(0.4, 0, 0.2, 1),transform .8s cubic-bezier(0.4, 0, 0.2, 1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity .8s cubic-bezier(0.4, 0, 0.2, 1),transform .8s cubic-bezier(0.4, 0, 0.2, 1)}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(40px);transition:opacity .8s cubic-bezier(0.4, 0, 0.2, 1),transform .8s cubic-bezier(0.4, 0, 0.2, 1)}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(0.92);transition:opacity .8s cubic-bezier(0.34, 1.56, 0.64, 1),transform .8s cubic-bezier(0.34, 1.56, 0.64, 1)}
.reveal-scale.visible{opacity:1;transform:scale(1)}

/* Stagger children */
.stagger-children > *{opacity:0;transform:translateY(20px);transition:all .6s cubic-bezier(0.4, 0, 0.2, 1)}
.stagger-children.visible > *{opacity:1;transform:translateY(0)}
.stagger-children.visible > *:nth-child(1){transition-delay:.05s}
.stagger-children.visible > *:nth-child(2){transition-delay:.15s}
.stagger-children.visible > *:nth-child(3){transition-delay:.25s}
.stagger-children.visible > *:nth-child(4){transition-delay:.35s}
.stagger-children.visible > *:nth-child(5){transition-delay:.45s}
.stagger-children.visible > *:nth-child(6){transition-delay:.55s}

/* Slide indicators */
.hero-indicators{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  display:flex;gap:8px;z-index:5;
}
.hero-indicator{
  width:32px;height:4px;border-radius:2px;
  background:rgba(255,255,255,0.3);cursor:pointer;
  transition:all .3s;border:none;padding:0;
}
.hero-indicator.active{background:var(--orange);width:48px}
.hero-indicator:hover{background:rgba(255,255,255,0.6)}
@media(max-width:768px){
  .hero-indicators{bottom:16px}
  .hero-indicator{width:24px;height:3px}
  .hero-indicator.active{width:36px}
}

/* WHATSAPP FLOATING BUTTON */
.whatsapp-float{
  position:fixed;bottom:24px;right:24px;
  width:62px;height:62px;border-radius:50%;
  background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 28px rgba(37,211,102,0.45),0 4px 12px rgba(0,0,0,0.15);
  z-index:998;text-decoration:none;
  transition:all .3s cubic-bezier(0.34, 1.56, 0.64, 1);
  animation:whatsappPulse 2.5s infinite;
}
.whatsapp-float::before{
  content:'';position:absolute;inset:-6px;
  border-radius:50%;background:rgba(37,211,102,0.4);
  z-index:-1;animation:whatsappRing 2s infinite;
}
@keyframes whatsappPulse{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.06)}
}
@keyframes whatsappRing{
  0%{transform:scale(1);opacity:.6}
  100%{transform:scale(1.5);opacity:0}
}
.whatsapp-float:hover{transform:scale(1.12) rotate(8deg);background:#1eb858}
.whatsapp-float svg{width:32px;height:32px}
.whatsapp-tooltip{
  position:absolute;right:74px;top:50%;transform:translateY(-50%);
  background:var(--navy);color:#fff;
  padding:9px 16px;border-radius:8px;
  font-size:13px;font-weight:600;white-space:nowrap;
  opacity:0;visibility:hidden;
  transition:all .25s;pointer-events:none;
  letter-spacing:.02em;
  box-shadow:0 6px 20px rgba(30,30,122,0.25);
}
.whatsapp-tooltip::after{
  content:'';position:absolute;left:100%;top:50%;transform:translateY(-50%);
  border-left:7px solid var(--navy);
  border-top:6px solid transparent;border-bottom:6px solid transparent;
}
.whatsapp-float:hover .whatsapp-tooltip{opacity:1;visibility:visible;right:80px}
@media(max-width:768px){
  .whatsapp-float{width:54px;height:54px;bottom:18px;right:18px}
  .whatsapp-float svg{width:28px;height:28px}
  .whatsapp-tooltip{display:none}
}


/* ═══ MOBILE TYPOGRAPHY FIX (≤480px) — accessibility-friendly label sizes ═══ */
@media(max-width:480px){
  /* Tiny badges/labels - bump from 10-10.5px to 11-12px for legibility */
  .values-ayah-label,
  .grade-card-badge,
  .team-card-role-badge,
  .download-badge,
  .photo-card-category,
  .contact-card-badge,
  .section-label,
  .video-item-cat,
  .video-main-category{
    font-size:11.5px !important;
    letter-spacing:.1em !important;
  }
  /* Body text minimum 14px on phones for comfortable reading */
  p, li, .info-desc, .about-card-text, .team-card-bio, 
  .grade-card-desc, .pillar-card-text, .why-card-text,
  .vmc-card-text, .principle-text, .faculty-desc{
    font-size:14px !important;
  }
  /* Buttons & form inputs: prevent iOS zoom-on-focus by ensuring 16px+ */
  input, textarea, select{
    font-size:16px !important;
  }
}


/* ═══════════════════════════════════════════════════════
   WORDPRESS MENU COMPATIBILITY PATCH (v1.6.1)
   wp_nav_menu() outputs .menu-item-has-children + .sub-menu
   instead of HTML's .nav-has-dropdown + .nav-dropdown.
   Map all WP classes to same visual styles.
   ═══════════════════════════════════════════════════════ */

/* Add dropdown caret arrow on parent menu items with children */
.nav-menu > li.menu-item-has-children > a::after,
.nav-menu > li.page_item_has_children > a::after {
  content: '';
  display: inline-block;
  width: 0; height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid currentColor;
  margin-left: 8px;
  transition: transform .2s;
  vertical-align: middle;
}
.nav-menu > li.menu-item-has-children:hover > a::after,
.nav-menu > li.page_item_has_children:hover > a::after {
  transform: rotate(180deg);
}

/* Sub-menu (WordPress-generated dropdown) — match .nav-dropdown styling */
.nav-menu .sub-menu,
.nav-menu .children {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  min-width: 220px;
  background: #fff;
  border-radius: var(--r8);
  box-shadow: 0 10px 30px rgba(30,30,122,0.15);
  padding: 8px;
  list-style: none;
  margin: 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: all .25s;
  border: 1px solid var(--line);
  z-index: 1000;
}

/* Show on hover (parent <li>) */
.nav-menu > li.menu-item-has-children:hover > .sub-menu,
.nav-menu > li.page_item_has_children:hover > .children,
.nav-menu > li:hover > .sub-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

/* Bridge gap between parent and sub-menu (so hover doesn't drop) */
.nav-menu > li.menu-item-has-children::before,
.nav-menu > li.page_item_has_children::before {
  content: '';
  position: absolute;
  top: 100%;
  left: 0; right: 0;
  height: 8px;
}

/* Sub-menu items */
.nav-menu .sub-menu li,
.nav-menu .children li {
  list-style: none;
  position: relative;
}
.nav-menu .sub-menu a,
.nav-menu .children a {
  display: block;
  padding: 10px 14px;
  font-size: 13px;
  font-weight: 600;
  color: var(--navy);
  border-radius: var(--r4);
  transition: all .2s;
  text-transform: none;
  letter-spacing: normal;
  white-space: nowrap;
}
.nav-menu .sub-menu a:hover,
.nav-menu .children a:hover,
.nav-menu .sub-menu li.current-menu-item > a {
  background: var(--cream);
  color: var(--orange);
  padding-left: 18px;
}

/* Hide sub-menu items when not parent hovered (prevent flat rendering) */
.nav-menu .sub-menu li > a,
.nav-menu .children li > a {
  display: block;
}

/* ═══ HERO BUTTONS — defensive bottom spacing for slide indicators ═══ */
/* Indicators are absolute-positioned at bottom:24px of the .hero section.
   Hero-inner needs ≥ 90px padding-bottom so buttons clear the dots. */
.hero-inner {
  padding-bottom: 100px !important;
}
@media (max-width: 1024px) {
  .hero-inner {
    padding-bottom: 90px !important;
  }
}
@media (max-width: 768px) {
  .hero-inner {
    padding-bottom: 80px !important;
  }
}

/* Ensure .site-nav inherits all `nav` styles + admin bar offset */
.site-nav {
  position: sticky;
  top: 0;
  z-index: 999;
  height: 64px;
  padding: 0 60px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: #fff;
  border-bottom: 1px solid var(--line);
  box-shadow: 0 4px 16px rgba(30,30,122,0.08);
}
body.admin-bar .site-nav {
  top: 32px;
}
@media (max-width: 782px) {
  body.admin-bar .site-nav {
    top: 46px;
  }
}
@media (max-width: 1100px) {
  .site-nav { padding: 0 24px; }
}
@media (max-width: 768px) {
  .site-nav { display: none; }  /* hidden on mobile, hamburger instead */
}
