:root{
  --bg:#0a0a12; --bg2:#11111d; --card:#161627; --line:#262640;
  --txt:#ede9ff; --muted:#9a96b8;
  --neon:#ff2e88; --neon2:#16e0ff; --neon3:#b14bff;
  --grad:linear-gradient(120deg,var(--neon),var(--neon3) 55%,var(--neon2));
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--txt);font-family:'Outfit',system-ui,sans-serif;overflow-x:hidden}
a{color:inherit;text-decoration:none}
em{font-style:normal;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
h2{font-size:clamp(2rem,5vw,3.5rem);font-family:'Bebas Neue',sans-serif;letter-spacing:1px}
.btn{display:inline-block;padding:.85rem 1.6rem;border-radius:999px;font-weight:600;cursor:pointer;border:none;font-size:1rem;transition:.2s;font-family:inherit}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 8px 30px rgba(255,46,136,.35)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(177,75,255,.5)}
.btn-ghost{background:transparent;color:var(--txt);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--neon2);color:var(--neon2)}

/* ===== SPLASH ===== */
#splash{position:fixed;inset:0;z-index:1000;background:radial-gradient(circle at 50% 40%,#1a1030,#05050b);display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .8s,visibility .8s}
#splash.hidden{opacity:0;visibility:hidden}
.splash-inner{text-align:center;animation:fadeUp 1s}
.splash-logo{font-family:'Bebas Neue';font-size:clamp(4rem,16vw,11rem);line-height:.9;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 0 30px rgba(255,46,136,.5))}
.splash-sub{font-size:1.4rem;color:var(--neon2);letter-spacing:4px;margin:.5rem 0 2rem;text-transform:uppercase}
.enter-btn{font-family:'Bebas Neue';font-size:1.6rem;letter-spacing:3px;padding:1rem 3.5rem;border-radius:999px;border:2px solid var(--neon);background:transparent;color:#fff;cursor:pointer;transition:.25s}
.enter-btn:hover{background:var(--grad);border-color:transparent;transform:scale(1.05);box-shadow:0 0 40px rgba(255,46,136,.6)}
.splash-hint{margin-top:1.2rem;color:var(--muted);font-size:.85rem}
.splash-eq{display:flex;gap:6px;margin-top:3rem;height:50px;align-items:flex-end}
.splash-eq span{width:7px;background:var(--grad);border-radius:4px;animation:eq 1s infinite ease-in-out}
.splash-eq span:nth-child(1){animation-delay:0s}.splash-eq span:nth-child(2){animation-delay:.15s}
.splash-eq span:nth-child(3){animation-delay:.3s}.splash-eq span:nth-child(4){animation-delay:.45s}
.splash-eq span:nth-child(5){animation-delay:.3s}.splash-eq span:nth-child(6){animation-delay:.15s}.splash-eq span:nth-child(7){animation-delay:0s}
@keyframes eq{0%,100%{height:10px}50%{height:50px}}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}

/* ===== NAV ===== */
#nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;gap:1.5rem;padding:1rem 5vw;transition:.3s;backdrop-filter:blur(0)}
#nav.scrolled{background:rgba(10,10,18,.85);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);padding:.6rem 5vw}
.brand{font-family:'Bebas Neue';font-size:1.8rem;letter-spacing:2px;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
#nav nav{display:flex;gap:1.6rem;margin-left:auto}
#nav nav a{color:var(--muted);font-weight:600;font-size:.95rem;transition:.2s}
#nav nav a:hover{color:var(--neon2)}
.nav-play{width:42px;height:42px;border-radius:50%;border:1px solid var(--line);background:var(--card);color:var(--neon2);font-size:1.2rem;cursor:pointer;transition:.2s}
.nav-play:hover{border-color:var(--neon2);box-shadow:0 0 18px rgba(22,224,255,.4)}
.nav-play.playing{background:var(--grad);color:#fff;border-color:transparent}
.nav-toggle{display:none;background:none;border:none;color:var(--txt);font-size:1.6rem;cursor:pointer}

/* ===== HERO ===== */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:
  radial-gradient(circle at 20% 20%,rgba(255,46,136,.25),transparent 40%),
  radial-gradient(circle at 80% 30%,rgba(22,224,255,.2),transparent 40%),
  radial-gradient(circle at 50% 90%,rgba(177,75,255,.25),transparent 45%),var(--bg);animation:bgmove 12s ease-in-out infinite alternate}
@keyframes bgmove{to{filter:hue-rotate(40deg)}}
#viz{position:absolute;bottom:0;left:0;width:100%;height:140px;opacity:.55}
.hero-content{position:relative;z-index:2;padding:0 1rem;animation:fadeUp 1s}
.kicker{color:var(--neon2);letter-spacing:3px;font-size:.8rem;font-weight:600;margin-bottom:1rem}
.hero h1{font-family:'Bebas Neue';font-size:clamp(5rem,22vw,16rem);line-height:.85;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 0 40px rgba(255,46,136,.4))}
.tagline{font-family:'Bebas Neue';font-size:clamp(1.4rem,4vw,2.4rem);letter-spacing:4px;color:var(--txt);margin:.3rem 0 2rem}
.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.hero-stats{display:flex;gap:2.5rem;justify-content:center;margin-top:3rem;flex-wrap:wrap}
.hero-stats strong{display:block;font-family:'Bebas Neue';font-size:2.6rem;color:var(--neon2)}
.hero-stats span{color:var(--muted);font-size:.85rem;text-transform:uppercase;letter-spacing:1px}
.hero-next{position:absolute;bottom:1.2rem;z-index:2;color:var(--muted);font-size:.9rem}
.hero-next strong{color:var(--neon)}
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--neon);box-shadow:0 0 10px var(--neon);animation:pulse 1.2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* ===== SECTIONS ===== */
.section{padding:6rem 5vw;max-width:1200px;margin:0 auto}
.section.alt{background:var(--bg2);max-width:none;margin:0;border-block:1px solid var(--line)}
.section.alt>*{max-width:1200px;margin-inline:auto}
.section-head{text-align:center;margin-bottom:3rem}
.section-head p{color:var(--muted);margin-top:.6rem}
.reveal{opacity:0;transform:translateY(40px);transition:.7s}
.reveal.in{opacity:1;transform:none}

/* ===== DATES ===== */
.dates{display:flex;flex-direction:column;gap:1rem}
.date-card{display:grid;grid-template-columns:90px 1fr auto;gap:1.5rem;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:1.2rem 1.6rem;transition:.25s}
.date-card:hover{border-color:var(--neon3);transform:translateX(6px);box-shadow:0 10px 40px rgba(177,75,255,.15)}
.date-when{text-align:center}
.date-when .d{font-family:'Bebas Neue';font-size:2.4rem;line-height:1;color:var(--neon2)}
.date-when .m{text-transform:uppercase;font-size:.75rem;color:var(--muted);letter-spacing:1px}
.date-info h3{font-size:1.25rem}
.date-info p{color:var(--muted);font-size:.92rem;margin-top:.2rem}
.date-tags{margin-top:.5rem;display:flex;gap:.5rem;flex-wrap:wrap}
.tag{font-size:.7rem;padding:.2rem .6rem;border-radius:99px;background:rgba(177,75,255,.15);color:var(--neon3);font-weight:600}
.date-action{text-align:right}
.badge-sold{color:var(--neon);font-weight:700;border:1px solid var(--neon);padding:.5rem 1rem;border-radius:99px;font-size:.85rem}
.dates-cta{text-align:center;margin-top:2.5rem}

/* ===== PLAYER ===== */
.player{display:flex;gap:1.2rem;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:1.2rem;margin-bottom:2rem}
.player-art{width:70px;height:70px;border-radius:12px;background:var(--grad);display:grid;place-items:center;font-size:2rem;flex-shrink:0}
.player-main{flex:1;min-width:0}
.player-title{font-weight:600;margin-bottom:.5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.player-bar{height:6px;background:var(--line);border-radius:99px;overflow:hidden;cursor:pointer}
#playerProg{height:100%;width:0;background:var(--grad)}
.player-row{display:flex;align-items:center;gap:1rem;margin-top:.7rem}
.pp{width:44px;height:44px;border-radius:50%;border:none;background:var(--grad);color:#fff;font-size:1.1rem;cursor:pointer}
#playerTime{color:var(--muted);font-size:.85rem}
#vol{margin-left:auto;accent-color:var(--neon)}
.mixes{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}
.mix-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:1.1rem;cursor:pointer;transition:.2s}
.mix-card:hover{border-color:var(--neon2);transform:translateY(-4px)}
.mix-card .cover{height:120px;border-radius:10px;background:var(--grad);margin-bottom:.8rem;display:grid;place-items:center;font-size:1.8rem}
.mix-card h4{font-size:1rem}
.mix-card span{color:var(--muted);font-size:.82rem}

/* ===== ABOUT ===== */
.about-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:3rem;align-items:center}
.about-photo .photo-ph{aspect-ratio:4/5;border-radius:20px;background:linear-gradient(160deg,#1c1330,#0c0c18);border:1px solid var(--line);display:grid;place-items:center;font-family:'Bebas Neue';font-size:2.5rem;color:var(--neon3);letter-spacing:3px}
.about-text p{color:var(--muted);margin:1rem 0;line-height:1.7}
.about-list{list-style:none;margin:1.5rem 0;display:grid;gap:.6rem}
.about-list li{padding-left:.2rem}

/* ===== GALLERY ===== */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.8rem}
.gallery .cell{aspect-ratio:1;border-radius:12px;border:1px solid var(--line);display:grid;place-items:center;font-size:2rem;transition:.25s;cursor:pointer}
.gallery .cell:hover{transform:scale(1.04);box-shadow:0 0 30px rgba(255,46,136,.3)}

/* ===== FORMS ===== */
.booking-grid,.community-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.contact-list{list-style:none;margin-top:1.5rem;display:grid;gap:.7rem;color:var(--muted)}
.contact-list a:hover{color:var(--neon2)}
.form{display:grid;gap:1rem;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:1.8rem}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form input,.form select,.form textarea{width:100%;padding:.85rem 1rem;border-radius:10px;border:1px solid var(--line);background:var(--bg);color:var(--txt);font-family:inherit;font-size:.95rem}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--neon2)}
.form textarea{min-height:110px;resize:vertical}
.form-msg{font-size:.9rem;min-height:1.2em}
.form-msg.ok{color:#4be08a}.form-msg.err{color:var(--neon)}
.sub-form h3,.invite-card h3{margin-bottom:1rem}
.invite-card{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:1.8rem}
.invite-card p{color:var(--muted);margin-bottom:1rem}
.share{display:flex;gap:.6rem;flex-wrap:wrap}
.share button{padding:.7rem 1.2rem;border-radius:99px;border:1px solid var(--line);background:var(--bg);color:var(--txt);cursor:pointer;font-family:inherit;transition:.2s}
.share button:hover{border-color:var(--neon2);color:var(--neon2)}
.socials{display:flex;gap:1.5rem;justify-content:center;margin-top:3rem;flex-wrap:wrap}
.socials a{color:var(--muted);font-weight:600;transition:.2s}
.socials a:hover{color:var(--neon);text-shadow:0 0 12px var(--neon)}

/* ===== FOOTER ===== */
footer{text-align:center;padding:3rem 5vw;border-top:1px solid var(--line);color:var(--muted)}
footer .brand{font-size:2rem;display:block;margin-bottom:.6rem}
.madeby a{color:var(--neon2)}
footer p{margin:.3rem 0;font-size:.9rem}

/* ===== RESPONSIVE ===== */
@media(max-width:820px){
  #nav nav{position:fixed;inset:0 0 0 auto;width:70%;max-width:300px;flex-direction:column;background:rgba(10,10,18,.97);backdrop-filter:blur(20px);padding:6rem 2rem;transform:translateX(100%);transition:.3s;margin:0}
  #nav nav.open{transform:none}
  #nav nav a{font-size:1.2rem}
  .nav-toggle{display:block;margin-left:auto}
  .nav-play{order:-1}
  .about-grid,.booking-grid,.community-grid{grid-template-columns:1fr}
  .form .row{grid-template-columns:1fr}
  .date-card{grid-template-columns:70px 1fr;grid-template-rows:auto auto}
  .date-action{grid-column:1/-1;text-align:left}
}
