:root{
  --bg:#0a0118;
  --bg-2:#13042a;
  --ink:#f6f0ff;
  --muted:#c3b3da;
  --magenta:#ff2e9a;
  --purple:#9b3bff;
  --cyan:#22e3ff;
  --grad:linear-gradient(100deg,#ff2e9a 0%,#9b3bff 45%,#22e3ff 100%);
  --grad-soft:linear-gradient(135deg,rgba(255,46,154,.18),rgba(155,59,255,.16),rgba(34,227,255,.14));
  --card:rgba(255,255,255,.04);
  --card-line:rgba(255,255,255,.10);
  --radius:18px;
  --wrap:1120px;
  --tap:46px;
  font-synthesis:none;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:"Segoe UI",system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
  line-height:1.6;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--cyan);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 20px}

.skip-link{position:absolute;left:-999px;top:0;background:var(--magenta);color:#fff;padding:10px 16px;z-index:200;border-radius:0 0 10px 0}
.skip-link:focus{left:0}

:focus-visible{outline:3px solid var(--cyan);outline-offset:2px;border-radius:6px}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:var(--tap);padding:13px 24px;border-radius:999px;
  font-weight:700;font-size:1rem;cursor:pointer;border:0;
  transition:transform .18s ease,box-shadow .18s ease;
  text-align:center;
}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn-cta{background:var(--grad);color:#fff;box-shadow:0 8px 28px rgba(255,46,154,.35)}
.btn-cta:hover{box-shadow:0 12px 36px rgba(155,59,255,.5)}
.btn-ghost{background:transparent;color:var(--ink);border:2px solid var(--card-line)}
.btn-ghost:hover{border-color:var(--cyan);color:var(--cyan)}
.btn-lg{padding:16px 30px;font-size:1.06rem}
.btn-block{width:100%}

/* Header */
.site-header{position:sticky;top:0;z-index:100;backdrop-filter:blur(12px);background:rgba(10,1,24,.7);border-bottom:1px solid var(--card-line);transition:background .3s}
.header-inner{display:flex;align-items:center;gap:18px;padding-top:10px;padding-bottom:10px}
.logo img{height:44px;width:auto}
.nav{display:none;gap:22px;margin-left:auto}
.nav a{color:var(--muted);font-weight:600;font-size:.95rem}
.nav a:hover{color:var(--ink);text-decoration:none}
.nav-cta{display:none}

/* Hero */
.hero{position:relative;overflow:hidden;padding:72px 0 64px;isolation:isolate}
.hero-bg{position:absolute;inset:0;z-index:-1}
.orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.55}
.orb-1{width:420px;height:420px;background:var(--magenta);top:-120px;left:-100px;animation:float1 14s ease-in-out infinite}
.orb-2{width:380px;height:380px;background:var(--purple);bottom:-140px;right:-80px;animation:float2 17s ease-in-out infinite}
.orb-3{width:300px;height:300px;background:var(--cyan);top:30%;right:25%;opacity:.4;animation:float3 20s ease-in-out infinite}
.silhouettes{position:absolute;inset:0;overflow:hidden}
.dancer{position:absolute;bottom:-10px;width:90px;opacity:.22;fill:url(#g) ;color:var(--cyan)}
.dancer path{fill:currentColor}
.dancer-a{left:6%;color:var(--magenta);animation:sway 6s ease-in-out infinite}
.dancer-b{right:10%;color:var(--cyan);width:110px;animation:sway 7s ease-in-out infinite .8s}
.dancer-c{right:38%;color:var(--purple);width:80px;animation:sway 5.5s ease-in-out infinite .4s}

.hero-inner{position:relative;text-align:center;max-width:760px;margin:0 auto}
.eyebrow{text-transform:uppercase;letter-spacing:.22em;font-size:.78rem;font-weight:700;color:var(--cyan);margin:0 0 14px}
.kinetic{font-size:clamp(2.5rem,9vw,4.6rem);line-height:1.02;font-weight:900;margin:0 0 18px;letter-spacing:-.02em}
.kinetic .line{display:block}
.grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-sub{font-size:clamp(1.05rem,2.6vw,1.35rem);color:var(--muted);max-width:600px;margin:0 auto 28px}
.hero-sub strong{color:var(--ink)}
.hero-cta{display:flex;flex-direction:column;gap:12px;align-items:center}
.beat{display:flex;gap:8px;justify-content:center;margin-top:40px;height:42px;align-items:flex-end}
.beat span{width:8px;background:var(--grad);border-radius:6px;height:14px;animation:beat 1s ease-in-out infinite}
.beat span:nth-child(2){animation-delay:.15s}
.beat span:nth-child(3){animation-delay:.3s}
.beat span:nth-child(4){animation-delay:.45s}
.beat span:nth-child(5){animation-delay:.6s}

/* Sections */
.section{padding:72px 0}
.section-alt{background:linear-gradient(180deg,var(--bg),var(--bg-2))}
.kicker{text-transform:uppercase;letter-spacing:.2em;font-size:.78rem;font-weight:700;color:var(--magenta);margin:0 0 10px}
.kicker.light{color:var(--cyan)}
.section-title{font-size:clamp(1.9rem,5.5vw,3rem);font-weight:900;line-height:1.06;margin:0 0 16px;letter-spacing:-.02em}
.section-lead{color:var(--muted);font-size:1.1rem;max-width:640px;margin:0 0 36px}
.fineprint{color:var(--muted);font-size:.85rem;margin-top:18px;opacity:.8}

/* Class grid */
.class-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:34px}
.card{
  background:var(--card);border:1px solid var(--card-line);border-radius:var(--radius);
  padding:24px;position:relative;overflow:hidden;
  transition:transform .2s ease,border-color .2s ease;
}
.card::before{content:"";position:absolute;inset:0;background:var(--grad-soft);opacity:0;transition:opacity .25s}
.card:hover{transform:translateY(-4px);border-color:transparent}
.card:hover::before{opacity:1}
.card>*{position:relative}
.card h3{margin:0 0 8px;font-size:1.25rem;font-weight:800}
.card p{margin:0;color:var(--muted);font-size:.96rem}
.card-accent{border-color:var(--magenta)}
.card-accent::before{opacity:.55}

/* Schedule */
.hours-grid{max-width:520px;border:1px solid var(--card-line);border-radius:var(--radius);overflow:hidden;background:var(--card)}
.hours-row{display:flex;justify-content:space-between;padding:16px 22px;border-bottom:1px solid var(--card-line)}
.hours-row:last-child{border-bottom:0}
.hours-row .day{font-weight:700}
.hours-row .time{color:var(--muted)}

/* About */
.about-grid{display:grid;grid-template-columns:1fr;gap:36px;align-items:center}
.about-copy p{color:var(--muted);margin:0 0 16px}
.badges{list-style:none;padding:0;margin:24px 0 0;display:flex;flex-wrap:wrap;gap:10px}
.badges li{background:var(--card);border:1px solid var(--card-line);border-radius:999px;padding:8px 16px;font-size:.88rem;font-weight:600}
.about-media img{border-radius:var(--radius);border:1px solid var(--card-line)}

/* Reviews */
.rating-line{display:flex;align-items:center;gap:12px;margin-bottom:28px;font-weight:600}
.stars{color:#ffc83d;font-size:1.3rem;letter-spacing:2px}
.review-grid{display:grid;grid-template-columns:1fr;gap:16px}
.review{
  margin:0;background:var(--card);border:1px solid var(--card-line);
  border-left:4px solid;border-image:var(--grad) 1;border-radius:12px;
  padding:22px;color:var(--ink);font-size:1.02rem;font-style:italic;
}

/* Location */
.loc-grid{display:grid;grid-template-columns:1fr;gap:18px}
.loc-card{background:var(--card);border:1px solid var(--card-line);border-radius:var(--radius);padding:26px}
.loc-card h3{margin:0 0 12px;font-size:1.2rem}
.loc-card address{font-style:normal;color:var(--muted);margin-bottom:10px}
.loc-link{font-weight:700}

/* Contact */
.section-cta{background:radial-gradient(120% 120% at 50% 0%,rgba(155,59,255,.22),transparent 60%),var(--bg-2)}
.contact-grid{display:grid;grid-template-columns:1fr;gap:34px}
.contact-copy p{color:var(--muted)}
.contact-list{list-style:none;padding:0;margin:22px 0 0;display:grid;gap:10px}
.contact-list li{font-size:1.05rem}
.trial-form{background:var(--card);border:1px solid var(--card-line);border-radius:var(--radius);padding:26px}
.trial-form h3{margin:0 0 18px;font-size:1.4rem;font-weight:800}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:6px}
.field input,.field select{
  width:100%;min-height:var(--tap);padding:11px 14px;border-radius:12px;
  border:1px solid var(--card-line);background:rgba(0,0,0,.25);color:var(--ink);font-size:1rem;
}
.field input:focus,.field select:focus{border-color:var(--cyan);outline:none}
.form-note{margin:14px 0 0;font-weight:600;min-height:1.2em}
.form-note.ok{color:var(--cyan)}

/* Footer */
.site-footer{background:var(--bg);border-top:1px solid var(--card-line);padding:44px 0 24px}
.footer-inner{display:grid;grid-template-columns:1fr;gap:24px}
.footer-logo{height:44px;width:auto;margin-bottom:12px}
.site-footer p{color:var(--muted);margin:4px 0}
.copyright{text-align:center;color:var(--muted);font-size:.85rem;margin-top:30px;opacity:.7}

/* Sticky mobile CTA */
.sticky-cta{
  position:fixed;left:14px;right:14px;bottom:14px;z-index:90;
  display:flex;align-items:center;justify-content:center;
  min-height:52px;border-radius:999px;font-weight:800;color:#fff;
  background:var(--grad);box-shadow:0 10px 30px rgba(255,46,154,.45);
}
.sticky-cta:hover{text-decoration:none}

/* Reveal animation base */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* Keyframes */
@keyframes float1{0%,100%{transform:translate(0,0)}50%{transform:translate(40px,30px)}}
@keyframes float2{0%,100%{transform:translate(0,0)}50%{transform:translate(-50px,-30px)}}
@keyframes float3{0%,100%{transform:translate(0,0)}50%{transform:translate(30px,-40px)}}
@keyframes sway{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-14px) rotate(2deg)}}
@keyframes beat{0%,100%{height:14px;opacity:.6}50%{height:40px;opacity:1}}

/* Desktop */
@media(min-width:760px){
  .nav{display:flex}
  .nav-cta{display:inline-flex}
  .hero-cta{flex-direction:row;justify-content:center}
  .class-grid{grid-template-columns:repeat(3,1fr)}
  .review-grid{grid-template-columns:repeat(3,1fr)}
  .loc-grid{grid-template-columns:1fr 1fr}
  .about-grid{grid-template-columns:1.1fr .9fr}
  .contact-grid{grid-template-columns:1fr 1fr;align-items:start}
  .footer-inner{grid-template-columns:1fr auto}
  .sticky-cta{display:none}
  .dancer{width:130px}
  .dancer-b{width:160px}
}

@media(min-width:760px){
  body{padding-bottom:0}
}
/* Pad body so sticky CTA never covers content on mobile */
@media(max-width:759px){
  body{padding-bottom:84px}
}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
