/* ============================================
   Child Preschool – Main Stylesheet
   ============================================ */

/* ---------- Design Tokens ---------- */
:root {
  --clr-primary: #f46106;
  --clr-primary-light: #f88a43;
  --clr-primary-dark: #b94805;
  --clr-accent: #4b5056;
  --clr-accent-dark: #2d3136;
  --clr-warm: #fff1e4;
  --clr-warm-mid: #f8deca;
  --clr-bg: #fdf7f1;
  --clr-white: #ffffff;
  --clr-text: #242628;
  --clr-text-light: #53575c;
  --clr-text-muted: #7c8187;
  --clr-border: #ecd8c8;
  --clr-hero-overlay: rgba(244, 97, 6, 0.68);
  --clr-soft-bg: #f1f2f4;
  --clr-btn-accent: #fff4ea;
  --clr-btn-accent-dark: #262b31;

  --ff-heading: 'DM Serif Display', Georgia, serif;
  --ff-body: 'Inter', 'Segoe UI', sans-serif;

  --fs-xs: 0.75rem;
  --fs-sm: 0.875rem;
  --fs-base: 1rem;
  --fs-md: 1.125rem;
  --fs-lg: 1.25rem;
  --fs-xl: 1.5rem;
  --fs-2xl: 2rem;
  --fs-3xl: 2.5rem;
  --fs-4xl: 3.25rem;

  --radius: 12px;
  --radius-sm: 8px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.08);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.1);
  --shadow-lg: 0 8px 30px rgba(0,0,0,0.12);

  --container: 1200px;
  --header-height: 80px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--ff-body);font-size:var(--fs-base);line-height:1.7;color:var(--clr-text);background:var(--clr-bg)}
body.page-bright-white{background:#fff}
img,svg{display:block;max-width:100%;height:auto}
a{color:var(--clr-primary);text-decoration:none;transition:color .2s}
a:hover{color:var(--clr-primary-dark)}
ul,ol{list-style:none}
button{cursor:pointer;font-family:inherit;border:none;background:none}
h1,h2,h3,h4,h5,h6{font-family:var(--ff-heading);line-height:1.25;color:var(--clr-primary)}
h2,h3{position:relative}
h3{font-size:var(--fs-xl)}
h4{font-size:var(--fs-xl)}
h2::after,h3::after{content:'';display:block;width:60px;height:3px;margin-top:12px;border-radius:999px;background:linear-gradient(rgba(45,49,54,0.7),rgba(45,49,54,0.7)) left center/2px 8px no-repeat,linear-gradient(rgba(45,49,54,0.7),rgba(45,49,54,0.7)) right center/2px 8px no-repeat,linear-gradient(90deg,rgba(45,49,54,0.24) 0 20px,rgba(45,49,54,0.7) 20px 40px,rgba(45,49,54,0.24) 40px 100%)}

/* ---------- Utility ---------- */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 24px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.text-center{text-align:center}
.text-accent{color:var(--clr-accent-dark)}
.bg-warm{background:var(--clr-warm)}
.bg-soft{background:var(--clr-soft-bg)}
.bg-white{background:var(--clr-white)}
.bg-primary{background:var(--clr-primary);color:#fff}
.icon-stroke{stroke:currentColor;fill:none;stroke-width:1.85;stroke-linecap:round;stroke-linejoin:round}

.section{padding:80px 0}
.section-sm{padding:56px 0}
.section-header{text-align:center;max-width:720px;margin:0 auto 48px}
.section-header h2{font-size:var(--fs-3xl);margin-bottom:12px}
.section-header h2::after{width:74px;margin-left:auto;margin-right:auto;background:linear-gradient(rgba(45,49,54,0.7),rgba(45,49,54,0.7)) left center/2px 8px no-repeat,linear-gradient(rgba(45,49,54,0.7),rgba(45,49,54,0.7)) right center/2px 8px no-repeat,linear-gradient(90deg,rgba(45,49,54,0.22) 0 18px,rgba(45,49,54,0.7) 18px 56px,rgba(45,49,54,0.22) 56px 100%)}
.section-header p{font-size:var(--fs-md);color:var(--clr-text-light)}
.section-sets-apart{background:var(--clr-primary)}
.section-limited-offer{background:url(../images/offer-background.png) no-repeat center/cover,linear-gradient(135deg,var(--clr-primary-dark) 0%,var(--clr-primary) 50%,var(--clr-primary-light) 100%)}
.section-fees-info{background:var(--clr-accent-dark)}
.section-limited-offer .btn-white{color:var(--clr-primary)}
.section-limited-offer .btn-white:hover{background:var(--clr-primary);color:#fff}
.section-special-offer-main .btn-white:hover{background:var(--clr-accent-dark);color:#fff}
.section-sets-apart .section-header h2{color:#fff}
.section-sets-apart .section-header h2::after{background:linear-gradient(rgba(255,255,255,0.95),rgba(255,255,255,0.95)) left center/2px 8px no-repeat,linear-gradient(rgba(255,255,255,0.95),rgba(255,255,255,0.95)) right center/2px 8px no-repeat,linear-gradient(90deg,rgba(255,255,255,0.28) 0 18px,rgba(255,255,255,0.92) 18px 56px,rgba(255,255,255,0.28) 56px 100%)}
.section-sets-apart .section-header p{color:#fff}
.section-sets-apart .feature-card{border-color:var(--clr-accent-dark)}
.section-packing-offer{background:var(--clr-primary)}
.section-packing-offer .section-header h2,.section-packing-offer .section-header p{color:#fff}
.section-packing-offer .section-header h2::after{background:linear-gradient(rgba(255,255,255,0.95),rgba(255,255,255,0.95)) left center/2px 8px no-repeat,linear-gradient(rgba(255,255,255,0.95),rgba(255,255,255,0.95)) right center/2px 8px no-repeat,linear-gradient(90deg,rgba(255,255,255,0.28) 0 18px,rgba(255,255,255,0.92) 18px 56px,rgba(255,255,255,0.28) 56px 100%)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border-radius:50px;font-size:var(--fs-base);font-weight:600;transition:all .25s;text-align:center;line-height:1.3}
.btn-primary{background:var(--clr-primary);color:#fff}
.btn-primary:hover{background:var(--clr-primary-dark);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-accent{background:var(--clr-btn-accent);color:var(--clr-btn-accent-dark)}
.btn-accent:hover{background:var(--clr-btn-accent-dark);color:#fff;transform:translateY(-2px)}
.btn-outline{border:2px solid var(--clr-primary);color:var(--clr-primary)}
.btn-outline:hover{background:var(--clr-primary);color:#fff;transform:translateY(-2px)}
.btn-white{background:#fff;color:var(--clr-primary-dark)}
.btn-white:hover{background:var(--clr-warm);color:var(--clr-primary-dark);transform:translateY(-2px)}
.btn-sm{padding:10px 24px;font-size:var(--fs-sm)}

/* ---------- Header / Navigation ---------- */
.site-header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background:rgba(255,255,255,0.97);backdrop-filter:blur(8px);z-index:1000;border-bottom:1px solid var(--clr-border);transition:box-shadow .3s}
.site-header.scrolled{box-shadow:var(--shadow-sm)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-height);max-width:var(--container);margin:0 auto;padding:0 24px}
.logo{font-family:var(--ff-heading);font-size:var(--fs-2xl);color:var(--clr-primary-dark);font-weight:700;letter-spacing:-0.5px;display:flex;align-items:center;gap:8px}
.logo img{height:60px;width:auto}
.logo span{color:var(--clr-primary-light)}
.nav-links{display:flex;align-items:center;gap:8px}
.nav-links a{padding:8px 14px;font-size:var(--fs-sm);font-weight:500;color:var(--clr-text);border-radius:var(--radius-sm);transition:background .2s,color .2s}
.nav-links a:hover,.nav-links a.active{background:var(--clr-warm);color:var(--clr-primary)}
.nav-links .btn{margin-left:8px}
.header-phone{display:flex;align-items:center;gap:6px;font-weight:600;color:var(--clr-primary);font-size:var(--fs-md)}
.header-phone svg{width:16px;height:16px}

/* ---------- Navigation Dropdowns ---------- */
.nav-dropdown{position:relative}
.nav-dropdown-toggle{display:inline-flex;align-items:center;gap:5px;padding:8px 14px;font-size:var(--fs-sm);font-weight:500;color:var(--clr-text);border-radius:var(--radius-sm);transition:background .2s,color .2s;cursor:pointer;background:none;border:none;font-family:var(--ff-body);line-height:1.5}
.nav-dropdown-toggle:hover,.nav-dropdown-toggle.active{background:var(--clr-warm);color:var(--clr-primary)}
.nav-dropdown-toggle .dropdown-arrow{transition:transform .2s;flex-shrink:0}
.nav-dropdown.open .nav-dropdown-toggle .dropdown-arrow{transform:rotate(180deg)}
.nav-dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;min-width:200px;background:#fff;border-radius:var(--radius-sm);box-shadow:var(--shadow-md);border:1px solid var(--clr-border);padding:8px 0;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .2s,visibility .2s,transform .2s;z-index:100}
.nav-dropdown.open .nav-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-dropdown-menu a{display:block;padding:10px 20px;font-size:var(--fs-sm);color:var(--clr-text);transition:background .15s,color .15s;white-space:nowrap}
.nav-dropdown-menu a:hover,.nav-dropdown-menu a.active{background:var(--clr-warm);color:var(--clr-primary)}
.nav-offer{padding:8px 14px;font-size:var(--fs-sm);font-weight:600;color:var(--clr-accent-dark)!important;border-radius:var(--radius-sm);transition:background .2s}
.nav-offer:hover{background:var(--clr-warm)}

/* Mobile menu */
.menu-toggle{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer}
.menu-toggle span{display:block;width:24px;height:2px;background:var(--clr-text);border-radius:2px;transition:all .3s}
.menu-toggle.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.menu-toggle.open span:nth-child(2){opacity:0}
.menu-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

@media(max-width:1024px){
  .nav-links{position:fixed;top:var(--header-height);left:0;right:0;bottom:0;background:#fff;flex-direction:column;align-items:stretch;padding:32px 24px;gap:4px;transform:translateX(100%);transition:transform .3s ease;overflow-y:auto}
  .nav-links.open{transform:translateX(0)}
  .nav-links a{padding:14px 16px;font-size:var(--fs-md);border-bottom:1px solid var(--clr-border)}
  .nav-links .btn{margin:16px 0 0;text-align:center;justify-content:center}
  .menu-toggle{display:flex}
  .header-phone{display:none}
  .nav-dropdown{width:100%}
  .nav-dropdown-toggle{padding:14px 16px;font-size:var(--fs-md);width:100%;justify-content:space-between;border-bottom:1px solid var(--clr-border);border-radius:0}
  .nav-dropdown-menu{position:static;box-shadow:none;border:none;border-radius:0;padding:0;opacity:1;visibility:visible;transform:none;max-height:0;overflow:hidden;transition:max-height .3s ease;background:var(--clr-warm)}
  .nav-dropdown.open .nav-dropdown-menu{max-height:500px}
  .nav-dropdown-menu a{padding:12px 16px 12px 32px;border-bottom:1px solid var(--clr-border);font-size:var(--fs-sm)}
  .nav-offer{padding:14px 16px;font-size:var(--fs-md);border-bottom:1px solid var(--clr-border);display:block}
}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:600px;display:flex;align-items:center;background:var(--clr-primary-dark);margin-top:var(--header-height);overflow:hidden}
.hero::after{content:'';position:absolute;inset:0;background:rgba(45,49,54,0.42);z-index:1}
.hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,var(--clr-primary-dark) 0%,var(--clr-primary) 50%,var(--clr-primary-light) 100%);opacity:.9}
.hero-bg-img{position:absolute;inset:0;background-size:cover;background-position:center}
.hero-bg-img + .hero-bg{background:var(--clr-hero-overlay);opacity:1}
.hero-pattern{position:absolute;inset:0;opacity:.06;background-image:radial-gradient(circle at 25% 25%,#fff 1px,transparent 1px),radial-gradient(circle at 75% 75%,#fff 1px,transparent 1px);background-size:40px 40px}
.hero-content{position:relative;z-index:2;padding:80px 0;max-width:960px;margin:0 auto;text-align:center}
.hero-text-panel{width:100%;padding:34px 0 38px;position:relative}
.hero h1{font-size:var(--fs-4xl);color:#fff;margin:0 0 16px}
.hero .tagline{font-size:var(--fs-xl);color:var(--clr-warm);margin:0 auto 10px;width:fit-content;max-width:100%;font-style:italic;font-family:var(--ff-heading);text-align:center}
.hero p{font-size:var(--fs-md);color:rgba(255,255,255,0.92);margin:0;max-width:820px;margin-left:auto;margin-right:auto}
.hero-btns{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;margin-top:28px}
.hero .btn-accent:hover,.hero .btn-white:hover{background:var(--clr-primary);color:#fff}

/* Inner-page hero (shorter) */
.hero-inner{min-height:600px}
.hero-inner .hero-content{padding:56px 0}
.hero-inner h1{font-size:var(--fs-3xl)}

/* ---------- Promo Banner ---------- */
.promo-banner{background:linear-gradient(135deg,var(--clr-primary-dark),var(--clr-accent));color:#fff;text-align:center;padding:14px 24px;font-weight:600;font-size:var(--fs-sm)}
.promo-banner a{color:#fff;text-decoration:underline;font-weight:700}

/* ---------- Feature Cards ---------- */
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:32px}
.feature-card{background:#fff;border-radius:var(--radius);padding:36px 28px;box-shadow:var(--shadow-sm);border:2px solid var(--clr-primary);transition:box-shadow .3s,transform .3s}
.feature-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}
.feature-icon,.contact-card .icon,.pillar-icon,.two-col-icon{display:flex;align-items:center;justify-content:center;color:var(--clr-primary);background:linear-gradient(180deg,#fafbfc,var(--clr-soft-bg));border:1px solid rgba(75,80,86,0.18);box-shadow:4px 4px 0 var(--clr-accent-dark)}
.feature-icon{width:58px;height:58px;border-radius:18px;margin-bottom:20px}
.feature-icon svg,.contact-card .icon svg,.pillar-icon svg,.two-col-icon svg,.team-avatar svg{width:28px;height:28px;stroke:currentColor;fill:none;stroke-width:1.85;stroke-linecap:round;stroke-linejoin:round}
.feature-card h3{font-size:var(--fs-xl);margin-bottom:10px}
.feature-card p{color:var(--clr-text-light);font-size:var(--fs-sm);line-height:1.7}

/* ---------- Room Cards ---------- */
.rooms-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:28px}
.room-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:2px solid var(--clr-primary);transition:box-shadow .3s,transform .3s}
.room-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.room-card-img{height:200px;background:var(--clr-primary-light);display:flex;align-items:center;justify-content:center;font-size:64px;color:rgba(255,255,255,0.5);overflow:hidden}
.room-card-img img{width:100%;height:100%;object-fit:cover}
.room-card-body{padding:28px}
.room-card-body h3{font-size:var(--fs-xl);margin-bottom:4px}
.room-card-body h3::after,.pricing-card h3::after,.team-card h3::after,.contact-card h3::after,.step-card h3::after,.pillar-card h3::after{width:52px;margin-top:10px}
.room-card-body .age-badge{display:inline-block;background:var(--clr-warm);color:var(--clr-primary-dark);padding:4px 14px;border-radius:20px;font-size:var(--fs-xs);font-weight:700;margin-bottom:12px}
.room-card-body .ratio{font-size:var(--fs-md);font-weight:700;color:var(--clr-primary);margin-bottom:8px}
.room-card-body p{color:var(--clr-text-light);font-size:var(--fs-sm);line-height:1.7}

/* ---------- Testimonials ---------- */
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:28px}
.testimonial-card{background:#fff;border-radius:var(--radius);padding:32px;box-shadow:var(--shadow-sm);border:2px solid var(--clr-primary);position:relative}
.testimonial-card::before{content:'\201C';font-family:var(--ff-heading);font-size:72px;color:var(--clr-warm-mid);position:absolute;top:12px;left:20px;line-height:1}
.testimonial-card blockquote{font-size:var(--fs-sm);color:var(--clr-text-light);line-height:1.8;margin-bottom:16px;padding-top:22px;position:relative;z-index:1}
.testimonial-card .family-name{font-weight:700;color:var(--clr-primary);font-size:var(--fs-sm)}
.testimonial-card .family-loc{font-size:var(--fs-xs);color:var(--clr-text-muted)}

/* ---------- FAQ ---------- */
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--clr-border)}
.faq-item summary{padding:20px 0;font-size:var(--fs-md);font-weight:600;cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:16px;color:var(--clr-primary-dark)}
.faq-item summary::after{content:'+';font-size:var(--fs-xl);font-weight:300;transition:transform .3s;flex-shrink:0;color:var(--clr-primary)}
.faq-item[open] summary::after{content:'\2212'}
.faq-item .faq-body{padding:0 0 24px;color:var(--clr-text-light);line-height:1.8;font-size:var(--fs-sm)}
.faq-item .faq-body ul{margin:12px 0 12px 20px;list-style:disc}
.faq-item .faq-body li{margin-bottom:6px}

/* ---------- Stats ---------- */
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:24px;text-align:center}
.stat-item h3{font-size:var(--fs-3xl);color:var(--clr-primary-light);margin-bottom:4px}
.stat-item h3::after{display:none}
.stat-item p{font-size:var(--fs-sm);color:rgba(255,255,255,0.85);font-weight:500}
.bg-primary .stat-item h3{color:var(--clr-warm)}

/* ---------- Timeline / Routine ---------- */
.routine-timeline{max-width:720px;margin:0 auto;position:relative}
.routine-timeline::before{content:'';position:absolute;left:32px;top:0;bottom:0;width:3px;background:var(--clr-warm-mid);border-radius:2px}
.routine-item{display:flex;gap:24px;margin-bottom:32px;position:relative}
.routine-time{flex-shrink:0;width:64px;height:64px;border-radius:50%;background:var(--clr-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--fs-sm);z-index:1;text-align:center;line-height:1.2}
.routine-body h4{font-size:var(--fs-md);margin-bottom:4px;color:var(--clr-primary-dark)}
.routine-body p{color:var(--clr-text-light);font-size:var(--fs-sm);line-height:1.7}

/* ---------- Pricing / Fees ---------- */
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:28px}
.pricing-card{background:#fff;border-radius:var(--radius);padding:36px 28px;box-shadow:var(--shadow-sm);border:2px solid var(--clr-primary);text-align:center;transition:box-shadow .3s,transform .3s;display:flex;flex-direction:column}
.pricing-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.pricing-card.featured{border-color:var(--clr-primary)}
.pricing-card h3{font-size:var(--fs-xl);margin-bottom:8px}
.pricing-card h3::after{margin-left:auto;margin-right:auto}
.pricing-card .price{font-size:var(--fs-3xl);color:var(--clr-primary);font-weight:700;margin-bottom:4px;font-family:var(--ff-heading)}
.pricing-card .price-note{font-size:var(--fs-sm);color:var(--clr-text-muted);margin-bottom:20px}
.pricing-card ul{text-align:left;margin-bottom:24px;flex:1 0 auto}
.pricing-card li{padding:8px 0;font-size:var(--fs-sm);border-bottom:1px solid var(--clr-border);color:var(--clr-text-light)}
.pricing-card li::before{content:'✓ ';color:var(--clr-primary);font-weight:700}
.pricing-card .btn{margin-top:auto;align-self:center}

/* ---------- Team ---------- */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:32px}
.team-card{text-align:center;background:#fff;border-radius:var(--radius);padding:36px 28px;box-shadow:var(--shadow-sm);border:2px solid var(--clr-primary)}
.team-avatar{width:120px;height:120px;border-radius:32px;background:linear-gradient(180deg,#fff9f3,var(--clr-warm-mid));margin:0 auto 20px;display:flex;align-items:center;justify-content:center;overflow:hidden;border:1px solid rgba(244,97,6,0.14);box-shadow:5px 5px 0 var(--clr-accent-dark)}
.team-avatar img{width:100%;height:100%;object-fit:cover}
.team-avatar svg{width:52px;height:52px;color:var(--clr-primary-dark)}
.team-card h3{font-size:var(--fs-xl);margin-bottom:4px}
.team-card h3::after{margin-left:auto;margin-right:auto}
.team-card .role{font-size:var(--fs-sm);color:var(--clr-primary);font-weight:600;margin-bottom:12px}
.team-card p{font-size:var(--fs-sm);color:var(--clr-text-light);line-height:1.7}

/* ---------- CTA Section ---------- */
.section-cta{padding:0}
.cta-section{background:linear-gradient(135deg,var(--clr-accent-dark),var(--clr-accent));color:#fff;text-align:center;padding:72px 24px;border-radius:0;margin:0}
.cta-section h2{color:#fff;font-size:var(--fs-2xl);margin-bottom:12px}
.cta-section h2::after,.offer-card h2::after{width:74px;margin-left:auto;margin-right:auto;background:linear-gradient(rgba(255,255,255,0.95),rgba(255,255,255,0.95)) left center/2px 8px no-repeat,linear-gradient(rgba(255,255,255,0.95),rgba(255,255,255,0.95)) right center/2px 8px no-repeat,linear-gradient(90deg,rgba(255,255,255,0.3) 0 18px,rgba(255,255,255,0.85) 18px 56px,rgba(255,255,255,0.3) 56px 100%)}
.cta-section p{color:rgba(255,255,255,0.85);margin-bottom:28px;font-size:var(--fs-md);max-width:560px;margin-left:auto;margin-right:auto}
.cta-section .btn-accent:hover,.cta-section .btn-white:hover{background:var(--clr-primary);color:#fff}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ---------- Forms ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-group{display:flex;flex-direction:column}
.form-group.full{grid-column:1/-1}
.form-group label{font-size:var(--fs-sm);font-weight:600;margin-bottom:6px;color:var(--clr-text)}
.form-group input,.form-group select,.form-group textarea{padding:12px 16px;border:1px solid var(--clr-border);border-radius:var(--radius-sm);font-size:var(--fs-base);font-family:var(--ff-body);transition:border-color .2s;background:#fff}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--clr-primary);box-shadow:0 0 0 3px rgba(45,106,79,0.12)}
.form-group textarea{min-height:120px;resize:vertical}
.form-note{font-size:var(--fs-xs);color:var(--clr-text-muted);margin-top:4px}

@media(max-width:640px){
  .form-grid{grid-template-columns:1fr}
}

/* ---------- Contact Info Cards ---------- */
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px;margin-bottom:0}
.contact-card{background:#fff;border-radius:var(--radius);padding:28px;text-align:center;box-shadow:var(--shadow-sm);border:2px solid var(--clr-primary)}
.contact-card .icon{width:64px;height:64px;border-radius:20px;margin:0 auto 16px}
.contact-card h3{font-size:var(--fs-xl);margin-bottom:6px}
.contact-card h3::after{margin-left:auto;margin-right:auto}
.contact-card p,.contact-card a{font-size:var(--fs-sm);color:var(--clr-text-light)}
.contact-card a:hover{color:var(--clr-primary)}

/* ---------- Map placeholder ---------- */
.map-container{border-radius:var(--radius);overflow:hidden;height:360px;background:var(--clr-warm-mid);display:flex;align-items:center;justify-content:center;margin-top:48px;border:1px solid var(--clr-border)}
.map-container iframe{width:100%;height:100%;border:0}

/* ---------- Checklist ---------- */
.checklist{max-width:680px;margin:0 auto}
.checklist li{padding:12px 0;font-size:0.9375rem;border-bottom:1px solid var(--clr-border);display:flex;align-items:flex-start;gap:12px;color:var(--clr-text-light)}
.checklist li::before{content:'✓';display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--clr-primary);color:#fff;font-size:var(--fs-xs);font-weight:700;flex-shrink:0;margin-top:2px}

/* ---------- Steps ---------- */
.steps-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:32px;counter-reset:step;max-width:1120px;margin:0 auto}
.step-card{text-align:center;position:relative;counter-increment:step;background:#fff;border-radius:var(--radius);padding:36px 28px;box-shadow:var(--shadow-sm);border:2px solid var(--clr-primary);transition:box-shadow .3s,transform .3s;grid-column:span 2}
.step-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}
.step-card:nth-child(4){grid-column:2 / span 2}
.step-card:nth-child(5){grid-column:4 / span 2}
.step-number{width:56px;height:56px;border-radius:50%;background:var(--clr-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--fs-lg);margin:0 auto 16px;font-family:var(--ff-heading)}
.step-card h3{font-size:var(--fs-xl);margin-bottom:8px}
.step-card h3::after{margin-left:auto;margin-right:auto}
.step-card p{font-size:var(--fs-sm);color:var(--clr-text-light);line-height:1.7;text-align:center}

/* ---------- Two-column layout ---------- */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:stretch}
.two-col-text h2{font-size:var(--fs-2xl);margin-bottom:16px}
.two-col-text p{color:var(--clr-text-light);margin-bottom:16px;line-height:1.8}
.two-col-img{position:relative;border-radius:var(--radius);overflow:hidden;background:linear-gradient(145deg,#fffaf5,var(--clr-warm-mid));display:flex;align-items:center;justify-content:center;color:var(--clr-primary-dark);border:1px solid var(--clr-border);height:100%;align-self:stretch;min-height:0}
.two-col-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.two-col-icon{width:96px;height:96px;border-radius:28px}
.two-col-icon svg{width:40px;height:40px}

@media(max-width:768px){
  .two-col{grid-template-columns:1fr;gap:24px}
  .two-col-img{min-height:240px}
}

/* ---------- Offer Banner ---------- */
.offer-card{background:linear-gradient(135deg,var(--clr-primary-dark),var(--clr-accent));border-radius:var(--radius);padding:48px;color:#fff;text-align:center}
.offer-card h2{color:#fff;font-size:var(--fs-2xl);margin-bottom:12px}
.offer-card p{font-size:var(--fs-md);margin-bottom:24px;opacity:.92}
.offer-tiers{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin:0 auto 28px;max-width:720px}
.offer-tier{background:#fff;border-radius:var(--radius-sm);padding:20px}
.offer-tier .discount{font-size:var(--fs-2xl);font-weight:700;font-family:var(--ff-heading);color:var(--clr-primary)}
.offer-tier .period{font-size:var(--fs-sm);color:var(--clr-text)}

/* ---------- Health & Safety Info ---------- */
.policy-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:28px}
.policy-card{background:#fff;border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm);border:2px solid var(--clr-primary)}
.policy-card h3{font-size:var(--fs-xl);margin-bottom:12px;text-align:center}
.policy-card h3 svg{width:22px;height:22px;color:var(--clr-primary-dark);stroke:currentColor;fill:none;stroke-width:1.85;stroke-linecap:round;stroke-linejoin:round;display:block;margin:0 auto 8px}
.policy-card h3::after{width:52px;margin-left:auto;margin-right:auto}
.policy-card p,.policy-card li{font-size:var(--fs-sm);color:var(--clr-text-light);line-height:1.8}
.policy-card ul{margin:12px 0 0 20px;list-style:disc}
.policy-card li{margin-bottom:4px}

/* ---------- Footer ---------- */
.site-footer{background:var(--clr-primary-dark);color:rgba(255,255,255,0.85);padding:64px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
.footer-brand .logo{color:#fff;margin-bottom:12px}
.footer-brand p{font-size:var(--fs-sm);line-height:1.8;opacity:.8;margin-bottom:20px}
.footer-social{display:flex;gap:12px}
.footer-social a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,0.12);display:flex;align-items:center;justify-content:center;color:#fff;transition:background .2s}
.footer-social a:hover{background:var(--clr-accent);color:#fff}
.footer-col h4{color:#fff;font-size:var(--fs-sm);text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;font-family:var(--ff-body);font-weight:700}
.footer-col a{display:block;padding:4px 0;font-size:var(--fs-sm);color:rgba(255,255,255,0.7);transition:color .2s}
.footer-col a:hover{color:var(--clr-accent)}
.footer-col p{font-size:var(--fs-sm);color:rgba(255,255,255,0.7);line-height:1.8}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.12);padding:20px 0;text-align:center;font-size:var(--fs-xs);color:rgba(255,255,255,0.5)}
.footer-bottom a{color:#fff;font-weight:700}
.footer-bottom a:hover{color:var(--clr-accent-dark)}

@media(max-width:768px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .hero h1{font-size:var(--fs-2xl)}
  .hero .tagline{font-size:var(--fs-lg)}
  .section{padding:56px 0}
  .section-header h2{font-size:var(--fs-2xl)}
  .stats-row{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
  .hero-btns{flex-direction:column}
  .rooms-grid{grid-template-columns:1fr}
  .testimonials-grid{grid-template-columns:1fr}
}

/* ---------- Animations ---------- */
.fade-in{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* ---------- Curriculum Pillars ---------- */
.pillars-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:28px;max-width:1120px;margin:0 auto}
.pillar-card{background:#fff;border-radius:var(--radius);padding:32px 24px;text-align:center;box-shadow:var(--shadow-sm);border:2px solid var(--clr-primary);grid-column:span 2;height:100%}
.pillar-card:nth-child(4){grid-column:2 / span 2}
.pillar-card:nth-child(5){grid-column:4 / span 2}
.pillar-card h3{font-size:var(--fs-xl);margin-bottom:10px}
.pillar-card h3::after{margin-left:auto;margin-right:auto}
.pillar-card p{font-size:var(--fs-sm);color:var(--clr-text-light);line-height:1.7}
.pillar-icon{width:64px;height:64px;border-radius:20px;margin:0 auto 16px}

/* ---------- Curriculum Learning Strands Slider ---------- */
.learning-strands-slider{position:relative;max-width:980px;margin:0 auto;padding:0 76px}
.learning-strands-viewport{overflow:hidden}
.learning-strands-track{display:flex;transition:transform .45s ease}
.learning-strand-slide{flex:0 0 100%;max-width:100%;min-height:320px;padding:40px 44px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center}
.learning-strand-slide .pillar-icon{margin:0 0 18px}
.learning-strand-slide h3{font-size:calc(var(--fs-xl) + 0.2rem);margin-bottom:14px}
.learning-strand-slide h3::after{margin-left:auto;margin-right:auto;width:64px}
.learning-strand-slide p{font-size:var(--fs-base);line-height:1.8;max-width:740px;margin-left:auto;margin-right:auto}
.slider-control{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;border:2px solid var(--clr-primary);background:#fff;color:var(--clr-primary);display:flex;align-items:center;justify-content:center;font-size:0;box-shadow:var(--shadow-sm);transition:background .2s,color .2s,transform .2s}
.slider-control::before{font-size:20px;line-height:1}
.slider-control:hover{background:var(--clr-primary);color:#fff;transform:translateY(calc(-50% - 1px))}
.slider-control-prev{left:8px}
.slider-control-next{right:8px}
.slider-control-prev::before{content:'\2039'}
.slider-control-next::before{content:'\203a'}
.slider-dots{display:flex;justify-content:center;align-items:center;gap:10px;margin-top:22px}
.slider-dot{width:11px;height:11px;border-radius:50%;background:rgba(75,80,86,0.28);border:0;transition:transform .2s,background .2s}
.slider-dot:hover{background:rgba(75,80,86,0.5)}
.slider-dot.is-active{background:var(--clr-primary);transform:scale(1.12)}

@media(max-width:900px){
  .pillars-grid{grid-template-columns:repeat(2,minmax(0,1fr));max-width:none}
  .pillar-card,.pillar-card:nth-child(4),.pillar-card:nth-child(5){grid-column:span 1}
  .step-card,.step-card:nth-child(4),.step-card:nth-child(5){grid-column:span 1}
  .steps-grid{grid-template-columns:repeat(2,minmax(0,1fr));max-width:none}
}

@media(max-width:600px){
  .pillars-grid{grid-template-columns:1fr}
  .steps-grid{grid-template-columns:1fr}
  .learning-strands-slider{padding:0 18px}
  .slider-control{display:none}
  .learning-strand-slide{padding:30px 24px;min-height:290px}
}

/* ---------- Breadcrumb ---------- */
.breadcrumb{font-size:var(--fs-xs);color:rgba(255,255,255,0.65);margin-bottom:12px}
.breadcrumb a{color:rgba(255,255,255,0.65)}
.breadcrumb a:hover{color:#fff}
.breadcrumb span{margin:0 6px}

/* ---------- Inline Info List ---------- */
.info-list{list-style:none;margin:16px 0}
.info-list li{padding:10px 0;border-bottom:2px solid var(--clr-border);font-size:var(--fs-sm);display:flex;gap:12px;align-items:flex-start}
.info-list li strong{flex-shrink:0;min-width:140px;color:var(--clr-text)}
.info-list li span{color:var(--clr-text-light)}
.teacher-standards-list li{display:grid;grid-template-columns:180px minmax(0,1fr);column-gap:12px;align-items:start}
.teacher-standards-list li strong{display:block;min-width:0;line-height:1.4}
.settling-in-list li{display:grid;grid-template-columns:160px minmax(0,1fr);column-gap:12px;align-items:start}

/* ---------- Skip link ---------- */
.skip-link{position:absolute;top:-100%;left:16px;padding:12px 24px;background:var(--clr-primary);color:#fff;border-radius:var(--radius-sm);z-index:9999;font-weight:600}
.skip-link:focus{top:16px}

/* ---------- Back To Top ---------- */
.back-to-top{position:fixed;right:20px;bottom:20px;width:48px;height:48px;border-radius:50%;background:var(--clr-accent-dark);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:4px 4px 0 rgba(45,49,54,0.28);z-index:1100;opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .25s,transform .25s,visibility .25s}
.back-to-top:hover{background:var(--clr-primary);color:#fff;transform:translateY(0)}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}

/* ---------- Print ---------- */
@media print{
  .site-header,.site-footer,.cta-section,.promo-banner,.menu-toggle,.back-to-top{display:none!important}
  .hero{min-height:auto;background:#fff!important;color:#000!important}
  .hero h1,.hero p{color:#000!important}
  body{font-size:12pt}
}
