/* Color palette */
:root{
  --ink:#2f3e2c;
  --sky:#bad4aa;
  --rose:#4f8a5b;
  --cream:#ebf5df;
  --white:#ffffff;
  --muted:#6a7c6e;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);
  background:var(--cream);
}
img{max-width:100%;height:auto;display:block}
a{color:inherit}

.container{width:min(1100px,92%);margin-inline:auto}
.center{text-align:center}
.small{font-size:.925rem}
.muted{color:var(--muted)}

/* Header */
.site-header{
  position:sticky;top:0;z-index:10;
  backdrop-filter:saturate(180%) blur(8px);
  background:color-mix(in oklab, var(--cream) 85%, white 15%);
  border-bottom:1px solid color-mix(in oklab, var(--sky) 40%, transparent);
}
.header-inner{display:flex;align-items:center;gap:20px;min-height:64px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.brand-mark{width:26px;height:26px}
.brand-name{font-weight:600;letter-spacing:-.2px}

.nav{margin-left:auto;display:flex;gap:16px;align-items:center}
.nav a{padding:8px 10px;text-decoration:none;border-radius:10px}
.nav a:hover{background:var(--sky)}
.nav .btn{padding:10px 14px}
.nav .btn-primary{background:var(--rose);color:var(--cream);border:1px solid var(--rose)}
.nav .btn-outline{border:1px solid var(--ink)}

.nav-toggle{display:none;margin-left:auto;font-size:24px;line-height:1;background:none;border:0}

@media (max-width: 860px){
  .nav{position:fixed;inset:64px 0 auto 0;background:var(--cream);border-bottom:1px solid var(--sky);padding:16px;flex-direction:column;align-items:flex-start;display:none}
  .nav.open{display:flex}
  .nav-toggle{display:inline-block}
}

/* Hero */
.hero{
  padding:48px 0 24px;
}
.hero-inner{display:grid;grid-template-columns:1.2fr .8fr;gap:32px;align-items:center}
.hero-copy h1{font-size:clamp(32px,5vw,48px);line-height:1.1;margin:0 0 12px}
.hero-copy p{font-size:1.1rem;margin:0 0 18px;max-width:52ch}
.hero-cta{display:flex;gap:12px;margin:18px 0 10px}
.hero-points{margin:12px 0 0;padding-left:18px}
.hero-points li{margin:6px 0}

.hero-card{background:var(--sky);border-radius:24px;padding:22px;border:1px solid color-mix(in oklab, var(--ink) 20%, transparent)}
.hero-card .note{font-size:.95rem;margin:0 0 14px}

/* Hero video placeholder */
.video-placeholder{background:color-mix(in oklab, var(--sky) 35%, var(--cream) 65%);border:1px solid color-mix(in oklab, var(--ink) 20%, transparent);border-radius:20px;overflow:hidden}
.video-inner{aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:6px}
.video-text{font-weight:600}
.video-sub{color:var(--muted);font-size:.9rem}
.play{width:56px;height:56px;border-radius:50%;background:var(--ink);position:relative}
.play:after{content:"";position:absolute;left:22px;top:18px;border-style:solid;border-width:10px 0 10px 16px;border-color:transparent transparent transparent var(--cream)}

/* Hero image (replaces video) */
.hero-image{border-radius:24px;border:1px solid color-mix(in oklab, var(--ink) 20%, transparent);overflow:hidden;background:var(--white)}
.hero-image img{display:block;width:100%;height:auto;aspect-ratio:16/9;object-fit:cover}

/* About image alignment */
.about-photo{border-radius:16px;display:block;margin-top:12px}

/* Sections */
.section{padding:56px 0}
.section.alt{background:color-mix(in oklab, var(--sky) 25%, var(--cream) 75%);} 
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start}
@media (max-width: 860px){.hero-inner,.grid-2{grid-template-columns:1fr}}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media (max-width: 860px){.cards{grid-template-columns:1fr}}

.card{background:var(--white);border:1px solid color-mix(in oklab, var(--ink) 15%, transparent);border-radius:16px;padding:18px}
/* Consistent media layout for cards */
.card-media{aspect-ratio:16/9;overflow:hidden;border-radius:12px;margin:-6px -6px 12px}
.card-media img{width:100%;height:100%;object-fit:cover;display:block}
.card.list .list-item{padding:10px 0;border-bottom:1px dashed color-mix(in oklab, var(--ink) 15%, transparent)}
.card.list .list-item:last-child{border-bottom:0}

/* Pricing */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:16px}
@media (max-width: 860px){.pricing{grid-template-columns:1fr}}
.price-card{background:var(--white);border:1px solid color-mix(in oklab, var(--ink) 15%, transparent);border-radius:16px;padding:18px;display:flex;flex-direction:column;gap:10px}
.price-card .price{font-size:1.5rem;font-weight:700}
.price-card.featured{border-color:var(--rose);box-shadow:0 8px 24px rgba(255,131,163,.2)}

/* Quotes */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media (max-width: 860px){.quotes{grid-template-columns:1fr}}
.quote{margin:0;background:var(--white);border:1px solid color-mix(in oklab, var(--ink) 15%, transparent);border-radius:16px;padding:18px;display:flex;gap:12px;align-items:flex-start}
.quote .avatar{width:48px;height:48px;border-radius:50%;flex:0 0 48px}
.quote blockquote{margin:0 0 8px}

/* FAQ */
.faq details{background:var(--white);border:1px solid color-mix(in oklab, var(--ink) 15%, transparent);border-radius:12px;padding:14px;margin:10px 0}
.faq summary{cursor:pointer;font-weight:600}

/* Contact */
.form{display:grid;gap:12px}
label span{display:block;font-size:.9rem;margin-bottom:6px}
input,textarea,select{width:100%;padding:10px 12px;border-radius:10px;border:1px solid color-mix(in oklab, var(--ink) 15%, transparent);background:var(--white);color:var(--ink)}
.row{display:grid;gap:10px;grid-template-columns:1fr 1fr}
.row .grow-1{grid-column:1}
.row .grow-2{grid-column:2}
.contact-intro h2{margin:0 0 6px;font-size:2.4rem;line-height:1.1;margin:0 0 12px;font-weight:800;text-transform:uppercase}
.contact-intro h3{margin:0 0 10px;font-size:1.25rem;color:var(--ink)}
.contact-intro .overline{letter-spacing:.12em;font-size:.9rem;text-transform:uppercase;color:var(--muted);margin:0 0 6px;font-weight:700}
.contact-intro p{font-size:1.05rem;line-height:1.6;margin:0 0 12px}
.contact-list{list-style:none;padding:0;margin:12px 0 0;display:grid;gap:10px}
.contact-item{display:flex;gap:12px;align-items:flex-start;padding:8px 0}
.icon-circle{width:38px;height:38px;border-radius:50%;border:1px solid color-mix(in oklab, var(--ink) 20%, transparent);display:inline-flex;align-items:center;justify-content:center;color:var(--ink);flex:0 0 38px;background:var(--white)}
.icon-circle svg{width:20px;height:20px}
.label{font-weight:800;text-transform:uppercase;font-size:.9rem;letter-spacing:.06em}
.contact-list a{font-weight:600}
.contact .grid-2{grid-template-columns:1fr 1fr}
@media (max-width: 860px){.contact .grid-2{grid-template-columns:1fr}}

/* Buttons */
.btn{display:inline-block;text-decoration:none;border-radius:30px;padding:12px 16px;border:1px solid transparent}
.btn-block{display:block;text-align:center;width:100%}
.btn-primary{background:var(--rose);color:var(--cream);border-color:var(--rose)}
.btn-primary:hover{filter:brightness(.95)}
.btn-dark{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.btn-dark:hover{filter:brightness(1.1)}

/* Footer */
.site-footer{padding:36px 0;border-top:1px solid color-mix(in oklab, var(--sky) 40%, transparent)}
.footer-inner{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.footer-links{display:flex;gap:14px;flex-wrap:wrap}
.footer-links a{text-decoration:none}
.footer-links a:hover{text-decoration:underline}

/* Lead forms & CTA blocks */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.lead-form{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.lead-form input{flex:1 1 220px}
.lead-signup{background:color-mix(in oklab, var(--sky) 18%, var(--cream) 82%)}
.lead-signup-inner{display:flex;align-items:center;gap:12px;justify-content:space-between;flex-wrap:wrap}
.cta-block{margin-top:20px}
.cta-block h3{margin:0 0 10px}

/* Slide-in popup */
.slide-popup{position:fixed;right:20px;bottom:20px;max-width:460px;width:92vw;z-index:9999;background:var(--white);border:1px solid color-mix(in oklab, var(--ink) 15%, transparent);border-radius:18px;box-shadow:0 16px 40px rgba(0,0,0,.18);padding:18px 18px 20px;transform:translateX(120%);opacity:.0}
.slide-popup.open{transform:translateX(0);opacity:1;animation:popupIn .6s cubic-bezier(.2,.9,.25,1) both}
.slide-popup h4{margin:0 0 8px;display:flex;align-items:center;gap:8px}
.slide-popup p{margin:0 0 10px}
.slide-popup .close{position:absolute;top:8px;right:10px;background:transparent;border:0;font-size:20px;line-height:1;cursor:pointer;color:var(--muted)}
.slide-popup form{display:grid;gap:8px;margin-top:8px}
.slide-popup .btn{width:100%}
.slide-popup .dance{font-size:22px;display:inline-flex;align-items:center;justify-content:center;animation:dance 1.2s ease-in-out infinite}

@keyframes popupIn{
  0%{transform:translateX(120%);opacity:0}
  70%{transform:translateX(-8px);opacity:1}
  100%{transform:translateX(0)}
}
@keyframes dance{
  0%,100%{transform:translateY(0) rotate(0)}
  25%{transform:translateY(-2px) rotate(-4deg)}
  50%{transform:translateY(0) rotate(0)}
  75%{transform:translateY(-3px) rotate(4deg)}
}

/* Contact choices */
.choices{border:1px dashed color-mix(in oklab, var(--ink) 20%, transparent);border-radius:12px;padding:12px}
.choices legend{font-weight:600}
.choices .choice{display:block;margin:6px 0}
.required{color:var(--muted);font-size:.85rem}

/* Centered modal popup for course alert */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:1000;opacity:0;pointer-events:none;transition:opacity .25s ease}
.modal-overlay.open{opacity:1;pointer-events:auto}
.modal{position:fixed;inset:0;display:grid;place-items:center;z-index:1001;opacity:0;pointer-events:none;transition:opacity .25s ease}
.modal.open{opacity:1;pointer-events:auto}
.modal-card{background:var(--white);border:1px solid color-mix(in oklab, var(--ink) 18%, transparent);border-radius:18px;max-width:780px;width:92vw;box-shadow:0 24px 60px rgba(0,0,0,.25);overflow:hidden}
.modal-media{aspect-ratio:16/9;overflow:hidden}
.modal-media img{width:100%;height:100%;object-fit:cover;display:block}
.modal-body{padding:18px}
.modal-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.modal-close{position:absolute;right:10px;top:10px;background:transparent;border:0;font-size:22px;cursor:pointer;color:var(--muted)}
