
:root{
  --bg:#0d1220;--bg-soft:#131a2b;--card:#ffffff;--text:#1a2333;--muted:#5d6980;
  --primary:#6f4ef6;--primary-2:#ff4f7b;--gold:#f7c35f;--light:#f6f8fc;--white:#ffffff;
  --shadow:0 20px 50px rgba(20,30,55,.12);--radius:24px;--radius-sm:16px;--max:1180px;
}
*{box-sizing:border-box} html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,Arial,Helvetica,sans-serif;color:var(--text);background:var(--light);line-height:1.6}
a{text-decoration:none;color:inherit} img{max-width:100%;display:block}
.container{width:min(var(--max),calc(100% - 2rem));margin-inline:auto}
.btn{display:inline-flex;align-items:center;gap:.6rem;padding:1rem 1.35rem;border-radius:999px;font-weight:700;transition:.25s ease;cursor:pointer;border:0}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;box-shadow:0 10px 30px rgba(111,78,246,.25)}
.btn-primary:hover,.btn-secondary:hover{transform:translateY(-2px)}
.btn-secondary{background:#fff;color:var(--primary);border:1px solid rgba(111,78,246,.15);box-shadow:0 8px 22px rgba(20,30,55,.06)}
.badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.14);color:#fff;padding:.65rem .9rem;border-radius:999px;font-size:.92rem;font-weight:700;backdrop-filter:blur(8px)}
.topbar{background:#0a0f1a;color:#c6d0e5;font-size:.92rem}
.topbar .container{display:flex;justify-content:space-between;gap:1rem;padding:.7rem 0;flex-wrap:wrap}
header{position:sticky;top:0;z-index:20;backdrop-filter:blur(12px);background:rgba(246,248,252,.82);border-bottom:1px solid rgba(10,15,26,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;gap:1rem}
.brand{display:flex;align-items:center;gap:.9rem;font-weight:800;font-size:1.1rem}
.brand-mark{width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,var(--primary),var(--primary-2));display:grid;place-items:center;color:#fff;font-weight:900;box-shadow:var(--shadow)}
.nav-links{display:flex;gap:1.1rem;align-items:center;flex-wrap:wrap}
.nav-links a{font-weight:600;color:#33405b}
.nav-links a:hover{color:var(--primary)}
.menu-toggle{display:none;background:#fff;border:1px solid #e6ebf4;border-radius:12px;padding:.8rem}
.hero{background:radial-gradient(circle at top left, rgba(255,79,123,.22), transparent 35%),radial-gradient(circle at top right, rgba(111,78,246,.26), transparent 35%),linear-gradient(135deg,#0e1527,#151e35 60%, #0d1220);color:#fff;overflow:hidden}
.hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center;padding:5rem 0 4rem}
.hero-copy h1{font-size:clamp(2.2rem,4vw,4.6rem);line-height:1.04;margin:.8rem 0 1rem}
.hero-copy p{font-size:1.08rem;color:#d6ddf0;max-width:58ch}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin:1.7rem 0}
.hero-points{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem;margin-top:2rem}
.hero-point{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);padding:1rem;border-radius:18px;color:#e6ebf6}
.hero-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);border-radius:32px;padding:1rem;box-shadow:0 30px 60px rgba(0,0,0,.2)}
.mockup{background:#fff;border-radius:26px;overflow:hidden;box-shadow:var(--shadow)}
.mockup-top{padding:1rem 1rem .3rem;background:#fff;border-bottom:1px solid #eef1f6}
.dots{display:flex;gap:.4rem}.dot{width:12px;height:12px;border-radius:50%}
.dot:nth-child(1){background:#ff6b6b}.dot:nth-child(2){background:#ffd166}.dot:nth-child(3){background:#06d6a0}
.mockup-body{padding:1.4rem}.mockup-grid{display:grid;gap:1rem}
.info-card,.feature-card,.price-card,.faq-item,.seo-card,.contact-card,.policy-card,.blog-card,.blog-cta,.article-grid .sidebar-card{background:#fff;border-radius:24px;box-shadow:var(--shadow)}
section{padding:4.5rem 0}.section-head{text-align:center;max-width:760px;margin:0 auto 2.2rem}
.section-head h2{font-size:clamp(1.8rem,3vw,3rem);margin:0 0 .7rem}.section-head p{color:var(--muted);margin:0}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem}
.feature-card,.price-card,.seo-card,.blog-card{padding:1.5rem}.feature-card h3,.price-card h3,.seo-card h3,.blog-card h3,.contact-card h3{margin-top:0}
.feature-icon{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(111,78,246,.1),rgba(255,79,123,.12));color:var(--primary);font-weight:900;font-size:1.25rem;margin-bottom:.8rem}
.split-card{display:grid;grid-template-columns:1fr 1fr;overflow:hidden;background:#fff;border-radius:24px;box-shadow:var(--shadow)}
.split-media{min-height:320px;background:linear-gradient(135deg,rgba(111,78,246,.86),rgba(255,79,123,.82)),url('../img/placeholder-dance.svg') center/cover no-repeat}
.split-copy{padding:2rem}.list{padding-left:1.1rem;margin:.7rem 0 0}.list li{margin:.5rem 0}
.price-card{position:relative;border:1px solid #ebeff6}.price-card.popular{border:2px solid rgba(111,78,246,.22);transform:translateY(-6px)}
.tag{display:inline-block;padding:.45rem .75rem;border-radius:999px;background:#eef2ff;color:var(--primary);font-size:.82rem;font-weight:800}
.price{font-size:2.2rem;font-weight:900;line-height:1;margin:.9rem 0 .2rem}.small{font-size:.92rem;color:var(--muted)}
.banner{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;border-radius:32px;padding:2rem;display:grid;gap:1rem;align-items:center}
.banner-flex{display:flex;justify-content:space-between;gap:1rem;align-items:center;flex-wrap:wrap}
.faq{display:grid;gap:1rem}
.faq-item{padding:0;overflow:hidden}
.faq-trigger{width:100%;text-align:left;background:#fff;border:0;padding:1.25rem 1.4rem;font:inherit;font-weight:800;color:var(--text);display:flex;justify-content:space-between;align-items:center;cursor:pointer}
.faq-trigger span:last-child{font-size:1.2rem;color:var(--primary)}
.faq-panel{padding:0 1.4rem 1.3rem;display:none;color:var(--muted)}
.faq-item.open .faq-panel{display:block}
.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}.contact-card{padding:1.6rem}
.contact-list{display:grid;gap:.9rem}.contact-line{padding:1rem;border-radius:16px;background:#f7f9fd}
.page-hero{background:radial-gradient(circle at top left, rgba(255,79,123,.22), transparent 35%),radial-gradient(circle at top right, rgba(111,78,246,.26), transparent 35%),linear-gradient(135deg,#0e1527,#151e35 60%, #0d1220);color:#fff;padding:4.2rem 0 3.2rem}
.page-hero h1{font-size:clamp(2rem,3vw,3.4rem);margin:.5rem 0}.page-hero p{max-width:60ch;color:#dce4f4}.breadcrumbs{color:#cfd7e9;font-size:.95rem}
.policy-grid,.blog-grid,.seo-grid{display:grid;gap:1rem}.policy-card{padding:1.5rem}
.blog-card{overflow:hidden;padding:0}
.blog-card img{height:220px;width:100%;object-fit:cover;background:#ddd}
.blog-card-content{padding:1.35rem}
.blog-card .eyebrow{font-size:.82rem;font-weight:800;color:var(--primary);text-transform:uppercase;letter-spacing:.06em}
.blog-card p{color:var(--muted)}
.blog-cta{padding:1.6rem;background:linear-gradient(135deg,#fff,#f7f4ff)}
.article-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(280px,.9fr);gap:1.2rem;align-items:start}
.article-main{background:#fff;border-radius:24px;box-shadow:var(--shadow);overflow:hidden}
.article-cover{height:360px;background:linear-gradient(135deg,rgba(111,78,246,.86),rgba(255,79,123,.82)),url('assets/img/placeholder-dance.svg') center/cover no-repeat}
.article-content{padding:2rem}
.article-content h2{margin-top:2rem;font-size:1.6rem}
.article-content .lead{font-size:1.14rem;color:#394763}
.article-hook{font-size:1.2rem;font-weight:700;color:#24324f}
.inline-cta{margin:2rem 0;padding:1.4rem;border-radius:20px;background:linear-gradient(135deg,#f6f3ff,#fff1f6);border:1px solid #ece6ff}
.sidebar-card{padding:1.3rem;position:sticky;top:110px}
.sidebar-card p{color:var(--muted)}
.quote-box{padding:1.2rem 1.3rem;border-left:4px solid var(--primary);background:#f8f7ff;border-radius:18px;margin:1.2rem 0}
footer{background:#0b1120;color:#d2dbef;padding:3rem 0 1.5rem;margin-top:3rem}.footer-grid{display:grid;grid-template-columns:1.1fr .8fr .8fr;gap:1.3rem}
.footer-links{display:grid;gap:.6rem}.footer-links a{color:#d2dbef}.footer-links a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.09);margin-top:1.5rem;padding-top:1rem;font-size:.92rem;color:#a8b5cf}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease, transform .7s ease}.reveal.visible{opacity:1;transform:none}
@media (max-width:980px){.hero-inner,.split-card,.contact-wrap,.footer-grid,.grid-3,.grid-2,.article-grid{grid-template-columns:1fr}.hero-points{grid-template-columns:1fr}.sidebar-card{position:static}}
@media (max-width:760px){.menu-toggle{display:block}.nav-links{display:none;position:absolute;top:78px;left:1rem;right:1rem;background:#fff;border:1px solid #e8edf7;border-radius:22px;padding:1rem;box-shadow:var(--shadow)}.nav-links.open{display:grid}.topbar .container{justify-content:center;text-align:center}.hero-inner{padding:4rem 0 3rem}section{padding:3.5rem 0}.article-cover{height:260px}}


.brand img{height:64px;width:auto;display:block}
.footer-logo{height:70px;width:auto;display:block}
.service-thumb,
.inline-photo{
  width:100%;
  object-fit:cover;
  border-radius:18px;
  display:block;
}
.service-thumb{height:220px;margin-bottom:1rem}
.inline-photo{max-width:520px}
.hero-preview{
  width:100%;
  border-radius:20px;
  object-fit:cover;
  display:block;
}
.article-cover{background-position:center;background-size:cover;background-repeat:no-repeat}


.about-single{
  width:100%;
  background:#fff;
  border-radius:24px;
  box-shadow:var(--shadow);
  padding:2rem 2.2rem;
}


.map-wrap{
  border-radius:24px;
  overflow:hidden;
  box-shadow:var(--shadow);
  background:#fff;
}
.map-wrap iframe{
  display:block;
  width:100%;
  min-height:420px;
  border:0;
}


.contact-wrap{
  align-items:stretch;
}
.contact-card h3{
  margin-bottom:.5rem;
}
.contact-highlight{
  background:linear-gradient(135deg,#f6f3ff,#fff1f6);
  border:1px solid #ece6ff;
  border-radius:20px;
  padding:1rem 1.1rem;
  margin-top:1rem;
}
.contact-badges{
  display:flex;
  flex-wrap:wrap;
  gap:.7rem;
  margin-top:1rem;
}
.contact-badge{
  display:inline-flex;
  align-items:center;
  padding:.55rem .9rem;
  border-radius:999px;
  background:#eef2ff;
  color:var(--primary);
  font-weight:700;
  font-size:.9rem;
}


/* Homepage redesign */
.home-about{
  padding:0;
}
.home-about-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:600px;
  width:100%;
}
.home-about-media{
  min-height:420px;
  background:
    linear-gradient(rgba(13,18,32,.18), rgba(13,18,32,.18)),
    url('../img/jeff-teaching.jpg') center/cover no-repeat;
}
.home-about-copy{
  padding:3rem;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.home-parallax{
  position:relative;
  min-height:360px;
  display:grid;
  place-items:center;
  text-align:center;
  color:#fff;
  overflow:hidden;
  background:
    linear-gradient(rgba(13,18,32,.48), rgba(13,18,32,.48)),
    url('../img/hero-dance.jpg') center/cover fixed no-repeat;
}
.home-parallax::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at top left, rgba(255,79,123,.18), transparent 30%),
    radial-gradient(circle at bottom right, rgba(111,78,246,.22), transparent 34%);
}
.home-parallax .container{
  position:relative;
  z-index:1;
}
.home-parallax h2{
  font-size:clamp(2rem,4vw,3.6rem);
  margin:0 0 .8rem;
}
.home-parallax p{
  max-width:760px;
  margin:0 auto 1.2rem;
  color:#e6ebf6;
  font-size:1.06rem;
}
.home-soft{
  background:linear-gradient(180deg,#f6f8fc 0%, #eef2fb 100%);
}
.home-faq-wrap{
  background:#fff;
  border-radius:28px;
  padding:1.2rem;
  box-shadow:var(--shadow);
}
@media (max-width:980px){
  .home-about-row{
    grid-template-columns:1fr;
  }
  .home-about-copy{
    padding:2rem;
  }
  .home-parallax{
    background-attachment:scroll;
  }
}

.home-about .container{
  max-width:100%;
  padding:0;
}
.home-about-copy{
  padding:4rem;
}


/* Conversion upgrades */
.grid-4{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1.2rem;
}
.price-card.featured{
  border:2px solid rgba(111,78,246,.28);
  transform:translateY(-8px);
  box-shadow:0 24px 60px rgba(111,78,246,.16);
}
.pricing-grid-home .price-card .btn{
  margin-top:1rem;
}
.seo-copy{
  padding:2rem 0 0;
}
.seo-copy .section-head{
  margin-bottom:0;
}
.schedule-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.2rem;
}
.value-strip{
  margin-top:1.2rem;
  background:#fff;
  border-radius:22px;
  box-shadow:var(--shadow);
  padding:1rem 1.2rem;
  border-left:4px solid var(--primary);
}
.comparison-box{
  margin-top:1.5rem;
  background:#fff;
  border-radius:28px;
  box-shadow:var(--shadow);
  padding:1.6rem;
}
.comparison-box h3{
  margin-top:0;
}
.comparison-row{
  display:flex;
  justify-content:space-between;
  gap:1rem;
  padding:.9rem 0;
  border-top:1px solid #eef1f6;
}
.comparison-row:first-of-type{
  border-top:0;
}
@media (max-width:980px){
  .grid-4,
  .schedule-grid{
    grid-template-columns:1fr;
  }
  .price-card.featured{
    transform:none;
  }
}

.feature-card .btn + .btn{margin-left:.65rem}
@media (max-width:700px){.feature-card .btn + .btn{margin-left:0;margin-top:.75rem}}

.grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:1.2rem}
.policy-card h2{margin-top:1.6rem}
.policy-card h2:first-child{margin-top:0}
@media (max-width:1100px){.grid-5{grid-template-columns:repeat(3,1fr)}}
@media (max-width:820px){.grid-5{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.grid-5{grid-template-columns:1fr}}

.feature-card .btn,.price-card .btn,.blog-card .btn,.sidebar-card .btn{margin-top:1rem}


.social-icons{display:flex;gap:.7rem;align-items:center;flex-wrap:wrap}
.social-icons a{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:999px;background:rgba(255,255,255,.14);transition:.25s ease}
.social-icons a:hover{transform:translateY(-2px);background:rgba(255,255,255,.24)}
.social-icon{width:20px;height:20px;display:block}
footer .social-icons{margin-top:1rem}
footer .social-icons a{background:rgba(255,255,255,.08)}
footer .social-icons a:hover{background:rgba(255,255,255,.16)}


.contact-hours-strip{
  margin-top:1rem;
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
}
.contact-hours-badge{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  background:#fff;
  color:var(--text);
  padding:.75rem 1rem;
  border-radius:999px;
  box-shadow:var(--shadow);
  border:1px solid rgba(111,78,246,.08);
}


.contact-info-banner{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1rem;
  margin-top:-1rem;
}
.contact-info-item{
  background:#fff;
  border-radius:22px;
  box-shadow:var(--shadow);
  padding:1rem 1.2rem;
  border:1px solid rgba(111,78,246,.08);
}
.contact-info-item strong{
  display:block;
  margin-bottom:.25rem;
  color:var(--primary);
}
.contact-info-item span{
  color:var(--text);
  font-size:.96rem;
}
@media (max-width:820px){
  .contact-info-banner{grid-template-columns:1fr}
}
