/* ─── RESET ─── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:#2c2c2c;background:#fff;overflow-x:hidden;padding-top:68px}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

/* ─── TOKENS ─── */
:root{
  --blue:#00aeef; --pink:#ff2d78; --purple:#9b3dff;
  --amber:#f5a623; --green:#a5d91a; --teal:#00c9b1;
  --dark:#1a1a1a; --char:#2c2c2c; --d60:#444444; --d40:#888888;
}

/* ─── TYPE ─── */
h1,h2,h3{font-family:'Bricolage Grotesque',sans-serif;letter-spacing:-0.5px;line-height:1.1;color:var(--dark)}
h1{font-size:56px;font-weight:700;line-height:64px;letter-spacing:-1px}
h2{font-size:40px;font-weight:700;line-height:44px}
p{line-height:1.7;color:#555}
.eyebrow{font-family:'Inter',sans-serif;font-size:14px!important;font-weight:400!important;line-height:1.2!important;letter-spacing:1.38px!important;text-transform:uppercase!important;color:var(--d60);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}

/* ─── BUTTONS ─── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:16px 40px;border-radius:100px;border:none;cursor:pointer;font-family:'Inter',sans-serif;font-size:16px;font-weight:600;line-height:24px;letter-spacing:.2px;transition:background .2s;white-space:nowrap}
.btn-blue{background:var(--blue);color:#fff}
.btn-blue:hover{background:#0090ca}
.btn-outline{background:transparent;border:1.5px solid var(--dark);color:var(--dark)}
.btn-outline:hover{background:rgba(0,0,0,.04)}

/* Text link */
.text-link{display:inline-flex;align-items:center;gap:6px;font-family:'Inter',sans-serif;font-weight:500;font-size:16px;color:var(--d60);letter-spacing:.2px;transition:color .15s}
.text-link:hover{color:var(--blue)}
.link-arrow{display:inline-flex;align-items:center;flex-shrink:0;transition:transform .2s ease}
.text-link:hover .link-arrow{transform:translateX(4px)}

/* ─── NAV (shared with index.html) ─── */
.header-wrap{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:flex-start;padding:0 max(24px, calc((100% - 1200px) / 2));background:transparent;border-bottom:1px solid transparent}
@keyframes stickySlideIn{from{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes navLogoIn{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
.header-wrap.scrolled{background:#fff;border-bottom:1px solid rgba(0,0,0,0.06);animation:stickySlideIn .35s cubic-bezier(0.16,1,0.3,1) forwards}
.logo-panel{flex-shrink:0;overflow:hidden;width:fit-content}
.logo-box{display:block;background:transparent;padding:14px 0;line-height:0;max-height:200px;opacity:1;transition:max-height .2s ease,opacity .2s ease,padding .2s ease}
.logo-full{height:120px;width:auto;display:block}
.logo-compact-wrap{display:none;align-items:center;gap:10px;flex-shrink:0}
.logo-compact{width:40px;height:40px;border-radius:8px;background:transparent;display:block;object-fit:contain;flex-shrink:0}
.nav-brand .brand-name{font-family:'Inter',sans-serif;font-weight:700;font-size:14px;color:#1a1a1a;line-height:1.3}
.nav-brand .brand-tag{font-family:'Inter',sans-serif;font-size:10px;font-weight:600;color:var(--blue);line-height:1.4}
.header-wrap.scrolled .logo-panel{max-width:0;overflow:hidden}
.header-wrap.scrolled .logo-box{max-height:0;opacity:0;padding-top:0;padding-bottom:0}
.header-wrap.scrolled .nav{padding-left:0}
.header-wrap.scrolled .logo-compact-wrap{display:flex;animation:navLogoIn .3s .15s ease both}
.nav{flex:1;display:flex;align-items:center;padding:14px 0 14px 24px}
.nav-links{display:flex;align-items:center;margin-left:auto}
.nav-links a{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;font-family:'Inter',sans-serif;font-weight:400;font-size:14px;color:var(--dark);white-space:nowrap;transition:background .15s}
.nav-links a:hover{background:rgba(0,0,0,.04)}
.nav-chevron{width:14px;height:14px;display:block;flex-shrink:0;opacity:.7}
.nav-cta{background:var(--blue);color:#fff;padding:0 20px;height:40px;border-radius:100px;font-family:'Inter',sans-serif;font-weight:600;font-size:14.4px;display:inline-flex;align-items:center;flex-shrink:0;margin-left:24px;transition:background .2s}
.nav-cta:hover{background:#0090ca}
.nav-dropdown{position:relative}
.nav-dropdown .dropdown-menu{display:none;position:absolute;top:100%;left:0;padding-top:8px;min-width:200px;z-index:200}
.nav-dropdown .dropdown-menu-inner{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.1);padding:10px;display:flex;flex-direction:column;gap:4px}
.nav-dropdown:hover .dropdown-menu{display:block}
.dropdown-menu-inner a{display:flex;align-items:center;min-height:44px;padding:10px 20px;border-radius:7px;font-family:'Inter',sans-serif;font-size:14px;font-weight:500;color:var(--dark);white-space:nowrap;transition:background .12s}
.dropdown-menu-inner a:hover{background:rgba(0,0,0,.04)}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;width:40px;height:40px;justify-content:center;align-items:center}
.hamburger span{display:block;width:22px;height:2px;background:var(--dark);transition:transform .25s,opacity .15s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:none;position:fixed;top:52px;left:0;right:0;background:#fff;padding:4px 20px 24px;box-shadow:0 10px 30px rgba(0,0,0,.08);z-index:45;flex-direction:column;gap:0;border-top:1px solid rgba(0,0,0,.06)}
@keyframes mobMenuItemIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.mobile-menu.open > *{opacity:0;animation:mobMenuItemIn .32s cubic-bezier(.16,1,.3,1) forwards}
.mobile-menu.open > *:nth-child(1){animation-delay:.04s}
.mobile-menu.open > *:nth-child(2){animation-delay:.08s}
.mobile-menu.open > *:nth-child(3){animation-delay:.12s}
.mobile-menu.open > *:nth-child(4){animation-delay:.16s}
.mobile-menu.open > *:nth-child(5){animation-delay:.20s}
.mobile-menu.open > *:nth-child(6){animation-delay:.24s}
.mobile-menu.open > *:nth-child(7){animation-delay:.28s}
.mobile-menu.open > *:nth-child(8){animation-delay:.32s}
.mobile-menu.open > *:nth-child(9){animation-delay:.36s}
.mobile-menu.open{display:flex}
.mob-link{padding:14px 8px;font-size:16px;color:var(--d60);border-bottom:1px solid rgba(0,0,0,.05);display:block}
.mob-group{border-bottom:1px solid rgba(0,0,0,.05)}
.mob-group-trigger{padding:14px 8px;font-size:16px;color:var(--d60);display:flex;align-items:center;justify-content:space-between;cursor:pointer;user-select:none}
.mob-group-trigger svg{transition:transform .2s}
.mob-group.open .mob-group-trigger svg{transform:rotate(180deg)}
.mob-group .mob-sub{display:none;padding:0 8px 10px 20px;flex-direction:column;gap:0}
.mob-group.open .mob-sub{display:flex}
.mob-sub a{padding:10px 0;font-size:15px;color:var(--d60)}
.mob-group .mob-link{border-bottom:none}
.mob-cta{margin-top:12px}
.mob-cta .btn{width:100%;justify-content:center}

/* ─── HERO ─── */
.pre-hero{padding:128px max(24px, calc((100% - 1200px) / 2)) 96px;position:relative;overflow:hidden}
.pre-hero-inner{display:grid;grid-template-columns:1fr 568px;gap:80px;align-items:center;position:relative}
.pre-hero .eyebrow{margin-bottom:24px}
.pre-hero h1{margin-bottom:32px}
.pre-hero h1 .w-green{color:var(--green)}
.pre-hero h1 .w-purple{color:var(--purple)}
.pre-hero h1 .w-blue{color:var(--blue)}
.pre-hero-sub{font-size:18px;line-height:30px;color:var(--d60);margin-bottom:40px;max-width:520px}
.pre-hero-actions{display:flex;gap:16px;flex-wrap:wrap}
.pre-hero-right{position:relative;display:grid;grid-template-columns:276px 276px;grid-template-rows:207px 207px;gap:16px}
.pre-hero-right img{width:100%;height:100%;object-fit:cover;border-radius:16px}
.ph-img1{grid-column:1;grid-row:1}
.ph-img2{grid-column:1;grid-row:2}
.ph-img3{grid-column:2;grid-row:1/span 2;height:430px}
.pre-hero-sp{position:absolute;pointer-events:none;z-index:2}
.ph-sp1{top:-20px;right:-10px;width:81px;height:78px}
.ph-sp2{bottom:-20px;right:90px;width:49px;height:48px}
.ph-sp3{bottom:20px;right:-40px;width:70px;height:68px}

/* ─── SECTION: LEARNING APPROACH ─── */
.sec-approach{background:linear-gradient(to top,#ffe8f0 0%,#fff 80%);padding:96px max(24px, calc((100% - 1200px) / 2))}
.sec-head{text-align:center;max-width:720px;margin:0 auto 56px}
.sec-head .eyebrow{display:inline-block;margin-bottom:32px}
.sec-head h2{margin-bottom:20px}
.sec-head h2 em{font-style:normal;color:var(--pink)}
.sec-head p{font-family:'Bricolage Grotesque',sans-serif;font-weight:400;font-size:18px;line-height:22px;color:#383838}
.sec-head p + p{margin-top:14px}
.approach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1005px;margin:0 auto}
.approach-card{background:#fff;border-radius:16px;padding:24px;border:0;box-shadow:none}
.approach-icon{width:96px;height:96px;display:flex;align-items:center;justify-content:center;margin-bottom:28px}
.approach-icon img{width:96px;height:96px;display:block}
.approach-card h3{font-family:'Bricolage Grotesque',sans-serif;font-size:24px;font-weight:700;line-height:18.4px;margin-bottom:14px;color:var(--dark)}
.approach-card h3.t-purple{color:var(--purple)}
.approach-card h3.t-green{color:var(--green)}
.approach-card h3.t-teal{color:var(--teal)}
.approach-card p{font-family:'Inter',sans-serif;font-size:13.6px;line-height:20px;color:var(--d60)}

/* ─── SECTION: FOUR SPACES ─── */
.sec-spaces{background:#f8f8f8;padding:80px max(24px, calc((100% - 1320px) / 2))}
.sec-head h2 .teal{color:var(--dark)}
.spaces2-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;max-width:1212px;margin:0 auto}
.space2-card{position:relative;border-radius:16px;overflow:hidden;background:#fff;border:1px solid rgba(0,0,0,.04);aspect-ratio:591/332;display:flex;flex-direction:column;justify-content:flex-end}
.space2-card .space2-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.space2-card:hover .space2-img{transform:scale(1.04)}
.space2-body{position:relative;z-index:2;background:#1a1a1a;padding:24px 32px 32px;color:#fff;transition:padding-top .4s ease}
.space2-eyebrow{font-family:'Inter',sans-serif;font-size:14px!important;font-weight:400!important;line-height:1.2!important;letter-spacing:1.38px!important;text-transform:uppercase!important;color:var(--d60);margin-bottom:12px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.space2-card.c-purple .space2-eyebrow{color:var(--purple)}
.space2-card.c-blue .space2-eyebrow{color:var(--blue)}
.space2-card.c-amber .space2-eyebrow{color:var(--amber)}
.space2-card.c-green .space2-eyebrow{color:#7aba1a}
.space2-title{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:24px;line-height:27.6px;color:#fff;letter-spacing:-.2px}
.space2-desc{margin-top:12px;font-family:'Inter',sans-serif;font-size:15.2px;line-height:25.84px;color:rgba(255,255,255,.92);max-height:0;opacity:0;overflow:hidden;transition:max-height .45s ease,opacity .3s ease,margin-top .3s ease}
.space2-card.default-open .space2-desc{max-height:120px;opacity:1;margin-top:12px}
.space2-card:hover .space2-desc{max-height:120px;opacity:1;margin-top:12px}

/* ─── SECTION: GROW MATTERS ─── */
.sec-grow{padding:80px max(24px, calc((100% - 1200px) / 2));background:#fff}
.grow-inner{display:grid;grid-template-columns:537px 591px;gap:72px;align-items:start;max-width:1200px;margin:0 auto}
.grow-left .eyebrow{margin-bottom:30px}
.grow-left h2{margin-bottom:30px;color:#2c2c2c}
.grow-left h2 em{font-style:normal;color:#1a1a1a}
.grow-left .grow-body{font-family:'Inter',sans-serif;font-size:16px;line-height:26px;color:#1a1a1a}
.grow-left .grow-body p{margin:0 0 26px}
.grow-left .grow-body p:last-child{margin:0}
.grow-left .grow-body em{font-style:italic}
.grow-right{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:160px 160px;gap:12px}
.grow-tile{position:relative;border-radius:12px;overflow:hidden;background:#eee}
.grow-tile img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.grow-tile::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.63)}
.grow-tile-body{position:absolute;inset:0;padding:16px;display:flex;flex-direction:column;justify-content:center;z-index:2;color:#fff}
.grow-tile-title{font-family:'Bricolage Grotesque',sans-serif;font-weight:600;font-size:24px;line-height:28px;color:#fff;margin-bottom:8px;letter-spacing:-.2px}
.grow-tile-desc{font-family:'Inter',sans-serif;font-size:14px;line-height:18px;color:rgba(255,255,255,.82);max-width:246px}

/* ─── SECTION: EDUCATORS / ORBIT ─── */
.sec-educators{padding:80px max(24px, calc((100% - 1200px) / 2));background:#fff}
.edu-inner{display:grid;grid-template-columns:1fr 521px;gap:80px;align-items:center;max-width:1200px;margin:0 auto}
.edu-left .eyebrow{margin-bottom:30px}
.edu-left h2{margin-bottom:30px;color:#2c2c2c}
.edu-left h2 em{font-style:normal;color:#1a1a1a}
.edu-left > p{font-family:'Inter',sans-serif;font-size:16px;line-height:26px;color:#1a1a1a;margin-bottom:40px;max-width:543px}
.edu-list{display:flex;flex-direction:column;gap:18px}
.edu-item{display:flex;gap:14px;align-items:flex-start}
.edu-check{flex-shrink:0;width:38px;height:38px;border-radius:10px;background:rgba(0,174,239,.1);display:flex;align-items:center;justify-content:center}
.edu-check img{width:18px;height:18px;display:block}
.edu-item h4{font-family:'Inter',sans-serif;font-size:15.2px;font-weight:600;color:#2c2c2c;margin-bottom:4px}
.edu-item p{font-family:'Inter',sans-serif;font-size:13.6px;line-height:18px;color:#777}
/* Orbit (mirror preschool orbit on homepage) */
.edu-orbit{position:relative;width:521px;height:452px;margin:0 auto}
.orbit2-rings{position:absolute;left:calc(50% - 226px);top:0;width:452px;height:452px;z-index:1;pointer-events:none}
.orbit2-photo{position:absolute;left:calc(50% - 132px);top:94px;width:264px;height:264px;z-index:3;border-radius:50%;overflow:hidden}
.orbit2-photo img{width:100%;height:100%;object-fit:cover}
.orbit2-pill{position:absolute;background:#fff;border-radius:14px;box-shadow:0 8px 28px rgba(0,0,0,.08);height:48px;width:158px;padding:0 14px;display:flex;align-items:center;gap:10px;white-space:nowrap;z-index:2}
.orbit2-pill .eye{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.orbit2-pill .eye img{width:14px;height:14px;display:block}
.orbit2-pill span{color:var(--blue);font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:16px}
.orbit2-pill .eye{background:rgba(0,174,239,.1);color:var(--blue)}
.o2-explore{left:0;top:94px}
.o2-explore .eye{background:#cceffc;color:var(--blue)}
.o2-listen{left:363px;top:40px}
.o2-document{left:37px;top:377px}
.o2-design{left:332px;top:391px}
.edu-sp{position:absolute;pointer-events:none;z-index:4}
.edu-sp-blue{left:197px;top:70px;width:53px;height:51px}
.edu-sp-green{left:364px;top:311px;width:49px;height:47px}

/* ─── SECTION: WHAT THIS MEANS FOR YOUR CHILD ─── */
.sec-meaning{padding:80px max(24px, calc((100% - 1200px) / 2));background:#f8f8f8}
.meaning-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;max-width:1200px;margin:0 auto}
.meaning-card{background:#fff;border-radius:16px;padding:32px 24px;border:0;min-height:157px;display:flex;flex-direction:column;gap:12px}
.meaning-icon{width:36px;height:36px;display:inline-block;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;-webkit-mask-size:contain;mask-size:contain;margin-bottom:4px}
.mc-purple .meaning-icon{background-color:var(--purple);-webkit-mask-image:url(../../images/phosphor/compass.svg);mask-image:url(../../images/phosphor/compass.svg)}
.mc-green .meaning-icon{background-color:var(--green);-webkit-mask-image:url(../../images/phosphor/lightbulb.svg);mask-image:url(../../images/phosphor/lightbulb.svg)}
.mc-blue .meaning-icon{background-color:var(--blue);-webkit-mask-image:url(../../images/phosphor/hand-heart.svg);mask-image:url(../../images/phosphor/hand-heart.svg)}
.mc-amber .meaning-icon{background-color:var(--amber);-webkit-mask-image:url(../../images/phosphor/plant.svg);mask-image:url(../../images/phosphor/plant.svg)}
.meaning-card h3{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:18px;line-height:24px;margin:0;color:var(--dark);letter-spacing:-0.2px}
.meaning-card.mc-purple h3{color:var(--purple)}
.meaning-card.mc-green h3{color:var(--green)}
.meaning-card.mc-blue h3{color:var(--blue)}
.meaning-card.mc-amber h3{color:var(--amber)}
.meaning-card p{font-family:'Inter',sans-serif;font-size:14px;line-height:21px;color:#555;margin:0}

/* ─── SECTION: AGE GROUPS ─── */
.sec-ages{padding:80px max(24px, calc((100% - 1200px) / 2)) 96px;background:linear-gradient(to top,#ffe8f0 0%,#fff 80%)}
.sec-ages .sec-head{margin-bottom:40px}
.sec-ages .sec-head h2 em{font-style:normal;color:var(--pink)}
.ages-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14.8px;max-width:1200px;margin:0 auto 24px}
.age-card{background:#fff;border:1.5px solid transparent;border-radius:12px;padding:28px 20px 26px;text-align:center;min-height:260px}
.age-icon{width:56px;height:56px;border-radius:28px;margin:0 auto 14px;display:flex;align-items:center;justify-content:center}
.age-icon svg,.age-icon img{width:24px;height:24px;display:block}
.age-name{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:17.6px;line-height:20.24px;color:#2c2c2c;margin-bottom:4px}
.age-band{font-family:'Inter',sans-serif;font-size:14px!important;font-weight:400!important;line-height:1.2!important;letter-spacing:1.38px!important;text-transform:uppercase!important;color:var(--d60);margin-bottom:12px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.age-desc{font-family:'Inter',sans-serif;font-size:14px;line-height:22px;color:#777;max-width:200px;margin:0 auto}
.age-a .age-icon{background:rgba(0,174,239,.10)} .age-a .age-band{color:var(--blue)}
.age-b .age-icon{background:rgba(165,217,26,.16)} .age-b .age-band{color:var(--green)}
.age-c .age-icon{background:rgba(245,166,35,.14)} .age-c .age-band{color:var(--amber)}
.age-d .age-icon{background:rgba(155,61,255,.12)} .age-d .age-band{color:var(--purple)}
.age-e .age-icon{background:rgba(0,201,177,.14)} .age-e .age-band{color:var(--teal)}
.age-note{text-align:center;max-width:720px;margin:0 auto;padding:16px 25px;background:rgba(255,255,255,.55);border-radius:12px;border:1px dashed rgba(255,255,255,.22)}
.age-note p{font-family:'Inter',sans-serif;font-size:14.4px;line-height:22px;color:#666;margin:0}
.age-note strong{color:var(--blue);font-weight:700}

/* ─── SECTION: PROMISE ─── */
.sec-promise{padding:96px max(24px, calc((100% - 1200px) / 2));background:#fff}
.sec-promise .sec-head h2 em.t-wgreen{font-style:normal;color:#7aba1a}
.sec-promise .sec-head h2 em.t-wred{font-style:normal;color:#ff3d3d}
.promise-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;max-width:1200px;margin:0 auto}
.promise-col{border-radius:12px;padding:42px 32px;border:0}
.pc-will{background:#f9ffe8}
.pc-wont{background:#fff2f2}
.promise-tag{display:inline-block;padding:4px 12px;border-radius:100px;font-family:'Inter',sans-serif;font-size:14px!important;font-weight:400!important;line-height:1.2!important;letter-spacing:1.38px!important;text-transform:uppercase!important;margin-bottom:10px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.pc-will .promise-tag{background:rgba(165,217,26,.22);color:#6fa30f}
.pc-wont .promise-tag{background:rgba(255,61,61,.12);color:#ff3d3d}
.promise-list{display:flex;flex-direction:column;gap:0;margin-top:4px}
.promise-item{display:flex;gap:12px;align-items:flex-start;padding:13px 0;min-height:52px}
.promise-mark{flex-shrink:0;display:flex;align-items:center;justify-content:center}
.pc-will .promise-mark{width:26px;height:26px;border-radius:50%;color:#a5d91a}
.pc-wont .promise-mark{width:28px;height:28px;border-radius:8px;background:rgba(255,61,61,.12);color:#ff3d3d}
.promise-mark img,.promise-mark svg{display:block}
.pc-will .promise-mark img{width:26px;height:26px}
.pc-wont .promise-mark img{width:16px;height:16px}
.promise-item p{font-family:'Inter',sans-serif;font-size:16px;font-weight:500;line-height:22.816px;color:#444}

/* ─── SECTION: LOGISTICS ─── */
.sec-logistics{padding:80px max(24px, calc((100% - 1200px) / 2)) 96px;background:#f8f8f8}
.sec-logistics .sec-head h2 em{font-style:normal;color:#1a1a1a;font-weight:700}
.log-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1200px;margin:0 auto}
.log-card{background:#fff;border-radius:16px;padding:32px 24px;border:0;min-height:157px;display:flex;flex-direction:column;gap:16px}
.log-card h3{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:24px;line-height:28px;margin:0}
.log-card.lc-blue h3{color:var(--blue)}
.log-card.lc-purple h3{color:var(--purple)}
.log-card.lc-green h3{color:var(--green)}
.log-card p{font-family:'Inter',sans-serif;font-size:14px;line-height:22.528px;color:#444;margin:0}

/* ─── CTA BANNER ─── */
.cta-banner{position:relative;background:linear-gradient(to top,#bfeeff 0%,#fff 80.17%);padding:120px max(24px, calc((100% - 1200px) / 2)) 100px;text-align:center;overflow:hidden;min-height:480px}
.cta-banner h2{font-family:'Bricolage Grotesque',sans-serif;font-size:44.8px;line-height:56px;font-weight:700;max-width:658px;margin:0 auto 40px;letter-spacing:-0.5px;color:#2c2c2c}
.cta-banner h2 .learn{display:block;color:var(--purple)}
.cta-banner h2 .amber{color:var(--amber)}
.cta-actions{display:inline-flex;gap:24px;flex-wrap:wrap;justify-content:center;margin-top:4px}
.cta-actions .btn{width:200px;height:60px;border-radius:100px;display:inline-flex;align-items:center;justify-content:center;font-family:'Inter',sans-serif;font-weight:600;font-size:16px}
.cta-actions .btn-blue{background:var(--blue);color:#fff;border:0}
.cta-actions .btn-outline{background:transparent;color:#1a1a1a;border:1px solid #000;font-size:14.4px}
.cta-deco{position:absolute;pointer-events:none;border-radius:8px;overflow:hidden}
.cta-d1{left:160px;top:100px;width:151px;height:114px}
.cta-d2{right:232px;top:340px;width:131px;height:98px}
.cta-d3{right:120px;top:80px;width:197px;height:148px}
.cta-d4{left:120px;top:300px;width:197px;height:148px}
.cta-deco img{width:100%;height:100%;object-fit:cover;display:block}
.cta-sparkle{position:absolute;pointer-events:none}
.cta-sparkle img{width:100%;height:100%;display:block}
.cta-sparkle.sp1{left:486px;top:104px;width:52px;height:52px}
.cta-sparkle.sp2{left:1039px;top:268px;width:56px;height:56px}
.cta-sparkle.sp3{left:962px;top:85px;width:32px;height:32px}
.cta-sparkle.sp4{left:475px;top:285px;width:30px;height:30px}
.sp1{left:487px;top:87px;width:49px;height:47px}
.sp2{left:1039px;top:267px;width:45px;height:43px}
.sp3{left:961px;top:66px;width:27px;height:26px}
.sp4{left:475px;top:285px;width:25px;height:24px}

/* ─── FOOTER (shared with index.html) ─── */
footer{background:#1a1a1a;position:relative;overflow:hidden}
.footer-main{display:flex;justify-content:space-between;padding:60px max(24px, calc((100% - 1200px) / 2));gap:40px}
.footer-brand{width:320px;display:flex;flex-direction:column;gap:24px}
.footer-logo{display:flex;align-items:center;gap:12px}
.footer-logo img{width:44px;height:44px;border-radius:10px}
.footer-brand-name{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:18px;color:#fff}
.footer-brand-tag{font-family:'Inter',sans-serif;font-size:14px!important;font-weight:400!important;letter-spacing:1.38px!important;text-transform:uppercase!important;color:var(--blue);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.footer-desc{font-family:'Inter',sans-serif;font-size:14px;line-height:24px;color:#888;width:280px}
.footer-social-lbl{font-family:'Inter',sans-serif;font-size:14px!important;font-weight:400!important;letter-spacing:1.38px!important;text-transform:uppercase!important;color:#555;margin-bottom:12px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.social-icons{display:flex;gap:8px}
.s-icon{width:36px;height:36px;background:#2c2c2c;border:1px solid #333;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:background .2s;color:#fff}
.s-icon:hover{background:#3a3a3a}
.s-icon img{width:20px;height:20px;opacity:.9}
.s-icon svg{width:18px;height:18px;display:block;opacity:.85;flex-shrink:0}
.footer-col{display:flex;flex-direction:column;gap:20px}
.footer-col-title{font-family:'Inter',sans-serif;font-size:14px!important;font-weight:400!important;letter-spacing:1.38px!important;text-transform:uppercase!important;color:#fff;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.footer-links-list{display:flex;flex-direction:column;gap:14px}
.footer-links-list a{font-family:'Inter',sans-serif;font-size:14px;color:#888;transition:color .2s}
.footer-links-list a:hover{color:#ccc}
.contact-item{display:flex;align-items:flex-start;gap:12px;margin-bottom:20px}
.contact-item:last-child{margin-bottom:0}
.c-icon{width:32px;height:32px;background:#2c2c2c;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.c-icon img{width:15px;height:15px}
.c-name{font-family:'Inter',sans-serif;font-size:14px;font-weight:600;color:#ccc;line-height:1.4;white-space:nowrap}
.c-addr{font-family:'Inter',sans-serif;font-size:14px;color:#888;line-height:20px;margin-top:2px;width:220px}
.c-link{font-family:'Inter',sans-serif;font-size:14px;color:#888;display:block;line-height:1.55}
.c-link:hover{color:#ccc}
.footer-bottom{border-top:1px solid #2c2c2c;display:flex;justify-content:space-between;align-items:center;padding:20px max(24px, calc((100% - 1200px) / 2));font-family:'Inter',sans-serif;font-size:14px;color:#555}
.footer-bottom-links{display:flex;gap:24px}
.footer-bottom-links a{color:#555}
.footer-bottom-links a:hover{color:#888}
.f-deco{position:absolute;pointer-events:none;opacity:.4}
.f-deco img{width:100%;height:100%}
.fd1{left:58px;top:42px;width:50px;height:51px}
.fd2{right:87px;bottom:60px;width:86px;height:87px}

/* ─── RESPONSIVE (tablet & mobile) ─── */
@media (max-width:1024px){
  body{min-width:0}
  html{min-width:0}
  .nav{padding-left:24px;padding-right:24px}
  .nav-links,.nav-cta{display:none}
  .hamburger{display:flex}
  .pre-hero-inner{grid-template-columns:1fr;gap:40px}
  .pre-hero-right{grid-template-columns:1fr 1fr;grid-template-rows:160px 160px;max-width:560px}
  .ph-img3{height:100%}
  .approach-grid{grid-template-columns:1fr 1fr}
  .spaces2-grid{grid-template-columns:1fr 1fr;gap:20px}
  .grow-inner{grid-template-columns:1fr;gap:48px}
  .edu-inner{grid-template-columns:1fr;gap:48px}
  .ages-grid{grid-template-columns:repeat(3,1fr)}
  .promise-grid{grid-template-columns:1fr;gap:20px}
  .log-grid{grid-template-columns:1fr 1fr}
  .meaning-grid{grid-template-columns:1fr 1fr}
  .cta-deco{display:none}
}
@media (max-width:768px){
  body{padding-top:0}
  /* NAV — non-scrolled: big logo centred; scrolled: compact logo left + hamburger right */
  .header-wrap{display:flex;align-items:center;justify-content:center;padding:0;min-height:96px;background:transparent!important;border-color:transparent!important}
  .header-wrap.scrolled{background:#fff!important;border-color:rgba(0,0,0,0.06)!important;min-height:52px}
  .logo-panel{overflow:visible;flex-shrink:0}
  .logo-box{padding:0}
  .logo-full{height:80px}
  .nav{position:absolute;right:0;top:0;bottom:0;display:flex;align-items:center;padding:0 20px;width:auto;flex:0}
  .nav-links,.nav-cta{display:none!important}
  .hamburger{display:flex}
  .header-wrap.scrolled{justify-content:flex-start;padding:0 16px}
  .header-wrap.scrolled .nav{position:static;flex:1;padding:8px 0;width:auto;justify-content:space-between}
  .header-wrap.scrolled .logo-compact-wrap{display:flex!important}

  h1{font-size:36px;line-height:44px;letter-spacing:-.5px}
  h2{font-size:28px;line-height:34px}
  .pre-hero{padding:120px 20px 64px}
  .pre-hero-left{text-align:center}
  .pre-hero h1{font-size:34px;line-height:42px}
  .pre-hero-sub{font-size:16px;line-height:26px;margin-bottom:28px;margin-left:auto;margin-right:auto}
  .pre-hero-actions{gap:12px;justify-content:center}
  .pre-hero-actions .btn{padding:14px 24px;font-size:15px}
  .pre-hero-right{grid-template-columns:1fr 1fr;grid-template-rows:130px 130px;gap:10px;max-width:none}
  .ph-img3{grid-column:2;grid-row:1/span 2}
  .ph-sp1{width:42px;height:40px;top:-16px;right:-4px}
  .ph-sp2{width:26px;height:25px;bottom:-10px;right:40%}
  .ph-sp3{width:34px;height:33px;bottom:10px;right:-8px}
  .sec-approach,.sec-spaces,.sec-grow,.sec-educators,.sec-meaning,.sec-ages,.sec-promise,.sec-logistics{padding:64px 20px}
  .meaning-grid{grid-template-columns:1fr;gap:14px}
  .meaning-card{min-height:0;padding:22px 20px}
  .sec-head{margin-bottom:40px}
  .approach-grid{grid-template-columns:1fr;gap:16px}
  /* SPACES — stacked full-width cards on mobile */
  .spaces2-grid{display:flex;flex-direction:column;gap:16px;grid-template-columns:none}
  .space2-card{width:100%;aspect-ratio:auto;display:block}
  .space2-card .space2-img{position:relative;inset:auto;width:100%;height:auto;aspect-ratio:591/332;display:block;object-fit:cover}
  .space2-body{position:static;padding:16px 20px 20px}
  .space2-title{font-size:20px;line-height:26px}
  .space2-card .space2-desc{display:none}
  .grow-right{grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:12px}
  .grow-tile{aspect-ratio:auto;min-height:240px}
  .grow-tile-body{padding:20px;justify-content:flex-end}
  .grow-tile-title{font-size:22px;line-height:26px;margin-bottom:6px}
  .grow-tile-desc{font-size:14px;line-height:18px;max-width:none}
  .edu-orbit{zoom:0.68}
  .ages-grid{grid-template-columns:1fr;gap:12px;margin-bottom:18px}
  .age-card{display:block;text-align:left;padding:24px 20px;min-height:0}
  .age-icon{margin:0 0 14px}
  .age-name{margin-bottom:4px}
  .age-band{margin-bottom:10px}
  .age-desc{max-width:none;margin:0}
  .promise-col{padding:28px 22px}
  .promise-item p{font-size:14.5px;line-height:21px;white-space:normal}
  /* LOGISTICS CAROUSEL */
  .sec-logistics{padding-left:0!important;padding-right:0!important}
  .sec-logistics .sec-head{padding:0 20px}
  .log-grid{
    display:flex;overflow-x:auto;gap:14px;justify-content:flex-start;
    scroll-snap-type:x mandatory;scroll-padding-left:20px;scrollbar-width:none;
    padding:0 20px 8px 20px!important;grid-template-columns:none;
  }
  .log-grid::-webkit-scrollbar{display:none}
  .log-card{flex:0 0 calc(70vw - 34px);width:calc(70vw - 34px);scroll-snap-align:start;flex-shrink:0}
  .cta-banner{padding:80px 20px 64px;min-height:0}
  .cta-banner h2{font-size:28px;line-height:36px;max-width:none}
  .cta-banner h2 br{display:none}
  /* Keep sparkles visible — shrink & nudge (never display:none per brand) */
  .cta-sparkle{position:absolute}
  .cta-sparkle.sp1{left:auto!important;right:24px;top:28px;width:28px;height:28px}
  .cta-sparkle.sp2{left:20px!important;right:auto;top:auto;bottom:40px;width:24px;height:24px}
  .cta-sparkle.sp3{left:20px!important;right:auto;top:40px;width:20px;height:20px}
  .cta-sparkle.sp4{left:auto!important;right:36px;top:auto;bottom:30px;width:22px;height:22px}
  .cta-actions{flex-direction:column;align-items:stretch;gap:20px;width:100%;max-width:320px;margin:0 auto}
  .cta-actions .btn{width:100%;height:52px;font-size:15px}
  .cta-actions .btn-outline{font-size:14px}
  .footer-main{flex-direction:column;padding:44px 20px;gap:36px}
  .footer-brand,.footer-col{width:100%!important}
  .footer-bottom{flex-direction:column;gap:10px;text-align:center;padding:16px 20px}
}

/* ── micro-animations (shared system) ── */
@media (prefers-reduced-motion: no-preference){
  .reveal{opacity:0;transform:scale(.86) translateY(16px);transition:opacity .8s ease-out, transform .8s cubic-bezier(.22,.75,.2,1)}
  .reveal.in-view{opacity:1;transform:none}
  @keyframes twinkle{0%,100%{opacity:.85;transform:scale(1) rotate(0)}50%{opacity:1;transform:scale(1.18) rotate(6deg)}}
  .pre-hero-sp img,.edu-sp img,.cta-sparkle img{animation:twinkle 3.2s ease-in-out infinite;transform-origin:center;will-change:transform,opacity}
  .ph-sp2 img{animation-delay:.4s}
  .ph-sp3 img{animation-delay:.8s}
  .edu-sp-green img{animation-delay:.6s}
  .sp2 img{animation-delay:.3s} .sp3 img{animation-delay:.6s} .sp4 img{animation-delay:.9s}
  [data-parallax]{transform:translate3d(0,var(--py,0),0);transition:transform .08s linear;will-change:transform}
}