/* ═══════════════════════════════════════════════════════
   EMOGY DANCE ALCHEMY — Main Stylesheet
   ═══════════════════════════════════════════════════════ */

*{margin:0;padding:0;box-sizing:border-box}
:root{
  --black:#060310;
  --deep:#0E0520;
  --purple:#1F0B4A;
  --mid-purple:#4A1D96;
  --electric:#7C3AED;
  --violet:#A855F7;
  --gold:#D4A843;
  --gold-bright:#FFD060;
  --teal:#00C9A7;
  --teal-dark:#008F76;
  --white:#F5F0FF;
  --muted:#9580B8;
  --font-display:'Bebas Neue',sans-serif;
  --font-accent:'Cormorant Garamond',serif;
  --font-body:'DM Sans',sans-serif;
}
html{scroll-behavior:smooth}
body{background:var(--black);color:var(--white);font-family:var(--font-body);overflow-x:hidden;cursor:none}

/* HAMBURGER & MOBILE MENU */
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.hamburger span{display:block;width:24px;height:2px;background:var(--white);transition:all .3s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(6,3,16,.98);backdrop-filter:blur(20px);z-index:700;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:80px 24px 60px;overflow-y:auto}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:var(--font-display);font-size:clamp(20px,5vw,28px);letter-spacing:.08em;color:var(--white);cursor:pointer;transition:color .2s;text-decoration:none;min-height:44px;display:flex;align-items:center;justify-content:center;width:100%;padding:6px 0}
.mobile-menu a:hover{color:var(--gold)}
.mobile-menu a:active{color:var(--gold);opacity:.7}

/* CUSTOM CURSOR */
.cursor{position:fixed;width:12px;height:12px;background:var(--gold);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform .1s,width .2s,height .2s;mix-blend-mode:difference}
.cursor-ring{position:fixed;width:36px;height:36px;border:1px solid var(--gold);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:transform .15s ease-out,width .2s,height .2s;opacity:.6}
.cursor.hovering{width:6px;height:6px}
.cursor-ring.hovering{width:50px;height:50px;opacity:.3}

/* CANVAS BACKGROUND */
#bg-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:600;padding:20px 48px;display:flex;justify-content:space-between;align-items:center;transition:background .3s;background:rgba(6,3,16,.75);backdrop-filter:blur(12px)}
nav.scrolled{background:rgba(6,3,16,.85);backdrop-filter:blur(20px);border-bottom:1px solid rgba(212,168,67,.15)}
.nav-logo{font-family:var(--font-display);font-size:28px;letter-spacing:.08em;color:var(--white);cursor:pointer;position:relative}
.nav-logo span{color:var(--gold)}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);text-decoration:none;cursor:pointer;transition:color .2s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--gold);transition:width .3s}
.nav-links a:hover{color:var(--white)}
.nav-links a:hover::after{width:100%}
.nav-links a.active{color:var(--gold)}
.nav-cta{background:transparent;border:1px solid var(--gold);color:var(--gold);padding:10px 24px;font-family:var(--font-body);font-size:13px;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all .25s;position:relative;overflow:hidden}
.nav-cta::before{content:'';position:absolute;inset:0;background:var(--gold);transform:translateX(-100%);transition:transform .25s;z-index:-1}
.nav-cta:hover{color:var(--black)}
.nav-cta:hover::before{transform:translateX(0)}
.nav-auth-area{display:flex;align-items:center;gap:12px}
.nav-member-name{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);cursor:pointer}

/* PAGES */
.page{position:relative;z-index:1;display:none;min-height:100vh}
.page.active{display:block}

/* ═══════════════ HOME PAGE ═══════════════ */
/* HERO */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;position:relative;padding:0 48px;overflow:hidden}
.hero-eyebrow{font-family:var(--font-accent);font-size:18px;font-style:italic;color:var(--gold);letter-spacing:.06em;margin-bottom:20px;opacity:0;animation:fadeUp .8s .4s forwards}
.hero-title{font-family:var(--font-display);font-size:clamp(80px,14vw,200px);line-height:.9;letter-spacing:-.01em;margin-bottom:16px;overflow:hidden}
.hero-title .line{display:block;opacity:0;transform:translateY(100px)}
.hero-title .line:nth-child(1){animation:slideUp .7s .5s cubic-bezier(.16,1,.3,1) forwards}
.hero-title .line:nth-child(2){animation:slideUp .7s .65s cubic-bezier(.16,1,.3,1) forwards;color:var(--gold)}
.hero-title .line:nth-child(3){animation:slideUp .7s .8s cubic-bezier(.16,1,.3,1) forwards}
.hero-sub{font-family:var(--font-accent);font-size:22px;font-style:italic;color:var(--muted);max-width:500px;line-height:1.6;margin-bottom:48px;opacity:0;animation:fadeUp .8s 1s forwards}
.hero-actions{display:flex;gap:20px;opacity:0;animation:fadeUp .8s 1.1s forwards}
.btn-primary{background:var(--gold);color:var(--black);padding:16px 40px;font-family:var(--font-body);font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;border:none;cursor:pointer;transition:all .25s;position:relative;overflow:hidden}
.btn-primary:hover{background:var(--gold-bright);transform:translateY(-2px);box-shadow:0 12px 40px rgba(212,168,67,.4)}
.btn-secondary{background:transparent;color:var(--white);padding:16px 40px;font-family:var(--font-body);font-size:13px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;border:1px solid rgba(255,255,255,.2);cursor:pointer;transition:all .25s}
.btn-secondary:hover{border-color:var(--white);background:rgba(255,255,255,.06);transform:translateY(-2px)}
.hero-freq-badge{position:absolute;right:80px;bottom:80px;opacity:0;animation:fadeUp .8s 1.3s forwards}
.freq-ring{width:160px;height:160px;border-radius:50%;border:1px solid rgba(212,168,67,.3);display:flex;align-items:center;justify-content:center;position:relative;animation:spin 20s linear infinite}
.freq-ring::before{content:'';position:absolute;inset:-12px;border-radius:50%;border:1px dashed rgba(212,168,67,.15)}
.freq-inner{text-align:center;animation:spinReverse 20s linear infinite}
.freq-inner .hz{font-family:var(--font-display);font-size:36px;color:var(--gold);line-height:1}
.freq-inner .label{font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-top:4px}
.hero-scroll{position:absolute;bottom:40px;left:48px;display:flex;align-items:center;gap:12px;opacity:0;animation:fadeUp .8s 1.4s forwards}
.hero-scroll span{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.scroll-line{width:48px;height:1px;background:linear-gradient(90deg,var(--gold),transparent);transform-origin:left;animation:scaleX 1.5s 1.5s ease-in-out infinite alternate}

/* STATEMENT */
.statement{padding:120px 48px;position:relative;overflow:hidden}
.statement-inner{max-width:1000px;margin:0 auto;text-align:center}
.statement-text{font-family:var(--font-accent);font-size:clamp(28px,4vw,52px);font-style:italic;line-height:1.3;color:var(--white);font-weight:300}
.statement-text em{font-style:normal;color:var(--gold)}
.statement-line{width:60px;height:2px;background:var(--gold);margin:40px auto}

/* PILLARS */
.pillars{padding:80px 48px 120px;position:relative}
.section-label{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;display:flex;align-items:center;gap:12px}
.section-label::before{content:'';width:30px;height:1px;background:var(--gold)}
.section-title{font-family:var(--font-display);font-size:clamp(40px,6vw,80px);margin-bottom:60px;line-height:.95}
.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.pillar-card{position:relative;padding:56px 40px;overflow:hidden;cursor:pointer;transition:transform .3s}
.pillar-card::before{content:'';position:absolute;inset:0;opacity:0;transition:opacity .4s;z-index:0}
.pillar-card:hover{transform:translateY(-8px)}
.pillar-heal{background:linear-gradient(135deg,rgba(0,201,167,.08),rgba(0,143,118,.04));border:1px solid rgba(0,201,167,.15)}
.pillar-heal::before{background:linear-gradient(135deg,rgba(0,201,167,.15),rgba(0,143,118,.08))}
.pillar-heal:hover::before{opacity:1}
.pillar-express{background:linear-gradient(135deg,rgba(124,58,237,.1),rgba(74,29,150,.06));border:1px solid rgba(124,58,237,.2)}
.pillar-express::before{background:linear-gradient(135deg,rgba(124,58,237,.2),rgba(74,29,150,.1))}
.pillar-express:hover::before{opacity:1}
.pillar-compete{background:linear-gradient(135deg,rgba(212,168,67,.08),rgba(255,208,96,.04));border:1px solid rgba(212,168,67,.2)}
.pillar-compete::before{background:linear-gradient(135deg,rgba(212,168,67,.15),rgba(255,208,96,.08))}
.pillar-compete:hover::before{opacity:1}
.pillar-num{font-family:var(--font-display);font-size:80px;opacity:.06;position:absolute;top:20px;right:30px;z-index:0;transition:opacity .3s}
.pillar-card:hover .pillar-num{opacity:.12}
.pillar-icon{font-size:36px;margin-bottom:20px;position:relative;z-index:1}
.pillar-name{font-family:var(--font-display);font-size:48px;letter-spacing:.04em;margin-bottom:12px;position:relative;z-index:1}
.pillar-heal .pillar-name{color:var(--teal)}
.pillar-express .pillar-name{color:var(--violet)}
.pillar-compete .pillar-name{color:var(--gold)}
.pillar-hz{font-family:var(--font-accent);font-size:13px;font-style:italic;margin-bottom:16px;position:relative;z-index:1}
.pillar-heal .pillar-hz{color:rgba(0,201,167,.7)}
.pillar-express .pillar-hz{color:rgba(168,85,247,.7)}
.pillar-compete .pillar-hz{color:rgba(212,168,67,.7)}
.pillar-desc{font-size:15px;line-height:1.65;color:var(--muted);position:relative;z-index:1}
.pillar-arrow{position:absolute;bottom:32px;right:32px;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .3s;z-index:1}
.pillar-heal .pillar-arrow{border:1px solid rgba(0,201,167,.3);color:var(--teal)}
.pillar-express .pillar-arrow{border:1px solid rgba(168,85,247,.3);color:var(--violet)}
.pillar-compete .pillar-arrow{border:1px solid rgba(212,168,67,.3);color:var(--gold)}
.pillar-card:hover .pillar-arrow{transform:translate(4px,-4px)}

/* ATTUNED STRIP */
.attuned-strip{padding:80px 48px;background:linear-gradient(90deg,rgba(212,168,67,.04),rgba(124,58,237,.06),rgba(0,201,167,.04));border-top:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.05)}
.attuned-inner{display:flex;align-items:center;gap:80px;max-width:1200px;margin:0 auto}
.attuned-letters{display:flex;gap:4px}
.a-letter{display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:transform .2s}
.a-letter:hover{transform:translateY(-6px)}
.a-char{font-family:var(--font-display);font-size:72px;line-height:1;transition:color .2s}
.a-word{font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);transition:color .2s;white-space:nowrap}
.a-letter:nth-child(1) .a-char{color:var(--teal)}
.a-letter:nth-child(2) .a-char,.a-letter:nth-child(3) .a-char{color:var(--violet)}
.a-letter:nth-child(4) .a-char{color:var(--gold)}
.a-letter:nth-child(5) .a-char{color:var(--teal)}
.a-letter:nth-child(6) .a-char,.a-letter:nth-child(7) .a-char{color:rgba(255,255,255,.3)}
.attuned-text{flex:1}
.attuned-text h3{font-family:var(--font-display);font-size:36px;margin-bottom:12px;letter-spacing:.04em}
.attuned-text p{color:var(--muted);line-height:1.7;font-size:15px}
.attuned-cta{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);cursor:pointer;display:flex;align-items:center;gap:8px;margin-top:20px;transition:gap .2s}
.attuned-cta:hover{gap:14px}

/* FREQUENCIES */
.frequencies{padding:100px 48px;position:relative}
.freq-grid{display:grid;grid-template-columns:repeat(9,1fr);gap:0;margin-top:60px}
.freq-item{padding:32px 16px;text-align:center;border-right:1px solid rgba(255,255,255,.06);cursor:pointer;transition:all .25s;position:relative;overflow:hidden}
.freq-item:last-child{border-right:none}
.freq-item::before{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--gold);transform:scaleX(0);transition:transform .3s}
.freq-item:hover::before{transform:scaleX(1)}
.freq-item:hover{background:rgba(212,168,67,.04)}
.freq-hz{font-family:var(--font-display);font-size:28px;color:var(--gold);margin-bottom:6px}
.freq-name{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.freq-effect{font-size:11px;line-height:1.4;color:rgba(255,255,255,.35)}
.freq-bar{width:100%;height:3px;background:rgba(212,168,67,.1);margin-top:16px;position:relative}
.freq-fill{height:100%;width:100%;background:linear-gradient(90deg,var(--gold),var(--teal));transform-origin:left;transform:scaleX(0);transition:transform .6s cubic-bezier(.16,1,.3,1)}

/* MEMBERSHIP CTA */
.membership-cta{padding:120px 48px;text-align:center;position:relative;overflow:hidden}
.membership-cta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 50%,rgba(124,58,237,.12),transparent)}
.cta-eyebrow{font-family:var(--font-accent);font-size:18px;font-style:italic;color:var(--gold);margin-bottom:20px}
.cta-title{font-family:var(--font-display);font-size:clamp(50px,8vw,110px);line-height:.9;margin-bottom:24px}
.cta-sub{font-size:17px;color:var(--muted);margin-bottom:40px;max-width:500px;margin-left:auto;margin-right:auto;line-height:1.6}
.pricing-chips{display:flex;justify-content:center;gap:12px;margin-bottom:48px;flex-wrap:wrap}
.price-chip{padding:10px 24px;border:1px solid rgba(255,255,255,.1);font-size:13px;color:var(--muted);transition:all .25s;cursor:pointer}
.price-chip span{color:var(--gold);font-weight:600}
.price-chip:hover{border-color:var(--gold);color:var(--white);background:rgba(212,168,67,.06)}

/* ═══════════════ CLASSES PAGE ═══════════════ */
.classes-hero{padding:160px 48px 80px;position:relative}
.classes-hero h1{font-family:var(--font-display);font-size:clamp(60px,10vw,140px);line-height:.9;margin-bottom:20px}
.classes-hero h1 span{color:var(--gold)}
.classes-hero p{font-family:var(--font-accent);font-size:22px;font-style:italic;color:var(--muted);max-width:600px;line-height:1.6}

/* TABS */
.class-tabs{padding:0 48px 60px;display:flex;gap:0;border-bottom:1px solid rgba(255,255,255,.08)}
.tab-btn{padding:16px 40px;font-family:var(--font-body);font-size:13px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;background:none;border:none;color:var(--muted);cursor:pointer;transition:all .25s;position:relative;border-bottom:2px solid transparent;margin-bottom:-1px}
.tab-btn.active{color:var(--white);border-bottom-color:var(--gold)}
.tab-btn:hover:not(.active){color:var(--white)}

/* CLASS CARDS */
.classes-section{padding:60px 48px}
.classes-section.hidden{display:none}
.classes-intro{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px}
.classes-intro h2{font-family:var(--font-display);font-size:56px}
.classes-intro h2.heal{color:var(--teal)}
.classes-intro h2.express{color:var(--violet)}
.classes-intro h2.compete{color:var(--gold)}
.classes-intro p{color:var(--muted);max-width:360px;text-align:right;font-size:15px;line-height:1.6}
.class-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:60px}
.class-grid-2col{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:60px}
.class-card{background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.06);padding:36px;position:relative;overflow:hidden;transition:all .3s;cursor:pointer}
.class-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.class-card.heal::after{background:linear-gradient(90deg,var(--teal),transparent)}
.class-card.express::after{background:linear-gradient(90deg,var(--violet),transparent)}
.class-card.compete::after{background:linear-gradient(90deg,var(--gold),transparent)}
.class-card:hover{transform:translateY(-6px);border-color:rgba(255,255,255,.12);background:rgba(255,255,255,.04)}
.class-card-hz{font-family:var(--font-display);font-size:52px;opacity:.12;position:absolute;bottom:16px;right:20px;line-height:1}
.class-card-tag{font-size:10px;letter-spacing:.15em;text-transform:uppercase;padding:4px 12px;border-radius:100px;display:inline-block;margin-bottom:16px}
.class-card.heal .class-card-tag{background:rgba(0,201,167,.1);color:var(--teal);border:1px solid rgba(0,201,167,.2)}
.class-card.express .class-card-tag{background:rgba(168,85,247,.1);color:var(--violet);border:1px solid rgba(168,85,247,.2)}
.class-card.compete .class-card-tag{background:rgba(212,168,67,.1);color:var(--gold);border:1px solid rgba(212,168,67,.2)}
.class-card h3{font-family:var(--font-display);font-size:32px;letter-spacing:.03em;margin-bottom:10px}
.class-card-hz-label{font-family:var(--font-accent);font-size:14px;font-style:italic;color:var(--muted);margin-bottom:14px}
.class-card p{font-size:14px;line-height:1.65;color:rgba(255,255,255,.5);margin-bottom:24px}
.class-meta{display:flex;gap:16px}
.class-meta-item{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:6px}
.class-meta-item::before{content:'';width:6px;height:6px;border-radius:50%}
.class-card.heal .class-meta-item::before{background:var(--teal)}
.class-card.express .class-meta-item::before{background:var(--violet)}
.class-card.compete .class-meta-item::before{background:var(--gold)}

/* AUDITION BANNER */
.audition-banner{background:rgba(212,168,67,.06);border:1px solid rgba(212,168,67,.25);padding:28px 36px;margin-bottom:48px;display:flex;align-items:center;gap:28px;flex-wrap:wrap}
.audition-banner-icon{font-size:36px;flex-shrink:0;color:var(--gold)}
.audition-banner-text{flex:1;min-width:260px}
.audition-banner-title{font-family:var(--font-display);font-size:22px;letter-spacing:.06em;color:var(--gold);margin-bottom:6px}
.audition-banner-desc{font-size:14px;color:rgba(255,255,255,.55);line-height:1.7;margin:0}
.audition-banner-btn{flex-shrink:0;white-space:nowrap}

/* MEMBERSHIPS */
.memberships{padding:80px 48px 120px;background:linear-gradient(180deg,transparent,rgba(124,58,237,.04),transparent)}
.mem-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;margin-top:48px}
.mem-card{padding:40px 32px;background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.06);position:relative;transition:all .3s;cursor:pointer}
.mem-card:hover{background:rgba(255,255,255,.05);transform:translateY(-4px)}
.mem-card.featured{background:rgba(212,168,67,.06);border-color:rgba(212,168,67,.25)}
.mem-card.featured::before{content:'MOST POPULAR';position:absolute;top:-1px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--black);font-size:9px;font-weight:700;letter-spacing:.15em;padding:4px 14px}
.mem-name{font-family:var(--font-display);font-size:28px;letter-spacing:.04em;margin-bottom:6px}
.mem-price{font-family:var(--font-display);font-size:52px;color:var(--gold);line-height:1;margin:16px 0 4px}
.mem-price sub{font-size:20px;color:var(--muted)}
.mem-period{font-size:12px;color:var(--muted);letter-spacing:.08em;margin-bottom:20px}
.mem-features{list-style:none;margin-bottom:28px}
.mem-features li{font-size:13px;color:rgba(255,255,255,.55);padding:8px 0;border-bottom:1px solid rgba(255,255,255,.05);display:flex;align-items:center;gap:10px}
.mem-features li::before{content:'→';color:var(--gold);font-size:11px;flex-shrink:0}
.mem-btn{width:100%;padding:14px;font-family:var(--font-body);font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:all .25s;background:transparent;color:var(--gold);border:1px solid rgba(212,168,67,.4)}
.mem-card.featured .mem-btn{background:var(--gold);color:var(--black);border-color:var(--gold)}
.mem-card:hover .mem-btn{background:var(--gold);color:var(--black)}

/* ═══════════════ ABOUT PAGE ═══════════════ */
.about-hero{padding:160px 48px 80px;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-hero-text h1{font-family:var(--font-display);font-size:clamp(60px,9vw,120px);line-height:.9;margin-bottom:24px}
.about-hero-text h1 em{font-style:normal;color:var(--gold)}
.about-hero-text p{font-size:17px;line-height:1.8;color:rgba(255,255,255,.6);margin-bottom:32px}
.about-hero-visual{position:relative;height:500px;display:flex;align-items:center;justify-content:center}
.about-rings{position:relative;width:400px;height:400px}
.ring{position:absolute;border-radius:50%;border:1px solid;top:50%;left:50%}
.ring-1{width:400px;height:400px;border-color:rgba(212,168,67,.08);animation:spin 30s linear infinite;margin-top:-200px;margin-left:-200px}
.ring-2{width:300px;height:300px;border-color:rgba(0,201,167,.12);animation:spin 20s linear infinite reverse;margin-top:-150px;margin-left:-150px}
.ring-3{width:200px;height:200px;border-color:rgba(168,85,247,.2);animation:spin 12s linear infinite;margin-top:-100px;margin-left:-100px}
.ring-4{width:100px;height:100px;border-color:rgba(212,168,67,.4);animation:spin 6s linear infinite reverse;margin-top:-50px;margin-left:-50px}
.ring-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}
.ring-center-word{font-family:var(--font-display);font-size:48px;color:var(--gold);display:block}
.ring-center-sub{font-family:var(--font-accent);font-size:13px;font-style:italic;color:var(--muted)}

/* FOUNDER */
.founder{padding:80px 48px;display:grid;grid-template-columns:400px 1fr;gap:80px;align-items:start}
.founder-image{position:relative}
.founder-img-placeholder{width:100%;aspect-ratio:3/4;background:linear-gradient(135deg,rgba(124,58,237,.15),rgba(0,201,167,.1));border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;font-size:80px;position:relative;overflow:hidden}
.founder-img-placeholder::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(6,3,16,.8))}
.founder-tag{position:absolute;bottom:-16px;left:20px;right:20px;background:var(--gold);color:var(--black);padding:16px 20px;font-family:var(--font-display);font-size:18px;letter-spacing:.04em}
.founder-content h2{font-family:var(--font-display);font-size:64px;line-height:.9;margin-bottom:24px}
.founder-content h2 span{color:var(--gold)}
.founder-content p{font-size:16px;line-height:1.85;color:rgba(255,255,255,.6);margin-bottom:20px}
.founder-quote{border-left:3px solid var(--gold);padding-left:24px;margin:32px 0}
.founder-quote p{font-family:var(--font-accent);font-size:22px;font-style:italic;color:var(--white);line-height:1.5}

/* ATTUNED METHOD STAGES */
.attuned-stages{padding:100px 48px;background:linear-gradient(180deg,transparent,rgba(74,29,150,.06),transparent)}
.stages-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:0;margin-top:60px;position:relative}
.stages-grid::before{content:'';position:absolute;top:60px;left:10%;right:10%;height:1px;background:linear-gradient(90deg,var(--teal),var(--violet),var(--gold),var(--violet),var(--teal));opacity:.3;z-index:0}
.stage-card{padding:40px 24px;text-align:center;position:relative;z-index:1;transition:transform .3s;cursor:pointer}
.stage-card:hover{transform:translateY(-10px)}
.stage-dot{width:20px;height:20px;border-radius:50%;margin:0 auto 20px;position:relative}
.stage-dot::before{content:'';position:absolute;inset:-6px;border-radius:50%;opacity:.3;animation:pulse 2s infinite}
.stage-1 .stage-dot{background:var(--teal);box-shadow:0 0 20px var(--teal)}
.stage-1 .stage-dot::before{background:var(--teal)}
.stage-2 .stage-dot{background:var(--violet);box-shadow:0 0 20px var(--violet)}
.stage-2 .stage-dot::before{background:var(--violet)}
.stage-3 .stage-dot{background:var(--gold);box-shadow:0 0 20px var(--gold)}
.stage-3 .stage-dot::before{background:var(--gold)}
.stage-4 .stage-dot{background:var(--electric);box-shadow:0 0 20px var(--electric)}
.stage-4 .stage-dot::before{background:var(--electric)}
.stage-5 .stage-dot{background:var(--teal);box-shadow:0 0 20px var(--teal)}
.stage-5 .stage-dot::before{background:var(--teal)}
.stage-6 .stage-dot{background:var(--gold);box-shadow:0 0 20px var(--gold)}
.stage-6 .stage-dot::before{background:var(--gold)}
.stage-7 .stage-dot{background:var(--violet);box-shadow:0 0 20px var(--violet)}
.stage-7 .stage-dot::before{background:var(--violet)}
.stage-letter{font-family:var(--font-display);font-size:80px;line-height:1;margin-bottom:8px}
.stage-1 .stage-letter{color:var(--teal)}
.stage-2 .stage-letter{color:var(--violet)}
.stage-3 .stage-letter{color:var(--gold)}
.stage-4 .stage-letter{color:var(--electric)}
.stage-5 .stage-letter{color:var(--teal)}
.stage-6 .stage-letter{color:var(--gold)}
.stage-7 .stage-letter{color:var(--violet)}
.stage-name{font-family:var(--font-display);font-size:18px;letter-spacing:.08em;margin-bottom:8px;color:var(--white)}
.stage-hz{font-family:var(--font-accent);font-size:13px;font-style:italic;color:var(--muted);margin-bottom:12px}
.stage-desc{font-size:13px;line-height:1.6;color:rgba(255,255,255,.4)}

/* PRINCIPLES */
.principles{padding:80px 48px 120px}
.principles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:60px}
.principle-card{padding:48px 40px;border:1px solid rgba(255,255,255,.06);position:relative;overflow:hidden;transition:all .3s}
.principle-card::before{content:attr(data-num);font-family:var(--font-display);font-size:120px;opacity:.04;position:absolute;top:-20px;right:-10px;line-height:1;color:var(--gold);transition:opacity .3s}
.principle-card:hover::before{opacity:.08}
.principle-card:hover{border-color:rgba(212,168,67,.2);background:rgba(212,168,67,.02)}
.principle-icon{font-size:32px;margin-bottom:20px}
.principle-name{font-family:var(--font-display);font-size:36px;letter-spacing:.04em;color:var(--gold);margin-bottom:12px}
.principle-title{font-family:var(--font-accent);font-size:20px;font-style:italic;color:var(--white);margin-bottom:16px}
.principle-desc{font-size:15px;line-height:1.75;color:rgba(255,255,255,.5)}

/* FOOTER */
footer{
  padding:80px 48px 60px;
  background:linear-gradient(180deg,var(--black) 0%,rgba(14,5,32,.98) 100%);
  border-top:1px solid rgba(212,168,67,.2);
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:56px;
  position:relative;
  z-index:1;
}
footer::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(212,168,67,.6),transparent);
}
.footer-brand .logo{font-family:var(--font-display);font-size:36px;letter-spacing:.08em;margin-bottom:6px;color:var(--white)}
.footer-brand .logo span{color:var(--gold)}
.footer-brand .tagline{font-family:var(--font-accent);font-size:14px;font-style:italic;color:rgba(212,168,67,.55);margin-bottom:20px;display:block}
.footer-brand p{font-size:13px;color:var(--muted);line-height:1.8;margin-bottom:28px;max-width:280px}
.social-links{display:flex;gap:10px}
.social-link{width:38px;height:38px;border:1px solid rgba(212,168,67,.2);display:flex;align-items:center;justify-content:center;font-size:13px;cursor:pointer;color:var(--muted);transition:all .25s;position:relative;overflow:hidden}
.social-link::before{content:'';position:absolute;inset:0;background:var(--gold);transform:scaleY(0);transform-origin:bottom;transition:transform .25s;z-index:0}
.social-link:hover{color:var(--black);border-color:var(--gold)}
.social-link:hover::before{transform:scaleY(1)}
.social-link span{position:relative;z-index:1}
.footer-col h4{font-family:var(--font-display);font-size:18px;letter-spacing:.06em;color:var(--white);margin-bottom:24px;padding-bottom:12px;border-bottom:1px solid rgba(212,168,67,.12);position:relative}
.footer-col h4::after{content:'';position:absolute;bottom:-1px;left:0;width:28px;height:1px;background:var(--gold)}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:12px}
.footer-col ul li a{font-size:13px;color:var(--muted);text-decoration:none;cursor:pointer;transition:all .22s;display:inline-flex;align-items:center;gap:0;letter-spacing:.02em}
.footer-col ul li a::before{content:'→';font-size:10px;color:var(--gold);opacity:0;max-width:0;overflow:hidden;transition:all .22s}
.footer-col ul li a:hover{color:var(--white)}
.footer-col ul li a:hover::before{opacity:1;max-width:18px;margin-right:6px}
.footer-bottom{padding:22px 48px;border-top:1px solid rgba(212,168,67,.08);display:flex;justify-content:space-between;align-items:center;background:rgba(6,3,16,.9)}
.footer-bottom p{font-size:12px;color:rgba(255,255,255,.18);letter-spacing:.02em}
.footer-bottom span{font-family:var(--font-accent);font-size:13px;font-style:italic;color:var(--gold);opacity:.65;letter-spacing:.04em}

/* SELECT OPTION STYLING */
select option{color:var(--white);background:var(--deep)}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideUp{from{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes spinReverse{from{transform:rotate(0deg)}to{transform:rotate(-360deg)}}
@keyframes scaleX{from{transform:scaleX(1);opacity:1}to{transform:scaleX(0);opacity:0}}
@keyframes pulse{0%,100%{transform:scale(1);opacity:.3}50%{transform:scale(1.8);opacity:0}}
@keyframes wave{0%,100%{transform:scaleY(1)}50%{transform:scaleY(.3)}}
@keyframes glow{0%,100%{opacity:.6}50%{opacity:1}}

/* Genre tag color variants */
.class-card.compete .class-card-tag.lyrical-tag{background:rgba(168,85,247,.12);color:#C084FC;border-color:rgba(168,85,247,.25)}
.class-card.compete .class-card-tag.jazz-tag{background:rgba(0,201,167,.1);color:var(--teal);border-color:rgba(0,201,167,.2)}
.class-card.compete .class-card-tag.hiphop-tag{background:rgba(251,146,60,.1);color:#F97316;border-color:rgba(251,146,60,.2)}
.somatic-badge{display:inline-flex;align-items:center;gap:6px;font-size:10px;letter-spacing:.12em;text-transform:uppercase;padding:3px 10px;background:rgba(212,168,67,.08);border:1px solid rgba(212,168,67,.2);color:var(--gold);margin-bottom:12px}
.recreational-card{border-color:rgba(0,201,167,.2)}
.recreational-card::after{background:linear-gradient(90deg,var(--teal),transparent)}
.class-card-tag.rec-tag{background:rgba(0,201,167,.1);color:var(--teal);border:1px solid rgba(0,201,167,.2)}

/* RESPONSIVE ADJUSTMENTS */
@media(max-width:1100px){
  .freq-grid{grid-template-columns:repeat(3,1fr)}
  .mem-grid{grid-template-columns:repeat(2,1fr)}
  .stages-grid{grid-template-columns:repeat(4,1fr)}
  .stages-grid::before{display:none}
  .founder{grid-template-columns:1fr}
  .nav-links{gap:20px}
}
@media(max-width:768px){
  .hamburger{display:flex}
  .desktop-only{display:none!important}
  nav{padding:16px 24px}
  .nav-links{display:none}
  .hero,.pillars,.statement,.attuned-strip,.frequencies,.membership-cta,.classes-hero,.class-tabs,.classes-section,.memberships,.about-hero,.founder,.attuned-stages,.principles{padding-left:24px;padding-right:24px}
  .pillars-grid,.class-grid,.class-grid-2col,.mem-grid,.principles-grid,.stages-grid{grid-template-columns:1fr}
  .attuned-letters{flex-wrap:wrap;justify-content:center}
  .about-hero{grid-template-columns:1fr}
  .about-hero-visual{display:none}
  .attuned-inner{flex-direction:column;gap:40px}
  .hero-freq-badge{display:none}
  footer{grid-template-columns:1fr 1fr;padding:40px 24px}
  .schedule-card{flex-direction:column;align-items:flex-start;gap:16px}
  .player-controls{flex-direction:column;align-items:stretch}
  .freq-selector-grid{grid-template-columns:repeat(3,1fr)}
  .dashboard-stats{grid-template-columns:1fr 1fr}
  .auth-modal-inner{padding:32px 24px}
}

/* ═══════════════ SCHEDULE PAGE ═══════════════ */
.schedule-hero{padding:160px 48px 60px;position:relative}
.schedule-hero h1{font-family:var(--font-display);font-size:clamp(60px,10vw,140px);line-height:.9;margin-bottom:16px}
.schedule-hero h1 span{color:var(--gold)}
.schedule-sub{font-family:var(--font-accent);font-size:20px;font-style:italic;color:var(--muted);max-width:600px;line-height:1.6}
.day-tabs-container{padding:0 48px;margin-bottom:0;overflow-x:auto;-webkit-overflow-scrolling:touch}
.day-tabs{display:flex;gap:0;border-bottom:1px solid rgba(255,255,255,.08);min-width:max-content}
.day-tab-btn{padding:14px 28px;font-family:var(--font-body);font-size:13px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;background:none;border:none;color:var(--muted);cursor:pointer;transition:all .25s;position:relative;border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap}
.day-tab-btn.active{color:var(--white);border-bottom-color:var(--gold)}
.day-tab-btn:hover:not(.active){color:var(--white)}
.day-tab-btn.today{color:var(--teal)}
.day-tab-btn.today.active{border-bottom-color:var(--teal)}
.schedule-content{padding:40px 48px 120px}
.schedule-day-header{margin-bottom:32px}
.schedule-day-title{font-family:var(--font-display);font-size:48px;color:var(--white);letter-spacing:.04em}
.schedule-day-subtitle{font-family:var(--font-accent);font-size:15px;font-style:italic;color:var(--muted);margin-top:6px}
.schedule-list{display:flex;flex-direction:column;gap:12px}
.schedule-card{background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.06);padding:24px 32px;display:flex;align-items:center;gap:24px;transition:all .3s;position:relative;overflow:hidden}
.schedule-card::before{content:'';position:absolute;top:0;left:0;bottom:0;width:3px}
.schedule-card.heal::before{background:var(--teal)}
.schedule-card.express::before{background:var(--violet)}
.schedule-card.compete::before{background:var(--gold)}
.schedule-card:hover{border-color:rgba(255,255,255,.12);background:rgba(255,255,255,.04)}
.schedule-time{font-family:var(--font-display);font-size:28px;color:var(--white);min-width:90px;flex-shrink:0}
.schedule-divider{width:1px;height:48px;background:rgba(255,255,255,.08);flex-shrink:0}
.schedule-info{flex:1}
.schedule-class-name{font-family:var(--font-display);font-size:24px;letter-spacing:.03em;margin-bottom:4px}
.schedule-card.heal .schedule-class-name{color:var(--teal)}
.schedule-card.express .schedule-class-name{color:var(--violet)}
.schedule-card.compete .schedule-class-name{color:var(--gold)}
.schedule-meta{display:flex;gap:16px;flex-wrap:wrap}
.schedule-meta-item{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.schedule-actions{flex-shrink:0;display:flex;align-items:center;gap:12px}
.book-btn{padding:10px 24px;font-family:var(--font-body);font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all .25s;background:transparent;border:1px solid rgba(212,168,67,.4);color:var(--gold)}
.book-btn:hover{background:var(--gold);color:var(--black)}
.book-btn.booked{background:rgba(0,201,167,.1);border-color:var(--teal);color:var(--teal);cursor:default}
.book-btn.booked:hover{background:rgba(0,201,167,.1);color:var(--teal)}
.book-btn.locked{opacity:.5;cursor:pointer;border-color:rgba(255,255,255,.15);color:var(--muted)}
.book-btn.locked:hover{background:rgba(255,255,255,.05);color:var(--white)}
.no-classes{padding:80px 0;text-align:center;color:var(--muted);font-family:var(--font-accent);font-size:20px;font-style:italic}

/* ═══════════════ PLAYER PAGE ═══════════════ */
.player-hero{padding:160px 48px 60px}
.player-hero .section-label{margin-bottom:16px}
.player-title{font-family:var(--font-display);font-size:clamp(60px,10vw,130px);line-height:.9;margin-bottom:20px}
.player-title span{color:var(--gold)}
.player-sub{font-family:var(--font-accent);font-size:18px;font-style:italic;color:var(--muted);max-width:560px;line-height:1.6}
.oscilloscope-wrap{padding:0 48px;margin-bottom:48px}
.oscilloscope-container{position:relative;width:100%;background:rgba(0,0,0,.4);border:1px solid rgba(212,168,67,.1);border-radius:2px;overflow:hidden}
#oscilloscope-canvas{width:100%;height:180px;display:block}
.oscilloscope-info{position:absolute;top:16px;left:24px;z-index:2}
.current-hz{font-family:var(--font-display);font-size:48px;color:var(--gold);line-height:1}
.current-name{font-family:var(--font-accent);font-size:14px;font-style:italic;color:var(--muted);margin-top:2px}
.oscilloscope-idle{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:13px;letter-spacing:.12em;text-transform:uppercase}
.freq-selector-section{padding:0 48px;margin-bottom:48px}
.freq-selector-grid{display:grid;grid-template-columns:repeat(9,1fr);gap:2px}
.freq-btn{padding:28px 8px;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);cursor:pointer;text-align:center;transition:all .25s;color:var(--white);font-family:var(--font-body);position:relative;overflow:hidden}
.freq-btn::after{content:'';position:absolute;inset:0;opacity:0;transition:opacity .25s;background:rgba(212,168,67,.06)}
.freq-btn:hover::after{opacity:1}
.freq-btn.active{border-color:rgba(212,168,67,.5);background:rgba(212,168,67,.08)}
.freq-btn .freq-btn-hz{font-family:var(--font-display);font-size:26px;color:var(--gold);display:block;line-height:1;margin-bottom:4px}
.freq-btn .freq-btn-name{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:4px}
.freq-btn .freq-btn-stage{font-family:var(--font-accent);font-size:11px;font-style:italic;color:rgba(255,255,255,.3);display:block}
.player-controls-section{padding:0 48px 48px}
.player-controls{background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);padding:32px;display:flex;flex-wrap:wrap;gap:24px;align-items:flex-start}
.control-group{display:flex;flex-direction:column;gap:10px}
.control-label{font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted)}
.player-btn-row{display:flex;gap:10px}
.player-btn{padding:12px 28px;font-family:var(--font-body);font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all .25s;border:none;background:transparent}
.player-btn.play{background:var(--gold);color:var(--black)}
.player-btn.play:hover{background:var(--gold-bright)}
.player-btn.stop{border:1px solid rgba(255,255,255,.2);color:var(--muted)}
.player-btn.stop:hover{border-color:var(--white);color:var(--white)}
.player-btn.stop:disabled{opacity:.3;cursor:not-allowed}
.volume-row{display:flex;align-items:center;gap:12px}
input[type=range]{-webkit-appearance:none;appearance:none;height:2px;background:rgba(255,255,255,.15);outline:none;cursor:pointer;width:160px}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;background:var(--gold);border-radius:50%;cursor:pointer}
input[type=range]::-moz-range-thumb{width:14px;height:14px;background:var(--gold);border-radius:50%;cursor:pointer;border:none}
.timer-row{display:flex;gap:8px;flex-wrap:wrap}
.timer-btn{padding:8px 16px;font-family:var(--font-body);font-size:11px;letter-spacing:.08em;text-transform:uppercase;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.1);color:var(--muted);cursor:pointer;transition:all .2s}
.timer-btn:hover{border-color:var(--gold);color:var(--gold)}
.timer-btn.active{background:rgba(212,168,67,.1);border-color:var(--gold);color:var(--gold)}
.timer-display{font-family:var(--font-display);font-size:32px;color:var(--white);letter-spacing:.04em}
.binaural-row{display:flex;align-items:center;gap:12px}
.toggle-switch{position:relative;width:44px;height:24px;cursor:pointer}
.toggle-switch input{opacity:0;width:0;height:0;position:absolute}
.toggle-track{display:block;width:44px;height:24px;background:rgba(255,255,255,.1);border-radius:12px;transition:background .25s;border:1px solid rgba(255,255,255,.1)}
.toggle-switch input:checked + .toggle-track{background:rgba(212,168,67,.3);border-color:var(--gold)}
.toggle-thumb{position:absolute;top:3px;left:3px;width:16px;height:16px;background:var(--muted);border-radius:50%;transition:all .25s}
.toggle-switch input:checked ~ .toggle-thumb{left:23px;background:var(--gold)}
.binaural-label{font-size:13px;color:var(--muted)}
.binaural-info{font-size:11px;color:rgba(255,255,255,.25);margin-top:3px;line-height:1.4;max-width:260px}
.freq-method-map{padding:0 48px 120px}
.freq-method-map h3{font-family:var(--font-display);font-size:32px;letter-spacing:.04em;margin-bottom:32px}
.freq-map-grid{display:grid;grid-template-columns:repeat(9,1fr);gap:0}
.freq-map-item{padding:24px 12px;text-align:center;border-right:1px solid rgba(255,255,255,.05);cursor:pointer;transition:all .25s}
.freq-map-item:last-child{border-right:none}
.freq-map-item:hover{background:rgba(212,168,67,.03)}
.freq-map-hz{font-family:var(--font-display);font-size:22px;color:var(--gold);margin-bottom:4px}
.freq-map-stage{font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.freq-map-desc{font-size:11px;line-height:1.45;color:rgba(255,255,255,.3)}

/* ═══════════════ AUTH MODULE ═══════════════ */
.page-login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:80px 24px}
.auth-card{width:100%;max-width:480px;background:var(--deep);border:1px solid rgba(212,168,67,.2)}
.auth-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.08)}
.auth-tab-btn{flex:1;padding:16px;font-family:var(--font-body);font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;background:none;border:none;color:var(--muted);cursor:pointer;transition:all .25s;border-bottom:2px solid transparent;margin-bottom:-1px}
.auth-tab-btn.active{color:var(--gold);border-bottom-color:var(--gold)}
.auth-tab-btn:hover:not(.active){color:var(--white)}
.auth-form{padding:40px}
.auth-logo{font-family:var(--font-display);font-size:40px;text-align:center;margin-bottom:6px}
.auth-logo span{color:var(--gold)}
.auth-tagline{font-family:var(--font-accent);font-size:14px;font-style:italic;color:var(--muted);text-align:center;margin-bottom:32px;display:block}
.auth-section{display:none}
.auth-section.active{display:block}
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.form-input{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);color:var(--white);padding:14px 16px;font-family:var(--font-body);font-size:14px;outline:none;transition:border .2s;box-sizing:border-box}
.form-input:focus{border-color:rgba(212,168,67,.5)}
.form-input.error{border-color:rgba(220,50,50,.6)}
select.form-input{cursor:pointer;color:var(--muted)}
select.form-input.has-value{color:var(--white)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-submit{width:100%;margin-top:8px}
.form-error{font-size:12px;color:rgba(220,50,50,.8);margin-bottom:12px;min-height:18px}
.form-footer{text-align:center;margin-top:20px;font-size:12px;color:var(--muted)}
.form-footer a{color:var(--gold);cursor:pointer;text-decoration:none}
.form-footer a:hover{text-decoration:underline}
.tier-options{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:4px}
.tier-option{padding:12px;border:1px solid rgba(255,255,255,.1);cursor:pointer;transition:all .2s;text-align:center}
.tier-option input{display:none}
.tier-option-name{font-family:var(--font-display);font-size:18px;letter-spacing:.04em;display:block;margin-bottom:2px}
.tier-option-price{font-size:11px;color:var(--muted)}
.tier-option:has(input:checked){border-color:var(--gold);background:rgba(212,168,67,.08)}
.tier-option:has(input:checked) .tier-option-name{color:var(--gold)}

/* ═══════════════ DASHBOARD PAGE ═══════════════ */
.dashboard-hero{padding:160px 48px 60px}
.dashboard-hero h1{font-family:var(--font-display);font-size:clamp(48px,7vw,100px);line-height:.9;margin-bottom:8px}
.dashboard-hero h1 span{color:var(--gold)}
.tier-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 16px;border:1px solid;font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:600}
.tier-badge.heal{border-color:var(--teal);color:var(--teal);background:rgba(0,201,167,.08)}
.tier-badge.express{border-color:var(--violet);color:var(--violet);background:rgba(168,85,247,.08)}
.tier-badge.full{border-color:var(--gold);color:var(--gold);background:rgba(212,168,67,.08)}
.tier-badge.compete{border-color:var(--gold-bright);color:var(--gold-bright);background:rgba(255,208,96,.08)}
.dashboard-content{padding:0 48px 120px}
.dashboard-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-bottom:60px}
.stat-card{padding:32px;background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.06)}
.stat-value{font-family:var(--font-display);font-size:52px;color:var(--gold);line-height:1;margin-bottom:6px}
.stat-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.dashboard-section{margin-bottom:48px}
.dashboard-section-title{font-family:var(--font-display);font-size:28px;letter-spacing:.04em;margin-bottom:24px;color:var(--white)}
.booking-list{display:flex;flex-direction:column;gap:8px}
.booking-item{display:flex;align-items:center;gap:16px;padding:16px 24px;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);transition:all .25s}
.booking-item:hover{border-color:rgba(255,255,255,.1)}
.booking-item-time{font-family:var(--font-display);font-size:20px;min-width:70px;color:var(--white)}
.booking-item-info{flex:1}
.booking-item-name{font-family:var(--font-display);font-size:18px;letter-spacing:.03em;margin-bottom:2px}
.booking-item-day{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.booking-cancel-btn{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);background:none;border:none;cursor:pointer;padding:6px 10px;transition:color .2s}
.booking-cancel-btn:hover{color:rgba(220,80,80,.8)}
.no-bookings{padding:40px;text-align:center;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);color:var(--muted);font-family:var(--font-accent);font-size:18px;font-style:italic}
.settings-row{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);margin-bottom:8px}
.settings-row-info{}
.settings-row-label{font-size:14px;color:var(--white);margin-bottom:4px}
.settings-row-desc{font-size:12px;color:var(--muted);line-height:1.4}
.logout-btn{background:transparent;border:1px solid rgba(255,255,255,.15);color:var(--muted);padding:10px 24px;font-family:var(--font-body);font-size:12px;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all .25s;margin-top:16px}
.logout-btn:hover{border-color:rgba(220,80,80,.5);color:rgba(220,80,80,.8)}

/* ═══════════════ NOTIFICATION BANNER ═══════════════ */
.notif-prompt{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--deep);border:1px solid rgba(212,168,67,.3);padding:16px 24px;display:flex;align-items:center;gap:16px;z-index:300;max-width:500px;width:calc(100% - 48px);box-shadow:0 8px 40px rgba(0,0,0,.4)}
.notif-prompt-text{flex:1;font-size:13px;color:rgba(255,255,255,.7);line-height:1.4}
.notif-prompt-text strong{color:var(--white);display:block;margin-bottom:2px}
.notif-prompt-actions{display:flex;gap:8px;flex-shrink:0}
.notif-allow-btn{padding:8px 16px;background:var(--gold);color:var(--black);border:none;font-family:var(--font-body);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:background .2s}
.notif-allow-btn:hover{background:var(--gold-bright)}
.notif-dismiss-btn{padding:8px 12px;background:none;border:1px solid rgba(255,255,255,.15);color:var(--muted);font-family:var(--font-body);font-size:11px;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:all .2s}
.notif-dismiss-btn:hover{border-color:var(--white);color:var(--white)}

/* ═══════════════ INSTALL BANNER ═══════════════ */
.install-banner{position:fixed;bottom:24px;right:24px;background:var(--deep);border:1px solid rgba(212,168,67,.25);padding:16px 20px;z-index:300;max-width:300px;box-shadow:0 8px 40px rgba(0,0,0,.4)}
.install-banner-title{font-family:var(--font-display);font-size:18px;color:var(--white);margin-bottom:4px}
.install-banner-desc{font-size:12px;color:var(--muted);margin-bottom:14px;line-height:1.4}
.install-banner-actions{display:flex;gap:8px}
.install-btn{padding:8px 16px;background:var(--gold);color:var(--black);border:none;font-family:var(--font-body);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;flex:1}
.install-dismiss{padding:8px;background:none;border:none;color:var(--muted);cursor:pointer;font-size:18px;line-height:1}
.install-banner.hidden{display:none}

/* ═══════════════ PWA / SAFE AREA ═══════════════ */
@supports (padding-top: env(safe-area-inset-top)) {
  nav { padding-top: max(20px, env(safe-area-inset-top)); }
  body { padding-bottom: env(safe-area-inset-bottom); }
}
@media (display-mode: standalone) {
  nav { padding-top: max(24px, env(safe-area-inset-top)); }
  .install-banner { display: none !important; }
}
@media (display-mode: window-controls-overlay) {
  nav {
    padding-top: max(20px, env(titlebar-area-height, 40px));
    padding-left: max(48px, env(titlebar-area-x, 48px));
  }
}

/* Touch optimizations for all mobile OS */
button, a, [onclick] {
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

/* Accessibility: hide custom cursor and restore native cursor on touch/pointer:coarse devices */
@media (pointer: coarse) {
  body { cursor: auto; }
  .cursor, .cursor-ring { display: none; }
}
/* Restore native cursor when user prefers reduced motion (likely a11y user) */
@media (prefers-reduced-motion: reduce) {
  body { cursor: auto; }
  .cursor, .cursor-ring { display: none; }
}

/* Accessibility: keyboard focus indicators */
:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
}
button:focus-visible, a:focus-visible, input:focus-visible,
select:focus-visible, textarea:focus-visible, [tabindex]:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
  border-radius: 2px;
}

/* Nav links: add href-equivalent semantics via tabindex */
.nav-links a, .mobile-menu a { cursor: pointer; }


/* ── Hamburger always tappable ───────────────────── */
#hamburger{position:relative;z-index:800}



/* ════════════════════════════════════════════════════════════
   PERFORMANCES PAGE — original style
   ════════════════════════════════════════════════════════════ */
.perf-hero {
  padding: 120px 48px 80px;
  text-align: center;
  background: var(--black);
}
.perf-hero-eyebrow {
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}
.perf-hero-title {
  font-family: var(--font-display);
  font-size: clamp(56px, 12vw, 112px);
  line-height: .85;
  letter-spacing: .04em;
  color: var(--white);
  margin-bottom: 20px;
}
.perf-hero-title span { color: var(--gold); }
.perf-hero-sub {
  font-family: var(--font-accent);
  font-size: 18px;
  font-style: italic;
  color: var(--muted);
  max-width: 560px;
  margin: 0 auto 48px;
  line-height: 1.7;
}
.perf-hero-events {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}
.perf-event-pill {
  padding: 16px 32px;
  cursor: pointer;
  transition: transform .2s;
  text-align: center;
  min-width: 200px;
}
.perf-event-pill:hover { transform: translateY(-3px); }
.perf-event-pill.heal {
  border: 1px solid rgba(0,201,167,.3);
  background: rgba(0,201,167,.05);
}
.perf-event-pill.compete {
  border: 1px solid rgba(212,168,67,.3);
  background: rgba(212,168,67,.05);
}
.perf-pill-name {
  display: block;
  font-family: var(--font-display);
  font-size: 28px;
  letter-spacing: .1em;
  color: var(--white);
  margin-bottom: 6px;
}
.perf-pill-desc {
  display: block;
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted);
}
.perf-show {
  padding: 100px 48px;
  background: var(--deep);
  border-top: 1px solid rgba(255,255,255,.05);
}
.perf-show-dark { background: var(--black); }
.perf-show-inner {
  max-width: 1080px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 80px 1fr 280px;
  gap: 48px;
  align-items: start;
}
.perf-show-label { text-align: right; padding-top: 8px; }
.perf-show-season {
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 6px;
}
.perf-show-num {
  font-family: var(--font-display);
  font-size: 40px;
  color: rgba(255,255,255,.08);
  line-height: 1;
}
.perf-show-title {
  font-family: var(--font-display);
  font-size: clamp(56px, 10vw, 96px);
  line-height: .85;
  letter-spacing: .06em;
  color: var(--white);
  margin-bottom: 16px;
}
.perf-show-quote {
  font-family: var(--font-accent);
  font-size: 17px;
  font-style: italic;
  color: var(--muted);
  margin-bottom: 20px;
  line-height: 1.6;
}
.perf-show-desc {
  font-size: 15px;
  color: var(--muted);
  line-height: 1.8;
  margin-bottom: 32px;
  max-width: 520px;
}
.perf-details-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 32px;
}
.perf-detail {
  border-left: 2px solid rgba(255,255,255,.06);
  padding-left: 14px;
}
.perf-detail-label {
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 4px;
  opacity: .6;
}
.perf-detail-value { font-size: 13px; color: var(--white); line-height: 1.5; }
.perf-show-content {}
.perf-show-cta { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; }
.perf-cta-note { font-size: 12px; color: var(--muted); font-style: italic; }
.perf-show-visual {
  padding: 32px 24px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 280px;
  position: sticky;
  top: 80px;
}
.embody-visual {
  border: 1px solid rgba(0,201,167,.2);
  background: rgba(0,201,167,.03);
}
.frequency-visual {
  border: 1px solid rgba(212,168,67,.2);
  background: rgba(212,168,67,.03);
}
.perf-visual-hz {
  font-family: var(--font-display);
  font-size: 48px;
  letter-spacing: .06em;
  color: var(--gold);
  line-height: 1;
}
.perf-visual-label {
  font-family: var(--font-display);
  font-size: 18px;
  letter-spacing: .16em;
  color: var(--white);
}
.perf-visual-sub {
  font-family: var(--font-accent);
  font-size: 13px;
  font-style: italic;
  color: var(--muted);
}
.perf-visual-pillars {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
  font-family: var(--font-display);
  font-size: 12px;
  letter-spacing: .1em;
}
.perf-divider { color: rgba(255,255,255,.2); font-size: 8px; }
.perf-calendar {
  padding: 80px 48px;
  background: var(--deep);
  text-align: center;
  border-top: 1px solid rgba(255,255,255,.05);
}
.perf-calendar-title {
  font-family: var(--font-display);
  font-size: clamp(36px, 7vw, 64px);
  letter-spacing: .06em;
  color: var(--white);
  margin-bottom: 48px;
  line-height: .9;
}
.perf-timeline {
  display: grid;
  grid-template-columns: repeat(11, 1fr);
  gap: 4px;
  max-width: 1080px;
  margin: 0 auto;
  align-items: end;
}
.perf-timeline-item { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.perf-tl-month {
  font-size: 9px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--muted);
  opacity: .5;
  white-space: nowrap;
}
.perf-tl-bar { width: 100%; border-radius: 2px; min-height: 8px; }
.perf-tl-bar.spring    { height: 48px; background: rgba(0,201,167,.2); }
.perf-tl-bar.fall      { height: 48px; background: rgba(168,85,247,.2); }
.perf-tl-bar.rehearsal { height: 32px; background: rgba(255,255,255,.1); }
.perf-tl-bar.intensive { height: 32px; background: rgba(212,168,67,.2); }
.perf-tl-bar.embody    { height: 64px; background: var(--teal); }
.perf-tl-bar.frequency { height: 64px; background: var(--gold); }
.perf-tl-bar.break     { height: 20px; background: rgba(255,255,255,.04); }
.perf-tl-label { font-size: 10px; letter-spacing: .06em; color: var(--white); text-align: center; line-height: 1.3; }
.perf-tl-sub   { font-size: 9px; color: var(--muted); text-align: center; opacity: .5; }
.perf-tickets-cta {
  padding: 80px 48px;
  background: var(--black);
  border-top: 1px solid rgba(255,255,255,.05);
}
.perf-tickets-inner {
  max-width: 1080px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
  margin-bottom: 40px;
}
.perf-tickets-title {
  font-family: var(--font-display);
  font-size: clamp(40px, 7vw, 72px);
  line-height: .85;
  letter-spacing: .06em;
  color: var(--white);
  margin-bottom: 16px;
}
.perf-tickets-sub {
  font-family: var(--font-accent);
  font-size: 16px;
  font-style: italic;
  color: var(--muted);
  line-height: 1.7;
}
.perf-ticket-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.perf-ticket-card { padding: 24px 20px; border: 1px solid rgba(255,255,255,.08); }
.embody-ticket   { border-top: 3px solid var(--teal); }
.frequency-ticket { border-top: 3px solid var(--gold); }
.perf-ticket-show {
  font-family: var(--font-display);
  font-size: 20px;
  letter-spacing: .1em;
  color: var(--teal);
  margin-bottom: 16px;
}
.perf-ticket-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 0;
  border-bottom: 1px solid rgba(255,255,255,.05);
  font-size: 13px;
  color: var(--muted);
}
.perf-ticket-row:last-child { border-bottom: none; }
.perf-ticket-row.featured-row { color: var(--white); }
.perf-ticket-price { font-family: var(--font-display); font-size: 18px; color: var(--white); }
.perf-tickets-note { text-align: center; font-size: 12px; color: var(--muted); font-style: italic; max-width: 600px; margin: 0 auto; }
@media (max-width: 900px) {
  .perf-show-inner { grid-template-columns: 1fr; }
  .perf-show-label { display: none; }
  .perf-show-visual { position: static; min-height: auto; margin-top: 32px; }
  .perf-timeline { grid-template-columns: repeat(6, 1fr); overflow-x: auto; }
  .perf-tickets-inner { grid-template-columns: 1fr; gap: 32px; }
}
@media (max-width: 600px) {
  .perf-hero { padding: 80px 24px 60px; }
  .perf-show { padding: 60px 24px; }
  .perf-calendar { padding: 60px 24px; }
  .perf-tickets-cta { padding: 60px 24px; }
  .perf-details-grid { grid-template-columns: 1fr; }
  .perf-ticket-grid { grid-template-columns: 1fr; }
  .perf-hero-events { flex-direction: column; align-items: center; }
}

/* ════════════════════════════════════════════════════════════
   MASTERS APPLY PAGE — original style
   ════════════════════════════════════════════════════════════ */
.ma-hero {
  padding: 120px 48px 80px;
  background: var(--black);
  border-bottom: 1px solid rgba(212,168,67,.1);
}
.ma-hero-inner { max-width: 680px; margin: 0 auto; }
.ma-hero-title {
  font-family: var(--font-display);
  font-size: clamp(64px, 14vw, 120px);
  line-height: .82;
  letter-spacing: .04em;
  color: var(--white);
  margin-bottom: 20px;
}
.ma-hero-title span { color: var(--gold); }
.ma-hero-sub {
  font-family: var(--font-accent);
  font-size: 18px;
  font-style: italic;
  color: var(--muted);
  line-height: 1.7;
  margin-bottom: 32px;
  max-width: 520px;
}
.ma-hero-reqs { display: flex; flex-direction: column; gap: 10px; }
.ma-req { display: flex; align-items: center; gap: 10px; font-size: 14px; color: var(--muted); }
.ma-req-icon { color: var(--gold); font-size: 8px; flex-shrink: 0; }
.ma-process-section {
  padding: 80px 48px;
  background: var(--deep);
}
.ma-process {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 0;
  margin-top: 48px;
  position: relative;
}
.ma-step {
  padding: 32px 24px;
  border: 1px solid rgba(255,255,255,.06);
  background: rgba(255,255,255,.02);
  position: relative;
}
.ma-step-num {
  font-family: var(--font-display);
  font-size: 52px;
  line-height: 1;
  color: var(--gold);
  opacity: .2;
  margin-bottom: 12px;
}
.ma-step-label {
  font-family: var(--font-display);
  font-size: 20px;
  letter-spacing: .08em;
  color: var(--white);
  margin-bottom: 8px;
}
.ma-step-desc { font-size: 13px; color: var(--muted); line-height: 1.6; }
.ma-step-arrow {
  position: absolute;
  right: -12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--gold);
  opacity: .3;
  font-size: 16px;
  z-index: 1;
}
.mb-section { padding: 80px 48px; }
.mb-inner { max-width: 1100px; margin: 0 auto; }
.mb-header { margin-bottom: 48px; }
.mb-title {
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.mb-title::before {
  content: '';
  display: inline-block;
  width: 28px;
  height: 1px;
  background: var(--gold);
  opacity: .6;
}
.mb-sub {
  font-family: var(--font-accent);
  font-style: italic;
  font-size: 17px;
  color: var(--muted);
  margin-bottom: 48px;
  max-width: 560px;
}
.mb-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(260px,1fr)); gap: 2px; }
.mb-card {
  background: rgba(255,255,255,.025);
  border: 1px solid rgba(255,255,255,.06);
  padding: 28px 24px;
  transition: border-color .2s;
}
.mb-card:hover { border-color: rgba(212,168,67,.2); }
.mb-card-icon { font-size: 22px; margin-bottom: 12px; opacity: .7; }
.mb-card-title {
  font-family: var(--font-display);
  font-size: 20px;
  letter-spacing: .07em;
  color: var(--white);
  margin-bottom: 8px;
}
.mb-card-desc { font-size: 13px; color: var(--muted); line-height: 1.6; margin-bottom: 12px; }
.mb-card-rates { display: flex; flex-direction: column; gap: 4px; }
.mb-rate {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  color: var(--muted);
  padding: 4px 0;
  border-top: 1px solid rgba(255,255,255,.04);
}
.mb-rate-val { color: var(--gold); font-weight: 600; }
.mb-offset-callout {
  background: rgba(212,168,67,.06);
  border: 1px solid rgba(212,168,67,.2);
  padding: 28px 32px;
  margin-top: 32px;
  display: flex;
  gap: 20px;
  align-items: flex-start;
}
.mb-offset-icon { font-size: 24px; margin-top: 2px; }
.mb-offset-text { flex: 1; }
.mb-offset-title {
  font-family: var(--font-display);
  font-size: 20px;
  letter-spacing: .07em;
  color: var(--gold);
  margin-bottom: 6px;
}
.mb-offset-desc { font-size: 13px; color: var(--muted); line-height: 1.6; }
.ma-distinction { padding: 80px 48px; background: rgba(14,5,32,.5); }
.ma-distinction-inner {
  max-width: 900px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 32px;
  align-items: start;
  margin-top: 48px;
}
.ma-distinction-card { padding: 32px; border: 1px solid rgba(255,255,255,.08); background: rgba(255,255,255,.02); }
.ma-distinction-card--masters { border-color: rgba(212,168,67,.2); }
.ma-distinction-card--instructor { border-color: rgba(168,85,247,.2); }
.ma-dist-role { font-family: var(--font-display); font-size: 22px; letter-spacing: .1em; margin-bottom: 8px; }
.ma-distinction-card--masters .ma-dist-role { color: var(--gold); }
.ma-distinction-card--instructor .ma-dist-role { color: var(--violet); }
.ma-dist-label { font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--muted); margin-bottom: 20px; opacity: .6; }
.ma-dist-fee { font-size: 13px; color: var(--gold); letter-spacing: .06em; margin-bottom: 16px; }
.ma-dist-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.ma-dist-list li { font-size: 13px; color: var(--muted); padding-left: 16px; position: relative; line-height: 1.5; }
.ma-dist-list li::before { content: '→'; position: absolute; left: 0; color: var(--gold); opacity: .5; }
.ma-distinction-vs { display: flex; flex-direction: column; align-items: center; justify-content: center; padding-top: 40px; }
.ma-distinction-vs span { font-family: var(--font-display); font-size: 24px; letter-spacing: .12em; color: var(--muted); opacity: .3; }
.ma-distinction-note { font-size: 12px; color: var(--muted); opacity: .5; text-align: center; margin-top: 32px; font-style: italic; max-width: 700px; margin-left: auto; margin-right: auto; }
.ma-form-section { padding: 80px 48px 100px; background: var(--deep); }
.ma-form-wrap { max-width: 680px; margin: 0 auto; }
.ma-form-section-label {
  font-family: var(--font-display);
  font-size: 13px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold);
  padding: 28px 0 16px;
  margin-top: 12px;
  border-top: 1px solid rgba(255,255,255,.06);
}
.ma-form-section-label:first-of-type { border-top: none; padding-top: 0; margin-top: 0; }
.ma-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.ma-materials-note { font-size: 13px; color: var(--muted); line-height: 1.7; margin-bottom: 20px; font-style: italic; }
.ma-materials-note strong { color: var(--white); font-style: normal; }
.ma-success-icon { font-size: 52px; color: var(--gold); margin-bottom: 16px; }
.ma-success-title { font-family: var(--font-display); font-size: 36px; letter-spacing: .1em; color: var(--white); margin-bottom: 12px; }
.ma-success-sub { font-family: var(--font-accent); font-size: 16px; font-style: italic; color: var(--muted); line-height: 1.7; max-width: 440px; margin: 0 auto; }
@media (max-width: 768px) {
  .ma-hero { padding: 80px 24px 60px; }
  .ma-process { grid-template-columns: 1fr 1fr; }
  .ma-distinction-inner { grid-template-columns: 1fr; }
  .ma-distinction-vs { display: none; }
  .ma-row-2 { grid-template-columns: 1fr; }
  .mb-grid { grid-template-columns: 1fr; }
  .ma-form-section, .mb-section, .ma-distinction { padding: 60px 24px; }
}

/* ════════════════════════════════════════════════════════════
   AUTHORIZATION PAGE — original style
   ════════════════════════════════════════════════════════════ */
.cert-hero {
  padding: 120px 48px 80px;
  background: var(--black);
  border-bottom: 1px solid rgba(168,85,247,.1);
  text-align: center;
}
.cert-hero-inner { max-width: 800px; margin: 0 auto; }
.cert-hero-title {
  font-family: var(--font-display);
  font-size: clamp(56px, 12vw, 112px);
  line-height: .85;
  letter-spacing: .04em;
  color: var(--white);
  margin-bottom: 20px;
}
.cert-hero-title span { color: var(--violet); }
.cert-hero-sub {
  font-family: var(--font-accent);
  font-size: 18px;
  font-style: italic;
  color: var(--muted);
  max-width: 560px;
  margin: 0 auto 32px;
  line-height: 1.7;
}
.cert-hero-tags { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; margin-top: 28px; }
.cert-tag, .cert-pill {
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 5px 14px;
  border: 1px solid rgba(168,85,247,.3);
  color: var(--violet);
}
.cert-tracks { padding: 80px 48px; background: var(--deep); }
.cert-tracks-inner { max-width: 1100px; margin: 0 auto; }
.cert-tracks-title {
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.cert-tracks-title::before { content: ''; display: inline-block; width: 28px; height: 1px; background: var(--gold); opacity: .6; }
.cert-tracks-sub {
  font-family: var(--font-accent);
  font-style: italic;
  font-size: 17px;
  color: var(--muted);
  max-width: 560px;
  margin-bottom: 48px;
}
.cert-track-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; margin-top: 48px; }
.cert-track {
  background: rgba(255,255,255,.025);
  border: 1px solid rgba(255,255,255,.06);
  padding: 32px 28px;
  position: relative;
  transition: border-color .2s;
}
.cert-track:hover { border-color: rgba(168,85,247,.25); }
.cert-track-num { font-family: var(--font-display); font-size: 48px; line-height: 1; color: var(--violet); opacity: .2; margin-bottom: 8px; }
.cert-track-hz { font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: var(--gold); opacity: .6; margin-bottom: 8px; }
.cert-track-name { font-family: var(--font-display); font-size: 28px; letter-spacing: .08em; color: var(--white); margin-bottom: 12px; }
.cert-track-desc { font-size: 13px; color: var(--muted); line-height: 1.6; margin-bottom: 20px; }
.cert-track-covers { display: flex; flex-direction: column; gap: 6px; }
.cert-cover-item { font-size: 12px; color: var(--muted); padding-left: 16px; position: relative; }
.cert-cover-item::before { content: '→'; position: absolute; left: 0; color: var(--violet); opacity: .5; }
.cert-pricing { padding: 80px 48px; }
.cert-pricing-inner { max-width: 1100px; margin: 0 auto; }
.cert-pricing-title {
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.cert-pricing-title::before { content: ''; display: inline-block; width: 28px; height: 1px; background: var(--gold); opacity: .6; }
.cert-pricing-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(220px,1fr)); gap: 2px; margin-top: 48px; }
.cert-price-card {
  background: rgba(255,255,255,.025);
  border: 1px solid rgba(255,255,255,.06);
  padding: 28px 24px;
  transition: border-color .2s;
}
.cert-price-card--bundle { border-color: rgba(212,168,67,.25); background: rgba(212,168,67,.04); }
.cert-price-card:hover { border-color: rgba(255,255,255,.14); }
.cert-price-track { font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--gold); opacity: .7; margin-bottom: 8px; }
.cert-price-amt { font-family: var(--font-display); font-size: 44px; line-height: 1; letter-spacing: .02em; color: var(--white); }
.cert-price-label { font-size: 11px; color: var(--muted); letter-spacing: .08em; margin-top: 4px; opacity: .6; }
.cert-pill-name { font-family: var(--font-display); font-size: 16px; letter-spacing: .07em; color: var(--violet); margin: 12px 0 4px; }
.cert-pill-label { font-size: 11px; color: var(--muted); letter-spacing: .06em; }
.cert-pathway { padding: 0 48px 80px; }
.cert-pathway-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; max-width: 900px; }
.cert-pathway-header { padding: 24px; background: rgba(168,85,247,.08); border: 1px solid rgba(168,85,247,.2); margin-bottom: 2px; }
.cert-pathway-title { font-family: var(--font-display); font-size: 20px; letter-spacing: .1em; color: var(--violet); margin-bottom: 4px; }
.cert-pathway-desc { font-size: 12px; color: var(--muted); letter-spacing: .06em; }
.cert-pathway-badge { display: inline-block; font-size: 9px; letter-spacing: .14em; text-transform: uppercase; padding: 3px 10px; border: 1px solid rgba(168,85,247,.3); color: var(--violet); margin-bottom: 8px; }
.cert-pathway-pills { display: flex; flex-direction: column; gap: 4px; padding: 16px; }
.cert-pay-banner {
  background: linear-gradient(90deg, rgba(168,85,247,.08) 0%, rgba(212,168,67,.08) 100%);
  border: 1px solid rgba(168,85,247,.2);
  padding: 28px 32px;
  margin: 0 48px 80px;
  display: flex;
  align-items: center;
  overflow: hidden;
  position: relative;
}
.cert-pay-item { flex: 1; text-align: center; padding: 0 16px; position: relative; }
.cert-pay-item + .cert-pay-item::before { content: '→'; position: absolute; left: -8px; top: 50%; transform: translateY(-50%); color: var(--gold); opacity: .4; }
.cert-pay-tag { font-size: 9px; letter-spacing: .18em; text-transform: uppercase; color: var(--muted); opacity: .6; margin-bottom: 4px; }
.cert-pay-rate { font-family: var(--font-display); font-size: 28px; letter-spacing: .04em; color: var(--gold); line-height: 1; }
.cert-pay-item--auth .cert-pay-rate { color: var(--violet); }
.cert-pay-label { font-size: 10px; color: var(--muted); margin-top: 4px; opacity: .6; letter-spacing: .06em; }
.cert-pay-arrow { font-size: 18px; color: var(--gold); opacity: .3; margin: 0 8px; }
.cert-outcomes { padding: 80px 48px; background: var(--deep); }
.cert-outcomes-inner { max-width: 1100px; margin: 0 auto; }
.cert-outcomes-title {
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.cert-outcomes-title::before { content: ''; display: inline-block; width: 28px; height: 1px; background: var(--gold); opacity: .6; }
.cert-outcomes-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(240px,1fr)); gap: 2px; margin-top: 48px; }
.cert-outcome { background: rgba(255,255,255,.025); border: 1px solid rgba(255,255,255,.06); padding: 28px 24px; transition: border-color .2s; }
.cert-outcome:hover { border-color: rgba(168,85,247,.2); }
.cert-outcome-icon { font-size: 24px; margin-bottom: 12px; opacity: .7; }
.cert-outcome-title { font-family: var(--font-display); font-size: 18px; letter-spacing: .08em; color: var(--white); margin-bottom: 8px; }
.cert-outcome-desc { font-size: 13px; color: var(--muted); line-height: 1.6; }
.cert-teach-section { padding: 80px 48px; }
.cert-teach-wrap { max-width: 800px; border: 1px solid rgba(168,85,247,.2); background: rgba(168,85,247,.04); overflow: hidden; }
.cert-teach-inner { padding: 40px; }
.cert-teach-icon { font-size: 32px; margin-bottom: 16px; }
.cert-teach-title { font-family: var(--font-display); font-size: clamp(28px,4vw,48px); letter-spacing: .06em; color: var(--violet); margin-bottom: 12px; }
.cert-teach-desc { font-size: 15px; color: var(--muted); line-height: 1.7; max-width: 600px; }
.cert-teach-conditions { margin-top: 24px; display: flex; flex-direction: column; gap: 10px; }
.cert-cond { font-size: 13px; color: var(--muted); padding-left: 20px; position: relative; line-height: 1.5; }
.cert-cond::before { content: '✓'; position: absolute; left: 0; color: var(--violet); font-size: 11px; }
.cert-teach-content { padding: 0 40px 40px; }
.cert-dist-section { padding: 80px 48px; background: rgba(14,5,32,.5); }
.cert-distinction-banner { border: 1px solid rgba(255,255,255,.06); overflow: hidden; max-width: 900px; margin-top: 48px; }
.cert-dist-inner { display: grid; grid-template-columns: 1fr auto 1fr; align-items: start; }
.cert-dist-card { padding: 32px; }
.cert-dist-card--instructor { border-right: 1px solid rgba(255,255,255,.06); }
.cert-dist-title {
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.cert-dist-title::before { content: ''; display: inline-block; width: 28px; height: 1px; background: var(--gold); opacity: .6; }
.cert-dist-sub { font-family: var(--font-display); font-size: 20px; letter-spacing: .1em; margin-bottom: 8px; }
.cert-dist-card--instructor .cert-dist-sub { color: var(--violet); }
.cert-dist-card--masters .cert-dist-sub { color: var(--gold); }
.cert-dist-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.cert-dist-list li { font-size: 13px; color: var(--muted); padding-left: 16px; position: relative; }
.cert-dist-list li::before { content: '→'; position: absolute; left: 0; opacity: .4; }
.cert-dist-card--instructor .cert-dist-list li::before { color: var(--violet); }
.cert-dist-card--masters .cert-dist-list li::before { color: var(--gold); }
.cert-dist-vs { padding: 32px 16px; display: flex; align-items: center; justify-content: center; }
.cert-dist-vs span { font-family: var(--font-display); font-size: 20px; letter-spacing: .1em; color: var(--muted); opacity: .25; }
.cert-dist-note { font-size: 12px; color: var(--muted); opacity: .45; text-align: center; padding: 16px 32px 24px; border-top: 1px solid rgba(255,255,255,.04); font-style: italic; }
.cert-apply-cta { padding: 80px 48px; background: var(--deep); text-align: center; }
.cert-apply-inner { max-width: 600px; margin: 0 auto; }
.cert-apply-title { font-family: var(--font-display); font-size: clamp(36px,6vw,64px); letter-spacing: .06em; color: var(--white); margin-bottom: 16px; }
.cert-apply-sub { font-family: var(--font-accent); font-style: italic; font-size: 18px; color: var(--muted); margin-bottom: 36px; }
.cert-apply-btns { display: flex; gap: 12px; justify-content: center; }
.cert-apply-note { font-size: 12px; color: var(--muted); opacity: .45; margin-top: 20px; letter-spacing: .06em; }
.btn-secondary {
  background: none;
  border: 1px solid rgba(255,255,255,.2);
  color: var(--white);
  padding: 16px 32px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: .12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all .25s;
}
.btn-secondary:hover { border-color: var(--violet); color: var(--violet); }
@media (max-width: 768px) {
  .cert-hero { padding: 80px 24px 60px; }
  .cert-track-grid { grid-template-columns: 1fr; }
  .cert-dist-inner { grid-template-columns: 1fr; }
  .cert-dist-vs { display: none; }
  .cert-pay-banner { flex-direction: column; gap: 16px; margin: 0 24px 48px; }
  .cert-pay-item + .cert-pay-item::before { display: none; }
  .cert-pathway-grid { grid-template-columns: 1fr; }
  .cert-tracks, .cert-pricing, .cert-outcomes, .cert-teach-section, .cert-dist-section, .cert-apply-cta { padding: 60px 24px; }
  .cert-pathway { padding: 0 24px 60px; }
}

/* ════════════════════════════════════════════════════════════
   MEDIA PAGE — original style
   ════════════════════════════════════════════════════════════ */
.media-hero {
  padding: 120px 48px 80px;
  background: var(--black);
  text-align: center;
}
.media-hero h1 {
  font-family: var(--font-display);
  font-size: clamp(56px, 12vw, 112px);
  line-height: .85;
  letter-spacing: .04em;
  color: var(--white);
  margin-bottom: 20px;
}
.media-hero-sub {
  font-family: var(--font-accent);
  font-style: italic;
  font-size: 18px;
  color: var(--muted);
  max-width: 560px;
  margin: 0 auto;
  line-height: 1.7;
}
.music-player-section { padding: 80px 48px; background: var(--deep); }
.music-player-header { margin-bottom: 48px; }
.music-player-title {
  font-family: var(--font-display);
  font-size: clamp(32px,5vw,56px);
  letter-spacing: .06em;
  color: var(--white);
  line-height: 1;
  margin-bottom: 8px;
}
.music-player-sub { font-family: var(--font-accent); font-style: italic; font-size: 17px; color: var(--muted); }
.music-upload-note { font-size: 12px; color: var(--muted); opacity: .5; margin-top: 48px; letter-spacing: .06em; }
.pillar-block { margin-bottom: 56px; padding-bottom: 48px; border-bottom: 1px solid rgba(255,255,255,.05); }
.pillar-block:last-child { border-bottom: none; }
.pillar-block-header { display: flex; align-items: center; gap: 12px; margin-bottom: 24px; }
.pillar-block-icon { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 14px; }
.heal-block .pillar-block-icon { background: rgba(0,201,167,.15); color: var(--teal); }
.express-block .pillar-block-icon { background: rgba(168,85,247,.15); color: var(--violet); }
.compete-block .pillar-block-icon { background: rgba(212,168,67,.15); color: var(--gold); }
.pillar-block-name { font-family: var(--font-display); font-size: 22px; letter-spacing: .1em; color: var(--white); }
.pillar-block-desc { font-size: 12px; color: var(--muted); letter-spacing: .08em; margin-top: 2px; }
.track-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(280px,1fr)); gap: 2px; }
.track-card { background: rgba(255,255,255,.02); border: 1px solid rgba(255,255,255,.06); padding: 20px 24px; transition: all .2s; cursor: pointer; position: relative; }
.track-card:hover { background: rgba(255,255,255,.05); border-color: rgba(255,255,255,.12); }
.track-name { font-family: var(--font-display); font-size: 18px; letter-spacing: .06em; color: var(--white); margin-bottom: 4px; }
.track-hz { font-size: 10px; letter-spacing: .16em; text-transform: uppercase; color: var(--gold); opacity: .7; margin-bottom: 12px; }
.track-stage-badge { display: inline-block; font-size: 9px; letter-spacing: .14em; text-transform: uppercase; padding: 3px 8px; border: 1px solid rgba(168,85,247,.3); color: var(--violet); margin-bottom: 12px; }
.track-version-toggle { display: flex; gap: 4px; margin-bottom: 12px; }
.ver-btn { font-size: 10px; letter-spacing: .1em; text-transform: uppercase; padding: 5px 12px; border: 1px solid rgba(255,255,255,.12); background: none; color: var(--muted); cursor: pointer; transition: all .2s; font-family: var(--font-body); }
.ver-btn:hover, .ver-btn.active { border-color: var(--gold); color: var(--gold); background: rgba(212,168,67,.08); }
.track-play-btn { display: flex; align-items: center; gap: 8px; background: none; border: none; cursor: pointer; padding: 0; margin-top: 4px; }
.track-play-icon { width: 32px; height: 32px; border-radius: 50%; background: var(--gold); display: flex; align-items: center; justify-content: center; color: var(--black); font-size: 11px; transition: transform .2s; }
.track-play-btn:hover .track-play-icon { transform: scale(1.1); }
.track-play-label { font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); }
.now-playing-bar { position: fixed; bottom: 0; left: 0; right: 0; z-index: 200; background: rgba(6,3,16,.95); backdrop-filter: blur(20px); border-top: 1px solid rgba(212,168,67,.2); padding: 12px 48px; display: none; }
.now-playing-bar.active { display: block; }
.npb-left { display: flex; align-items: center; gap: 16px; }
.npb-center { flex: 1; padding: 0 24px; }
.npb-right { display: flex; align-items: center; gap: 12px; }
.npb-info { display: flex; flex-direction: column; gap: 2px; }
.npb-title { font-family: var(--font-display); font-size: 16px; letter-spacing: .06em; color: var(--white); }
.npb-meta { font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--gold); opacity: .7; }
.npb-play-btn, .npb-stop-btn { width: 36px; height: 36px; border-radius: 50%; border: 1px solid rgba(255,255,255,.15); background: none; color: var(--white); cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 13px; transition: all .2s; }
.npb-play-btn:hover { border-color: var(--gold); color: var(--gold); }
.npb-stop-btn:hover { border-color: rgba(255,100,100,.5); color: rgba(255,100,100,.8); }
.npb-progress-wrap { height: 3px; background: rgba(255,255,255,.08); cursor: pointer; position: relative; border-radius: 2px; }
.npb-progress-bar { height: 100%; background: var(--gold); border-radius: 2px; width: 0%; transition: width .3s linear; }
.npb-times { display: flex; justify-content: space-between; font-size: 10px; color: var(--muted); margin-top: 4px; letter-spacing: .06em; }
.media-section { padding: 80px 48px; }
.media-section + .media-section { border-top: 1px solid rgba(255,255,255,.06); }
.media-section-label { font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: var(--gold); margin-bottom: 20px; display: flex; align-items: center; gap: 12px; }
.media-section-label::before { content: ''; display: inline-block; width: 28px; height: 1px; background: var(--gold); opacity: .6; }
.media-section-icon { font-size: 13px; opacity: .5; margin-right: 6px; }
.video-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(280px,1fr)); gap: 16px; margin-top: 32px; }
.video-card { position: relative; cursor: pointer; border: 1px solid rgba(255,255,255,.06); overflow: hidden; background: rgba(255,255,255,.02); transition: border-color .2s; }
.video-card:hover { border-color: rgba(255,255,255,.15); }
.video-thumb { aspect-ratio: 16/9; position: relative; overflow: hidden; }
.video-thumb-bg { width: 100%; height: 100%; background: var(--purple); background-image: radial-gradient(ellipse at 30% 40%, rgba(168,85,247,.2) 0%, transparent 70%); }
.video-play-btn { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-size: 28px; color: var(--white); opacity: .7; transition: opacity .2s; }
.video-card:hover .video-play-btn { opacity: 1; }
.video-card-label { font-family: var(--font-display); font-size: 15px; letter-spacing: .07em; color: var(--white); padding: 14px 16px 4px; }
.video-card-sub { font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); opacity: .6; padding: 0 16px 14px; }
.media-upload-note { font-size: 12px; color: var(--muted); opacity: .45; margin-top: 32px; letter-spacing: .04em; font-style: italic; }
.media-upload-note a { color: var(--gold); opacity: .7; text-decoration: none; }
@media (max-width: 768px) {
  .media-hero, .music-player-section, .media-section { padding: 60px 24px; }
  .track-grid { grid-template-columns: 1fr; }
  .video-grid { grid-template-columns: 1fr 1fr; }
  .now-playing-bar { padding: 12px 20px; }
}

/* ════════════════════════════════════════════════════════════
   CONTACT PAGE — original style
   ════════════════════════════════════════════════════════════ */
.contact-hero { padding: 120px 48px 60px; background: var(--black); }
.contact-label { font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: var(--gold); margin-bottom: 16px; }
.contact-hero h1 { font-family: var(--font-display); font-size: clamp(48px,9vw,100px); line-height: .9; letter-spacing: .03em; color: var(--white); margin-bottom: 20px; }
.contact-sub { font-family: var(--font-accent); font-style: italic; font-size: 18px; color: var(--muted); max-width: 560px; }
.contact-form-section { padding: 80px 48px; }
.contact-form-wrap { max-width: 720px; margin: 0 auto; }
.form-group { margin-bottom: 24px; }
.form-group-label, .form-label { display: block; font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--gold); margin-bottom: 8px; opacity: .8; }
.form-input, .waitlist-input { width: 100%; background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.1); color: var(--white); font-family: var(--font-body); font-size: 14px; padding: 14px 16px; box-sizing: border-box; transition: border-color .2s; outline: none; resize: vertical; }
.form-input:focus, .waitlist-input:focus { border-color: rgba(212,168,67,.4); background: rgba(212,168,67,.04); }
.form-hint { font-size: 11px; color: var(--muted); opacity: .5; margin-top: 6px; letter-spacing: .04em; }
.waitlist-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.waitlist-btn { background: var(--gold); color: var(--black); border: none; padding: 16px 40px; font-family: var(--font-body); font-size: 13px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; cursor: pointer; transition: opacity .2s; margin-top: 8px; }
.waitlist-btn:hover { opacity: .85; }
.contact-direct { padding: 0 48px 80px; }
.contact-direct-item { padding: 24px 0; border-bottom: 1px solid rgba(255,255,255,.05); display: flex; align-items: baseline; gap: 24px; }
.contact-direct-label { font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--muted); min-width: 80px; opacity: .6; }
.contact-direct-value { font-family: var(--font-accent); font-size: 17px; color: var(--white); }
.contact-direct-value a { color: var(--gold); text-decoration: none; }
.contact-direct-value a:hover { opacity: .7; }
@media (max-width: 768px) {
  .contact-hero, .contact-form-section { padding: 60px 24px; }
  .contact-direct { padding: 0 24px 60px; }
  .waitlist-form-row { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════════════════
   AGE FILTER — original style
   ════════════════════════════════════════════════════════════ */
.age-filter-wrap {
  padding: 16px 24px 0;
  max-width: 1080px;
  margin: 0 auto;
}
.age-filter {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  margin-bottom: 4px;
}
.age-filter-btn {
  font-family: var(--font-body);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 6px 14px;
  background: none;
  border: 1px solid rgba(255,255,255,.1);
  color: var(--muted);
  cursor: pointer;
  transition: all .2s;
  white-space: nowrap;
}
.age-filter-btn:hover { border-color: rgba(255,255,255,.3); color: var(--white); }
.age-filter-btn.active {
  background: rgba(0,201,167,.1);
  border-color: var(--teal);
  color: var(--teal);
}
.age-filter-btn.company-filter-btn { border-color: rgba(212,168,67,.25); color: var(--gold); opacity: .7; }
.age-filter-btn.company-filter-btn.active { background: rgba(212,168,67,.1); border-color: var(--gold); opacity: 1; }
.age-tag { background: rgba(255,255,255,.04) !important; border: 1px solid rgba(255,255,255,.1) !important; color: var(--muted) !important; font-size: 10px !important; letter-spacing: .08em; }
@media (max-width: 600px) {
  .age-filter { gap: 6px; }
  .age-filter-btn { font-size: 10px; padding: 5px 10px; }
}


/* ════════════════════════════════════════════════════════════
   HOME PAGE — STUDIO FREQUENCIES & CHARTER MEMBERS SECTIONS
   ════════════════════════════════════════════════════════════ */

/* ── Hero video ─────────────────────────────────────────── */
.hero-video-wrap {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}
.hero-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .35;
}
.hero-video-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(6,3,16,.4) 0%, rgba(6,3,16,.7) 100%);
}

/* ── Studio Frequencies / Media teaser section ───────────── */
.media-teaser-section {
  padding: 100px 48px;
  background: var(--deep);
  border-top: 1px solid rgba(255,255,255,.04);
}
.media-teaser-inner {
  max-width: 960px;
  margin: 0 auto;
  text-align: center;
}
.media-teaser-sub {
  font-family: var(--font-accent);
  font-size: 18px;
  font-style: italic;
  color: var(--muted);
  line-height: 1.7;
  max-width: 600px;
  margin: 0 auto 40px;
}
.media-teaser-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-bottom: 40px;
}
.media-teaser-card {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.07);
  padding: 32px 24px;
  cursor: pointer;
  transition: border-color .2s, background .2s, transform .2s;
  text-align: center;
}
.media-teaser-card:hover {
  border-color: rgba(212,168,67,.3);
  background: rgba(212,168,67,.03);
  transform: translateY(-3px);
}
.media-teaser-icon {
  font-size: 28px;
  margin-bottom: 14px;
  display: block;
  color: var(--gold);
}
.media-teaser-title {
  font-family: var(--font-display);
  font-size: 18px;
  letter-spacing: .08em;
  color: var(--white);
  margin-bottom: 8px;
}
.media-teaser-desc {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.6;
  font-style: italic;
}
@media (max-width: 640px) {
  .media-teaser-section { padding: 60px 24px; }
  .media-teaser-grid { grid-template-columns: 1fr; }
}

/* ── Charter Members / Waitlist section ─────────────────── */
.waitlist-section {
  padding: 120px 48px;
  background: linear-gradient(180deg, var(--black) 0%, var(--deep) 60%, var(--black) 100%);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.waitlist-section::before {
  content: '';
  position: absolute;
  top: 0; left: 50%; transform: translateX(-50%);
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(212,168,67,.06) 0%, transparent 70%);
  pointer-events: none;
}
.waitlist-inner {
  max-width: 540px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.waitlist-sub {
  font-family: var(--font-accent);
  font-size: 18px;
  font-style: italic;
  color: var(--muted);
  line-height: 1.7;
  margin-bottom: 32px;
}
.waitlist-spots {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  background: rgba(212,168,67,.08);
  border: 1px solid rgba(212,168,67,.2);
  padding: 12px 24px;
  margin-bottom: 40px;
}
.waitlist-spots-num {
  font-family: var(--font-display);
  font-size: 36px;
  letter-spacing: .04em;
  color: var(--gold);
  line-height: 1;
}
.waitlist-spots-label {
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
}
.waitlist-tiers {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  margin-bottom: 24px;
}
.waitlist-tier-opt { display: flex; align-items: center; }
.waitlist-tier-opt input[type="radio"] { display: none; }
.waitlist-tier-pill {
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 6px 14px;
  border: 1px solid rgba(255,255,255,.15);
  color: var(--muted);
  cursor: pointer;
  transition: all .2s;
  white-space: nowrap;
}
.waitlist-tier-opt input:checked + .waitlist-tier-pill {
  background: rgba(255,255,255,.06);
  color: var(--white);
  border-color: rgba(255,255,255,.35);
}
.heal-pill     { border-color: rgba(0,201,167,.3) !important; color: var(--teal) !important; }
.foundations-pill { border-color: rgba(0,201,167,.3) !important; color: var(--teal) !important; }
.explore-pill  { border-color: rgba(168,85,247,.3) !important; color: var(--violet) !important; }
.express-pill  { border-color: rgba(168,85,247,.3) !important; color: var(--violet) !important; }
.company-pill  { border-color: rgba(212,168,67,.3) !important; color: var(--gold) !important; }
.waitlist-tier-opt input:checked + .heal-pill     { background: rgba(0,201,167,.1); }
.waitlist-tier-opt input:checked + .foundations-pill { background: rgba(0,201,167,.1); }
.waitlist-tier-opt input:checked + .explore-pill  { background: rgba(168,85,247,.08); }
.waitlist-tier-opt input:checked + .express-pill  { background: rgba(168,85,247,.08); }
.waitlist-tier-opt input:checked + .company-pill  { background: rgba(212,168,67,.08); }
.waitlist-tier-label {
  font-size: 10px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 10px;
  opacity: .6;
}
.waitlist-fine {
  font-size: 12px;
  color: var(--muted);
  opacity: .4;
  margin-top: 16px;
  letter-spacing: .04em;
  font-style: italic;
}

/* ── Founding member perks grid ─────────────────────────── */
.fm-perks {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin: 36px 0 40px;
  text-align: left;
}
.fm-perk {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(212,168,67,.12);
  padding: 20px 18px;
}
.fm-perk-icon {
  font-size: 20px;
  color: var(--gold);
  margin-bottom: 10px;
}
.fm-perk-title {
  font-family: var(--font-display);
  font-size: 16px;
  letter-spacing: .08em;
  color: var(--white);
  margin-bottom: 6px;
}
.fm-perk-desc {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.6;
}

/* ── Drop-in price chip variant ─────────────────────────── */
.price-chip-dropin {
  border-color: rgba(255,255,255,.12) !important;
  color: var(--muted) !important;
  opacity: .7;
}

@media (max-width: 640px) {
  .waitlist-section { padding: 80px 24px; }
  .fm-perks { grid-template-columns: 1fr; }
  .waitlist-tiers { gap: 6px; }
  .waitlist-tier-pill { font-size: 9px; padding: 5px 10px; }
}

/* ════════════════════════════════════════════════════════════
   CLASSES PAGE — section labels, division filter, apply btn
   ════════════════════════════════════════════════════════════ */

/* Inline sub-label (e.g. "Exclusive Technique — Company Only") */
.section-label-inline {
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.heal-label    { color: var(--teal); }
.express-label { color: var(--violet); }
.compete-label { color: var(--gold); }

/* Price badge below the section title */
.classes-price-badge {
  display: inline-block;
  font-size: 12px;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 5px 14px;
  margin-bottom: 16px;
  margin-top: 4px;
}

/* Company division filter bar */
.company-division-filter {
  margin-bottom: 28px;
  padding: 20px 24px;
  background: rgba(212,168,67,.04);
  border: 1px solid rgba(212,168,67,.15);
}
.division-filter-label {
  font-size: 10px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--gold);
  opacity: .6;
  margin-bottom: 12px;
}
.division-filter-btns {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.division-btn {
  font-family: var(--font-body);
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 8px 16px;
  background: none;
  border: 1px solid rgba(255,255,255,.1);
  color: var(--muted);
  cursor: pointer;
  transition: all .2s;
  display: flex;
  align-items: center;
  gap: 6px;
}
.division-btn:hover {
  border-color: rgba(212,168,67,.4);
  color: var(--white);
}
.division-btn.active {
  background: rgba(212,168,67,.1);
  border-color: var(--gold);
  color: var(--gold);
}
.div-age {
  font-size: 10px;
  opacity: .6;
  font-style: italic;
}

/* Apply/link button inside class cards */
.class-card-apply-btn {
  display: inline-block;
  margin: 8px 0 12px;
  background: none;
  border: 1px solid rgba(212,168,67,.3);
  color: var(--gold);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 7px 16px;
  cursor: pointer;
  transition: background .2s, border-color .2s;
  font-family: var(--font-body);
}
.class-card-apply-btn:hover {
  background: rgba(212,168,67,.08);
  border-color: var(--gold);
}

@media (max-width: 600px) {
  .division-filter-btns { gap: 6px; }
  .division-btn { font-size: 11px; padding: 7px 12px; }
}

/* ════════════════════════════════════════════════════════════
   MODALS — Audition + Masters Application
   ════════════════════════════════════════════════════════════ */
.modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(6,3,16,.92);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  z-index: 800;
  align-items: flex-start;
  justify-content: center;
  padding: 24px;
  overflow-y: auto;
}
.modal-overlay.active { display: flex; }
.modal-content {
  background: var(--deep);
  border: 1px solid rgba(255,255,255,.08);
  width: 100%;
  max-width: 560px;
  padding: 40px;
  position: relative;
  margin: auto;
}
.modal-close {
  position: absolute;
  top: 16px;
  right: 20px;
  background: none;
  border: none;
  color: var(--muted);
  font-size: 24px;
  cursor: pointer;
  line-height: 1;
  padding: 4px;
  transition: color .2s;
}
.modal-close:hover { color: var(--white); }
.modal-header { margin-bottom: 24px; }
.modal-body { display: flex; flex-direction: column; gap: 0; }
.modal-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.modal-section-label {
  font-size: 10px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--gold);
  opacity: .7;
  margin: 20px 0 8px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,.06);
}
@media (max-width: 600px) {
  .modal-content { padding: 28px 20px; }
  .modal-form-row { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════════════════
   LITTLE MOVERS — class card badge + card accent
   ════════════════════════════════════════════════════════════ */
.little-movers-badge {
  font-size: 9px !important;
  letter-spacing: .12em;
  text-transform: uppercase;
  background: rgba(0,201,167,.1);
  border: 1px solid rgba(0,201,167,.3);
  color: var(--teal) !important;
  padding: 2px 7px;
}
.little-movers-card {
  border-color: rgba(0,201,167,.2);
  background: rgba(0,201,167,.02);
  position: relative;
}
.little-movers-card::before {
  content: 'AGES 4 \2013 6';
  position: absolute;
  top: -1px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--teal);
  color: var(--black);
  font-family: var(--font-body);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .14em;
  padding: 3px 12px;
  white-space: nowrap;
}

/* ════════════════════════════════════════════════════════════
   FLOATING MINI PLAYER — original style
   ════════════════════════════════════════════════════════════ */
.float-player {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 500;
  width: 300px;
  background: rgba(14,5,32,.97);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(212,168,67,.2);
  box-shadow: 0 8px 40px rgba(0,0,0,.5);
  transform: translateY(120%);
  opacity: 0;
  transition: transform .4s cubic-bezier(.16,1,.3,1), opacity .3s;
  pointer-events: none;
}
.float-player.visible {
  transform: translateY(0);
  opacity: 1;
  pointer-events: all;
}
.float-player.hidden { display: none !important; }

/* Collapsed pill */
.fp-collapsed {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  cursor: pointer;
  transition: background .2s;
}
.fp-collapsed:hover { background: rgba(255,255,255,.04); }
.fp-collapsed-icon {
  font-size: 16px;
  color: var(--gold);
  animation: fpPulse 2s ease-in-out infinite;
}
@keyframes fpPulse {
  0%,100% { opacity:.6; transform:scale(1); }
  50% { opacity:1; transform:scale(1.15); }
}
.fp-collapsed-text {
  font-family: var(--font-display);
  font-size: 13px;
  letter-spacing: .08em;
  color: var(--white);
}

/* Expanded */
.fp-expanded { padding: 16px 16px 12px; }
.fp-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 12px;
}
.fp-track-name {
  font-family: var(--font-display);
  font-size: 15px;
  letter-spacing: .06em;
  color: var(--white);
  line-height: 1.2;
}
.fp-track-meta {
  font-size: 10px;
  color: var(--gold);
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-top: 3px;
  opacity: .7;
}
.fp-header-actions {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
  margin-left: 8px;
}

/* Waveform progress */
.fp-progress-wrap {
  position: relative;
  height: 36px;
  cursor: pointer;
  margin-bottom: 4px;
  overflow: hidden;
}
.fp-progress-fill {
  position: absolute;
  left: 0; top: 0;
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg,
    rgba(0,201,167,.15) 0%,
    rgba(212,168,67,.15) 50%,
    rgba(168,85,247,.15) 100%);
  transition: width .1s linear;
  pointer-events: none;
}
.fp-waveform {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  gap: 2.5px;
  padding: 0 2px;
  pointer-events: none;
}
.fp-waveform span {
  flex: 1;
  background: rgba(212,168,67,.3);
  border-radius: 1px;
  animation: fpWave 1.2s ease-in-out infinite;
}
.fp-waveform span:nth-child(odd)  { height: 40%; animation-delay: .1s; }
.fp-waveform span:nth-child(3n)   { height: 70%; animation-delay: .2s; }
.fp-waveform span:nth-child(4n)   { height: 55%; animation-delay: .3s; }
.fp-waveform span:nth-child(5n)   { height: 80%; animation-delay: .05s; }
.fp-waveform span:nth-child(even) { height: 45%; }
@keyframes fpWave {
  0%,100% { transform: scaleY(1); opacity: .3; }
  50% { transform: scaleY(1.4); opacity: .7; }
}
.float-player.paused .fp-waveform span {
  animation-play-state: paused;
  opacity: .2;
}

/* Times */
.fp-times {
  display: flex;
  justify-content: space-between;
  font-size: 10px;
  color: var(--muted);
  margin-bottom: 12px;
  font-variant-numeric: tabular-nums;
}

/* Controls */
.fp-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-bottom: 12px;
}
.fp-btn {
  background: none;
  border: none;
  color: var(--muted);
  cursor: pointer;
  transition: color .2s;
  font-size: 14px;
  padding: 6px;
  line-height: 1;
}
.fp-btn:hover { color: var(--white); }
.fp-play-main {
  width: 44px; height: 44px;
  border-radius: 50% !important;
  background: var(--gold) !important;
  color: var(--black) !important;
  font-size: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  padding-left: 2px;
  transition: background .2s, transform .15s;
}
.fp-play-main:hover {
  background: var(--white) !important;
  transform: scale(1.06);
}
.fp-prev, .fp-next { font-size: 11px; }
.fp-shuffle.on { color: var(--gold); }
.fp-collapse-btn, .fp-close-btn { font-size: 16px; }

/* Track list mini */
.fp-tracklist {
  border-top: 1px solid rgba(255,255,255,.07);
  padding-top: 10px;
  margin-bottom: 8px;
}
.fp-tracklist-label {
  font-size: 9px;
  letter-spacing: .16em;
  color: var(--muted);
  margin-bottom: 6px;
  opacity: .5;
}
.fp-tracklist-scroll {
  max-height: 100px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.fp-tracklist-scroll::-webkit-scrollbar { width: 2px; }
.fp-tracklist-scroll::-webkit-scrollbar-track { background: transparent; }
.fp-tracklist-scroll::-webkit-scrollbar-thumb { background: rgba(255,255,255,.15); }
.fp-track-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 6px;
  cursor: pointer;
  transition: background .15s;
}
.fp-track-item:hover { background: rgba(255,255,255,.05); }
.fp-track-item.active { background: rgba(212,168,67,.08); }
.fp-track-item-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
  background: rgba(255,255,255,.2);
}
.fp-track-item.active .fp-track-item-dot { background: var(--gold); }
.fp-track-item-name {
  font-size: 11px;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1;
}
.fp-track-item.active .fp-track-item-name { color: var(--white); }
.fp-track-item-ver {
  font-size: 9px;
  color: var(--muted);
  opacity: .5;
  flex-shrink: 0;
}

/* Full player link */
.fp-full-link {
  display: block;
  width: 100%;
  background: none;
  border: 1px solid rgba(255,255,255,.08);
  color: var(--muted);
  font-size: 10px;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 7px;
  cursor: pointer;
  text-align: center;
  transition: border-color .2s, color .2s;
  font-family: var(--font-body);
}
.fp-full-link:hover { border-color: rgba(212,168,67,.3); color: var(--gold); }

/* Mobile */
@media (max-width: 480px) {
  .float-player { right: 12px; bottom: 12px; width: calc(100vw - 24px); max-width: 300px; }
}
