/* ============ Children At Play Learning Center ============ */
:root{
  --ink:#2C3E37;        /* deep spruce */
  --ink-soft:#536158;   /* muted spruce */
  --cream:#FAF4E8;      /* paper */
  --cream-2:#F4ECDA;    /* deeper paper band */
  --marigold:#E2922E;   /* primary warm */
  --marigold-d:#C97C1F; /* darker marigold for text-on-cream */
  --sage:#5E8E78;       /* secondary cool */
  --sage-d:#46705E;
  --coral:#D26A4F;      /* pop */
  --coral-d:#B9543B;
  --shadow:0 14px 34px -18px rgba(44,62,55,.40);
  --shadow-sm:0 8px 20px -14px rgba(44,62,55,.45);
  --r-lg:22px; --r-md:16px; --r-sm:11px;
  --maxw:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--cream);color:var(--ink);
  font-family:"Mulish",system-ui,sans-serif;font-size:17px;line-height:1.65;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
h1,h2,h3,h4{font-family:"Baloo 2",system-ui,sans-serif;line-height:1.12;margin:0;color:var(--ink);font-weight:700}
p{margin:0 0 1rem}
a{color:var(--sage-d);text-decoration:none}
img,svg{display:block;max-width:100%}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 26px}

.skip{position:absolute;left:-999px;top:0;background:var(--ink);color:var(--cream);padding:10px 16px;border-radius:0 0 var(--r-sm) 0;z-index:200}
.skip:focus{left:0}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:"Baloo 2",sans-serif;font-weight:600;font-size:1.02rem;
  padding:13px 26px;border-radius:var(--r-md);border:2px solid transparent;cursor:pointer;
  transition:background .22s ease,color .22s ease,border-color .22s ease}
.btn-primary{background:var(--ink);color:var(--cream)}
.btn-primary:hover,.btn-primary:focus-visible{background:var(--sage-d);color:#fff}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover,.btn-ghost:focus-visible{background:var(--ink);color:var(--cream)}
.btn-block{width:100%}

:focus-visible{outline:3px solid var(--marigold);outline-offset:3px;border-radius:4px}

.eyebrow{font-family:"Baloo 2",sans-serif;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  font-size:.8rem;color:var(--coral-d);margin:0 0 .7rem}

/* ---- header ---- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .3s ease,box-shadow .3s ease,padding .3s ease}
.site-header::before{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(250,244,232,.85),rgba(250,244,232,0));opacity:1;transition:opacity .3s ease;pointer-events:none}
.site-header.scrolled{background:var(--cream);box-shadow:0 4px 22px -16px rgba(44,62,55,.6)}
.site-header.scrolled::before{opacity:0}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:15px 0}
.brand{display:flex;align-items:center;gap:12px;color:var(--ink)}
.brand-mark{display:grid;place-items:center;flex:none}
.brand-text{font-family:"Baloo 2",sans-serif;font-weight:700;font-size:1.18rem;line-height:1;display:flex;flex-direction:column}
.brand-text small{font-weight:500;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sage-d);margin-top:3px}
.navlinks{display:flex;align-items:center;gap:26px}
.navlinks a{font-family:"Baloo 2",sans-serif;font-weight:500;color:var(--ink);font-size:1rem;position:relative;padding:6px 0}
.navlinks a:not(.callbtn)::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:2.5px;background:var(--marigold);border-radius:2px;transition:right .25s ease}
.navlinks a:not(.callbtn):hover::after,.navlinks a:not(.callbtn):focus-visible::after{right:0}
.navlinks a.callbtn{padding:10px 18px;background:var(--marigold);color:var(--ink);border-radius:var(--r-sm);font-weight:700;transition:background .22s ease,color .22s ease}
.navlinks a.callbtn:hover,.navlinks a.callbtn:focus-visible{background:var(--ink);color:var(--cream)}

.menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.menu-toggle span{width:26px;height:3px;background:var(--ink);border-radius:2px;transition:transform .3s ease,opacity .2s ease}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.mobile-nav{display:none;flex-direction:column;background:var(--cream);border-top:1px solid var(--cream-2);padding:10px 26px 22px}
.mobile-nav a{font-family:"Baloo 2",sans-serif;font-weight:600;color:var(--ink);padding:13px 0;border-bottom:1px solid var(--cream-2);font-size:1.08rem}
.mobile-nav a.callbtn{margin-top:14px;background:var(--marigold);color:var(--ink);border:0;border-radius:var(--r-sm);text-align:center;padding:14px}

/* ---- hero ---- */
.hero{position:relative;padding:148px 0 86px;background:
  radial-gradient(120% 90% at 80% -10%, #FCEFD6 0%, rgba(252,239,214,0) 55%),
  var(--cream);overflow:hidden}
.hero-deco{position:absolute;inset:0;pointer-events:none}
.big-sun{position:absolute;top:84px;right:6%;opacity:.95}
.blob{position:absolute;border-radius:50%;filter:blur(2px);opacity:.5}
.blob-sage{width:120px;height:120px;background:var(--sage);left:-30px;bottom:60px;opacity:.22}
.blob-coral{width:80px;height:80px;background:var(--coral);right:32%;bottom:30px;opacity:.20}
.kite{position:absolute;left:8%;top:120px;width:30px;height:30px;background:var(--sage);transform:rotate(45deg);border-radius:6px;opacity:.5}
.hero-inner{position:relative;max-width:720px}
.hero h1{font-size:clamp(2.5rem,6vw,4.2rem);font-weight:800;letter-spacing:-.01em}
.hero-sub{font-size:clamp(1.08rem,2.4vw,1.32rem);color:var(--ink-soft);max-width:560px;margin-top:1.2rem}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:2rem}
.hero-stats{list-style:none;display:flex;gap:38px;flex-wrap:wrap;margin:3rem 0 0;padding:0}
.hero-stats li{display:flex;flex-direction:column}
.hero-stats strong{font-family:"Baloo 2",sans-serif;font-size:1.7rem;font-weight:700;color:var(--ink)}
.hero-stats span{font-size:.92rem;color:var(--ink-soft)}

/* ---- welcome ---- */
.welcome{padding:84px 0}
.welcome-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:54px;align-items:start}
.welcome-copy h2{font-size:clamp(1.8rem,3.6vw,2.7rem);margin-bottom:1.1rem;max-width:16ch}
.ticks{list-style:none;padding:0;margin:1.4rem 0 0;display:grid;gap:.7rem}
.ticks li{position:relative;padding-left:30px;color:var(--ink)}
.ticks li::before{content:"";position:absolute;left:0;top:9px;width:13px;height:13px;background:var(--marigold);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat}
.welcome-card{background:var(--ink);color:var(--cream);border-radius:var(--r-lg);padding:32px 30px;box-shadow:var(--shadow)}
.welcome-card h3{color:#fff;font-size:1.35rem;margin-bottom:1rem}
.welcome-card dl{margin:0;display:grid;gap:.9rem}
.welcome-card dl div{display:flex;justify-content:space-between;gap:14px;border-bottom:1px solid rgba(250,244,232,.16);padding-bottom:.7rem}
.welcome-card dt{color:#CFE0D4;font-size:.9rem}
.welcome-card dd{margin:0;text-align:right;font-weight:600;font-size:.96rem}
.card-link{display:inline-block;margin-top:1.3rem;font-family:"Baloo 2",sans-serif;font-weight:600;color:var(--marigold)}
.welcome-card .card-link{color:#F3B765}
.card-link:hover{color:#fff}

/* ---- programs ---- */
.programs{padding:84px 0;background:var(--cream-2)}
.section-head{max-width:640px;margin-bottom:46px}
.section-head h2{font-size:clamp(1.8rem,3.6vw,2.7rem)}
.section-head .lead{color:var(--ink-soft);margin-top:.9rem;font-size:1.08rem}
.prog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.prog-card{background:var(--cream);border-radius:var(--r-lg);padding:32px 28px;box-shadow:var(--shadow-sm);
  border:1px solid #ECE2CD;transition:transform .25s ease,box-shadow .25s ease}
.prog-card:hover{box-shadow:var(--shadow);border-color:var(--marigold)}
.prog-icon{display:grid;place-items:center;width:64px;height:64px;border-radius:18px;background:#FBEFD7;margin-bottom:18px}
.prog-card h3{font-size:1.5rem}
.prog-age{font-family:"Baloo 2",sans-serif;font-weight:600;color:var(--sage-d);margin:.2rem 0 .8rem;font-size:.98rem}
.prog-card p:last-child{color:var(--ink-soft);margin:0}

/* ---- approach ---- */
.approach{padding:88px 0}
.approach-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.approach-copy h2{font-size:clamp(1.8rem,3.6vw,2.7rem);margin-bottom:1.1rem}
.approach-copy p{color:var(--ink-soft)}
.day-flow{list-style:none;margin:0;padding:0;display:grid;gap:6px}
.day-flow li{display:flex;gap:18px;align-items:flex-start;padding:16px 18px;border-radius:var(--r-md);transition:background .2s ease}
.day-flow li:hover{background:var(--cream-2)}
.day-num{flex:none;width:38px;height:38px;border-radius:12px;background:var(--marigold);color:var(--ink);
  font-family:"Baloo 2",sans-serif;font-weight:700;display:grid;place-items:center;font-size:1.1rem}
.day-flow h4{font-size:1.18rem;margin-bottom:.15rem}
.day-flow p{margin:0;color:var(--ink-soft);font-size:.98rem}

/* ---- why ---- */
.why{padding:84px 0;background:var(--ink);color:var(--cream)}
.why h2,.why .eyebrow{color:var(--cream)}
.why .eyebrow{color:#F3B765}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:rgba(250,244,232,.14);
  border:1px solid rgba(250,244,232,.14);border-radius:var(--r-lg);overflow:hidden}
.why-item{background:var(--ink);padding:30px 28px;transition:background .25s ease}
.why-item:hover{background:#34473F}
.why-item h3{color:#fff;font-size:1.28rem;margin-bottom:.55rem;position:relative;padding-bottom:.55rem}
.why-item h3::after{content:"";position:absolute;left:0;bottom:0;width:30px;height:3px;background:var(--marigold);border-radius:2px;transition:width .28s ease}
.why-item:hover h3::after{width:54px}
.why-item p{color:#CFE0D4;margin:0;font-size:.98rem}

/* ---- rating ---- */
.rating{padding:72px 0;background:var(--cream-2)}
.rating-inner{max-width:760px;margin:0 auto;text-align:center}
.rating-score{display:inline-flex;flex-direction:column;align-items:center;gap:.2rem}
.rating-num{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:3.4rem;color:var(--ink);line-height:1}
.stars{color:var(--marigold);font-size:1.5rem;letter-spacing:.15em}
.rating-meta{color:var(--ink-soft);font-size:.92rem}
.rating-line{font-family:"Baloo 2",sans-serif;font-weight:600;font-size:clamp(1.3rem,2.6vw,1.8rem);color:var(--ink);margin:1.2rem auto;max-width:24ch}

/* ---- faq ---- */
.faq{padding:84px 0}
.faq-list{max-width:780px}
.faq details{border-bottom:2px solid var(--cream-2);padding:6px 0}
.faq summary{font-family:"Baloo 2",sans-serif;font-weight:600;font-size:1.18rem;color:var(--ink);
  cursor:pointer;list-style:none;padding:18px 44px 18px 0;position:relative;transition:color .2s ease}
.faq summary::-webkit-details-marker{display:none}
.faq summary:hover{color:var(--coral-d)}
.faq summary::after{content:"";position:absolute;right:6px;top:50%;width:14px;height:14px;transform:translateY(-50%);
  background:var(--marigold);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M11 5h2v6h6v2h-6v6h-2v-6H5v-2h6z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M11 5h2v6h6v2h-6v6h-2v-6H5v-2h6z'/%3E%3C/svg%3E") center/contain no-repeat;
  transition:transform .25s ease}
.faq details[open] summary::after{transform:translateY(-50%) rotate(135deg)}
.faq-body{padding:0 44px 18px 0}
.faq-body p{color:var(--ink-soft);margin:0}

/* ---- enroll ---- */
.enroll{padding:88px 0;background:var(--cream-2)}
.enroll-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:54px;align-items:start}
.enroll-intro h2{font-size:clamp(1.8rem,3.6vw,2.7rem);margin-bottom:1rem}
.enroll-intro p{color:var(--ink-soft)}
.enroll-intro a{color:var(--coral-d);font-weight:700}
.enroll-addr{font-family:"Baloo 2",sans-serif;font-weight:600;color:var(--ink)!important;margin-top:1.4rem}
.enroll-form{background:var(--cream);border-radius:var(--r-lg);padding:34px 32px;box-shadow:var(--shadow);position:relative}
.field{margin-bottom:18px;display:flex;flex-direction:column}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
label{font-family:"Baloo 2",sans-serif;font-weight:600;font-size:.95rem;margin-bottom:7px;color:var(--ink)}
.opt{font-weight:400;color:var(--ink-soft);font-size:.85rem}
input,select,textarea{font-family:"Mulish",sans-serif;font-size:1rem;color:var(--ink);
  background:var(--cream-2);border:2px solid #E5DAC2;border-radius:var(--r-sm);padding:12px 14px;width:100%;transition:border-color .2s ease,background .2s ease}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--marigold);background:#fff}
textarea{resize:vertical}
.field.invalid input,.field.invalid select{border-color:var(--coral-d);background:#FBEAE4}
.err{color:var(--coral-d);font-size:.82rem;margin-top:5px;min-height:1px;font-weight:600}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.form-note{font-size:.84rem;color:var(--ink-soft);margin:1rem 0 0;text-align:center}
.form-success{position:absolute;inset:0;background:var(--cream);border-radius:var(--r-lg);display:flex;
  flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px;gap:.4rem}
.form-success h3{font-size:1.6rem;color:var(--ink)}
.form-success p{color:var(--ink-soft);max-width:30ch}
.success-mark{margin-bottom:.6rem}

/* ---- visit ---- */
.visit{padding:88px 0}
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.visit-copy h2{font-size:clamp(1.8rem,3.6vw,2.7rem);margin-bottom:1rem}
.visit-copy p{color:var(--ink-soft)}
.visit-details{margin:1.5rem 0;display:grid;gap:1rem}
.visit-details div{display:grid;grid-template-columns:90px 1fr;gap:14px;align-items:baseline;border-bottom:1px solid var(--cream-2);padding-bottom:.8rem}
.visit-details dt{font-family:"Baloo 2",sans-serif;font-weight:600;color:var(--sage-d);font-size:.9rem;text-transform:uppercase;letter-spacing:.06em}
.visit-details dd{margin:0;color:var(--ink);font-weight:600}
.visit-details a{color:var(--coral-d)}
.map-panel{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid #ECE2CD}
.map-art{position:relative;aspect-ratio:4/3;background:linear-gradient(135deg,#EFE6D2,#E6F0E8)}
.map-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(94,142,120,.18) 1px,transparent 1px),linear-gradient(90deg,rgba(94,142,120,.18) 1px,transparent 1px);background-size:38px 38px}
.map-road{position:absolute;background:var(--cream)}
.road-h{left:0;right:0;top:58%;height:30px;transform:rotate(-4deg);box-shadow:0 0 0 2px #E5DAC2 inset}
.road-v{top:0;bottom:0;left:34%;width:22px;box-shadow:0 0 0 2px #E5DAC2 inset}
.map-label{position:absolute;top:54%;left:14%;transform:rotate(-4deg);font-family:"Baloo 2",sans-serif;font-size:.8rem;color:var(--sage-d);font-weight:600}
.map-pin{position:absolute;left:42%;top:38%;transform:translate(-50%,-100%);filter:drop-shadow(0 6px 8px rgba(44,62,55,.3))}
.map-here{position:absolute;left:42%;top:39%;transform:translateX(-50%);background:var(--ink);color:var(--cream);
  font-family:"Baloo 2",sans-serif;font-weight:600;font-size:.78rem;padding:5px 11px;border-radius:8px;white-space:nowrap}

/* ---- footer ---- */
.site-footer{background:var(--ink);color:var(--cream);padding:56px 0 26px}
.footer-inner{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;align-items:start}
.footer-brand{display:flex;gap:16px;align-items:flex-start}
.footer-brand strong{font-family:"Baloo 2",sans-serif;font-size:1.18rem;color:#fff}
.footer-brand p{color:#CFE0D4;margin:.3rem 0 0;font-size:.95rem;max-width:30ch}
.footer-nav{display:flex;flex-direction:column;gap:.7rem}
.footer-nav a{color:var(--cream);font-family:"Baloo 2",sans-serif;font-weight:500;width:max-content;position:relative}
.footer-nav a:hover{color:#F3B765}
.footer-contact{display:flex;flex-direction:column;gap:.6rem;color:#CFE0D4;font-size:.95rem}
.footer-contact a{color:#fff;font-family:"Baloo 2",sans-serif;font-weight:700;font-size:1.18rem}
.footer-contact a:hover{color:#F3B765}
.footer-base{display:flex;justify-content:space-between;gap:20px;margin-top:40px;padding-top:22px;
  border-top:1px solid rgba(250,244,232,.16);color:#A9BBB0;font-size:.85rem;flex-wrap:wrap}

/* ---- reveal / motion ---- */
.reveal{opacity:1;transform:none}
.js-ready .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.js-ready .reveal.in{opacity:1;transform:none}
.js-ready .hero .reveal{transition-delay:calc((var(--d,1) - 1) * .11s)}

.sun-rays line,.hero-rays line{transform-origin:center}
.js-ready .hero-rays line{opacity:0;animation:rayIn .5s ease forwards}
.js-ready .hero-rays line:nth-child(1){animation-delay:.25s}
.js-ready .hero-rays line:nth-child(2){animation-delay:.31s}
.js-ready .hero-rays line:nth-child(3){animation-delay:.37s}
.js-ready .hero-rays line:nth-child(4){animation-delay:.43s}
.js-ready .hero-rays line:nth-child(5){animation-delay:.49s}
.js-ready .hero-rays line:nth-child(6){animation-delay:.55s}
.js-ready .hero-rays line:nth-child(7){animation-delay:.61s}
.js-ready .hero-rays line:nth-child(8){animation-delay:.67s}
@keyframes rayIn{from{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}

/* ---- responsive ---- */
@media (max-width:900px){
  .navlinks{display:none}
  .menu-toggle{display:flex}
  .site-header.menu-open .mobile-nav,.mobile-nav.open{display:flex}
  .welcome-grid,.approach-grid,.enroll-grid,.visit-grid{grid-template-columns:1fr;gap:36px}
  .prog-grid,.why-grid{grid-template-columns:1fr}
  .why-grid{gap:2px}
  .footer-inner{grid-template-columns:1fr;gap:30px}
  .big-sun{width:160px;height:160px;top:120px;right:-10px;opacity:.55}
}
@media (max-width:560px){
  body{font-size:16px}
  .hero{padding:128px 0 64px}
  .welcome,.programs,.approach,.why,.faq,.enroll,.visit{padding:60px 0}
  .rating{padding:54px 0}
  .wrap{padding:0 20px}
  .hero-stats{gap:24px}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{width:100%}
  .row2{grid-template-columns:1fr}
  .footer-base{flex-direction:column;gap:8px}
  .big-sun{display:none}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .js-ready .reveal{opacity:1!important;transform:none!important}
  .js-ready .hero-rays line{opacity:1!important}
}
