/* ============================================
   SOCCERMIDABLE — Design System v3
   BRIGHT · KID-FRIENDLY · PARENT-APPEALING
   Inspired by SoccerShots / KidsUnited
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Baloo+2:wght@400;500;600;700;800&family=Nunito:wght@400;600;700;800;900&family=SF UI Display Bold:wght@400;500;600;700&display=swap');

@font-face {
  font-family: 'Carena';
  src: url('fonts/Carena-Regular.otf') format('opentype');
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'SF UI Display Ultralight';
  font-style: normal;
  font-weight: normal;
  src: local('SF UI Display Ultralight'), url('fonts/sf-ui-display-ultralight-58646b19bf205.woff') format('woff');
  }
  

  @font-face {
  font-family: 'SF UI Display Thin';
  font-style: normal;
  font-weight: normal;
  src: local('SF UI Display Thin'), url('fonts/sf-ui-display-thin-58646e9b26e8b.woff') format('woff');
  }
  

  @font-face {
  font-family: 'SF UI Display Light';
  font-style: normal;
  font-weight: normal;
  src: local('SF UI Display Light'), url('fonts/sf-ui-display-light-58646b33e0551.woff') format('woff');
  }
  

  @font-face {
  font-family: 'SF UI Display Medium';
  font-style: normal;
  font-weight: normal;
  src: local('SF UI Display Medium'), url('fonts/sf-ui-display-medium-58646be638f96.woff') format('woff');
  }
  

  @font-face {
  font-family: 'SF UI Display Semibold';
  font-style: normal;
  font-weight: normal;
  src: local('SF UI Display Semibold'), url('fonts/sf-ui-display-semibold-58646eddcae92.woff') format('woff');
  }
  

  @font-face {
  font-family: 'SF UI Display Bold';
  font-style: normal;
  font-weight: normal;
  src: local('SF UI Display Bold'), url('fonts/sf-ui-display-bold-58646a511e3d9.woff') format('woff');
  }
  

  @font-face {
  font-family: 'SF UI Display Heavy';
  font-style: normal;
  font-weight: normal;
  src: local('SF UI Display Heavy'), url('fonts/sf-ui-display-heavy-586470160b9e5.woff') format('woff');
  }
  

  @font-face {
  font-family: 'SF UI Display Black';
  font-style: normal;
  font-weight: normal;
  src: local('SF UI Display Black'), url('fonts/sf-ui-display-black-58646a6b80d5a.woff') format('woff');
  }

:root {
  /* ── WARM PALETTE ── */
  --purple:       #4B0C5F;
  --purple-dark:  #2C0366;
  --purple-light: #9B6FD0;
  --purple-soft:  #F0E6FF;
  --purple-glow:  rgba(108,63,160,0.2);
  --gold:         #FFEA00;
  --gold-light:   #ffea00cc;
  --gold-soft:    #FFF8E7;
  --gold-glow:    rgba(245,166,35,0.3);
  --green:        #34C759;
  --green-soft:   #E6FAF0;
  --coral:        #FF6B6B;
  --sky:          #4FC3F7;
  --sky-soft:     #E8F6FE;
  --white:        #FFFFFF;
  --cream:        #FFFDF7;
  --off-white:    #F9F6FF;
  --lavender:     #F3EDFF;
  --dark:         #2D1B4E;
  --dark-2:       #1E1335;
  --text:         #3D2D5C;
  --text-light:   #7B6B95;
  --gray:         #8E82A0;
  --border:       rgba(108,63,160,0.12);
  --shadow-sm:    0 2px 12px rgba(108,63,160,0.08);
  --shadow-md:    0 8px 32px rgba(108,63,160,0.12);
  --shadow-lg:    0 16px 48px rgba(108,63,160,0.16);
  --radius:       16px;
  --radius-lg:    24px;
  --tr:           all 0.3s cubic-bezier(0.4,0,0.2,1);
}

*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  /* font-family:'SF UI Display Bold', system-ui, sans-serif; */
  background:var(--white); color:var(--text);
  overflow-x:hidden; -webkit-font-smoothing:antialiased;
}
img { max-width:100%; display:block; }
a { font-family: "SF UI Display Light" ; text-decoration:none; color:inherit; }
button { font-family: "SF UI Display Light" ; cursor:pointer; }
p { font-family: "SF UI Display Light" ; }

/* ── LANGUAGE ── */
[data-lang="en"] .fr { display:none !important; }
[data-lang="fr"] .en { display:none !important; }

/* ── LAYOUT ── */
.container { max-width:1180px; margin:0 auto; padding:0 1.5rem; }
.section    { padding:80px 0; }
.section-sm { padding:50px 0; }

/* ── BRAND TYPOGRAPHY ──
   "SoccerMidable" rendered in playful kid style */
.brand-name {
  font-family:'Carena';
  font-weight:800;
  letter-spacing:0.01em;
}

@media (max-width:480px) {
  .brand-name { font-size:1.3rem; }
} 

.brand-name .soccer { color:var(--purple); }
.brand-name .midable { color:var(--gold); }
.brand-name .midable-bounce {
  color:var(--gold);
  display:inline-block;
  animation:letterBounce 2s ease-in-out infinite;
}
@keyframes letterBounce {
  0%,100% { transform:translateY(0) rotate(0deg); }
  25%     { transform:translateY(-4px) rotate(-2deg); }
  75%     { transform:translateY(-2px) rotate(1deg); }
}

/* ============================================
   NAVBAR — Bright & Clear
   ============================================ */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  height:72px; display:flex; align-items:center; justify-content:space-between;
  padding:0 1.5rem;
  background:rgba(255,255,255,0.96); backdrop-filter:blur(20px);
  border-bottom:2px solid var(--purple-soft);
  transition:var(--tr);
}
.navbar.scrolled {
  box-shadow:var(--shadow-md);
  border-bottom-color:rgba(108,63,160,0.2);
}
.navbar-logo {
  display:flex; align-items:center; gap:10px;
  font-family:'Carena'; font-weight:800; font-size:1.5rem;
}
.navbar-logo img { height:42px; object-fit:contain; }
.navbar-logo .logo-text .soccer { color:var(--purple); }
.navbar-logo .logo-text .midable { color:var(--gold); }
.navbar-links { display:flex; align-items:center; gap:1.2rem; list-style:none; }
.navbar-links a {
  color:var(--text); font-family:'Nunito',sans-serif; font-weight:800;
  font-size:0.75rem; letter-spacing:0.08em; text-transform:uppercase;
  transition:color 0.2s; padding:6px 4px;
  border-bottom:2px solid transparent;
}
.navbar-links a:hover { color:var(--purple); border-bottom-color:var(--gold); }
.navbar-right { display:flex; align-items:center; gap:0.8rem; }
.lang-switch {
  display:flex; gap:3px; background:var(--lavender); border-radius:8px; padding:3px;
}
.lang-switch button {
  background:none; border:none; color:var(--text-light);
  font-family:'Nunito',sans-serif; font-weight:800; font-size:0.7rem;
  letter-spacing:0.1em; padding:5px 10px; border-radius:6px; transition:var(--tr);
}
.lang-switch button.active { background:var(--purple); color:white; }
.btn-nav-cta {
  background:var(--gold); color:var(--dark); padding:10px 20px; border-radius:50px; border:none;
  font-family:'Nunito',sans-serif; font-weight:900; font-size:0.78rem;
  letter-spacing:0.06em; text-transform:uppercase; transition:var(--tr); white-space:nowrap;
  box-shadow:0 4px 16px var(--gold-glow);
}
.btn-nav-cta:hover { background:var(--gold-light); transform:translateY(-2px); box-shadow:0 8px 28px var(--gold-glow); }

/* ── HAMBURGER — VERY VISIBLE ── */
.hamburger {
  display:none; width:44px; height:44px;
  flex-direction:column; gap:5px; align-items:center; justify-content:center;
  background:var(--purple); border:none; border-radius:12px;
  box-shadow:0 4px 12px var(--purple-glow); transition:var(--tr);
}
.hamburger:active { transform:scale(0.92); }
.hamburger span { display:block; width:20px; height:2.5px; background:white; border-radius:3px; transition:var(--tr); }

/* ── MOBILE MENU ── */
.mobile-menu {
  display:none; position:fixed; top:72px; left:0; right:0; bottom:0;
  background:white;
  z-index:999; flex-direction:column; padding:1.5rem; overflow-y:auto;
}
.mobile-menu.open { display:flex; }
.mobile-menu a {
  display:block; padding:0.9rem 0; color:var(--text);
  font-family:'Nunito',sans-serif; font-weight:800; font-size:1rem;
  letter-spacing:0.06em; text-transform:uppercase;
  border-bottom:1px solid var(--border); transition:color 0.2s;
}
.mobile-menu a:hover { color:var(--purple); }
.mobile-menu .mobile-cta {
  display:block; margin-top:1.5rem; text-align:center;
  background:var(--gold); color:var(--dark); padding:16px; border-radius:50px;
  font-family:'Nunito',sans-serif; font-weight:900; font-size:1rem;
  box-shadow:0 6px 20px var(--gold-glow);
}

/* ── BUTTONS ── */
.btn {
  display:inline-flex; align-items:center; gap:8px; padding:14px 28px;
  border-radius:50px; border:none;
  font-family:'Nunito',sans-serif; font-weight:900; font-size:0.85rem;
  letter-spacing:0.05em; text-transform:uppercase; transition:var(--tr); white-space:nowrap; cursor:pointer;
}
.btn-gold { background:var(--gold); color:var(--dark); box-shadow:0 4px 20px var(--gold-glow); }
.btn-gold:hover { background:var(--gold-light); transform:translateY(-3px); box-shadow:0 10px 36px var(--gold-glow); }
.btn-outline-white { background:transparent; color:white; border:2px solid rgba(255,255,255,0.5); }
.btn-outline-white:hover { border-color:white; background:rgba(255,255,255,0.15); }
.btn-purple { background:var(--purple); color:white; box-shadow:0 4px 20px var(--purple-glow); }
.btn-purple:hover { background:var(--purple-light); transform:translateY(-3px); }
.btn-outline-purple { background:transparent; color:var(--purple); border:2px solid var(--purple); }
.btn-outline-purple:hover { background:var(--purple); color:white; }
.btn-white { background:white; color:var(--purple); box-shadow:var(--shadow-md); }
.btn-white:hover { transform:translateY(-3px); box-shadow:var(--shadow-lg); }

/* ── SECTION LABELS ── */
.section-tag {
  display:inline-flex; align-items:center; gap:8px;
  font-family:'Nunito',sans-serif; font-weight:900; font-size:0.7rem;
  letter-spacing:0.2em; text-transform:uppercase; color:var(--purple); margin-bottom:0.8rem;
  background:var(--purple-soft); padding:6px 16px; border-radius:50px;
}
.section-tag::before { content:'⚽'; font-size:0.65rem; }
.section-tag.gold { background:var(--gold-soft); color:var(--purple-dark); }
.section-tag.gold::before { content:'⭐'; }
.section-tag.white { background:rgba(255,255,255,0.12); color:rgba(255,255,255,0.8); }
.section-tag.white::before { content:'⚽'; }

.section-title {
  font-family:'Carena'; font-weight:800;
  font-size:clamp(2.2rem,5vw,3.8rem);
  line-height:1.1; color:var(--dark); margin-bottom:1rem;
}
.section-title .accent { color:var(--purple); }
.section-title .gold   { color:var(--gold); }
.section-title.white   { color:white; }

.section-lead { font-size:1.05rem; color:var(--gray); line-height:1.75; max-width:560px; font-weight:500; }
.section-lead.white { color:rgba(255,255,255,0.7); }

/* ── ANIMATIONS ── */
.reveal       { opacity:0; transform:translateY(30px); transition:opacity 0.6s ease,transform 0.6s ease; }
.reveal-left  { opacity:0; transform:translateX(-30px); transition:opacity 0.6s ease,transform 0.6s ease; }
.reveal-right { opacity:0; transform:translateX(30px); transition:opacity 0.6s ease,transform 0.6s ease; }
.reveal.visible,.reveal-left.visible,.reveal-right.visible { opacity:1; transform:translate(0); }
.d1{transition-delay:0.08s} .d2{transition-delay:0.16s} .d3{transition-delay:0.24s}
.d4{transition-delay:0.32s} .d5{transition-delay:0.4s} .d6{transition-delay:0.48s}

/* ============================================
   HERO — Bright, Warm, Inviting
   ============================================ */
#hero {
  min-height:100vh; position:relative; display:flex; align-items:center;
  background:linear-gradient(165deg, var(--purple-dark) 0%, var(--purple) 45%, var(--purple-light) 100%);
  overflow:hidden;
}

@media (min-width:969px) {
 
  #hero .container {
    position:relative;
    z-index:2;
    display: inline-flex;
    align-items: center;
    gap: 2rem;
    max-width: 1440px;
    margin-top: 3rem;
  }

  #hero .container img{
    height: 100%;
    border-radius: var(--radius-lg);
  }

  #hero .kids-photo:hover img {
    border-radius: var(--radius-lg);
  }

}

@media (max-width:968px) {
  #hero .container{
    display: flex;
    flex-direction: column;
    margin: 3.5rem 0;

    /* .kids-photo { */
      /* border-radius: 100%; */
    /* } */
  }
}

.hero-bg {
  position:absolute; inset:0;
  /* background:url('../images/hero.jpg') center/cover no-repeat; */
  filter:brightness(0.35) saturate(0.8);
  transform:scale(1.05); animation:heroZoom 18s ease-in-out infinite alternate;
}
@keyframes heroZoom { from{transform:scale(1.05)} to{transform:scale(1.12)} }
.hero-overlay {
  position:absolute; inset:0;
  background:radial-gradient(circle at 80% 20%, rgba(245,166,35,0.15) 0%, transparent 50%),
             radial-gradient(circle at 20% 80%, rgba(255,255,255,0.05) 0%, transparent 50%);
}
/* Playful floating soccer balls */
.hero-decor {
  position:absolute; inset:0; pointer-events:none; overflow:hidden;
}
.hero-decor .ball {
  position:absolute; font-size:3rem; opacity:0.08; animation:floatBall 6s ease-in-out infinite;
}
.hero-decor .ball:nth-child(1) { top:15%; right:8%; animation-delay:0s; }
.hero-decor .ball:nth-child(2) { top:60%; right:15%; animation-delay:1.5s; font-size:2rem; }
.hero-decor .ball:nth-child(3) { bottom:20%; left:5%; animation-delay:3s; font-size:4rem; }
.hero-decor .ball:nth-child(4) { top:30%; left:12%; animation-delay:4s; font-size:1.5rem; }
@keyframes floatBall {
  0%,100% { transform:translateY(0) rotate(0deg); }
  50%     { transform:translateY(-20px) rotate(15deg); }
}

.hero-content {
  position:relative; z-index:2; width:100%; max-width:1180px;
  margin:0 auto; padding:60px 1.5rem 80px;
}
.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,0.12); border:1px solid rgba(255,255,255,0.25);
  color:white; padding:8px 20px; border-radius:50px;
  font-family:'Nunito',sans-serif; font-weight:800; font-size:0.72rem;
  letter-spacing:0.15em; text-transform:uppercase; margin-bottom:1.5rem;
  animation:fadeUp 0.8s ease both;
}
.hero-title {
  font-family:'Carena'; font-weight:800;
  font-size:clamp(3.5rem,10vw,8rem);
  color:white; line-height:0.95; margin-bottom:0.3em;
  animation:fadeUp 0.8s 0.06s ease both;
}
.hero-title .line-gold { color:var(--gold-light); display:block; }
.hero-sub {
  font-family:'SF UI Display Bold',sans-serif; font-weight:600;
  font-size:clamp(1rem,2vw,1.2rem); color:rgba(255,255,255,0.85); line-height:1.7;
  max-width:520px; margin-bottom:2.5rem; animation:fadeUp 0.8s 0.12s ease both;
}
.hero-actions { display:flex; gap:1rem; flex-wrap:wrap; animation:fadeUp 0.8s 0.18s ease both; }
.hero-stats {
  display:flex; gap:2.5rem; flex-wrap:wrap; margin-top:3.5rem; padding-top:1.5rem;
  border-top:1px solid rgba(255,255,255,0.15); animation:fadeUp 0.8s 0.24s ease both;
}
.hstat-num { font-family:'Carena',cursive; font-size:2.5rem; color:var(--gold-light); line-height:1; }
.hstat-label {
  font-family:'Nunito',sans-serif; font-weight:700; font-size:0.68rem;
  letter-spacing:0.1em; text-transform:uppercase; color:rgba(255,255,255,0.55); margin-top:2px;
}
@keyframes fadeUp { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:translateY(0)} }

/* ── TICKER ── */
#ticker { background:var(--gold); overflow:hidden; padding:14px 0; }
.ticker-track { display:flex; animation:tickerScroll 20s linear infinite; white-space:nowrap; }
.ticker-item {
  flex-shrink:0; padding:0 2rem; display:flex; align-items:center; gap:10px;
  font-family:'Carena',cursive; font-size:1rem; letter-spacing:0.1em;
  color:var(--dark); font-weight:700;
}
.ticker-item.purple-text { color:var(--purple-dark); }
.ticker-dot { width:8px; height:8px; border-radius:50%; background:var(--purple); }
@keyframes tickerScroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ── KIDS PHOTO STRIP ── */
#kids-strip { background:var(--white); padding:0; overflow:hidden; }
.kids-grid { display:grid; grid-template-columns:repeat(6,1fr); gap:4px; }
.kids-photo { position:relative; overflow:hidden; aspect-ratio:1; border-radius:4px; }
.kids-photo img {
  width:100%; height:100%; object-fit:cover;
  transition:transform 0.5s ease;
}
.kids-photo:hover img { transform:scale(1.08); }

/* ── VISION ── */
#vision { background:var(--cream); }
.vision-grid { display:grid; grid-template-columns:1fr 1.1fr; gap:4rem; align-items:center; }
.vision-card {
  background:linear-gradient(135deg, var(--purple) 0%, var(--purple-light) 100%);
  border-radius:var(--radius-lg); padding:3rem; color:white; position:relative; overflow:hidden;
}
.vision-card::after {
  content:'⚽'; position:absolute; right:-10px; bottom:-15px;
  font-size:9rem; opacity:0.08; line-height:1; pointer-events:none;
}
.vision-card blockquote {
  font-family:'SF UI Display Bold',sans-serif; font-size:1.15rem; font-weight:600; font-style:italic;
  line-height:1.65; border-left:3px solid var(--gold-light); padding-left:1.2rem; margin-bottom:1.2rem;
}
.vision-card cite {
  font-family:'Nunito',sans-serif; font-size:0.82rem; color:var(--gold-light);
  font-style:normal; font-weight:800; letter-spacing:0.08em;
}
.vision-float {
  position:absolute; bottom:-1rem; right:-1rem;
  background:var(--gold); border-radius:16px; padding:1.2rem 1.8rem; color:var(--dark);
  box-shadow:var(--shadow-lg); text-align:center;
}
.vf-num { font-family:'Carena',cursive; font-size:2.2rem; line-height:1; }
.vf-label { font-family:'Nunito',sans-serif; font-weight:800; font-size:0.62rem; letter-spacing:0.1em; text-transform:uppercase; }

/* ── ABOUT ── */
#about { background:var(--white); }
.about-grid { display:grid; grid-template-columns:1.1fr 1fr; gap:4rem; align-items:center; }
.values-row { display:flex; flex-wrap:wrap; gap:0.6rem; margin-top:1.5rem; }
.value-pill {
  display:flex; align-items:center; gap:6px;
  background:var(--purple-soft); border:2px solid transparent;
  border-radius:50px; padding:8px 16px;
  font-family:'Nunito',sans-serif; font-weight:800; font-size:0.78rem;
  color:var(--purple); transition:var(--tr);
}
.value-pill:hover { border-color:var(--purple); background:white; box-shadow:var(--shadow-sm); }
.mindset-list { display:grid; gap:1.2rem; }
.mindset-item {
  display:flex; gap:1.2rem; padding:1.4rem; background:var(--cream); border:2px solid var(--border);
  border-radius:var(--radius); transition:var(--tr); align-items:flex-start;
}
.mindset-item:hover { border-color:var(--purple); background:white; box-shadow:var(--shadow-md); transform:translateY(-3px); }
.mi-icon {
  width:48px; height:48px; min-width:48px; background:var(--purple-soft);
  border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:1.4rem;
}
.mi-title { font-family:'Nunito',sans-serif; font-weight:900; font-size:0.92rem; color:var(--dark); margin-bottom:4px; }
.mi-text { font-family:'SF UI Display Light',sans-serif; font-size:0.88rem; color:var(--gray); line-height:1.6; font-weight:500; }

/* ── PROGRAMS ── */
#programs {
  background:linear-gradient(135deg, var(--purple) 0%, var(--purple-dark) 100%);
  position:relative; overflow:hidden;
}
#programs::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(circle at 80% 20%, rgba(245,166,35,0.15) 0%, transparent 50%),
             radial-gradient(circle at 20% 80%, rgba(255,255,255,0.05) 0%, transparent 50%);
  pointer-events:none;
}
.programs-intro { display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:end; margin-bottom:3rem; position:relative; z-index:1; }
.programs-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem;
  position:relative; z-index:1;
}
.prog-card {
  background:rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.15);
  border-radius:var(--radius-lg); padding:2rem 1.5rem; text-align:center;
  backdrop-filter:blur(8px); transition:var(--tr);
}
.prog-card:hover { background:rgba(255,255,255,0.14); transform:translateY(-5px); border-color:var(--gold); }
.prog-icon { font-size:2.5rem; margin-bottom:1rem; }
.prog-title { font-family:'Carena',cursive; font-size:1.1rem; color:white; margin-bottom:0.6rem; }
.prog-text { font-size:0.88rem; color:rgba(255,255,255,0.65); line-height:1.6; margin-bottom:1rem; font-weight:500; }
.prog-badge {
  display:inline-block; background:var(--gold); color:var(--dark); padding:5px 14px;
  border-radius:50px; font-family:'Nunito',sans-serif; font-weight:900; font-size:0.68rem;
  letter-spacing:0.08em; text-transform:uppercase;
}

/* ── GALLERY ── */
#gallery { background:var(--off-white); }
.gallery-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; margin-top:2rem;
}
.gallery-item {
  border-radius:var(--radius); overflow:hidden; position:relative; cursor:pointer;
  box-shadow:var(--shadow-sm); transition:var(--tr);
}
.gallery-item:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.gallery-item img { width:100%; aspect-ratio:1; object-fit:cover; display:block; transition:transform 0.4s; }
.gallery-item:hover img { transform:scale(1.05); }
.gallery-item.wide { grid-column:span 2; }
.gallery-item.wide img { aspect-ratio:2/1; }
.gallery-caption {
  position:absolute; bottom:0; left:0; right:0;
  background:linear-gradient(to top, rgba(74,37,128,0.9) 0%, transparent 100%);
  padding:1.5rem 1rem 0.8rem; opacity:0; transition:opacity 0.3s;
}
.gallery-item:hover .gallery-caption { opacity:1; }
.gallery-caption-text {
  font-family:'Nunito',sans-serif; font-weight:800; font-size:0.82rem;
  color:white; letter-spacing:0.04em;
}

/* ── TESTIMONIALS ── */
#testimonials {
  background:linear-gradient(135deg, var(--cream) 0%, var(--purple-soft) 100%);
  position:relative;
}
.testi-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; margin-top:2rem; }
.testi-video-card {
  border-radius:var(--radius-lg); overflow:hidden; background:white;
  border:2px solid var(--border); box-shadow:var(--shadow-sm); transition:var(--tr);
}

.testi-video-wrap { aspect-ratio:16/9; }

.testi-video-wrap video {
  width:100%; height:100%; object-fit:cover; display:block; border:none;
  filter:brightness(0.9) contrast(1.1); transition:filter 0.3s;
}

.testi-video-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); }
.testi-video-wrap { aspect-ratio:16/9; }
.testi-video-wrap iframe { width:100%; height:100%; border:none; display:block; }
.testi-info { padding:1.2rem 1.5rem; }
.testi-name { font-family:'Nunito',sans-serif; font-weight:900; font-size:0.95rem; color:var(--dark); margin-bottom:3px; }
.testi-role { font-size:0.78rem; color:var(--purple); font-family:'Nunito',sans-serif; font-weight:700; }

/* ── VIDEOS ── */
#videos { background:var(--white); }
.videos-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; margin-top:2rem; }
.video-featured { grid-column:1/-1; }
.video-wrap {
  border-radius:var(--radius); overflow:hidden; aspect-ratio:16/9; background:var(--dark);
  box-shadow:var(--shadow-md); transition:var(--tr);
}

.video-wrap video { 
  width:100%; 
  height: 100%;
  object-fit:cover; 
  display:block; 
  border:none;  
  filter:brightness(0.95) contrast(1.1);  
  transition:filter 0.3s;
}

.video-featured .video-wrap { aspect-ratio:16/7; }
.video-wrap:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.video-wrap iframe { width:100%; height:100%; border:none; display:block; }

/* ── IMPACT ── */
#impact {
  background:linear-gradient(145deg, var(--purple-dark) 0%, var(--purple) 100%);
  position:relative; overflow:hidden;
}
.impact-top { display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:end; margin-bottom:3rem; }
.impact-kpis { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; margin-bottom:3rem; }
.kpi-card {
  background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.15);
  border-radius:var(--radius-lg); padding:1.8rem 1.2rem; text-align:center; transition:var(--tr);
}
.kpi-card:hover { background:rgba(255,255,255,0.16); transform:translateY(-4px); }
.kpi-num { font-family:'Carena',cursive; font-size:3.2rem; color:var(--gold-light); line-height:1; display:block; }
.kpi-label {
  font-family:'Nunito',sans-serif; font-weight:700; font-size:0.66rem;
  letter-spacing:0.1em; text-transform:uppercase; color:rgba(255,255,255,0.6); margin-top:0.3rem; display:block;
}
.countries-label { font-family:'Nunito',sans-serif; font-weight:800; font-size:0.7rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--gold-light); margin-bottom:1rem; }
.countries-wrap { display:flex; flex-wrap:wrap; gap:0.5rem; }
.country-tag {
  display:inline-flex; align-items:center; gap:5px;
  background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.18);
  color:white; padding:7px 14px; border-radius:50px;
  font-family:'Nunito',sans-serif; font-weight:700; font-size:0.78rem; transition:var(--tr);
}
.country-tag:hover,.country-tag.active { background:var(--gold); border-color:var(--gold); color:var(--dark); font-weight:800; }

/* ── STORY ── */
#story { background:var(--white); }
.story-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.story-visual { position:relative; }
.story-frame {
  border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:4/5;
  background:linear-gradient(165deg, var(--purple-dark), var(--purple-light));
  display:flex; align-items:center; justify-content:center; font-size:6rem; position:relative;
}
.story-frame-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(74,37,128,0.95) 0%, rgba(74,37,128,0.25) 60%, transparent 100%);
}
.story-frame-label { position:absolute; bottom:0; left:0; right:0; padding:1.8rem; z-index:1; }
.sf-name { font-family:'Carena',cursive; font-size:1.7rem; color:var(--gold-light); }
.sf-role { font-family:'Nunito',sans-serif; font-weight:700; font-size:0.75rem; letter-spacing:0.1em; text-transform:uppercase; color:rgba(255,255,255,0.75); }
.story-badge {
  position:absolute; top:-1rem; right:-1rem;
  background:var(--gold); border-radius:50%; width:88px; height:88px;
  display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center;
  font-family:'Nunito',sans-serif; font-weight:900; font-size:0.55rem; letter-spacing:0.06em; text-transform:uppercase;
  color:var(--dark); box-shadow:0 6px 24px var(--gold-glow);
}
.sb-year { font-family:'Carena',cursive; font-size:1.7rem; line-height:1; }
.story-quote {
  font-family:'SF UI Display Bold',sans-serif; font-size:1.05rem; font-weight:600; font-style:italic; line-height:1.7;
  color:var(--text); padding-left:1.2rem; border-left:4px solid var(--gold); margin-bottom:1.5rem;
}
.story-body { font-size:0.95rem; color:var(--gray); line-height:1.8; margin-bottom:1.2rem; font-weight:500; }
.awards { display:grid; gap:0.6rem; margin-top:1.5rem; }
.award-item { display:flex; align-items:center; gap:1rem; padding:0.9rem 1.2rem; background:var(--gold-soft); border-radius:12px; border:1px solid rgba(245,166,35,0.2); }
.award-icon { font-size:1.3rem; }
.award-text { font-family:'Nunito',sans-serif; font-weight:800; font-size:0.8rem; color:var(--dark); line-height:1.4; }

/* ── TEAM ── */
#team { background:var(--cream); }
.team-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; margin-top:2rem; }
.team-card {
  background:white; border:2px solid var(--border); border-radius:var(--radius-lg);
  padding:2rem 1.2rem; text-align:center; transition:var(--tr);
}
.team-card:hover { border-color:var(--purple); transform:translateY(-5px); box-shadow:var(--shadow-lg); }
.team-avatar {
  width:72px; height:72px; border-radius:50%;
  background:linear-gradient(135deg, var(--purple), var(--purple-light));
  margin:0 auto 0.8rem; display:flex; align-items:center; justify-content:center;
  font-family:'Carena',cursive; font-size:1.5rem; color:white;
  box-shadow:0 4px 16px var(--purple-glow);
}
.team-name { font-family:'Nunito',sans-serif; font-weight:900; font-size:0.88rem; color:var(--dark); margin-bottom:3px; }
.team-role { font-family:'Nunito',sans-serif; font-weight:700; font-size:0.65rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--purple); margin-bottom:0.5rem; }
.team-email { font-size:0.72rem; color:var(--gray); word-break:break-all; transition:color 0.2s; }
.team-email:hover { color:var(--purple); }

/* ── PARTNERS — MINIATURE SIDE BY SIDE ── */
#partners { background:var(--white); }
.partners-strip {
  display:flex; flex-wrap:wrap; justify-content:center; align-items:center;
  gap:2rem; margin-top:2rem; padding:1.5rem 2rem;
  background:var(--lavender); border-radius:var(--radius-lg); border:2px solid var(--border);
}
.partner-logo {
  display:flex; align-items:center; justify-content:center;
  flex:0 0 auto; transition:var(--tr);
}
.partner-logo:hover { transform:scale(1.1); }
.partner-logo img { height:80px; object-fit:contain; filter:grayscale(30%); transition:filter 0.3s; border-radius: .5rem; }
.partner-logo:hover img { filter:grayscale(0%); }

/* ── REGISTER ── */
#register { background:var(--dark); position:relative; overflow:hidden; }
#register::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 15% 50%, rgba(108,63,160,0.35) 0%, transparent 55%),
             radial-gradient(ellipse at 85% 50%, rgba(245,166,35,0.1) 0%, transparent 55%);
  pointer-events:none;
}
.register-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:start; position:relative; z-index:1; }
.reg-info-items { display:grid; gap:1.2rem; margin-top:2rem; }
.reg-info-item { display:flex; gap:1rem; align-items:flex-start; }
.rii-icon {
  width:42px; height:42px; min-width:42px;
  background:rgba(245,166,35,0.12); border:1px solid rgba(245,166,35,0.3);
  border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:1.1rem;
}
.rii-title { font-family:'Nunito',sans-serif; font-weight:900; font-size:0.88rem; color:white; margin-bottom:2px; }
.rii-sub   { font-size:0.82rem; color:rgba(255,255,255,0.5); line-height:1.5; }
.reg-form-box {
  background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.12);
  border-radius:var(--radius-lg); padding:2.5rem; backdrop-filter:blur(12px);
}
.reg-form-title { font-family:'Carena',cursive; font-size:1.2rem; color:white; margin-bottom:1.5rem; padding-bottom:1rem; border-bottom:1px solid rgba(255,255,255,0.1); }
.form-group { margin-bottom:1rem; }
.form-label { display:block; font-family:'Nunito',sans-serif; font-weight:800; font-size:0.68rem; letter-spacing:0.08em; text-transform:uppercase; color:rgba(255,255,255,0.55); margin-bottom:5px; }
.form-input {
  width:100%; padding:11px 14px; background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.14); border-radius:10px; color:white;
  font-family:'SF UI Display Bold',sans-serif; font-size:0.9rem; font-weight:500; transition:var(--tr); outline:none; appearance:none;
}
.form-input:focus { border-color:var(--gold); background:rgba(255,255,255,0.12); }
.form-input::placeholder { color:rgba(255,255,255,0.3); }
.form-input option { background:var(--dark-2); color:white; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:0.8rem; }
.form-submit {
  width:100%; padding:14px; background:var(--gold); color:var(--dark); border:none;
  border-radius:50px; font-family:'Nunito',sans-serif; font-weight:900; font-size:0.88rem;
  letter-spacing:0.06em; text-transform:uppercase; cursor:pointer; transition:var(--tr); margin-top:0.5rem;
  box-shadow:0 4px 20px var(--gold-glow);
}
.form-submit:hover { background:var(--gold-light); transform:translateY(-2px); box-shadow:0 8px 28px var(--gold-glow); }
.form-success { display:none; text-align:center; padding:2.5rem 1rem; }
.form-success.show { display:block; }
.form-success-icon { font-size:3rem; margin-bottom:0.8rem; }
.form-success h3 { font-family:'Carena',cursive; font-size:1.8rem; color:var(--gold-light); margin-bottom:0.8rem; }
.form-success p { color:rgba(255,255,255,0.7); font-size:0.92rem; line-height:1.6; }

/* ── WIDGET ── */
#widget { background:var(--off-white); }
.widget-preview { max-width:360px; margin:1.5rem auto; background:white; border:2px solid var(--purple); border-radius:var(--radius-lg); padding:2rem; box-shadow:var(--shadow-lg); }
.wp-logo { height:42px; object-fit:contain; margin:0 auto 1rem; display:block; }
.wp-title { font-family:'Carena',cursive; font-size:1.3rem; color:var(--purple); margin-bottom:4px; }
.wp-text { font-size:0.8rem; color:var(--gray); line-height:1.55; margin-bottom:1.2rem; }
.wp-btn { display:block; width:100%; padding:10px; border-radius:50px; border:none; font-family:'Nunito',sans-serif; font-weight:900; font-size:0.8rem; letter-spacing:0.06em; text-transform:uppercase; margin-bottom:0.5rem; cursor:pointer; transition:var(--tr); }
.wp-btn-gold { background:var(--gold); color:var(--dark); }
.wp-btn-gold:hover { background:var(--gold-light); }
.wp-btn-purple { background:var(--purple); color:white; }
.wp-btn-purple:hover { background:var(--purple-light); }
.code-box { background:var(--dark); border-radius:14px; padding:1.5rem; max-width:600px; margin:2rem auto 0; text-align:left; position:relative; }
.code-box pre { font-family:'Courier New',monospace; font-size:0.75rem; color:#98c379; line-height:1.6; word-break:break-word; white-space:pre-wrap; }
.code-copy { position:absolute; top:0.8rem; right:0.8rem; background:var(--purple); color:white; border:none; border-radius:8px; padding:5px 12px; font-family:'Nunito',sans-serif; font-weight:800; font-size:0.7rem; cursor:pointer; transition:var(--tr); }

/* ── SOCIAL ── */
#social-section { background:var(--lavender); padding:60px 0; text-align:center; }
.social-btns { display:flex; justify-content:center; gap:0.8rem; flex-wrap:wrap; margin-top:1.5rem; }
.soc-btn { display:inline-flex; align-items:center; gap:8px; padding:12px 22px; border-radius:50px; font-family:'Nunito',sans-serif; font-weight:800; font-size:0.82rem; letter-spacing:0.04em; text-decoration:none; transition:var(--tr); }
.soc-btn-ig { background:linear-gradient(135deg,#f09433 0%,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888 100%); color:white; }
.soc-btn-fb { background:#1877F2; color:white; }
.soc-btn:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); }

/* ── FOOTER ── */
footer { background:var(--dark); color:white; padding:60px 0 25px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:2.5rem; padding-bottom:2.5rem; border-bottom:1px solid rgba(255,255,255,0.08); }
.footer-brand-logo { height:44px; object-fit:contain; margin-bottom:0.8rem; }
.footer-brand-desc { font-size:0.82rem; color:rgba(255,255,255,0.4); line-height:1.7; margin-bottom:1.2rem; }
.footer-socials { display:flex; gap:0.6rem; }
.footer-soc-btn { width:34px; height:34px; border-radius:10px; background:rgba(255,255,255,0.08); border:none; display:flex; align-items:center; justify-content:center; font-size:0.9rem; text-decoration:none; transition:var(--tr); }
.footer-soc-btn:hover { background:var(--gold); transform:translateY(-3px); }
.footer-col-title { font-family:'Nunito',sans-serif; font-weight:900; font-size:0.7rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--gold); margin-bottom:1rem; }
.footer-links { list-style:none; display:grid; gap:0.5rem; }
.footer-links a { color:rgba(255,255,255,0.4); font-size:0.82rem; transition:color 0.2s; }
.footer-links a:hover { color:white; }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; padding-top:1.5rem; }
.footer-copy { font-size:0.75rem; color:rgba(255,255,255,0.25); }
.footer-slogan { font-family:'Carena',cursive; font-size:1rem; letter-spacing:0.15em; color:var(--gold); }

/* ── BACK TO TOP ── */
#back-top {
  position:fixed; bottom:1.5rem; right:1.5rem; z-index:900; width:44px; height:44px;
  border-radius:50%; background:var(--purple); color:white; border:none;
  display:flex; align-items:center; justify-content:center; font-size:1.1rem;
  cursor:pointer; transition:var(--tr); opacity:0; pointer-events:none;
  box-shadow:var(--shadow-md);
}
#back-top.visible { opacity:1; pointer-events:auto; }
#back-top:hover { background:var(--gold); color:var(--dark); transform:translateY(-3px); }

/* ── TOAST ── */
#toast {
  position:fixed; bottom:5rem; right:1.5rem; z-index:999;
  background:white; color:var(--dark); border:2px solid var(--gold); border-radius:14px;
  padding:0.8rem 1.2rem; font-family:'Nunito',sans-serif; font-weight:700; font-size:0.85rem;
  box-shadow:var(--shadow-lg);
  opacity:0; transform:translateY(10px); transition:all 0.35s; pointer-events:none;
}
#toast.show { opacity:1; transform:translateY(0); }

/* ============================================
   RESPONSIVE — Mobile-First Fixes
   ============================================ */
@media(max-width:1100px){
  .programs-grid { grid-template-columns:repeat(2,1fr); }
  .team-grid     { grid-template-columns:repeat(3,1fr); }
  .impact-kpis   { grid-template-columns:repeat(2,1fr); }
  .footer-grid   { grid-template-columns:1fr 1fr; }
  .kids-grid     { grid-template-columns:repeat(3,1fr); }
  .testi-grid    { grid-template-columns:1fr; }
}

@media(max-width:1245px){
  .navbar-links,.btn-nav-cta { display:none; }
  .hamburger { display:flex; }
}

@media(max-width:768px){
  .section   { padding:55px 0; }
  .vision-grid,.about-grid,.story-grid { grid-template-columns:1fr; gap:2rem; }
  .impact-top      { grid-template-columns:1fr; gap:1.5rem; }
  .programs-intro  { grid-template-columns:1fr; gap:1.2rem; }
  .programs-grid   { grid-template-columns:1fr; }
  .videos-grid     { grid-template-columns:1fr; }
  .video-featured  { grid-column:1; }
  .video-featured .video-wrap { aspect-ratio:16/9; }
  .team-grid       { grid-template-columns:repeat(2,1fr); }
  .register-grid   { grid-template-columns:1fr; gap:2.5rem; }
  .form-row        { grid-template-columns:1fr; }
  .footer-grid     { grid-template-columns:1fr; gap:1.5rem; }
  .kids-grid       { grid-template-columns:repeat(3,1fr); }
  .gallery-grid    { grid-template-columns:1fr 1fr; }
  .gallery-item.wide { grid-column:1; }
  .gallery-item.wide img { aspect-ratio:1; }
  .vision-float    { position:static; margin-top:1rem; border-radius:12px; }
  .story-badge     { display:none; }
  .impact-kpis     { grid-template-columns:repeat(2,1fr); }
  .partners-strip  { gap:1.5rem; padding:1.2rem 1rem; }
  .partner-logo img { height:32px; }
  .hero-title      { font-size:clamp(3rem,12vw,5rem); }
  .hero-stats      { gap:1.5rem; }
}
@media(max-width:480px){
  .container       { padding:0 1rem; }
  .hero-actions    { flex-direction:column; }
  .hero-actions .btn { width:100%; justify-content:center; }
  .hero-stats      { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
  .team-grid       { grid-template-columns:1fr 1fr; gap:0.8rem; }
  .team-card       { padding:1.5rem 1rem; }
  /* .kids-grid       { grid-template-columns:repeat(2,1fr); } */
  .social-btns     { flex-direction:column; align-items:center; }
  .footer-bottom   { flex-direction:column; text-align:center; }
  .gallery-grid    { grid-template-columns:1fr 1fr; }
  .partners-strip  { gap:1rem; }
  .partner-logo img { height:80px; border-radius: .2rem; }
  .section-title   { font-size:clamp(1.8rem,7vw,2.5rem); }
}

@media(max-width:768px){
  .kids-grid { display: none; }
}
