
:root{
  --bg:#F7FAFC; --surface:#FFFFFF; --muted:#4A5568; --text:#1A202C;
  --brand1:#2563EB; --brand2:#22C55E; --accent:#F59E0B; --ring: rgba(37,99,235,.35);
  --header-h:64px; --panel-pad:16px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:Inter,'Plus Jakarta Sans',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;scroll-behavior:smooth}
html{-webkit-text-size-adjust:100%}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
:focus-visible{outline:2px solid var(--ring); outline-offset:2px}
.container{width:min(1100px, 90%);margin-inline:auto}
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.85);backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid rgba(0,0,0,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
.brand{display:flex;align-items:center;gap:10px}
.brand__logo{width:96px;height:96px;border-radius:8px;box-shadow:0 0 0 3px rgba(0,0,0,.03);background:#fff}
.brand__name{font-weight:800;letter-spacing:.2px}
.nav__links{display:flex;gap:24px;align-items:center}
.nav__links a{opacity:.9}
.nav__links .btn{margin-left:6px}
.nav__toggle{display:none;flex-direction:column;gap:4px;background:none;border:none}
.nav__toggle span{width:22px;height:2px;background:#1F2937;border-radius:1px}

.hero{position:relative;overflow:hidden;padding:90px 0 40px}
.hero__shape{position:absolute;inset:auto -10% -5% -10%;opacity:.9;filter:blur(1px);pointer-events:none}
.hero__content{display:grid;grid-template-columns: 1.2fr .8fr;gap:40px;align-items:center}
.hero h1{font-size: clamp(32px, 5vw, 52px);line-height:1.05;margin:0 0 10px}
.grad{background:linear-gradient(90deg,var(--brand1),var(--brand2));-webkit-background-clip:text;background-clip:text;color:transparent}
.lead{font-size:clamp(16px,1.8vw,18px);opacity:.9}
.cta{display:flex;flex-direction:column;gap:8px;margin:18px 0 6px}
.cta-sub{font-size:13px;color:#475569}
.hero__badges{display:flex;flex-wrap:wrap;gap:14px;padding:0;margin:12px 0 0;list-style:none;color:var(--muted)}
.hero__right{position:relative}
.hero__card{display:flex;gap:14px;align-items:center;background:#ffffff; border:1px solid rgba(0,0,0,.06);padding:14px;border-radius:16px;box-shadow:0 10px 24px -12px rgba(37,99,235,.18)}
.hero__card img{width:54px;height:54px;border-radius:12px;background:#fff}
.stats{display:flex;gap:18px;margin-top:16px}
.stat{background:linear-gradient(180deg, rgba(34,197,94,.10), rgba(37,99,235,.10));border:1px solid rgba(0,0,0,.06);padding:16px 18px;border-radius:16px;min-width:110px;text-align:center}
.stat__num{font-size:28px;font-weight:800}
.stat__label{color:var(--muted);font-size:12px}

.section{padding:64px 0}
.section__title{font-size:28px;margin:0 0 6px}
.section__subtitle{color:var(--muted);margin:0 0 24px}
.grid{display:grid;gap:18px}
.cards{grid-template-columns:repeat(4,1fr)}
.card{background:var(--surface);border:1px solid rgba(0,0,0,.08);padding:18px;border-radius:18px;box-shadow:0 12px 24px -14px rgba(0,0,0,.2)}
.card h3{margin:0 0 8px}
.ticks{padding-left:18px;color:#334155}
.ticks li{margin:6px 0}

.features{grid-template-columns:repeat(4,1fr)}
.features.three{grid-template-columns:repeat(3,1fr)}
.feature{background:linear-gradient(180deg, rgba(255,255,255,1), rgba(255,255,255,.85));padding:18px;border-radius:16px;border:1px solid rgba(0,0,0,.06);box-shadow:0 10px 20px -14px rgba(0,0,0,.15)}
.feature__icon{font-size:22px;margin-bottom:6px}

results .marquee{display:flex;gap:40px;overflow:hidden;mask-image:linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);border-top:1px solid rgba(0,0,0,.06);border-bottom:1px solid rgba(0,0,0,.06);padding:18px 0;color:#334155;white-space:nowrap}
.results .marquee span{animation: scroll 20s linear infinite}
@keyframes scroll{to{transform:translateX(-100%)}}

.quotes{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}
.quote{background:#ffffff;border:1px solid rgba(0,0,0,.06);padding:18px;border-radius:16px;box-shadow:0 10px 24px -14px rgba(0,0,0,.15)}

.form{display:grid;gap:12px;background:#ffffff;border:1px solid rgba(0,0,0,.08);padding:18px;border-radius:18px;box-shadow:0 12px 24px -18px rgba(0,0,0,.15)}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
label{display:grid;gap:6px;font-size:14px}
input, select, textarea{background:#F8FAFC;border:1px solid rgba(0,0,0,.12);color:var(--text);padding:12px;border-radius:12px;outline:2px solid transparent;transition:.2s}
input:focus, select:focus, textarea:focus{outline-color:var(--ring)}
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}
.chips label{background:#F8FAFC;border:1px solid rgba(0,0,0,.12);padding:8px 10px;border-radius:999px;display:flex;align-items:center;gap:8px}
.form__actions{display:flex;align-items:center;gap:12px}
.form__status{color:var(--muted)}

.btn{display:inline-block;border:1px solid rgba(0,0,0,.12);padding:10px 14px;border-radius:12px}
.btn--primary{background:linear-gradient(90deg, var(--brand1), var(--brand2));border:none;color:white;font-weight:700;box-shadow:0 10px 22px -10px rgba(37,99,235,.35)}
.btn--ghost{background:transparent}
.btn--sm{padding:8px 12px}

.footer{border-top:1px solid rgba(0,0,0,.06);padding:24px 0 40px;background:linear-gradient(180deg, rgba(255,255,255,1), rgba(255,255,255,.6))}
.footer__grid{display:grid;grid-template-columns:1fr auto auto;gap:18px;align-items:center}
.footer__brand{display:flex;align-items:center;gap:10px}
.footer__brand img{width:96px;height:96px;border-radius:12px;background:#fff}
.footer__links{display:flex;gap:14px}
.footer__legal{display:flex;gap:16px;color:var(--muted)}

/* Animations / effects */
.reveal{opacity:0; transform: translateY(10px); animation: reveal .8s ease forwards .1s}
.reveal-delay{opacity:0; transform: translateY(10px); animation: reveal .8s ease forwards .25s}
.reveal-delay-2{opacity:0; transform: translateY(10px); animation: reveal .8s ease forwards .4s}
.reveal-delay-3{opacity:0; transform: translateY(10px); animation: reveal .8s ease forwards .55s}
@keyframes reveal {to{opacity:1;transform:none}}

.rise{transition:transform .25s ease, box-shadow .25s ease}
.rise:hover{transform:translateY(-4px);box-shadow:0 16px 28px -16px rgba(0,0,0,.25)}

.float{animation: float 6s ease-in-out infinite}
@keyframes float{ 0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)} }

.fade-in{opacity:0;transform:translateY(6px)}
.fade-in.is-visible{opacity:1;transform:none;transition:.6s ease}

/* Sticky mobile call CTA */
@media (max-width: 920px){
  .sticky-cta{
    position: fixed; left: 12px; right: 12px; bottom: 12px; z-index: 120;
    display: inline-block; text-align: center; padding: 14px 16px; border-radius: 14px;
    background: linear-gradient(90deg, var(--brand1), var(--brand2)); color:#fff; font-weight:700;
    box-shadow: 0 14px 30px -16px rgba(37,99,235,.45);
  }
  .footer{ padding-bottom: 80px; }
}

/* iPhone-friendly mobile panel nav */
body.no-scroll { position: fixed; inset: 0; width: 100%; }
.nav-backdrop{
  position: fixed; inset: 0; background: rgba(0,0,0,.35); 
  opacity: 0; pointer-events: none; transition: opacity .2s ease; z-index: 90;
}
.nav-backdrop.is-active{ opacity:1; pointer-events:auto; }

@media (max-width: 920px){
  .nav{ position: relative; }
  .nav__toggle{ display: flex; }
  .nav__links{
    display: none; flex-direction: column; gap: 10px;
    position: fixed; left: 0; right: 0;
    top: calc(var(--header-h) + env(safe-area-inset-top, 0px));
    height: calc(var(--vh, 1vh) * 100 - var(--header-h) - env(safe-area-inset-top, 0px));
    background: #fff; border-top: 1px solid rgba(0,0,0,.06);
    padding: calc(var(--panel-pad) + env(safe-area-inset-top, 0px)) var(--panel-pad) var(--panel-pad);
    box-shadow: 0 16px 28px -16px rgba(0,0,0,.25);
    z-index: 100; overflow-y: auto; -webkit-overflow-scrolling: touch;
  }
  .nav__links.is-open{ display: flex; }
  .nav__links a{ display: block; padding: 14px 4px; line-height: 1.3; border-radius: 10px; }
  .nav__links a:active{ background: #F1F5F9; }
  .hero__content{ grid-template-columns:1fr }
  .cards{ grid-template-columns:1fr 1fr }
  .features{ grid-template-columns:1fr 1fr }
  .features.three{ grid-template-columns:1fr }
  .quotes{ grid-template-columns:1fr }
  .form__row{ grid-template-columns:1fr }
  .footer__grid{ grid-template-columns:1fr }
}
@media (max-width: 560px){ .cards{ grid-template-columns:1fr } }

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  .reveal, .reveal-delay, .reveal-delay-2, .reveal-delay-3,
  .rise, .float, .fade-in,
  .nav__links { animation: none !important; transition: none !important; }
}

.hero{
  background:
    linear-gradient(90deg, rgba(255,255,255,0.97) 0%, rgba(255,255,255,0.90) 40%, rgba(255,255,255,0.82) 65%, rgba(255,255,255,0.72) 100%),
    url('./assets/hero-kids.jpg') center/cover no-repeat;
}
.hero__shape{ display:none !important; }
