
:root{
  --bg:#fffefd; --text:#1a1a1a; --muted:#6b6b6b;
  --brand:#8fb8a8; --brand-2:#f2d8d5; --brand-3:#f7f2e7;
  --radius:14px; --shadow:0 10px 25px rgba(0,0,0,.08);
}
*{box-sizing:border-box} html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.6}
h1,h2,h3,h4{font-family:Marcellus,Georgia,serif;line-height:1.2;margin:0 0 .5rem}
p{margin:.5rem 0 1rem} img{max-width:100%;display:block;border-radius:var(--radius)}
.container{width:min(1100px,92%);margin-inline:auto} .center{text-align:center}.small{font-size:.9rem;color:var(--muted)} .tiny{font-size:.8rem;color:var(--muted)} .sr-only{position:absolute;left:-9999px}

.site-header{position:sticky;top:0;z-index:999;background:rgba(255,255,255,.9);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid #eee}
.nav-wrapper{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0}
.brand{font-weight:600;text-decoration:none;color:var(--text)}
.primary-nav{display:flex;gap:1rem;align-items:center}
.primary-nav a{color:var(--text);text-decoration:none;padding:.4rem .6rem;border-radius:8px}
.primary-nav a:hover{background:#f3f3f3}
.nav-toggle{display:none;background:none;border:1px solid #ddd;padding:.4rem .6rem;border-radius:8px}

.btn{display:inline-block;padding:.7rem 1rem;border-radius:999px;border:1px solid #00000014;text-decoration:none;box-shadow:var(--shadow);background:#fff;color:var(--text);transition:transform .15s ease}
.btn:hover{transform:translateY(-1px)} .btn-primary{background:var(--brand);border-color:transparent;color:#07342a;font-weight:600}

.hero{position:relative;min-height:64vh}
.hero img{width:100%;height:64vh;object-fit:cover;border-radius:0}
.hero-overlay{position:absolute;inset:0;display:grid;place-items:center;text-align:center;color:#0d3026;background:linear-gradient(180deg, rgba(255,255,255,0.0) 0%, rgba(255,255,255,0.75) 40%, rgba(255,255,255,0.95) 70%)}
.hero h1{font-size:clamp(2rem,4vw,3rem)} .hero-ctas{display:flex;gap:.75rem;justify-content:center;margin-top:1rem}

.features{display:grid;gap:1.2rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));padding:2rem 0}
.feature img{aspect-ratio:4/3;object-fit:cover} .feature h3{margin-top:.6rem}

.stripe{background:var(--brand-3);padding:2.5rem 0;margin:2rem 0;border-top:1px solid #eee;border-bottom:1px solid #eee}
.stripe-inner{display:grid;gap:1rem;grid-template-columns:1.2fr .8fr;align-items:center}
@media (max-width: 800px){ .stripe-inner{grid-template-columns:1fr} .hero img{height:56vh} }

.testimonials{padding:1rem 0 2rem}
.testimonial-card{background:#fff;border:1px solid #eee;padding:1rem;border-radius:var(--radius);box-shadow:var(--shadow);min-height:160px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center}
.carousel{position:relative;overflow:hidden}
.carousel-track{display:flex;transition:transform .5s ease}
.carousel-dots{display:flex;gap:.4rem;justify-content:center;margin-top:.6rem}
.carousel-dots button{width:8px;height:8px;border-radius:50%;border:0;background:#ddd}
.carousel-dots button.active{background:#8fb8a8}

.page-hero{padding:3rem 0 1rem;background:linear-gradient(180deg,var(--brand-3),#fff)}
.page-hero p{color:var(--muted)}

.cards{display:grid;gap:1.2rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));padding:1rem 0 2rem}
.card{background:#fff;border:1px solid #eee;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}
.card img{aspect-ratio:4/3;object-fit:cover}
.card-body{padding:1rem}

.pricing{padding:2rem 0}
.pricing-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.price-card{background:linear-gradient(180deg,#fff, var(--brand-3));border:1px solid #eee;border-radius:var(--radius);text-align:center;padding:1rem;box-shadow:var(--shadow)}
.price{font-size:2rem;margin:.25rem 0 .75rem;color:#0d3026}

.two-col{display:grid;gap:2rem;grid-template-columns:1.1fr .9fr;align-items:center;padding:1rem 0 2rem}
@media (max-width: 900px){ .two-col{grid-template-columns:1fr} }

.people{list-style:none;display:grid;gap:1rem;padding:0;margin:1rem 0;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.people li{display:flex;gap:.8rem;align-items:center;background:#fff;border:1px solid #eee;padding:.6rem;border-radius:var(--radius)}

.newsletter{padding:2rem 0 3rem;text-align:center}
.inline-form{display:flex;gap:.6rem;justify-content:center;margin-top:.5rem}
.inline-form input{padding:.7rem .9rem;border-radius:999px;border:1px solid #ccc;min-width:260px}
.inline-form button{white-space:nowrap}

.contact-grid{display:grid;gap:2rem;grid-template-columns:1.1fr .9fr;padding:1rem 0 3rem}
.contact-form{background:#fff;border:1px solid #eee;border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow)}
.contact-form input, .contact-form select, .contact-form textarea{width:100%;padding:.7rem;border:1px solid #ccc;border-radius:10px;margin-top:.25rem}
.grid-2{display:grid;gap:1rem;grid-template-columns:1fr 1fr}
@media (max-width: 800px){ .contact-grid{grid-template-columns:1fr} .grid-2{grid-template-columns:1fr} }
.map-embed iframe{width:100%;height:240px;border:0;border-radius:var(--radius)}

.schedule-controls{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;justify-content:space-between;margin:.5rem 0 1rem}
.chips{display:flex;gap:.4rem;flex-wrap:wrap}
.chip{padding:.4rem .7rem;border:1px solid #ddd;border-radius:999px;background:#fff;cursor:pointer}
.chip.active{background:var(--brand);color:#07342a;border-color:transparent;font-weight:600}
.search{display:flex;gap:.4rem}
.search input{padding:.5rem .7rem;border-radius:999px;border:1px solid #ccc}
.schedule-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin:1rem 0 2rem}
.class-card{border:1px solid #eee;border-radius:var(--radius);padding:1rem;background:#fff;box-shadow:var(--shadow);transition:transform .2s ease}
.class-card:hover{transform:translateY(-2px)}

.site-footer{margin-top:2rem;border-top:1px solid #eee;padding:2rem 0;background:#fff}
.footer-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}
.socials a{margin-right:.5rem}

@media (max-width: 880px){
  .primary-nav{position:fixed;inset:64px 0 auto 0;background:#fffffff2;backdrop-filter:blur(8px);padding:1rem;display:none;flex-direction:column;gap:.5rem;border-bottom:1px solid #eee}
  .primary-nav.open{display:flex}
  .nav-toggle{display:inline-block}
}

/* Floating Book Now button + modal */
.booknow-root{position:fixed;right:16px;bottom:16px;z-index:1000}
.bookbtn{box-shadow:var(--shadow);}
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.4);display:grid;place-items:center;z-index:1100}
.modal{background:#fff;border-radius:16px;max-width:560px;width:92%;padding:1rem;border:1px solid #eee;box-shadow:var(--shadow)}
.modal header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}
.modal .grid-2{grid-template-columns:1fr 1fr}
.modal form button{margin-top:.5rem}
