:root {
  --navy: #0F1B33;
  --red:  #E83030;
  --orange: #FF8C00;
  --yellow: #FFD600;
  --green:  #00C853;
  --blue:   #00B0FF;
  --purple: #AA00FF;
  --cream:  #F5F0E8;
  --grey:   #6B7280;
  --tan:    #D4C5B9;
  --white:  #ffffff;
  --shadow:      0 8px 32px rgba(15,27,51,.08);
  --shadow-hover:0 16px 48px rgba(15,27,51,.14);
  --radius-card: 24px;
  --radius-btn:  999px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Nunito',Arial,sans-serif;background:var(--cream);color:var(--navy);line-height:1.65;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block;border-radius:16px}
h1,h2,h3,h4{font-family:'Fredoka',Arial,sans-serif;line-height:1.08;letter-spacing:-.01em}

/* ── UTILS ── */
.container{max-width:1200px;margin:0 auto;padding:0 28px}
.section{padding:96px 0}
.section-sm{padding:60px 0}
.eyebrow{display:inline-block;font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--red);margin-bottom:14px}
.lead{font-size:1.08rem;color:var(--grey);max-width:680px;margin-top:12px}
.center{text-align:center}
.center .lead{margin-left:auto;margin-right:auto}
.mt16{margin-top:16px}.mt24{margin-top:24px}.mt32{margin-top:32px}.mt40{margin-top:40px}.mt48{margin-top:48px}

/* ── RAINBOW BAR ── */
.rainbow-bar{height:4px;border-radius:999px;background:linear-gradient(90deg,var(--red),var(--orange),var(--yellow),var(--green),var(--blue),var(--purple))}
.rainbow-text{background:linear-gradient(90deg,var(--red),var(--orange),var(--yellow),var(--green),var(--blue),var(--purple));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 28px;border-radius:var(--radius-btn);font-family:'Nunito',Arial,sans-serif;font-weight:800;font-size:1rem;cursor:pointer;border:none;transition:transform .22s ease,box-shadow .22s ease,background .22s ease}
.btn-primary{background:linear-gradient(135deg,var(--red),var(--orange));color:#fff;box-shadow:0 4px 16px rgba(232,48,48,.30)}
.btn-primary:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 8px 24px rgba(232,48,48,.38)}
.btn-outline{border:2px solid var(--red);color:var(--red);background:transparent}
.btn-outline:hover{background:linear-gradient(135deg,var(--red),var(--orange));color:#fff;transform:translateY(-2px)}
.btn-white{background:#fff;color:var(--red);box-shadow:0 4px 16px rgba(0,0,0,.10)}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.14)}

/* ── NAV ── */
.site-nav{position:sticky;top:0;z-index:100;background:rgba(245,240,232,.93);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(15,27,51,.07);transition:box-shadow .25s}
.site-nav.scrolled{box-shadow:0 2px 20px rgba(15,27,51,.09)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:15px 0;gap:16px}
.nav-logo{font-family:'Fredoka',Arial,sans-serif;font-size:1.42rem;font-weight:700;color:var(--navy);display:flex;align-items:center;gap:6px;width:600px;}
.nav-logo .dot{width:9px;height:9px;border-radius:50%;background:var(--red);display:inline-block}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{padding:8px 14px;border-radius:999px;font-weight:700;font-size:.95rem;transition:background .18s,color .18s}
.nav-links a:hover,.nav-links a.active{background:#fff;color:var(--red);box-shadow:var(--shadow)}
.nav-hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px;border-radius:10px;flex-direction:column;gap:5px}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--navy);border-radius:2px;transition:.25s}
.mobile-menu{display:none;position:absolute;top:100%;left:0;right:0;background:var(--cream);border-bottom:1px solid rgba(15,27,51,.08);padding:16px 28px 24px;flex-direction:column;gap:6px}
.mobile-menu.open{display:flex}
.mobile-menu a{padding:12px 16px;border-radius:14px;font-weight:700;font-size:1rem}
.mobile-menu a:hover{background:#fff;color:var(--red)}
.mobile-menu .btn{margin-top:8px;width:100%;justify-content:center}

/* ── HERO ── */
.hero{position:relative;overflow:hidden;min-height:88vh;display:flex;align-items:center;background:
  radial-gradient(ellipse 55% 55% at 8% 12%, rgba(255,214,0,.28) 0%, transparent 70%),
  radial-gradient(ellipse 45% 45% at 88% 18%, rgba(0,176,255,.20) 0%, transparent 70%),
  radial-gradient(ellipse 40% 40% at 60% 85%, rgba(170,0,255,.13) 0%, transparent 70%),
  radial-gradient(ellipse 35% 35% at 20% 80%, rgba(0,200,83,.13) 0%, transparent 70%),
  linear-gradient(160deg, #fdfaf5 0%, var(--cream) 100%)}
.hero-blobs{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.blob{position:absolute;border-radius:50%;filter:blur(55px);opacity:.55;animation:blobDrift 12s ease-in-out infinite alternate}
.blob1{width:380px;height:380px;background:radial-gradient(circle,rgba(232,48,48,.45),transparent 70%);top:-80px;left:-60px;animation-delay:0s}
.blob2{width:300px;height:300px;background:radial-gradient(circle,rgba(255,214,0,.50),transparent 70%);top:40px;right:5%;animation-delay:-4s}
.blob3{width:260px;height:260px;background:radial-gradient(circle,rgba(0,176,255,.40),transparent 70%);bottom:40px;left:30%;animation-delay:-8s}
.blob4{width:220px;height:220px;background:radial-gradient(circle,rgba(0,200,83,.35),transparent 70%);bottom:-40px;right:12%;animation-delay:-2s}
@keyframes blobDrift{from{transform:translate(0,0) scale(1)}to{transform:translate(30px,25px) scale(1.08)}}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;padding:60px 0}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid rgba(232,48,48,.18);border-radius:999px;padding:8px 18px;font-size:.82rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--red);margin-bottom:22px;box-shadow:0 2px 12px rgba(232,48,48,.10)}
.hero-eyebrow::before{content:'🎨';font-size:1rem}
.hero-title{font-size:clamp(3.2rem,5.5vw,6.5rem);line-height:.9;margin-bottom:22px;letter-spacing:-.035em}
.hero-title .line2{display:block}
.hero-sub{font-size:1.12rem;color:#3d4e66;max-width:520px;line-height:1.65}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.hero-card{background:#fff;border-radius:28px;box-shadow:0 12px 40px rgba(15,27,51,.11);padding:0;overflow:hidden;position:relative}
.hero-card-top{background:conic-gradient(from 200deg,var(--red),var(--orange),var(--yellow),var(--green),var(--blue),var(--purple),var(--red));padding:5px;border-radius:28px}
.hero-card-body{background:#fff;border-radius:24px;padding:36px 28px;text-align:center}
.hero-card-body h3{font-size:1.75rem;line-height:1.1;margin-bottom:10px}
.hero-card-body p{color:var(--grey);font-size:.95rem}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:20px}
.stat{background:var(--cream);border-radius:16px;padding:14px 10px;text-align:center}
.stat strong{display:block;font-family:'Fredoka',Arial,sans-serif;font-size:1.6rem;color:var(--navy)}
.stat span{font-size:.78rem;font-weight:700;color:var(--grey);letter-spacing:.05em;text-transform:uppercase}

/* ── CARDS & GRID ── */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.card{background:#fff;border-radius:var(--radius-card);box-shadow:var(--shadow);padding:28px;transition:transform .25s ease,box-shadow .25s ease}
.card:hover{transform:translateY(-7px);box-shadow:var(--shadow-hover)}
.card-icon{width:54px;height:54px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;margin-bottom:18px}
.card h3{font-size:1.2rem;margin-bottom:9px}
.card p{color:var(--grey);font-size:.96rem}

/* ── PROGRAM CARDS ── */
.prog-badge{display:inline-flex;padding:6px 14px;border-radius:999px;background:rgba(232,48,48,.09);color:var(--red);font-weight:800;font-size:.82rem;margin-bottom:14px}
.prog-img{width:100%;height:180px;object-fit:cover;border-radius:16px;margin-bottom:16px;background:linear-gradient(135deg,var(--cream),var(--tan))}
.prog-img-placeholder{width:100%;height:180px;border-radius:16px;margin-bottom:16px;display:flex;align-items:center;justify-content:center;font-size:3rem}

/* ── TESTIMONIALS ── */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:32px}
.testi-card{background:#fff;border-radius:24px;box-shadow:var(--shadow);padding:28px;position:relative}
.testi-card::before{content:'C';font-family:'Fredoka',serif;font-size:5rem;line-height:.6;color:var(--red);opacity:.15;position:absolute;top:20px;left:22px}
.testi-quote{font-size:1rem;line-height:1.65;color:#334155;margin-bottom:20px;padding-top:16px}
.testi-author strong{font-weight:800;display:block}
.testi-author span{font-size:.88rem;color:var(--grey)}
.testi-stars{color:var(--yellow);font-size:1rem;margin-bottom:10px}

/* ── CTA BAND ── */
.cta-band{border-radius:32px;padding:52px 48px;background:linear-gradient(135deg,var(--red) 0%,var(--orange) 40%,var(--yellow) 70%,var(--green) 85%,var(--blue) 95%,var(--purple) 100%);color:#fff;text-align:center}
.cta-band h2{font-size:clamp(1.8rem,3.5vw,2.8rem);margin-bottom:12px}
.cta-band p{font-size:1.08rem;opacity:.92;max-width:560px;margin:0 auto 24px}

/* ── WHY SECTION ── */
.why-bg{background:#fff}

/* ── ABOUT ── */
.about-story{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;margin-top:40px}
.about-text p{color:#334155;line-height:1.75;margin-bottom:16px}
.about-img-block{border-radius:24px;overflow:hidden;box-shadow:var(--shadow)}
.teacher-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:36px}
.teacher-card{background:#fff;border-radius:24px;box-shadow:var(--shadow);overflow:hidden;transition:transform .25s,box-shadow .25s}
.teacher-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover)}
.teacher-card img{width:100%;height:220px;object-fit:cover;object-position:top}
.teacher-info{padding:20px 22px}
.teacher-info h3{font-size:1.15rem;margin-bottom:4px}
.teacher-info .role{font-size:.85rem;color:var(--red);font-weight:700;margin-bottom:8px}
.teacher-info p{font-size:.9rem;color:var(--grey)}
.values-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:32px}
.value-item{display:flex;gap:14px;align-items:flex-start;background:#fff;border-radius:18px;padding:20px;box-shadow:0 2px 12px rgba(0,0,0,.05)}
.value-dot{width:36px;height:36px;border-radius:12px;flex-shrink:0;display:grid;place-items:center;font-size:1.2rem}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:32px;margin-top:40px}
.info-card{background:#fff;border-radius:24px;box-shadow:var(--shadow);padding:32px}
.info-card h3{font-size:1.2rem;margin-bottom:20px}
.info-row{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-bottom:1px solid rgba(15,27,51,.07)}
.info-row:last-child{border-bottom:none}
.info-icon{width:38px;height:38px;border-radius:12px;background:rgba(232,48,48,.09);color:var(--red);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.1rem}
.info-label{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--grey);margin-bottom:3px}
.info-val{font-weight:700;font-size:.96rem}
.form-card{background:#fff;border-radius:24px;box-shadow:var(--shadow);padding:32px}
.form-card h3{font-size:1.2rem;margin-bottom:20px}
.form-row{margin-bottom:16px}
.form-row label{display:block;font-weight:700;font-size:.88rem;margin-bottom:6px;color:var(--navy)}
.form-row input,.form-row select,.form-row textarea{width:100%;padding:13px 16px;border:1.5px solid rgba(15,27,51,.15);border-radius:14px;font-family:'Nunito',Arial,sans-serif;font-size:.96rem;color:var(--navy);background:#fafafa;transition:border-color .2s,box-shadow .2s;outline:none}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(232,48,48,.12)}
.form-row textarea{min-height:130px;resize:vertical}
.form-grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.map-placeholder{border-radius:18px;overflow:hidden;margin-top:18px;background:linear-gradient(135deg,#e8f4ff,#f0ffe8);height:180px;display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--grey);border:1.5px dashed var(--tan)}

/* ── PROGRAMS PAGE ── */
.prog-header{text-align:center;max-width:720px;margin:0 auto 48px}
.pricing-table{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:32px}
.price-card{background:#fff;border-radius:24px;box-shadow:var(--shadow);padding:32px;text-align:center;transition:transform .25s,box-shadow .25s;position:relative}
.price-card:hover{transform:translateY(-7px);box-shadow:var(--shadow-hover)}
.price-card.featured{border:2.5px solid var(--red)}
.price-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--red);color:#fff;font-size:.78rem;font-weight:800;padding:4px 14px;border-radius:999px;letter-spacing:.07em;text-transform:uppercase}
.price-amount{font-family:'Fredoka',Arial,sans-serif;font-size:3rem;color:var(--navy);line-height:1;margin:16px 0 4px}
.price-amount span{font-size:1.2rem;vertical-align:super;margin-right:2px}
.price-period{font-size:.85rem;color:var(--grey);margin-bottom:20px}
.price-list{list-style:none;margin-bottom:24px;text-align:left}
.price-list li{padding:9px 0;border-bottom:1px solid rgba(15,27,51,.06);font-size:.93rem;display:flex;align-items:center;gap:8px}
.price-list li::before{content:'✓';color:var(--green);font-weight:800;flex-shrink:0}
.scholarship{background:linear-gradient(135deg,rgba(232,48,48,.06),rgba(255,140,0,.06));border:1.5px solid rgba(232,48,48,.18);border-radius:24px;padding:32px;margin-top:32px;display:flex;gap:24px;align-items:center}
.scholarship-icon{font-size:2.5rem;flex-shrink:0}

/* ── FOOTER ── */
.site-footer{background:var(--navy);color:#fff;padding:64px 0 32px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:48px}
.footer-brand{font-family:'Fredoka',Arial,sans-serif;font-size:1.4rem;font-weight:700;margin-bottom:12px}
.footer-desc{color:rgba(255,255,255,.60);font-size:.92rem;line-height:1.65;margin-bottom:18px;max-width:260px}
.footer-social{display:flex;gap:10px}
.social-btn{width:38px;height:38px;border-radius:12px;background:rgba(255,255,255,.10);display:flex;align-items:center;justify-content:center;font-size:1rem;transition:background .2s}
.social-btn:hover{background:var(--red)}
.footer-col h4{font-family:'Fredoka',Arial,sans-serif;font-size:1rem;font-weight:600;margin-bottom:16px;color:rgba(255,255,255,.85)}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:10px}
.footer-col ul li a{color:rgba(255,255,255,.55);font-size:.92rem;transition:color .2s}
.footer-col ul li a:hover{color:#fff}
.footer-contact-row{display:flex;gap:10px;align-items:flex-start;margin-bottom:12px;color:rgba(255,255,255,.60);font-size:.9rem}
.footer-contact-row strong{color:rgba(255,255,255,.85);font-size:.82rem;display:block;margin-bottom:1px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.10);padding-top:24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;color:rgba(255,255,255,.40);font-size:.85rem}

/* ── SCROLL REVEAL ── */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .teacher-grid{grid-template-columns:repeat(2,1fr)}
  .pricing-table{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .hero-inner,.about-story,.contact-grid,.grid2,.grid3,.grid4,.testi-grid,.values-grid{grid-template-columns:1fr}
  .nav-links,.btn.nav-cta{display:none}
  .nav-hamburger{display:flex}
  .section{padding:60px 0}
  .cta-band{padding:36px 24px}
  .hero-inner{padding:36px 0}
  .footer-grid{grid-template-columns:1fr}
  .teacher-grid{grid-template-columns:1fr}
  .pricing-table{grid-template-columns:1fr}
  .form-grid2{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .scholarship{flex-direction:column;text-align:center}
}
