/* ===== CSS VARIABLES ===== */
:root {
  --primary: hsl(224, 76%, 33%);
  --primary-light: hsl(224, 76%, 48%);
  --primary-fg: hsl(0, 0%, 100%);
  --secondary: hsl(45, 97%, 54%);
  --secondary-fg: hsl(222, 47%, 11%);
  --accent: hsl(0, 84%, 60%);
  --accent-fg: hsl(0, 0%, 100%);
  --background: hsl(220, 30%, 98%);
  --foreground: hsl(222, 47%, 11%);
  --card: hsl(0, 0%, 100%);
  --muted: hsl(220, 20%, 94%);
  --muted-fg: hsl(220, 15%, 25%);
  --border: hsl(220, 20%, 90%);
  --navy: hsl(222, 47%, 11%);
  --radius: 0.75rem;
  --shadow-sm: 0 4px 20px -4px rgba(30,58,138,0.08);
  --shadow-md: 0 8px 32px rgba(30,58,138,0.10);
  --shadow-lg: 0 20px 48px rgba(30,58,138,0.14);
}

/* ===== RESET & BASE ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Inter', sans-serif;
  background: var(--background);
  color: var(--foreground);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
h1,h2,h3,h4,h5,h6 { font-family: 'Sora', sans-serif; }
p { text-wrap: pretty; }
img { max-width: 100%; display: block; }
a { text-decoration: none; color: inherit; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
ul { list-style: none; }

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--background); }
::-webkit-scrollbar-thumb { background: hsl(224,76%,33%,0.3); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: hsl(224,76%,33%,0.5); }

/* ===== UTILITIES ===== */
.section-container { max-width: 1280px; margin: 0 auto; padding: 0 1rem; }
@media(min-width:640px){ .section-container { padding: 0 1.5rem; } }
@media(min-width:1024px){ .section-container { padding: 0 2rem; } }

.text-primary { color: var(--primary); }
.text-secondary { color: var(--secondary); }
.text-accent { color: var(--accent); }
.bg-primary { background: var(--primary); }
.bg-secondary { background: var(--secondary); }
.bg-accent { background: var(--accent); }
.flex-1 { flex: 1; }

/* ===== SECTION HEADER ===== */
.section-header { text-align: center; margin-bottom: 3.5rem; }
.section-label {
  display: inline-block;
  color: var(--primary);
  font-weight: 600;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 0.75rem;
}
.section-title {
  font-family: 'Sora', sans-serif;
  font-size: clamp(1.75rem, 4vw, 3rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.12;
  color: var(--foreground);
  margin-top: 0.5rem;
}
.section-desc {
  color: var(--muted-fg);
  font-size: 1.125rem;
  max-width: 42rem;
  margin: 1rem auto 0;
  line-height: 1.7;
}

/* ===== CARDS ===== */
.card-glass {
  border-radius: 1rem;
  overflow: hidden;
  transition: all 0.5s ease;
  border: 1px solid rgba(255,255,255,0.3);
  background: rgba(255,255,255,0.7);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: var(--shadow-md);
}
.card-glass:hover {
  background: rgba(255,255,255,0.85);
  box-shadow: var(--shadow-lg);
  transform: translateY(-6px);
}
.card-3d {
  border-radius: 1rem;
  overflow: hidden;
  transition: all 0.5s ease;
  background: var(--card);
  box-shadow: var(--shadow-sm);
  transform-style: preserve-3d;
  perspective: 1000px;
  position: relative;
}
.card-3d:hover { background: var(--primary); color: var(--primary-fg); }

/* ===== BUTTONS ===== */
.btn-primary-hero {
  display: inline-flex; align-items: center; gap: 0.5rem;
  background: var(--primary); color: var(--primary-fg);
  padding: 1rem 2rem; border-radius: 1rem;
  font-family: 'Sora', sans-serif; font-weight: 700; font-size: 1rem;
  transition: all 0.3s ease;
  box-shadow: 0 4px 20px -4px hsl(224,76%,33%,0.45);
  position: relative; overflow: hidden;
}
.btn-primary-hero:hover { transform: translateY(-4px); box-shadow: 0 8px 30px -4px hsl(224,76%,33%,0.55); }
.btn-primary-hero:active { transform: scale(0.97); }
.btn-sm { padding: 0.625rem 1.25rem; font-size: 0.875rem; border-radius: 0.75rem; }
.btn-secondary-hero {
  display: inline-flex; align-items: center; gap: 0.5rem;
  background: var(--secondary); color: var(--secondary-fg);
  padding: 1rem 2rem; border-radius: 1rem;
  font-family: 'Sora', sans-serif; font-weight: 700; font-size: 1rem;
  transition: all 0.3s ease;
  box-shadow: 0 4px 20px -4px hsl(45,97%,54%,0.4);
}
.btn-secondary-hero:hover { transform: translateY(-4px); }
.btn-outline-hero {
  display: inline-flex; align-items: center; gap: 0.5rem;
  border: 2px solid rgba(255,255,255,0.3); color: #fff;
  padding: 1rem 2rem; border-radius: 1rem;
  font-family: 'Sora', sans-serif; font-weight: 700; font-size: 1rem;
  transition: all 0.3s ease;
}
.btn-outline-hero:hover { transform: translateY(-4px); background: rgba(255,255,255,0.1); }
.btn-whatsapp {
  display: inline-flex; align-items: center; gap: 0.5rem;
  background: #25D366; color: #fff;
  padding: 0.75rem 1.5rem; border-radius: 1rem;
  font-family: 'Sora', sans-serif; font-weight: 700; font-size: 0.875rem;
  transition: all 0.3s ease;
}
.btn-whatsapp:hover { transform: translateY(-4px); }
.justify-center { justify-content: center; }

/* Shine */
.btn-shine { position: relative; overflow: hidden; }
.btn-shine::after {
  content: ''; position: absolute; top: 0; left: -100%;
  width: 50%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
  animation: shine 4s infinite;
}
@keyframes shine { 0%{left:-100%} 50%,100%{left:100%} }

/* Ripple */
.btn-ripple { position: relative; overflow: hidden; }
.btn-ripple::after {
  content: ''; position: absolute; width: 100%; height: 100%; top: 0; left: 0;
  background: radial-gradient(circle, rgba(255,255,255,0.3) 10%, transparent 10%);
  transform: scale(10); opacity: 0;
  transition: transform 0.5s, opacity 0.3s;
}
.btn-ripple:active::after { transform: scale(0); opacity: 1; transition: 0s; }

/* ===== BADGES ===== */
.admission-badge {
  display: inline-flex; align-items: center; gap: 0.375rem;
  padding: 0.375rem 1rem; font-size: 0.75rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.1em; border-radius: 9999px;
  background: rgba(239,68,68,0.12); color: var(--accent);
  border: 1px solid rgba(239,68,68,0.2);
}
.bg-accent-soft { background: rgba(239,68,68,0.15); color: var(--accent-fg); border-color: rgba(239,68,68,0.3); }

/* ===== ANIMATIONS ===== */
@keyframes blink-red-white {
  0%,100% { background: rgba(239,68,68,0.25); color: #fff; border-color: #EF4444; }
  50%      { background: #EF4444;              color: #fff; border-color: #EF4444; }
}
.blink-red-white { animation: blink-red-white 1s ease-in-out infinite; border: 2px solid #EF4444; }

@keyframes blink-badge {
  0%,100% { background: var(--primary); color: #fff; }
  50% { background: var(--secondary); color: var(--secondary-fg); }
}
.blink-badge { animation: blink-badge 1.5s ease-in-out infinite; }

@keyframes blink-purple-blue { 0%,100%{opacity:1} 50%{opacity:0.3} }
.blink-purple-blue { animation: blink-purple-blue 1.2s ease-in-out infinite; }

/* Purple blink: bg purple + white text ↔ bg white + purple text */
@keyframes blink-purple {
  0%,100% {
    background: #7c3aed;
    color: #ffffff;
    -webkit-text-fill-color: #ffffff;
    padding: 0.15em 0.4em;
    border-radius: 0.3em;
  }
  50% {
    background: #ffffff;
    color: #7c3aed;
    -webkit-text-fill-color: #7c3aed;
    padding: 0.15em 0.4em;
    border-radius: 0.3em;
  }
}
.blink-purple {
  display: inline-block;
  animation: blink-purple 1s ease-in-out infinite;
  padding: 0.15em 0.4em;
  border-radius: 0.3em;
  background: #7c3aed;
  color: #ffffff;
  -webkit-text-fill-color: #ffffff;
}

@keyframes float {
  0%,100% { transform: translateY(0) rotate(0deg); }
  50% { transform: translateY(-12px) rotate(3deg); }
}
@keyframes glow-pulse {
  0%,100% { box-shadow: 0 0 20px hsl(224,76%,33%,0.3); }
  50% { box-shadow: 0 0 40px hsl(224,76%,33%,0.6); }
}
.animate-glow { animation: glow-pulse 3s ease-in-out infinite; }

@keyframes pillar-highlight {
  0%,100% { box-shadow: 0 0 0 0 transparent; transform: scale(1); }
  50% { box-shadow: 0 0 25px 5px hsl(224,76%,33%,0.3); transform: scale(1.05); }
}
.pillar-pulse { animation: pillar-highlight 4s ease-in-out infinite; }

@keyframes moveLight { 0%{left:-25%} 100%{left:100%} }

/* Reveal animations */
.reveal, .reveal-left, .reveal-right {
  opacity: 0; transform: translateY(30px);
  transition: opacity 0.7s cubic-bezier(0.23,1,0.32,1), transform 0.7s cubic-bezier(0.23,1,0.32,1);
}
.reveal-left { transform: translateX(-60px); }
.reveal-right { transform: translateX(60px); }
.revealed { opacity: 1 !important; transform: none !important; }

/* Hero animate-in */
.animate-in {
  opacity: 0; transform: translateY(40px);
  animation: fadeInUp 0.8s cubic-bezier(0.23,1,0.32,1) forwards;
}
@keyframes fadeInUp { to { opacity:1; transform:translateY(0); } }

/* ===== NAVBAR ===== */
.navbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  background: rgba(255,255,255,0.97);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 2px 12px rgba(0,0,0,0.10);
  transition: box-shadow 0.3s ease;
}
.navbar.scrolled {
  box-shadow: 0 4px 24px rgba(0,0,0,0.14);
  border-bottom: 1px solid #e5e7eb;
}
.navbar-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 0.3rem;
  padding-bottom: 0.3rem;
  min-height: 3.25rem;
}
@media(min-width:480px) { .navbar-inner { min-height: 3.5rem; } }
@media(min-width:768px) { .navbar-inner { min-height: 3.75rem; padding-top: 0.35rem; padding-bottom: 0.35rem; } }

/* =====================================================
   SCHOOL BRAND — PIXEL-PERFECT LOCK
   Reference image measurements:
   • Logo circle  : full height of text block
   • ABHYASA      : ~48% of block height, bold serif, navy-blue gradient
   • Divider      : 2px solid #8B1A1A, full text-block width, 4px gap above/below
   • INNOV SCHOOL : ~35% of block height, bold serif, solid red #C0392B
   • Tagline      : ~17% of block height, normal, dark grey #333
   • Alignment    : LEFT-ALIGNED text block, vertically centered with logo
   • Logo gap     : 14px from text block
   ===================================================== */

.navbar-brand {
  display: flex;
  align-items: center;
  gap: 14px;               /* exact gap: logo → text */
  text-decoration: none;
  flex-shrink: 0;
}
.navbar-brand:hover .navbar-logo { transform: scale(1.03); }

/* ── Logo: circular, gold ring, no distortion ── */
.navbar-logo {
  height: 2.6rem;
  width:  2.6rem;
  border-radius: 50%;
  object-fit: cover;
  object-position: center;
  flex-shrink: 0;
  transition: transform 0.3s ease;
  background: #fff;
  border: 2.5px solid #C8A84B;
  box-shadow: 0 0 0 1px #9A7020;
}
@media(min-width:480px) { .navbar-logo { height: 2.9rem; width: 2.9rem; } }
@media(min-width:768px) { .navbar-logo { height: 3.2rem; width: 3.2rem; } }

/* ── Text block: width anchored to INNOVATIVE SCHOOL (wider text) ── */
.navbar-title {
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  align-items: stretch;
  gap: 0;
  line-height: 1;
  width: fit-content;
  overflow: visible;
}

/* ── LINE 1: ABHYASA ──
   scaleX() applied by JS to match INNOVATIVE SCHOOL width      */
.navbar-name {
  font-family: 'Georgia', 'Times New Roman', Times, serif;
  font-weight: 700;
  font-size: clamp(0.85rem, 1.7vw, 1.3rem);
  line-height: 1;
  letter-spacing: 0.05em;
  white-space: nowrap;
  display: block;
  width: fit-content;
  margin-bottom: 2px;
  transform-origin: left center;
  background: linear-gradient(180deg, #2E4DA0 0%, #1E3A8A 50%, #1A237E 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── DIVIDER LINE ──
   width:100% of container = INNOVATIVE SCHOOL width exactly      */
.navbar-divider {
  display: block;
  width: 100%;
  height: 2px;
  background: #8B1A1A;
  border: none;
  margin: 0 0 3px 0;
  padding: 0;
  flex-shrink: 0;
}

/* ── LINE 2: INNOVATIVE SCHOOL ──
   scaleX() applied by JS if narrower than anchor width         */
.navbar-sub {
  font-family: 'Georgia', 'Times New Roman', Times, serif;
  font-weight: 700;
  font-size: clamp(0.72rem, 1.5vw, 1.15rem);
  color: #C0392B;
  line-height: 1;
  letter-spacing: 0.04em;
  white-space: nowrap;
  display: block;
  text-transform: uppercase;
  margin-bottom: 4px;
  width: fit-content;
  transform-origin: left center;
}

/* ── LINE 3: Tagline ── */
.navbar-tagline {
  font-family: 'Inter', Arial, Helvetica, sans-serif;
  font-weight: 700;
  font-size: clamp(0.42rem, 0.75vw, 0.6rem);
  color: #000000;
  line-height: 1.2;
  letter-spacing: 0.01em;
  white-space: nowrap;
  display: none;
  margin: 0;
  width: 100%;
}
@media(min-width:480px) { .navbar-tagline { display: block; } }
.navbar-links { display:none; align-items:center; gap:1.75rem; }
@media(min-width:1024px){ .navbar-links { display:flex; } }
.nav-link {
  font-size:0.875rem; font-weight:500; color:#1a1a2e;
  transition:color 0.3s; position:relative;
}
.nav-link::after {
  content:''; position:absolute; bottom:-4px; left:0; width:0; height:2px;
  background:var(--secondary); border-radius:9999px; transition:width 0.3s;
}
.nav-link:hover { color:var(--primary); }
.nav-link:hover::after { width:100%; }
.navbar-toggle { display:flex; flex-direction:column; gap:5px; padding:0.5rem; }
@media(min-width:1024px){ .navbar-toggle { display:none; } }
.hamburger-line { width:24px; height:2px; background:var(--foreground); border-radius:2px; transition:all 0.3s; }
.navbar-toggle.open .hamburger-line:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.navbar-toggle.open .hamburger-line:nth-child(2) { opacity:0; }
.navbar-toggle.open .hamburger-line:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }
.mobile-menu {
  display:none; background:rgba(255,255,255,0.98);
  backdrop-filter:blur(24px); border-top:1px solid var(--border);
  overflow:hidden; transition:all 0.3s ease;
}
.mobile-menu.open { display:block; }
.mobile-menu-inner { padding:1rem 0; display:flex; flex-direction:column; gap:0.5rem; }
.mobile-nav-link { padding:0.625rem 0; font-size:1rem; font-weight:500; color:#1a1a2e; transition:color 0.3s; }
.mobile-nav-link:hover { color:var(--primary); }

/* ===== HERO ===== */
.hero-section {
  position:relative; min-height:100vh; min-height:100svh; display:flex; align-items:center; overflow:hidden; overflow-x:hidden;
}
.hero-slides { position:absolute; inset:0; width:100%; height:120%; top:-10%; }
.hero-slide { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:0; transition:opacity 1.5s ease; }
.hero-slide.active { opacity:1; }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(to bottom, rgba(34,47,11,0.7), rgba(34,47,11,0.5), rgba(34,47,11,0.8)); }
.hero-overlay-side { position:absolute; inset:0; background:linear-gradient(to right, hsl(224,76%,33%,0.3), transparent); }
.hero-wave { position:absolute; bottom:0; left:0; right:0; height:8rem; }
.hero-wave svg { width:100%; height:100%; }
.floating-icon {
  position:absolute; display:none; animation:float 6s ease-in-out infinite;
}
@media(min-width:768px){ .floating-icon { display:block; } }
.floating-icon > div {
  padding:0.75rem; border-radius:1rem;
  background:rgba(255,255,255,0.1); backdrop-filter:blur(4px);
  border:1px solid rgba(255,255,255,0.2); color:rgba(255,255,255,0.6);
}
.hero-content { position:relative; z-index:10; padding:8rem 0 10rem; }
@media(min-width:768px){ .hero-content { padding:10rem 0 12rem; } }
.hero-text {
  max-width: 52rem;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;       /* center-align all children */
  text-align: center;
  gap: 0.5rem;
}

/* 1. Admission badge — red border, light bg, blink */
.admission-badge {
  display: inline-flex; align-items: center; gap: 0.375rem;
  padding: 0.45rem 1.25rem;
  font-size: 0.8rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: 0.12em;
  border-radius: 9999px;
  background: rgba(255,255,255,0.12);
  color: #fff;
  border: 2px solid #EF4444;
  margin-bottom: 0.75rem;
}

/* 2. Grades line — responsive, one line tablet+, wraps cleanly on mobile */
.hero-grades {
  font-family: 'Sora', sans-serif;
  font-weight: 600;
  font-size: clamp(0.78rem, 3.8vw, 1.35rem);
  color: #ffffff;
  letter-spacing: -0.01em;
  line-height: 1.35;
  margin-bottom: 1rem;
  text-shadow: 0 2px 12px rgba(0,0,0,0.5);
  white-space: normal;        /* allow wrap on very small screens */
  word-break: keep-all;       /* break at spaces only, not mid-word */
  max-width: 100%;
}
@media(min-width: 480px) {
  .hero-grades {
    white-space: nowrap;      /* one line from 480px up */
    font-size: clamp(0.85rem, 2.8vw, 1.35rem);
  }
}

/* 3. "Expanding Excellence:" — large, purple blink */
.hero-excellence {
  font-family: 'Sora', sans-serif;
  font-weight: 800;
  font-size: clamp(2rem, 5.5vw, 4rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: #ffffff;
  margin-bottom: 0.5rem;
}

/* 4. "From Banjara Hills to Badangpet" — white, slightly smaller */
.hero-location {
  font-family: 'Sora', sans-serif;
  font-weight: 700;
  font-size: clamp(1.1rem, 2.8vw, 1.9rem);
  color: #ffffff;
  letter-spacing: 0.01em;
  line-height: 1.2;
  margin-bottom: 1.5rem;
  text-shadow: 0 2px 16px rgba(0,0,0,0.5);
}

.hero-feature-badges { display:flex; flex-wrap:wrap; gap:0.75rem; margin-bottom:1.5rem; justify-content:center; }
.feature-badge {
  display: flex; align-items: center; gap: 0.375rem;
  backdrop-filter: blur(4px); padding: 0.375rem 0.875rem; border-radius: 9999px;
  font-size: 0.875rem; font-weight: 600; color: #ffffff;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.25);
}
.hero-ctas { display:flex; flex-wrap:wrap; gap:1rem; justify-content:center; }

/* ===== HERO OFFER BANNER ===== */
.hero-offer-banner {
  width: 100%;
  margin-bottom: 1.25rem;
}
.hero-offer-inner {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
  background: linear-gradient(135deg, rgba(124,58,237,0.92), rgba(79,70,229,0.92));
  border: 1.5px solid rgba(255,255,255,0.3);
  border-radius: 1rem;
  padding: 0.875rem 1.5rem 1rem;
  backdrop-filter: blur(8px);
  box-shadow: 0 8px 32px rgba(124,58,237,0.4), 0 0 0 1px rgba(255,255,255,0.1);
  text-align: center;
  position: relative;
  overflow: hidden;
}
/* shimmer sweep */
.hero-offer-inner::before {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 60%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.12), transparent);
  animation: shine 3s ease-in-out infinite;
}
.hero-offer-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  background: rgba(255,255,255,0.18);
  border: 1px solid rgba(255,255,255,0.35);
  border-radius: 9999px;
  padding: 0.2rem 0.875rem;
  font-family: 'Sora', sans-serif;
  font-weight: 800;
  font-size: clamp(0.65rem, 1.2vw, 0.8rem);
  color: #fff;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.hero-offer-text {
  font-family: 'Sora', sans-serif;
  font-weight: 600;
  font-size: clamp(0.85rem, 1.8vw, 1.05rem);
  color: #fff;
  line-height: 1.3;
  margin: 0;
}
.hero-offer-text strong {
  color: #FDE68A;
  font-weight: 800;
}
.hero-offer-sub {
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  font-size: clamp(0.72rem, 1.3vw, 0.85rem);
  color: rgba(255,255,255,0.9);
  margin: 0;
  letter-spacing: 0.01em;
}
.hero-offer-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  margin-top: 0.25rem;
  background: #fff;
  color: #7c3aed;
  font-family: 'Sora', sans-serif;
  font-weight: 800;
  font-size: clamp(0.8rem, 1.4vw, 0.95rem);
  padding: 0.5rem 1.5rem;
  border-radius: 9999px;
  transition: all 0.3s ease;
  box-shadow: 0 4px 16px rgba(0,0,0,0.2);
  letter-spacing: 0.02em;
}
.hero-offer-btn:hover {
  background: #FDE68A;
  color: #5b21b6;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.25);
}
.hero-indicators { position:absolute; bottom:2.5rem; left:50%; transform:translateX(-50%); z-index:10; display:flex; gap:0.5rem; }
.hero-dot { height:0.5rem; border-radius:9999px; background:rgba(255,255,255,0.4); width:0.5rem; transition:all 0.5s; }
.hero-dot.active { background:var(--secondary); width:2.5rem; }

/* ===== TRUST STATS ===== */
.trust-stats-section { padding:4rem 0 6rem; background:var(--background); position:relative; overflow:hidden; }
.stats-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:2rem 3rem; }
@media(min-width:1024px){ .stats-grid { grid-template-columns:repeat(4,1fr); } }
.stat-item { text-align:center; }
.stat-icon-wrap {
  width:4rem; height:4rem; border-radius:1rem; background:hsl(224,76%,33%,0.1);
  display:flex; align-items:center; justify-content:center; margin:0 auto 1rem;
  color:var(--primary); transition:all 0.3s;
}
.stat-item:hover .stat-icon-wrap { background:var(--primary); color:#fff; transform:scale(1.1); }
.stat-number { font-family:'Sora',sans-serif; font-weight:800; font-size:clamp(2rem,4vw,3rem); color:var(--primary); font-variant-numeric:tabular-nums; }
.stat-suffix { font-family:'Sora',sans-serif; font-weight:800; font-size:clamp(2rem,4vw,3rem); color:var(--primary); }
.stat-label { color:var(--muted-fg); font-weight:500; font-size:0.75rem; text-transform:uppercase; letter-spacing:0.1em; margin-top:0.5rem; }

/* ===== WHY CHOOSE ===== */
.why-section { padding:5rem 0 8rem; background:var(--background); position:relative; overflow:hidden; }
.why-grid { display:grid; gap:1.5rem; }
@media(min-width:640px){ .why-grid { grid-template-columns:repeat(2,1fr); } }
@media(min-width:1024px){ .why-grid { grid-template-columns:repeat(3,1fr); } }
.why-card { padding:1.75rem; cursor:default; }
.why-icon-wrap {
  width:3.5rem; height:3.5rem; border-radius:1rem; background:hsl(224,76%,33%,0.1);
  display:flex; align-items:center; justify-content:center; margin-bottom:1.25rem;
  color:var(--primary); transition:all 0.3s;
}
.why-card:hover .why-icon-wrap { background:var(--primary); color:#fff; transform:scale(1.1); }
.why-card h3 { font-family:'Sora',sans-serif; font-weight:700; font-size:1.125rem; color:var(--foreground); margin-bottom:0.5rem; }
.why-card p { color:var(--muted-fg); font-size:0.875rem; line-height:1.7; }

/* ===== SCROLL STORY — HORIZONTAL DESKTOP / VERTICAL MOBILE+TABLET ===== */
.scroll-story-section { padding: 5rem 0 8rem; background: hsl(220,20%,94%,0.3); overflow: hidden; }

/* ── MOBILE & TABLET (< 1024px): vertical single-column timeline ── */
.timeline {
  position: relative;
  max-width: 40rem;
  margin: 0 auto;
}
.timeline-line {
  position: absolute;
  left: 1.75rem;
  top: 0; bottom: 0;
  width: 2px;
  background: var(--border);
}
.timeline-progress {
  width: 100%; height: 0%;
  background: linear-gradient(to bottom, var(--primary), var(--secondary), var(--accent));
  border-radius: 9999px;
  transition: height 0.1s linear;
}
.timeline-item {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 1.25rem;
  margin-bottom: 2.5rem;
  padding-left: 4rem;
  flex-direction: row !important;
}
.timeline-item:last-child { margin-bottom: 0; }
.timeline-dot {
  position: absolute;
  left: 1.25rem;
  top: 0.5rem;
  width: 1.1rem; height: 1.1rem;
  border-radius: 50%;
  border: 3px solid var(--background);
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
  z-index: 1;
  transform: none !important;
}
.timeline-content {
  flex: 1;
  text-align: left !important;
}
.timeline-content.card-glass { padding: 1.25rem 1.5rem; }
.timeline-icon {
  width: 3rem; height: 3rem;
  border-radius: 0.875rem;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 0.875rem;
  color: #fff;
  margin-left: 0 !important;
}
.timeline-content h3 {
  font-family: 'Sora', sans-serif; font-weight: 700;
  font-size: 1.125rem; color: var(--foreground); margin-bottom: 0.5rem;
}
.timeline-content p { color: var(--muted-fg); line-height: 1.7; }
.timeline-spacer { display: none !important; }

/* ── DESKTOP (≥ 1024px): horizontal 4-column row ── */
@media(min-width: 1024px) {
  .timeline {
    max-width: 100%;
    display: flex;
    flex-direction: column;
    gap: 0;
  }

  /* Hide the vertical line on desktop */
  .timeline-line { display: none; }

  /* All 4 items in one horizontal row */
  .timeline-items-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
    position: relative;
  }

  /* Horizontal connecting line across all cards */
  .timeline-items-row::before {
    content: '';
    position: absolute;
    top: 2.25rem;
    left: calc(12.5% + 0.75rem);
    right: calc(12.5% + 0.75rem);
    height: 2px;
    background: linear-gradient(to right, var(--primary), var(--secondary), var(--accent));
    z-index: 0;
  }

  .timeline-item {
    flex-direction: column !important;
    align-items: center;
    text-align: center;
    padding-left: 0;
    margin-bottom: 0;
    position: relative;
    z-index: 1;
  }

  .timeline-dot {
    position: relative;
    left: auto; top: auto;
    width: 1rem; height: 1rem;
    margin: 0.5rem auto 0.75rem;
    order: 2;
    transform: none !important;
  }

  .timeline-content {
    text-align: center !important;
    order: 3;
    width: 100%;
  }
  .timeline-content.card-glass { padding: 1.5rem; }

  .timeline-icon {
    width: 4.5rem; height: 4.5rem;
    border-radius: 1rem;
    margin: 0 auto 0;
    order: 1;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .timeline-item:nth-child(odd) .timeline-content,
  .timeline-item:nth-child(even) .timeline-content {
    padding-left: 0 !important;
    padding-right: 0 !important;
    text-align: center !important;
  }
  .timeline-item:nth-child(odd) .timeline-icon,
  .timeline-item:nth-child(even) .timeline-icon {
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .timeline-spacer { display: none !important; }
}
.gradient-primary { background:linear-gradient(135deg, hsl(224,76%,33%,0.15), hsl(224,76%,33%,0.03)); }
.gradient-secondary { background:linear-gradient(135deg, hsl(45,97%,54%,0.15), hsl(45,97%,54%,0.03)); }
.gradient-accent { background:linear-gradient(135deg, hsl(0,84%,60%,0.15), hsl(0,84%,60%,0.03)); }

/* ===== PROGRAMS ===== */
.programs-section { padding:5rem 0 8rem; background:var(--background); position:relative; overflow:hidden; }
.programs-grid { display:grid; gap:2rem; }
@media(min-width:768px){ .programs-grid { grid-template-columns:repeat(3,1fr); } }
.program-card { padding:2rem; cursor:default; transition:all 0.5s ease; }
.program-card:hover { background:var(--primary); color:var(--primary-fg); }
.program-icon-wrap {
  width:4rem; height:4rem; border-radius:1rem;
  display:flex; align-items:center; justify-content:center; margin-bottom:1.25rem;
  color:#fff; transition:transform 0.3s;
}
.program-card:hover .program-icon-wrap { transform:scale(1.1); }
.program-age { font-size:0.75rem; font-weight:700; text-transform:uppercase; letter-spacing:0.1em; color:var(--muted-fg); }
.program-card:hover .program-age { color:rgba(255,255,255,0.7); }
.program-card h3 { font-family:'Sora',sans-serif; font-weight:700; font-size:1.25rem; color:var(--foreground); margin:0.5rem 0 0.75rem; }
.program-card:hover h3 { color:#fff; }
.program-card p { color:var(--muted-fg); font-size:0.875rem; line-height:1.7; margin-bottom:1.25rem; }
.program-card:hover p { color:rgba(255,255,255,0.8); }
.program-tags { display:flex; flex-wrap:wrap; gap:0.5rem; }
.program-tag {
  font-size:0.75rem; font-weight:500; padding:0.375rem 0.75rem; border-radius:9999px;
  background:var(--muted); color:rgba(34,47,11,0.7);
}
.program-card:hover .program-tag { background:rgba(255,255,255,0.2); color:#fff; }

/* ===== PILLARS ===== */
.pillars-section { padding:5rem 0 8rem; background:hsl(220,20%,94%,0.3); position:relative; overflow:hidden; }
.pillars-wrapper { position:relative; }
.pillars-line {
  display:none; position:absolute; top:60px; left:12.5%; right:12.5%;
  height:4px; background:linear-gradient(to right, var(--primary), var(--secondary), var(--accent));
  border-radius:9999px; overflow:hidden;
}
@media(min-width:1024px){ .pillars-line { display:block; } }
.pillars-light {
  position:absolute; top:0; bottom:0; left:0; width:25%;
  background:linear-gradient(to right, transparent, rgba(255,255,255,0.8), transparent);
  border-radius:9999px; animation:moveLight 3s linear infinite;
}
.pillars-grid { display:grid; gap:1.5rem 2rem; position:relative; z-index:1; }
@media(min-width:640px){ .pillars-grid { grid-template-columns:repeat(2,1fr); } }
@media(min-width:1024px){ .pillars-grid { grid-template-columns:repeat(4,1fr); } }
.pillar-item { display:flex; flex-direction:column; align-items:center; text-align:center; }
.pillar-icon {
  width:7.5rem; height:7.5rem; border-radius:1rem;
  display:flex; align-items:center; justify-content:center; margin-bottom:1.25rem;
  color:#fff; box-shadow:0 4px 20px rgba(0,0,0,0.15);
}
.pillar-dot {
  display:none; width:1rem; height:1rem; border-radius:50%;
  background:var(--primary); border:4px solid var(--background);
  box-shadow:0 2px 8px rgba(0,0,0,0.15); margin-top:-0.75rem; margin-bottom:0.75rem;
}
@media(min-width:1024px){ .pillar-dot { display:block; } }
.pillar-item h3 { font-family:'Sora',sans-serif; font-weight:700; font-size:1.125rem; color:var(--foreground); margin-bottom:0.5rem; }
.pillar-item p { color:var(--muted-fg); font-size:0.875rem; line-height:1.7; max-width:15rem; }

/* ===== FACILITIES ===== */
.facilities-section { padding:5rem 0 8rem; background:var(--background); position:relative; overflow:hidden; }
.facilities-grid { display:grid; gap:1.5rem; }
@media(min-width:640px){ .facilities-grid { grid-template-columns:repeat(2,1fr); } }
@media(min-width:1024px){ .facilities-grid { grid-template-columns:repeat(3,1fr); } }
.facility-card { padding:0; cursor:pointer; }
.facility-img-wrap { position:relative; height:12rem; overflow:hidden; border-radius:1rem 1rem 0 0; }
.facility-img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform 0.7s ease; }
.facility-card:hover .facility-img-wrap img { transform:scale(1.1); }
.facility-img-wrap::after { content:''; position:absolute; inset:0; background:linear-gradient(to top, rgba(34,47,11,0.4), transparent); }
.facility-info { padding:1.25rem; }
.facility-icon-row { display:flex; align-items:center; gap:0.75rem; margin-bottom:0.5rem; }
.facility-icon-wrap {
  width:2.5rem; height:2.5rem; border-radius:0.75rem; background:hsl(224,76%,33%,0.1);
  display:flex; align-items:center; justify-content:center; color:var(--primary);
  transition:all 0.3s; flex-shrink:0;
}
.facility-card:hover .facility-icon-wrap { background:var(--primary); color:#fff; }
.facility-info h3 { font-family:'Sora',sans-serif; font-weight:700; font-size:1rem; color:var(--foreground); }
.facility-info p { color:var(--muted-fg); font-size:0.875rem; line-height:1.6; }

/* ===== ACTIVITIES ===== */
.activities-section { padding:5rem 0 8rem; background:hsl(220,20%,94%,0.3); }
.activities-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1rem; }
@media(min-width:768px){ .activities-grid { grid-template-columns:repeat(3,1fr); } }
@media(min-width:1024px){ .activities-grid { grid-template-columns:repeat(4,1fr); } }
.activity-card {
  position:relative; border-radius:1rem; overflow:hidden;
  aspect-ratio:1; cursor:pointer;
}
.activity-card img { width:100%; height:100%; object-fit:cover; transition:all 0.7s ease; }
.activity-card:hover img { transform:scale(1.1); filter:brightness(1.1); }
.activity-card::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(34,47,11,0.8), rgba(34,47,11,0.2), transparent);
  opacity:0.8; transition:opacity 0.3s; z-index:1;
}
.activity-card:hover::before { opacity:0.9; }
.activity-caption {
  position:absolute; bottom:0; left:0; right:0; padding:1rem;
  transform:translateY(8px); transition:transform 0.3s; z-index:2;
}
.activity-card:hover .activity-caption { transform:translateY(0); }
.activity-bar {
  width:2rem; height:4px; border-radius:9999px; margin-bottom:0.5rem;
  transform:scaleX(0); transform-origin:left; transition:transform 0.3s;
}
.activity-card:hover .activity-bar { transform:scaleX(1); }
.activity-caption p { font-family:'Sora',sans-serif; font-weight:700; font-size:0.875rem; color:#fff; }
@media(min-width:768px){ .activity-caption p { font-size:1rem; } }

/* ===== GALLERY ===== */
.gallery-section { padding:5rem 0 8rem; background:var(--background); }
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}
@media(min-width:640px) { .gallery-grid { grid-template-columns: repeat(3, 1fr); gap: 1.25rem; } }
@media(min-width:1024px) { .gallery-grid { grid-template-columns: repeat(4, 1fr); gap: 1.5rem; } }

.gallery-item {
  position: relative;
  border-radius: 1rem;
  overflow: hidden;
  cursor: pointer;
  background: #f1f5f9;
  box-shadow: var(--shadow-sm);
  transition: transform 0.35s ease, box-shadow 0.35s ease;
}
.gallery-item:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

/* full image visible — contain inside a fixed aspect box */
.gallery-item img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}
.gallery-item:hover img { transform: scale(1.04); }

/* caption bar slides up on hover */
.gallery-hover {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: linear-gradient(to top, rgba(15,23,42,0.85), transparent);
  padding: 1.5rem 0.875rem 0.75rem;
  transform: translateY(100%);
  transition: transform 0.35s ease;
  border-radius: 0 0 1rem 1rem;
}
.gallery-item:hover .gallery-hover { transform: translateY(0); }
.gallery-hover p {
  color: #fff;
  font-family: 'Sora', sans-serif;
  font-weight: 700;
  font-size: 0.875rem;
  margin: 0;
}
/* remove old span classes — no longer needed */
.span-2x2, .span-2x1 { grid-column: unset; grid-row: unset; }

/* ===== TESTIMONIALS ===== */
.testimonials-section { padding:5rem 0 8rem; background:hsl(220,20%,94%,0.3); position:relative; overflow:hidden; }
.testimonials-wrapper { max-width:48rem; margin:0 auto; }
.testimonials-track { position:relative; }
.testimonial-slide { display:none; }
.testimonial-slide.active { display:block; animation:slideIn 0.5s cubic-bezier(0.23,1,0.32,1); }
@keyframes slideIn { from{opacity:0;transform:translateX(50px)} to{opacity:1;transform:translateX(0)} }
.testimonial-card { padding:2rem; text-align:center; }
@media(min-width:768px){ .testimonial-card { padding:3rem; } }
.quote-icon { color:hsl(224,76%,33%,0.5); margin:0 auto 1rem; }
.stars { color:var(--secondary); font-size:1.25rem; margin-bottom:1rem; letter-spacing:2px; }
.testimonial-text { font-size:clamp(1rem,2vw,1.25rem); line-height:1.7; font-style:italic; color:var(--foreground); margin-bottom:1.5rem; }
.testimonial-author { display:flex; align-items:center; justify-content:center; gap:0.75rem; }
.author-avatar {
  width:3rem; height:3rem; border-radius:50%; background:hsl(224,76%,33%,0.1);
  display:flex; align-items:center; justify-content:center;
  font-family:'Sora',sans-serif; font-weight:700; font-size:1.25rem; color:var(--primary);
}
.testimonial-author strong { display:block; font-family:'Sora',sans-serif; font-weight:700; color:var(--foreground); }
.testimonial-author span { display:block; font-size:0.875rem; color:var(--muted-fg); }
.testimonials-nav { display:flex; align-items:center; justify-content:center; gap:1rem; margin-top:2rem; }
.testi-btn {
  width:2.5rem; height:2.5rem; border-radius:50%; background:var(--card);
  border:1px solid var(--border); display:flex; align-items:center; justify-content:center;
  transition:all 0.3s; color:var(--foreground);
}
.testi-btn:hover { background:var(--primary); color:#fff; }
.testi-dots { display:flex; gap:0.5rem; }
.testi-dot { height:0.5rem; border-radius:9999px; background:var(--border); width:0.5rem; transition:all 0.5s; }
.testi-dot.active { background:var(--primary); width:2rem; }

/* ===== ADMISSIONS ===== */
.admissions-section { padding:5rem 0 8rem; position:relative; overflow:hidden; }
.admissions-bg { position:absolute; inset:0; background:linear-gradient(135deg, var(--primary), var(--navy)); }
.admissions-dots {
  position:absolute; inset:0; opacity:0.1;
  background-image:radial-gradient(circle at 1px 1px, rgba(255,255,255,0.3) 1px, transparent 0);
  background-size:30px 30px;
}
.admissions-inner { position:relative; z-index:1; display:grid; gap:3rem; align-items:center; }
@media(min-width:1024px){ .admissions-inner { grid-template-columns:1fr 1fr; } }
.admissions-left { color:#fff; }
.admissions-heading {
  font-family:'Sora',sans-serif; font-weight:700;
  font-size:clamp(2rem,4vw,3rem); line-height:1.12; letter-spacing:-0.03em;
  color:#fff; margin:1rem 0;
}
.admissions-left p { color:rgba(255,255,255,0.95); font-size:1.125rem; line-height:1.7; max-width:28rem; }
.admissions-list { margin-top:2rem; display:flex; flex-direction:column; gap:1rem; }
.admissions-list li { display:flex; align-items:center; gap:0.75rem; color:#ffffff; font-size:0.875rem; font-weight:500; }
.check-circle {
  width:1.5rem; height:1.5rem; border-radius:50%; background:var(--secondary);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  color:var(--secondary-fg); font-size:0.75rem; font-weight:700;
}
.enquiry-form {
  background:rgba(255,255,255,0.97); backdrop-filter:blur(24px);
  border-radius:1.5rem; padding:1.5rem; box-shadow:0 25px 50px rgba(0,0,0,0.2);
  border:1px solid rgba(255,255,255,0.2); display:flex; flex-direction:column; gap:1.25rem;
}
@media(min-width:768px){ .enquiry-form { padding:2rem; } }
.form-header { text-align:center; }
.form-header h3 { font-family:'Sora',sans-serif; font-weight:700; font-size:1.25rem; color:var(--foreground); }
.form-header p { color:var(--muted-fg); font-size:0.875rem; margin-top:0.25rem; }
.form-field { position:relative; }
.floating-label input {
  width:100%; border:1px solid var(--border); background:var(--background);
  border-radius:0.75rem; padding:1.5rem 1rem 0.5rem;
  font-size:0.875rem; color:var(--foreground); outline:none; transition:all 0.3s;
  font-family:'Inter',sans-serif;
}
.floating-label label {
  position:absolute; left:1rem; top:50%; transform:translateY(-50%);
  font-size:0.875rem; color:var(--muted-fg); pointer-events:none; transition:all 0.3s;
}
.floating-label input:focus,
.floating-label input:not(:placeholder-shown) { border-color:var(--primary); box-shadow:0 0 0 3px hsl(224,76%,33%,0.1); }
.floating-label input:focus + label,
.floating-label input:not(:placeholder-shown) + label {
  top:0.375rem; transform:none; font-size:0.625rem; font-weight:700; color:var(--primary);
}
.select-label { display:block; font-size:0.75rem; font-weight:700; color:var(--foreground); margin-bottom:0.375rem; }
.form-field select, .form-field textarea {
  width:100%; border:1px solid var(--border); background:var(--background);
  border-radius:0.75rem; padding:0.75rem 1rem;
  font-size:0.875rem; color:var(--foreground); outline:none; transition:all 0.3s;
  font-family:'Inter',sans-serif;
}
.form-field select:focus, .form-field textarea:focus { border-color:var(--primary); box-shadow:0 0 0 3px hsl(224,76%,33%,0.1); }
.form-field textarea { resize:none; }
.form-actions { display:flex; flex-direction:column; gap:0.75rem; }
@media(min-width:640px){ .form-actions { flex-direction:row; } }
.form-actions .btn-primary-hero, .form-actions .btn-whatsapp { padding:0.75rem 1.5rem; font-size:0.875rem; justify-content:center; }

/* ===== CONTACT ===== */
.contact-section { padding:5rem 0 8rem; background:var(--background); }
.contact-grid { display:grid; gap:2rem; align-items:start; }
@media(min-width:1024px){ .contact-grid { grid-template-columns:1fr 1fr; } }
.contact-map {
  border-radius: 1.5rem;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(30,58,138,0.1);
  height: 22rem;
  border: 1px solid var(--border);
  position: relative;   /* needed for overlay button */
}
@media(min-width:768px){ .contact-map { height:28rem; } }
.contact-map iframe { width:100%; height:100%; border:0; }

/* "Get Directions" button overlaid on map bottom-left */
.map-directions-btn {
  position: absolute;
  bottom: 1rem;
  left: 1rem;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  background: #EA4335;
  color: #fff;
  font-family: 'Sora', sans-serif;
  font-weight: 700;
  font-size: 0.8rem;
  padding: 0.5rem 1rem;
  border-radius: 9999px;
  box-shadow: 0 4px 16px rgba(234,67,53,0.45);
  transition: all 0.3s ease;
  z-index: 10;
  letter-spacing: 0.02em;
  text-decoration: none;
}
.map-directions-btn:hover {
  background: #C5221F;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(234,67,53,0.5);
}

/* Inline directions link in address card */
.address-directions-link {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  margin-top: 0.5rem;
  color: #EA4335;
  font-family: 'Sora', sans-serif;
  font-weight: 700;
  font-size: 0.8rem;
  text-decoration: none;
  transition: color 0.2s;
}
.address-directions-link:hover { color: #C5221F; }
.contact-cards { display:flex; flex-direction:column; gap:1.25rem; }
.contact-card { padding:1.5rem; display:flex; gap:1rem; align-items:flex-start; }
.contact-icon-wrap {
  width:3rem; height:3rem; border-radius:0.75rem; background:hsl(224,76%,33%,0.1);
  display:flex; align-items:center; justify-content:center; color:var(--primary);
  flex-shrink:0; transition:all 0.3s;
}
.contact-card:hover .contact-icon-wrap { background:var(--primary); color:#fff; }
.contact-card h3 { font-family:'Sora',sans-serif; font-weight:700; color:var(--foreground); margin-bottom:0.25rem; }
.contact-card p { color:var(--muted-fg); font-size:0.875rem; line-height:1.7; }
.phone-grid { display:grid; grid-template-columns:1fr 1fr; gap:0.375rem 1.5rem; margin-top:0.5rem; }
.phone-grid a { font-size:0.875rem; color:#1a1a2e; font-weight:500; transition:color 0.3s; }
.phone-grid a:hover { color:var(--primary); }

/* ===== FOOTER ===== */
.footer { background:var(--foreground); color:#fff; position:relative; overflow:hidden; }
.footer-gradient-bar { height:4px; background:linear-gradient(to right, var(--primary), var(--secondary), var(--accent)); }
.footer-inner { padding:4rem 0 2rem; }
.footer-grid { display:grid; gap:2.5rem; margin-bottom:3.5rem; }
@media(min-width:640px){ .footer-grid { grid-template-columns:repeat(2,1fr); } }
@media(min-width:1024px){ .footer-grid { grid-template-columns:2fr 1fr 1fr 1.5fr; } }
.footer-brand { min-width: 0; }
.footer-logo-row {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 1.25rem;
}
.footer-logo {
  height: 3.2rem;
  width: 3.2rem;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  border: 2.5px solid #C8A84B;
  box-shadow: 0 0 0 1px #9A7020;
  background: #fff;
}

/* Footer brand text — exact mirror of navbar brand */
.footer-brand-text {
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  align-items: stretch;
  gap: 0;
  line-height: 1;
  width: fit-content;
  overflow: visible;
}
.footer-name {
  display: block;
  font-family: 'Georgia', 'Times New Roman', Times, serif;
  font-weight: 700;
  font-size: clamp(0.85rem, 1.7vw, 1.3rem);
  line-height: 1;
  letter-spacing: 0.05em;
  white-space: nowrap;
  width: fit-content;
  margin-bottom: 2px;
  transform-origin: left center;
  /* navy-blue gradient — same as navbar */
  background: linear-gradient(180deg, #2E4DA0 0%, #1E3A8A 50%, #1A237E 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.footer-divider {
  display: block;
  width: 100%;
  height: 1.5px;
  background: #8B1A1A;
  border: none;
  margin: 0 0 2px 0;
  padding: 0;
  flex-shrink: 0;
}
.footer-sub-name {
  display: block;
  font-family: 'Georgia', 'Times New Roman', Times, serif;
  font-weight: 700;
  font-size: clamp(0.58rem, 1.15vw, 0.9rem);
  color: #C0392B;
  line-height: 1;
  letter-spacing: 0.04em;
  white-space: nowrap;
  text-transform: uppercase;
  margin-bottom: 3px;
  width: fit-content;
  transform-origin: left center;
}
.footer-tagline {
  display: block;
  font-family: 'Inter', Arial, Helvetica, sans-serif;
  font-weight: 400;
  font-size: clamp(0.36rem, 0.6vw, 0.5rem);
  color: rgba(255,255,255,0.85);
  line-height: 1.2;
  margin-top: 2px;
  letter-spacing: 0.01em;
  white-space: nowrap;
  width: 100%;
}
.footer-brand p { color:rgba(255,255,255,0.92); font-size:0.875rem; line-height:1.7; margin-bottom:1rem; }
.social-icons { display:flex; gap:0.75rem; }
.social-icon {
  width:2.25rem; height:2.25rem; border-radius:0.5rem;
  background:rgba(255,255,255,0.1); display:flex; align-items:center; justify-content:center;
  color:#fff; transition:all 0.3s;
}
.social-icon:hover { background:var(--secondary); color:var(--secondary-fg); transform:scale(1.1); }
.footer-col h4 { font-family:'Sora',sans-serif; font-weight:700; font-size:0.75rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--secondary); margin-bottom:1.25rem; }
.footer-col ul { display:flex; flex-direction:column; gap:0.625rem; }
.footer-col a { font-size:0.875rem; color:rgba(255,255,255,0.92); transition:all 0.3s; display:inline-block; }
.footer-col a:hover { color:var(--secondary); transform:translateX(4px); }
.footer-contact-item { display:flex; gap:0.75rem; margin-bottom:1rem; color:rgba(255,255,255,0.92); font-size:0.875rem; }
.footer-contact-item svg { color:var(--secondary); flex-shrink:0; margin-top:2px; }
.footer-contact-item p { line-height:1.6; }
.footer-contact-item a { color:rgba(255,255,255,0.92); transition:color 0.3s; display:block; }
.footer-contact-item a:hover { color:var(--secondary); }
.footer-bottom {
  border-top:1px solid rgba(255,255,255,0.15); padding-top:1.5rem;
  display:flex; flex-direction:column; align-items:center; gap:1rem;
  font-size:0.75rem; color:rgba(255,255,255,0.8); text-align:center;
}
@media(min-width:768px){ .footer-bottom { flex-direction:row; justify-content:space-between; } }

/* ===== FLOATING BUTTONS ===== */
.floating-btn {
  position:fixed; z-index:50; display:flex; align-items:center; gap:0.5rem;
  padding:0.75rem 1.25rem; border-radius:9999px;
  font-family:'Sora',sans-serif; font-weight:700; font-size:0.875rem;
  box-shadow:0 4px 20px rgba(0,0,0,0.2); transition:all 0.3s;
}
.floating-btn:hover { transform:scale(1.05); box-shadow:0 8px 30px rgba(0,0,0,0.25); }
.floating-whatsapp { bottom:1.5rem; right:1.5rem; background:#25D366; color:#fff; }
.floating-call { bottom:1.5rem; left:1.5rem; background:var(--primary); color:#fff; }
.floating-btn span { display:none; }
@media(min-width:640px){ .floating-btn span { display:inline; } }
.mobile-bottom-bar {
  position:fixed; bottom:0; left:0; right:0; z-index:50;
  background:rgba(255,255,255,0.97); backdrop-filter:blur(24px);
  border-top:1px solid var(--border); box-shadow:0 -4px 20px rgba(30,58,138,0.1);
  display:grid; grid-template-columns:repeat(3,1fr);
}
@media(min-width:768px){ .mobile-bottom-bar { display:none; } }
.mobile-bar-btn {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:0.75rem; color:var(--primary); transition:background 0.3s; font-family:'Sora',sans-serif;
}
.mobile-bar-btn:hover { background:hsl(224,76%,33%,0.05); }
.mobile-bar-btn span { font-size:0.625rem; font-weight:700; text-transform:uppercase; letter-spacing:0.05em; margin-top:0.25rem; }
.mobile-bar-primary { background:var(--primary); color:#fff; }
.mobile-bar-primary:hover { background:var(--primary-light); }
.mobile-bar-wa { color:#25D366; }

/* ===== LIGHTBOX ===== */
.lightbox {
  position:fixed; inset:0; z-index:100;
  background:rgba(34,47,11,0.92); backdrop-filter:blur(4px);
  display:none; align-items:center; justify-content:center; padding:1rem;
}
.lightbox.open { display:flex; animation:fadeIn 0.3s ease; }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
.lightbox-close {
  position:absolute; top:1.5rem; right:1.5rem; color:#fff; transition:color 0.3s; z-index:10;
}
.lightbox-close:hover { color:var(--secondary); }
.lightbox-prev, .lightbox-next {
  position:absolute; color:#fff; transition:color 0.3s; z-index:10;
}
.lightbox-prev { left:1rem; } @media(min-width:768px){ .lightbox-prev { left:2rem; } }
.lightbox-next { right:1rem; } @media(min-width:768px){ .lightbox-next { right:2rem; } }
.lightbox-prev:hover, .lightbox-next:hover { color:var(--secondary); }
.lightbox-content { max-width:56rem; width:100%; animation:scaleIn 0.3s ease; }
@keyframes scaleIn { from{opacity:0;transform:scale(0.9)} to{opacity:1;transform:scale(1)} }
#lightboxImg { width:100%; max-height:80vh; border-radius:1rem; object-fit:contain; }
#lightboxCaption { text-align:center; color:#fff; font-family:'Sora',sans-serif; font-weight:700; font-size:1.125rem; margin-top:1rem; }

/* ===== BODY PADDING FOR MOBILE BAR ===== */
@media(max-width:767px){ body { padding-bottom:4rem; } }

/* ===== PREMIUM OFFER CARD ===== */

/* outer wrapper — positions the gold badge overflow */
.ofc-wrap {
  position: relative;
  width: 100%;
  max-width: 640px;
  margin: 1.5rem auto 1.75rem;
  /* push right so gold badge has room to overflow left */
  padding-left: 0;
  padding-top: 22px;
}

/* ── GOLD BADGE (top-left overflow) ── */
.ofc-gold-badge {
  position: absolute;
  top: -18px;
  left: -10px;
  z-index: 20;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  background: linear-gradient(145deg, #f5c518 0%, #e6a800 40%, #c87800 100%);
  border-radius: 1rem 1rem 1rem 0.3rem;
  padding: 0.55rem 0.9rem 0.55rem 0.7rem;
  box-shadow:
    0 0 0 3px rgba(245,197,24,0.4),
    0 0 18px rgba(245,197,24,0.6),
    0 6px 20px rgba(0,0,0,0.4);
  min-width: 110px;
}
.ofc-gift { font-size: 1.4rem; line-height: 1; }
.ofc-gold-text {
  font-family: 'Sora', sans-serif;
  font-size: 0.72rem;
  font-weight: 800;
  color: #3b1a00;
  line-height: 1.25;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.ofc-gold-text strong {
  font-size: 1.05rem;
  display: block;
  color: #1a0800;
}

/* ── MAIN CARD ── */
.ofc-card {
  position: relative;
  border-radius: 1.25rem;
  /* deep purple starfield background */
  background: radial-gradient(ellipse at 30% 40%, #4a1d8a 0%, #2d1060 40%, #1a0840 100%);
  /* neon border: cyan-blue bottom-left, pink-purple top-right */
  border: 2px solid transparent;
  background-clip: padding-box;
  box-shadow:
    /* neon glow layers */
    0 0 0 2px rgba(120,80,255,0.5),
    0 0 20px rgba(100,60,255,0.5),
    0 0 40px rgba(180,60,255,0.25),
    /* cyan accent bottom-left */
    -4px 4px 0 2px rgba(0,200,255,0.35),
    /* pink accent top-right */
    4px -4px 0 2px rgba(255,60,180,0.3),
    0 24px 60px rgba(0,0,0,0.6);
  padding: 2.25rem 2rem 1.75rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0.55rem;
  overflow: hidden;
}

/* animated neon border ring */
.ofc-card::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: 1.3rem;
  background: linear-gradient(135deg,
    rgba(0,200,255,0.6) 0%,
    rgba(120,60,255,0.4) 30%,
    rgba(255,60,180,0.5) 60%,
    rgba(255,180,0,0.4) 80%,
    rgba(0,200,255,0.6) 100%);
  background-size: 300% 300%;
  animation: ofc-border-glow 4s linear infinite;
  z-index: 0;
  border-radius: 1.3rem;
  -webkit-mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  mask-composite: exclude;
  padding: 2px;
}
@keyframes ofc-border-glow {
  0%,100% { background-position: 0% 50%; }
  50%      { background-position: 100% 50%; }
}

/* shimmer sweep */
.ofc-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg,
    transparent 35%,
    rgba(255,255,255,0.04) 50%,
    transparent 65%);
  background-size: 200% 100%;
  animation: ofc-shimmer 4s linear infinite;
  pointer-events: none;
  z-index: 1;
  border-radius: inherit;
}
@keyframes ofc-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* all content above pseudo-elements */
.ofc-card > * { position: relative; z-index: 2; }

/* ── STARFIELD DOTS ── */
.ofc-star {
  position: absolute;
  border-radius: 50%;
  background: rgba(255,255,255,0.75);
  box-shadow: 0 0 4px 1px rgba(255,255,255,0.5);
  animation: ofc-twinkle 3s ease-in-out infinite;
  z-index: 1;
}
@keyframes ofc-twinkle {
  0%,100% { opacity: 0.9; transform: scale(1); }
  50%      { opacity: 0.2; transform: scale(0.4); }
}

/* ── GOLD STREAK LINES ── */
.ofc-streak {
  position: absolute;
  width: 80px; height: 2px;
  background: linear-gradient(90deg, transparent, rgba(245,197,24,0.6), transparent);
  border-radius: 9999px;
  animation: ofc-streak-fade 3s ease-in-out infinite;
  z-index: 1;
}
@keyframes ofc-streak-fade {
  0%,100% { opacity: 0.7; }
  50%      { opacity: 0.15; }
}

/* ── TYPOGRAPHY ── */
.ofc-top-label {
  font-family: 'Sora', sans-serif;
  font-weight: 600;
  font-size: clamp(0.78rem, 1.8vw, 0.95rem);
  color: rgba(255,255,255,0.85);
  letter-spacing: 0.02em;
  margin: 0;
}

.ofc-sub-line {
  font-family: 'Sora', sans-serif;
  font-weight: 500;
  font-size: clamp(0.85rem, 2vw, 1.05rem);
  color: rgba(255,255,255,0.9);
  margin: 0;
}

.ofc-heading {
  font-family: 'Sora', sans-serif;
  font-weight: 800;
  font-size: clamp(1.4rem, 4vw, 2rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin: 0.1rem 0 0;
  /* gold gradient text */
  background: linear-gradient(135deg, #fde68a 0%, #f5c518 40%, #e6a800 70%, #fde68a 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-shadow: none;
  filter: drop-shadow(0 0 12px rgba(245,197,24,0.55));
}

/* horizontal divider with gold glow */
.ofc-divider-line {
  width: 70%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(245,197,24,0.5), transparent);
  margin: 0.2rem 0;
}

.ofc-limited {
  font-family: 'Sora', sans-serif;
  font-weight: 600;
  font-size: clamp(0.82rem, 1.8vw, 0.98rem);
  color: rgba(255,255,255,0.88);
  margin: 0;
}

/* ── ENROLL BUTTON ── */
.ofc-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 0.6rem;
  width: 80%;
  max-width: 320px;
  padding: 0.85rem 2rem;
  border-radius: 9999px;
  font-family: 'Sora', sans-serif;
  font-weight: 800;
  font-size: clamp(1rem, 2.2vw, 1.2rem);
  color: #5b21b6;
  background: #ffffff;
  letter-spacing: 0.02em;
  text-decoration: none;
  /* neon pill border */
  box-shadow:
    0 0 0 2px rgba(120,80,255,0.6),
    0 0 16px rgba(120,80,255,0.5),
    0 0 32px rgba(180,60,255,0.25),
    0 6px 20px rgba(0,0,0,0.3);
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}
.ofc-btn::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: 9999px;
  background: linear-gradient(90deg, #00c8ff, #a855f7, #ff3cb4, #f5c518, #00c8ff);
  background-size: 300% 100%;
  animation: ofc-btn-border 3s linear infinite;
  z-index: -1;
}
@keyframes ofc-btn-border {
  0%   { background-position: 0% 0; }
  100% { background-position: 300% 0; }
}
.ofc-btn:hover {
  background: #FDE047;
  color: #4c1d95;
  transform: translateY(-3px) scale(1.03);
  box-shadow:
    0 0 0 2px rgba(245,197,24,0.8),
    0 0 24px rgba(245,197,24,0.6),
    0 10px 30px rgba(0,0,0,0.35);
}
.ofc-btn:active { transform: scale(0.97); }


/* ===== RESPONSIVE FIXES ===== */

/* Prevent horizontal scroll */
body { overflow-x: hidden; }

/* Hero content padding — mobile */
@media(max-width: 767px) {
  .hero-content { padding: 5rem 0 7rem; }
  .hero-text { gap: 0.5rem; }
  .btn-primary-hero, .btn-secondary-hero { padding: 0.75rem 1.25rem; font-size: 0.875rem; }
  .btn-outline-hero { padding: 0.75rem 1.25rem; font-size: 0.875rem; }
  .ofc-card { padding: 1.5rem 1.25rem 1.25rem; }
  .ofc-gold-badge { left: 0; }
  .ofc-btn { max-width: min(320px, 90%); }
}

/* ofc-card extra small mobile padding */
@media(max-width: 479px) {
  .ofc-card { padding: 1.5rem 1.25rem 1.25rem; }
}

/* Hero content padding — tablet */
@media(min-width: 768px) and (max-width: 1023px) {
  .hero-content { padding: 7rem 0 9rem; }
}
