:root{
  --navy:#173f86;
  --navy-2:#0f2f70;
  --blue:#29a6ef;
  --blue-soft:#dff5ff;
  --sky:#effbff;
  --green:#35bc42;
  --green-soft:#e6ffe8;
  --orange:#ff9600;
  --orange-soft:#fff0d9;
  --red:#ff5454;
  --yellow:#ffd34e;
  --white:#ffffff;
  --text:#123671;
  --shadow:0 18px 40px rgba(35,98,164,.16);
  --shadow-soft:0 10px 24px rgba(35,98,164,.10);
  --radius-xl:34px;
  --radius-lg:26px;
  --radius-md:20px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Nunito", "Segoe UI", system-ui, sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at 10% 10%, rgba(76,196,255,.28), transparent 18%),
    radial-gradient(circle at 86% 18%, rgba(255,198,74,.22), transparent 14%),
    radial-gradient(circle at 88% 74%, rgba(62,198,93,.12), transparent 16%),
    linear-gradient(180deg,#d8f4ff 0%, #f8fdff 38%, #eef9ff 72%, #dff5ff 100%);
  overflow-x:hidden;
}
body::before,
body::after{
  content:"";
  position:fixed;
  inset:auto;
  z-index:-1;
  opacity:.45;
  pointer-events:none;
}
body::before{
  width:130px;height:130px;left:-36px;bottom:150px;
  background:radial-gradient(circle at 30% 30%, #87ddff 0 18%, transparent 20%), radial-gradient(circle at 70% 50%, #8ce99d 0 14%, transparent 16%), radial-gradient(circle at 45% 75%, #ffc861 0 18%, transparent 20%);
  filter:blur(1px);
}
body::after{
  width:110px;height:110px;right:-25px;top:210px;border-radius:50%;
  background:radial-gradient(circle, rgba(56,183,237,.18) 0 35%, transparent 37%), radial-gradient(circle at 65% 60%, rgba(255,147,0,.18) 0 18%, transparent 20%);
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(1140px,92vw);margin-inline:auto}
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(220,247,255,.8);
  backdrop-filter:blur(15px);
  border-bottom:1px solid rgba(255,255,255,.7);
}
.nav{height:92px;display:flex;align-items:center;gap:28px}
.brand img{width:220px;max-height:78px;object-fit:contain}
.nav-links{display:flex;align-items:center;gap:30px;margin-left:auto;font-weight:900;font-size:15px}
.nav-links a{position:relative;padding:12px 2px;color:var(--navy-2)}
.nav-links a.active::after,
.nav-links a:hover::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:4px;background:var(--navy);border-radius:99px;
}
.menu-toggle{display:none;border:0;background:transparent;color:var(--navy);font-size:34px;font-weight:900;margin-left:auto}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border-radius:999px;padding:15px 25px;font-weight:900;color:#fff;
  box-shadow:0 13px 24px rgba(0,0,0,.14);transition:.22s ease;line-height:1.08;text-align:center;
}
.btn:hover{transform:translateY(-3px) scale(1.01);filter:saturate(1.06)}
.btn-whatsapp{background:linear-gradient(180deg,#49cf59,#23a736)}
.btn-call{background:linear-gradient(180deg,#34acef,#0e84d4)}
.btn-small{font-size:14px;padding:12px 18px}
.nav-cta{padding:12px 21px;white-space:nowrap}
.section-kicker{
  margin:0 0 6px;
  font-size:15px;
  font-weight:900;
  color:#2b98df;
  letter-spacing:.02em;
}
.section-kicker.light{color:#ddf7ff}
.hero{
  padding:34px 0 84px;
  position:relative;
  overflow:hidden;
}
.hero::after{
  content:"";
  position:absolute;left:-2%;right:-2%;bottom:-56px;height:120px;
  background:#f6fcff;
  border-radius:55% 45% 0 0/100% 100% 0 0;
  box-shadow:0 -1px 0 rgba(255,255,255,.65) inset;
}
.hero-grid{display:grid;grid-template-columns:44% 56%;align-items:center;gap:34px;position:relative;z-index:1}
.hero-copy-card{
  position:relative;
  padding:18px 6px 18px 0;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;border-radius:999px;padding:12px 24px;font-weight:900;
  box-shadow:var(--shadow-soft);margin:0 0 18px;font-size:18px;
}
.hero h1{
  font-family:"Baloo 2", "Trebuchet MS", sans-serif;
  font-size:clamp(66px,8vw,108px);
  line-height:.9;margin:0 0 16px;letter-spacing:-2px;color:var(--navy);
}
.lead{
  font-size:clamp(23px,2.9vw,37px);
  font-weight:900;line-height:1.08;margin:0 0 26px;max-width:560px;
}
.hero-tags{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:28px;font-weight:900}
.hero-tags span{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.82);border-radius:999px;padding:11px 16px;
  box-shadow:var(--shadow-soft);font-size:16px;
}
.tag-puzzle{color:#2b98df}
.tag-ball{color:#329c3d}
.tag-sun{color:#ff8d11}
.hero-actions{display:flex;gap:18px;flex-wrap:wrap}
.hero-media{position:relative;isolation:isolate;padding:12px 0 0}
.hero-photo-wrap{
  position:relative;
  border-radius:40% 60% 48% 52%/42% 36% 64% 58%;
  background:linear-gradient(135deg,rgba(255,255,255,.92),rgba(73,196,241,.4));
  padding:16px;
  box-shadow:var(--shadow);
}
.hero-photo-wrap::before,
.hero-photo-wrap::after{
  content:"";
  position:absolute;
  border-radius:50%;
  z-index:-1;
}
.hero-photo-wrap::before{width:88px;height:88px;left:-24px;top:26px;background:rgba(255,157,0,.24)}
.hero-photo-wrap::after{width:56px;height:56px;right:20px;bottom:-16px;background:rgba(47,193,91,.24)}
.hero-media img{
  aspect-ratio:1.33;object-fit:cover;
  border-radius:38% 62% 47% 53%/42% 36% 64% 58%;
  box-shadow:var(--shadow-soft);
}
.blob{position:absolute;border-radius:50%;z-index:2;box-shadow:var(--shadow-soft)}
.blob-one{width:66px;height:66px;right:12%;bottom:-14px;background:#ff9818}
.blob-two{width:42px;height:42px;right:2%;top:68%;background:#49c6f1}
.blob-three{width:28px;height:28px;left:8%;top:8%;background:#61d36b}
.hero-floating{
  position:absolute;border-radius:999px;opacity:.85;filter:drop-shadow(0 12px 18px rgba(34,113,170,.08));
}
.hero-floating-one{width:16px;height:16px;left:7%;top:140px;background:#74d0ff}
.hero-floating-two{width:24px;height:24px;right:39%;top:120px;background:#9de4ff}
.hero-floating-three{width:18px;height:18px;right:9%;top:100px;background:#ffbd4d}
.playful-section{position:relative}
.playful-section::before,
.playful-section::after{
  content:"";position:absolute;border-radius:50%;opacity:.6;pointer-events:none;
}
.playful-section::before{width:18px;height:18px;left:8%;top:54px;background:#65cef6}
.playful-section::after{width:28px;height:28px;right:6%;bottom:40px;background:#8de58d}
.section-heading{text-align:center;margin-bottom:28px}
.section-heading.align-left{text-align:left}
.section-heading h2{
  font-family:"Baloo 2", "Trebuchet MS", sans-serif;
  font-size:clamp(34px,4vw,48px);line-height:.95;margin:0;color:var(--navy)
}
.section-heading span{
  display:block;width:72px;height:12px;margin:8px auto 0;border-bottom:5px solid var(--blue);border-radius:50%
}
.section-heading.align-left span{margin-left:0;margin-right:auto}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.program-card{
  text-align:center;border-radius:28px;padding:36px 28px 30px;min-height:270px;
  box-shadow:var(--shadow);background:rgba(255,255,255,.82);position:relative;overflow:hidden;border:2px solid rgba(255,255,255,.55)
}
.program-card::before{
  content:"";position:absolute;inset:auto auto -55px -28px;width:110px;height:110px;border-radius:50%;background:rgba(255,255,255,.46)
}
.program-card::after{
  content:"";position:absolute;right:-20px;top:-20px;width:88px;height:88px;border-radius:30px;background:rgba(255,255,255,.38);transform:rotate(18deg)
}
.program-card>*{position:relative;z-index:1}
.program-sticker{
  position:absolute;right:18px;top:18px;
  width:46px;height:46px;border-radius:14px;
  display:grid;place-items:center;font-size:22px;background:#fff;box-shadow:var(--shadow-soft)
}
.program-card .icon{font-size:62px}
.program-card h3{
  font-family:"Baloo 2", "Trebuchet MS", sans-serif;
  font-size:31px;line-height:.92;margin:10px 0 10px
}
.program-card p{font-weight:800;margin:0;font-size:16px;line-height:1.4}
.program-card .age{font-weight:900}
.program-card.blue{background:linear-gradient(135deg,#e3f7ff,#cfeeff)}
.program-card.green{background:linear-gradient(135deg,#f0ffef,#ddf6dc)}
.program-card.orange{background:linear-gradient(135deg,#fff6e8,#ffe8cb)}
.program-card.blue h3{color:#218ee0}
.program-card.green h3{color:#32af3e}
.program-card.orange h3{color:#f07d00}
.why{
  display:grid;grid-template-columns:1fr 1.38fr;gap:40px;align-items:center;padding:54px 0 10px
}
.why-list{
  background:rgba(255,255,255,.7);border-radius:30px;padding:26px 26px 30px;box-shadow:var(--shadow-soft)
}
.benefits{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.benefits div{
  display:flex;align-items:center;gap:12px;font-size:14px;padding:8px 0
}
.benefits span{
  display:grid;place-items:center;width:48px;height:48px;border-radius:16px;background:#fff;box-shadow:var(--shadow-soft);font-size:22px;flex:0 0 auto
}
.photo-frame{
  padding:12px;background:#fff;border-radius:30px;box-shadow:var(--shadow);position:relative
}
.playful-frame::before,
.playful-frame::after{
  content:"";position:absolute;border-radius:50%;z-index:0;opacity:.85
}
.playful-frame::before{width:36px;height:36px;left:-12px;bottom:24px;background:#6ad1ff}
.playful-frame::after{width:28px;height:28px;right:-8px;top:22px;background:#ffcf5b}
.why-photo img{position:relative;z-index:1;border-radius:22px;box-shadow:var(--shadow-soft);width:100%;height:280px;object-fit:cover}
.activities{padding:22px 0 16px}
.activity-row{display:grid;grid-template-columns:repeat(6,1fr);gap:18px;text-align:center}
.activity-row div{
  background:rgba(255,255,255,.7);
  border-radius:24px;padding:18px 12px 16px;box-shadow:var(--shadow-soft);
}
.activity-row span{display:block;font-size:42px;line-height:1}
.activity-row strong{display:block;font-size:15px;margin-top:10px;line-height:1.15}
.gallery{padding:14px 0 34px;text-align:center}
.section-heading.compact{margin-bottom:16px}
.gallery-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.gallery-grid img{
  height:122px;width:100%;object-fit:cover;border-radius:18px;box-shadow:0 12px 22px rgba(0,0,0,.12);border:4px solid rgba(255,255,255,.7)
}
.gallery-grid img:nth-child(2n){transform:translateY(12px)}
.gallery-grid img:nth-child(3n){transform:translateY(-8px)}
.mini-btn{
  display:inline-flex;margin-top:12px;background:#168cda;color:#fff;padding:10px 21px;border-radius:999px;font-weight:900;box-shadow:var(--shadow);font-size:14px
}
.about{padding:28px 0 34px}
.about-card{
  display:grid;grid-template-columns:40% 60%;gap:34px;align-items:center;
  background:linear-gradient(135deg,rgba(255,255,255,.92),rgba(245,252,255,.95));
  border-radius:30px;padding:16px 24px 16px 16px;box-shadow:var(--shadow);overflow:hidden;position:relative
}
.about-card::after{
  content:"";position:absolute;right:-34px;bottom:-34px;width:180px;height:180px;border-radius:46% 54% 61% 39%/45% 52% 48% 55%;background:linear-gradient(135deg,rgba(57,188,240,.22),rgba(55,200,89,.18));
}
.about-image-wrap{position:relative;z-index:1}
.about-image-wrap::before{
  content:"";position:absolute;left:-12px;top:-10px;width:64px;height:64px;border-radius:18px;background:rgba(255,150,21,.18);transform:rotate(14deg)
}
.about-card img{height:210px;width:100%;object-fit:cover;border-radius:22px;position:relative;z-index:1;box-shadow:var(--shadow-soft)}
.about-card h2{
  font-family:"Baloo 2", "Trebuchet MS", sans-serif;
  font-size:38px;line-height:.98;margin:0 0 14px;position:relative;z-index:1
}
.about-card h2 span{color:var(--red)}
.about-card p{font-weight:800;line-height:1.45;margin:0 0 18px;position:relative;z-index:1}
.final-cta{
  background:linear-gradient(135deg,#4cc7f1,#8ee3ff);
  text-align:center;color:#fff;padding:48px 0 40px;position:relative;overflow:hidden
}
.final-cta::before,
.final-cta::after{
  content:"";position:absolute;border-radius:50%;background:rgba(255,255,255,.2)
}
.final-cta::before{width:180px;height:180px;left:-60px;bottom:-70px}
.final-cta::after{width:120px;height:120px;right:-20px;top:-20px}
.final-cta h2{
  font-family:"Baloo 2", "Trebuchet MS", sans-serif;
  font-size:46px;line-height:1;margin:0;position:relative;z-index:1
}
.final-cta p{font-size:19px;font-weight:800;margin:8px 0 20px;position:relative;z-index:1}
.footer{
  background:#eaf9ff;padding:28px 0 14px;font-weight:700;position:relative
}
.footer::before{
  content:"";position:absolute;left:0;right:0;top:-36px;height:48px;background:#eaf9ff;border-radius:50% 50% 0 0/100% 100% 0 0;
}
.footer-grid{display:grid;grid-template-columns:1.2fr repeat(3,1fr);gap:25px;align-items:start;position:relative;z-index:1}
.footer img{width:140px}
.footer p{margin:6px 0;font-size:14px}
.copyright{text-align:center;font-size:12px;margin:14px 0 0;color:#547095;position:relative;z-index:1}
.floating-whatsapp{position:fixed;right:22px;bottom:22px;width:62px;height:62px;border-radius:50%;display:grid;place-items:center;background:#25d366;color:#fff;font-size:31px;box-shadow:0 12px 28px rgba(0,0,0,.22);z-index:60}
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

@media (max-width:980px){
  .nav{height:auto;min-height:82px}
  .brand img{width:170px}
  .menu-toggle{display:block}
  .nav-links{position:absolute;left:4vw;right:4vw;top:84px;background:white;border-radius:20px;box-shadow:var(--shadow);padding:18px;display:none;flex-direction:column;gap:8px}
  .nav-links.open{display:flex}
  .nav-cta{display:none}
  .hero-grid,.why,.about-card{grid-template-columns:1fr}
  .hero-copy{text-align:center}
  .hero-copy-card{padding-right:0}
  .hero-tags,.hero-actions{justify-content:center}
  .cards{grid-template-columns:1fr}
  .activity-row{grid-template-columns:repeat(3,1fr)}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .about-card{padding:16px}
  .about-card img,.why-photo img{height:240px}
  .hero h1{letter-spacing:-1px}
  .section-heading.align-left,.compact-mobile{text-align:center}
  .section-heading.align-left span{margin-left:auto;margin-right:auto}
}

@media (max-width:560px){
  .container{width:min(92vw,480px)}
  .hero{padding-top:18px;padding-bottom:70px}
  .hero h1{font-size:58px}
  .lead{font-size:24px}
  .btn{width:100%}
  .hero-actions{gap:12px}
  .activity-row{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid img:nth-child(2n),
  .gallery-grid img:nth-child(3n){transform:none}
  .footer-grid{grid-template-columns:1fr}
  .final-cta h2{font-size:34px}
  .about-card h2{font-size:31px}
  .benefits{grid-template-columns:1fr}
  .program-card{min-height:auto}
  .why-list{padding:20px}
  .hero-photo-wrap{padding:10px}
}
