@font-face{font-family:"Firs";src:url("assets/fonts/TT Firs Neue Trial Regular.ttf") format("truetype");font-weight:400;font-display:swap}
@font-face{font-family:"Firs";src:url("assets/fonts/TT Firs Neue Trial Medium.ttf") format("truetype");font-weight:500;font-display:swap}
@font-face{font-family:"Firs";src:url("assets/fonts/TT Firs Neue Trial Bold.ttf") format("truetype");font-weight:700;font-display:swap}
@font-face{font-family:"Firs";src:url("assets/fonts/TT Firs Neue Trial Black.ttf") format("truetype");font-weight:900;font-display:swap}
@font-face{font-family:"Miratrix";src:url("assets/fonts/Miratrix-Normal.otf") format("opentype");font-weight:400;font-display:swap}

:root{
  /* UTOPIA brand palette — exact hex from brand deck */
  --c-orange:#FF6700;
  --c-pink:#FB21B6;
  --c-blue:#2C3BC0;
  --c-deeppurple:#5B05C6;
  --c-coral:#FC77BB;
  --c-gold:#F3A529;
  --c-brightpurple:#A100FF;
  --c-spicy:#FE100E;
  --c-green:#006128;
  --c-hazel:#BDBC35;
  --c-yellow:#FFE600;
  --c-turquoise:#03C2F7;
  --c-acid:#F5FF00;

  /* neutrals */
  --c-plum:#2D152B;
  --c-midnight:#0F0141;
  --c-jet:#060200;
  --c-mauve:#4B355A;
  --c-peach:#F2C5B2;
  --c-navy:#0A1D5C;
  --c-cream:#FFF1EE;
  --c-tan:#B56F27;
  --c-oxblood:#3A1516;

  /* legacy aliases (still used by markup style="--accent:var(--c-*)") */
  --c-peach-old:var(--c-peach);
  --c-darkgreen:var(--c-green);
  --c-olive:var(--c-hazel);
  --c-magenta:var(--c-pink);
  --c-purple:var(--c-brightpurple);
  --c-salmon:var(--c-coral);
  --c-mustard:var(--c-gold);

  --pink:var(--c-pink);
  --pink-2:var(--c-coral);
  --violet:var(--c-brightpurple);
  --cyan:var(--c-blue);
  --orange:var(--c-orange);

  --bg:#060200;
  --bg-2:#0F0141;
  --ink:#FFF1EE;
  --mute:#b7a9c4;
  --line:rgba(255,241,238,.10);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);font-family:"Firs",system-ui,sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
::selection{background:var(--pink);color:#000}

/* grain */
.grain{position:fixed;inset:0;pointer-events:none;z-index:200;mix-blend-mode:overlay;opacity:.5;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.5 0'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.5'/></svg>")}

/* cursor */
.cursor{position:fixed;top:0;left:0;width:28px;height:28px;border-radius:50%;background:radial-gradient(circle,var(--pink),transparent 70%);transform:translate(-50%,-50%);pointer-events:none;z-index:300;mix-blend-mode:screen;transition:width .25s,height .25s,opacity .25s;opacity:.9}
.cursor.is-big{width:140px;height:140px}
@media (hover:none){.cursor{display:none}}

/* intro */
.intro{position:fixed;inset:0;z-index:500;background:#000;display:grid;place-items:center;transition:opacity .8s ease,visibility .8s ease;overflow:hidden}
.intro::before,.intro::after{content:"";position:absolute;width:60vmin;height:60vmin;border-radius:50%;filter:blur(80px);opacity:.55;pointer-events:none}
.intro::before{background:var(--c-magenta);top:-20%;left:-15%;animation:introBlobA 3s ease-in-out infinite alternate}
.intro::after{background:var(--c-orange);bottom:-20%;right:-15%;animation:introBlobB 3s ease-in-out infinite alternate}
@keyframes introBlobA{to{transform:translate(20vmin,10vmin) scale(1.2)}}
@keyframes introBlobB{to{transform:translate(-20vmin,-10vmin) scale(1.2)}}
.intro.is-done{opacity:0;visibility:hidden}
.intro__inner{
  text-align:center;
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
}
.intro__logo{animation:logoIn 1.2s cubic-bezier(.2,.8,.2,1) both}
.intro__logo img{
  height:clamp(48px,9vw,110px);
  width:auto;
  margin:0 auto;
  filter:drop-shadow(0 0 28px rgba(237,77,196,.55)) drop-shadow(0 0 60px rgba(232,97,42,.35));
  animation:logoHue 3s linear infinite
}
@keyframes logoIn{0%{transform:scale(.7);opacity:0;filter:blur(20px)}100%{transform:scale(1);opacity:1;filter:blur(0)}}
@keyframes logoHue{0%,100%{filter:drop-shadow(0 0 28px rgba(237,77,196,.6)) drop-shadow(0 0 60px rgba(232,97,42,.35))}50%{filter:drop-shadow(0 0 28px rgba(93,31,201,.6)) drop-shadow(0 0 60px rgba(43,224,122,.35))}}
.intro__bar{width:240px;height:3px;background:rgba(255,255,255,.12);margin:0 auto 32px;border-radius:3px;overflow:hidden}
.intro__bar span{display:block;height:100%;background:linear-gradient(90deg,var(--c-magenta),var(--c-orange),var(--c-mustard));transform-origin:left;animation:load 1.3s cubic-bezier(.7,0,.3,1) both}
.intro__meta{margin-top:18px;font-size:11px;letter-spacing:.4em;color:#fff;opacity:.7;animation:fade 1.4s .4s both}
@keyframes zoom{0%{transform:scale(.85);opacity:0;filter:blur(20px)}100%{transform:scale(1);opacity:1;filter:blur(0)}}
@keyframes load{0%{transform:scaleX(0)}100%{transform:scaleX(1)}}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:18px 36px;backdrop-filter:blur(14px);background:linear-gradient(180deg,rgba(7,7,8,.65),rgba(7,7,8,0));transition:background .3s}
.nav.is-scrolled{background:rgba(7,7,8,.85);border-bottom:1px solid var(--line)}
.nav__logo img{height:22px}
.nav__links{display:flex;gap:28px}
.nav__links a{font-size:13px;letter-spacing:.06em;color:var(--mute);font-weight:500;position:relative;transition:color .2s}
.nav__links a:hover{color:var(--ink)}
.nav__links a::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;background:var(--pink);transform:scaleX(0);transform-origin:left;transition:transform .25s}
.nav__links a:hover::after{transform:scaleX(1)}
.nav__cta{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:1px solid var(--ink);border-radius:999px;font-size:12px;font-weight:600;letter-spacing:.08em;transition:all .25s}
.nav__cta:hover{background:var(--pink);border-color:var(--pink);color:#000}
@media (max-width:780px){.nav__links{display:none}.nav{padding:14px 18px}}

/* HERO */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:140px 36px 80px;overflow:hidden}
.hero__ticker{position:absolute;top:78px;left:0;right:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;padding:10px 0;background:#000}
.hero__ticker-track{display:flex;gap:48px;white-space:nowrap;animation:ticker 28s linear infinite;font-size:11px;letter-spacing:.3em;color:var(--mute)}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

.hero__bg{position:absolute;inset:0;z-index:0;filter:blur(100px);opacity:.55}
.blob{position:absolute;width:520px;height:520px;border-radius:50%;mix-blend-mode:screen}
.blob--a{background:var(--c-pink);top:-10%;left:-8%;animation:float 14s ease-in-out infinite}
.blob--b{background:var(--c-brightpurple);bottom:-15%;right:-10%;animation:float 18s -3s ease-in-out infinite}
.blob--c{background:var(--c-orange);top:30%;right:20%;width:360px;height:360px;animation:float 22s -7s ease-in-out infinite;opacity:.85}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(60px,-40px) scale(1.1)}}

.hero__inner{position:relative;z-index:2;max-width:1280px;margin:0 auto;width:100%}
.hero__eyebrow{display:inline-flex;align-items:center;gap:10px;padding:8px 14px;border:1px solid var(--line);border-radius:999px;font-size:11px;letter-spacing:.18em;background:rgba(255,255,255,.04);margin-bottom:28px}
.hero__eyebrow-text{color:#f0f0f3}
.dot{width:8px;height:8px;border-radius:50%;background:var(--pink);box-shadow:0 0 0 0 var(--pink);animation:pulse 1.6s infinite}
.dot--green{background:#2BE07A}
.dot--green{animation:pulseGreen 1.6s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,45,135,.6)}70%{box-shadow:0 0 0 12px rgba(255,45,135,0)}100%{box-shadow:0 0 0 0 rgba(255,45,135,0)}}
@keyframes pulseGreen{0%{box-shadow:0 0 0 0 rgba(43,224,122,.6)}70%{box-shadow:0 0 0 12px rgba(43,224,122,0)}100%{box-shadow:0 0 0 0 rgba(43,224,122,0)}}

.hero__title{font-family:"Miratrix","Firs";font-weight:400;font-size:clamp(44px,6vw,92px);line-height:1;letter-spacing:.005em;text-transform:uppercase}
.hero__title .line{display:block;overflow:hidden;padding-right:.12em}
.hero__title .reveal{display:inline-block;transform:translateY(110%);animation:rise 1s .4s cubic-bezier(.2,.8,.2,1) both;padding-right:.08em}
.hero__title .reveal--pink{
  background:linear-gradient(110deg,
    var(--c-pink) 0%,
    var(--c-coral) 20%,
    var(--c-brightpurple) 45%,
    var(--c-orange) 75%,
    var(--c-gold) 100%);
  background-size:280% 100%;
  background-position:0% 50%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:rise 1s .55s cubic-bezier(.2,.8,.2,1) both,shimmerSmooth 14s ease-in-out infinite alternate;
  padding-right:.18em
}
@keyframes rise{from{transform:translateY(110%)}to{transform:translateY(0)}}
@keyframes shimmer{0%{background-position:0% 50%}100%{background-position:200% 50%}}
@keyframes shimmerSmooth{0%{background-position:0% 50%}100%{background-position:100% 50%}}

.hero__sub{max-width:560px;margin-top:32px;font-size:18px;line-height:1.55;color:#cfcfd6}
.hero__sub a{color:var(--pink);border-bottom:1px solid currentColor}
.hero__actions{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;border-radius:999px;font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;transition:transform .2s,background .2s,color .2s,border-color .2s}
.btn:hover{transform:translateY(-2px)}
.btn--primary{background:var(--pink);color:#000}
.btn--primary:hover{background:#fff}
.btn--ghost{border:1px solid rgba(255,255,255,.25);color:var(--ink)}
.btn--ghost:hover{border-color:var(--ink);background:rgba(255,255,255,.06)}

.hero__stats{display:flex;gap:48px;margin-top:64px}
.hero__stats div{display:flex;flex-direction:column}
.hero__stats strong{font-family:"Miratrix","Firs";font-weight:400;font-size:34px;letter-spacing:.01em}
.hero__stats span{font-size:11px;letter-spacing:.2em;color:var(--mute);margin-top:4px}

.hero__scroll{position:absolute;bottom:24px;left:36px;font-size:11px;letter-spacing:.3em;color:var(--mute);animation:bounce 2.2s ease-in-out infinite}
@keyframes bounce{0%,100%{transform:translateY(0);opacity:.7}50%{transform:translateY(6px);opacity:1}}

/* MARQUEE */
.marquee{overflow:hidden;background:var(--pink);color:#000;padding:18px 0;border-top:1px solid #000;border-bottom:1px solid #000}
.marquee__track{display:flex;gap:48px;white-space:nowrap;animation:ticker 22s linear infinite;font-family:"Miratrix";font-weight:400;font-size:32px;letter-spacing:.01em;text-transform:uppercase}

/* SECTIONS */
.section{padding:96px 36px;position:relative}
.section__head{max-width:1280px;margin:0 auto 56px}
.kicker{display:inline-flex;align-items:center;gap:8px;font-size:11px;letter-spacing:.3em;color:var(--mute);margin-bottom:18px}
.kicker__dot{width:6px;height:6px;border-radius:50%;background:var(--pink)}
.section__title{font-family:"Miratrix","Firs";font-weight:400;font-size:clamp(34px,4.6vw,64px);line-height:1.02;letter-spacing:.005em;max-width:20ch;text-transform:uppercase}
.section__title em{font-style:normal;background:linear-gradient(120deg,var(--c-pink),var(--c-gold) 60%,var(--c-orange));-webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block;padding-right:.15em}
.section__lede{margin-top:18px;color:var(--mute);font-size:17px;max-width:60ch}
.section__foot{max-width:1280px;margin:48px auto 0;text-align:center}

/* RELEASES */
.releases{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media (max-width:1100px){.releases{grid-template-columns:repeat(3,1fr)}}
@media (max-width:780px){.releases{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.releases{grid-template-columns:1fr}}

.release{position:relative;display:flex;flex-direction:column;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:var(--bg-2);transition:transform .35s cubic-bezier(.2,.8,.2,1),border-color .3s,box-shadow .35s}
.release:hover{transform:translateY(-6px);border-color:var(--accent);box-shadow:0 18px 50px -20px var(--accent)}
.release__art{position:relative;aspect-ratio:1;overflow:hidden;background:var(--accent)}
.release__cover-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s cubic-bezier(.2,.8,.2,1),filter .4s}
.release:hover .release__cover-img{transform:scale(1.06)}
.release__art::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,.5));pointer-events:none;opacity:0;transition:opacity .3s}
.release:hover .release__art::after{opacity:1}
.release__play{position:absolute;right:14px;bottom:14px;width:46px;height:46px;border-radius:50%;background:var(--accent);color:#000;display:grid;place-items:center;transform:translateY(10px);opacity:0;transition:transform .3s,opacity .3s;z-index:2;box-shadow:0 8px 24px rgba(0,0,0,.4)}
.release__play svg{width:18px;height:18px}
.release:hover .release__play{transform:translateY(0);opacity:1}
.release__body{padding:18px 18px 22px}
.release__meta{display:flex;justify-content:space-between;font-size:10px;letter-spacing:.2em;color:var(--mute);margin-bottom:10px;text-transform:uppercase}
.release__title{font-family:"Miratrix","Firs";font-weight:400;font-size:20px;letter-spacing:.01em;text-transform:uppercase;line-height:1.1}
.release__artist{color:var(--mute);font-size:13px;margin-top:4px}

/* Brand triangle border treatment (from deck p11/p13) */
.tri-border{
  --tri-c1:var(--c-pink);
  --tri-c2:var(--c-gold);
  height:18px;
  background-image:
    linear-gradient(45deg,var(--tri-c1) 25%,transparent 25%),
    linear-gradient(-45deg,var(--tri-c1) 25%,transparent 25%),
    linear-gradient(45deg,transparent 75%,var(--tri-c2) 75%),
    linear-gradient(-45deg,transparent 75%,var(--tri-c2) 75%);
  background-size:18px 18px;
  background-position:0 0,0 9px,9px -9px,9px 0;
}

/* PARTIES */
.parties{max-width:1280px;margin:0 auto;list-style:none;display:flex;flex-direction:column;gap:2px;border-top:1px solid var(--line)}
.party{display:grid;grid-template-columns:120px 1fr auto auto;gap:24px;align-items:center;padding:28px 8px;border-bottom:1px solid var(--line);transition:background .3s,padding-left .3s}
.party:hover{background:rgba(255,45,135,.05);padding-left:24px}
.party__date{display:flex;flex-direction:column;align-items:center;font-family:"Miratrix","Firs";font-weight:400}
.party__day{font-size:40px;line-height:1;letter-spacing:.01em}
.party__mo{font-size:12px;letter-spacing:.3em;color:var(--mute);margin-top:4px}
.party__info h3{font-size:22px;font-weight:700;letter-spacing:-.01em}
.party__info p{color:var(--mute);margin-top:4px;font-size:14px}
.party__tags{display:flex;gap:8px}
.party__tags span{padding:5px 10px;border:1px solid var(--line);border-radius:999px;font-size:10px;letter-spacing:.18em;color:var(--mute);text-transform:uppercase}
.party__cta{font-size:13px;font-weight:600;letter-spacing:.06em;color:var(--pink);white-space:nowrap}
.party__cta:hover{color:#fff}
@media (max-width:780px){.party{grid-template-columns:80px 1fr;grid-template-rows:auto auto}.party__tags,.party__cta{grid-column:2}.party__day{font-size:36px}}

/* ROSTER */
.roster{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
@media (max-width:780px){.roster{grid-template-columns:repeat(2,1fr)}}
.artist{background:var(--bg);padding:38px 24px;display:flex;flex-direction:column;gap:8px;cursor:pointer;transition:background .3s,color .3s;position:relative;overflow:hidden}
.artist::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--pink),var(--violet));transform:translateY(100%);transition:transform .4s cubic-bezier(.2,.8,.2,1);z-index:0}
.artist:hover::before{transform:translateY(0)}
.artist span,.artist em{position:relative;z-index:1}
.artist span{font-family:"Miratrix","Firs";font-weight:400;font-size:24px;letter-spacing:.01em;text-transform:uppercase}
.artist em{font-style:normal;font-size:11px;letter-spacing:.2em;color:var(--mute);text-transform:uppercase}
.artist:hover em{color:rgba(0,0,0,.7)}
.artist:hover span{color:#000}

/* ABOUT */
.about{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1.2fr 1fr;gap:80px;align-items:center}
@media (max-width:980px){.about{grid-template-columns:1fr}}
.about__copy p{color:#cfcfd6;font-size:17px;line-height:1.7;margin-top:18px;max-width:55ch}
.about__actions{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}
.about__visual{display:grid;place-items:center}
.vinyl{width:min(440px,90%);aspect-ratio:1;position:relative}
.vinyl__disc{position:absolute;inset:0;border-radius:50%;background:
  radial-gradient(circle,#1a1a1f 0,#1a1a1f 18%,#0a0a0c 18.5%,#0a0a0c 22%,#1a1a1f 22.5%,#1a1a1f 26%,#0a0a0c 26.5%,#0a0a0c 30%,#1a1a1f 30.5%,#1a1a1f 36%,#0a0a0c 36.5%,#0a0a0c 40%,#1a1a1f 40.5%,#1a1a1f 46%,#0a0a0c 46.5%,#0a0a0c 50%,#1a1a1f 50.5%);
  box-shadow:0 30px 80px rgba(255,45,135,.25),inset 0 0 60px rgba(0,0,0,.6);
  animation:spin 12s linear infinite}
.vinyl__label{position:absolute;inset:32%;border-radius:50%;background:radial-gradient(circle,var(--c-pink),var(--c-brightpurple));display:grid;place-items:center;font-family:"Miratrix";font-weight:400;font-size:32px;color:var(--c-gold);letter-spacing:.02em;box-shadow:inset 0 0 0 4px rgba(0,0,0,.2);text-transform:uppercase}
.vinyl__label::after{content:"";position:absolute;width:10px;height:10px;border-radius:50%;background:#000}
@keyframes spin{to{transform:rotate(360deg)}}

/* CONTACT */
.contact{max-width:1080px;margin:0 auto;text-align:center}
.contact__title{font-family:"Miratrix","Firs";font-weight:400;font-size:clamp(40px,6vw,84px);line-height:1.02;letter-spacing:.005em;text-transform:uppercase}
.contact__title em{font-style:normal;background:linear-gradient(120deg,var(--c-pink),var(--c-gold) 60%,var(--c-orange));-webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block;padding-right:.15em}
.contact p{color:var(--mute);margin-top:14px;font-size:17px}
.contact__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:48px}
@media (max-width:780px){.contact__grid{grid-template-columns:1fr}}
.contact__card{display:flex;flex-direction:column;align-items:flex-start;gap:8px;padding:28px;border:1px solid var(--line);border-radius:16px;background:var(--bg-2);transition:border-color .3s,transform .3s,background .3s;text-align:left}
.contact__card:hover{border-color:var(--pink);transform:translateY(-4px);background:rgba(255,45,135,.05)}
.contact__role{font-size:11px;letter-spacing:.3em;color:var(--pink);text-transform:uppercase}
.contact__email{font-family:"Miratrix","Firs";font-weight:400;font-size:20px;letter-spacing:.01em;text-transform:uppercase}
.socials{margin-top:48px;display:flex;justify-content:center;gap:14px;flex-wrap:wrap;font-size:13px;letter-spacing:.1em;color:var(--mute)}
.socials a{color:var(--ink);border-bottom:1px solid transparent;transition:border-color .2s,color .2s}
.socials a:hover{border-color:var(--pink);color:var(--pink)}

/* FOOT */
.foot{padding:64px 36px;border-top:1px solid var(--line);display:flex;flex-direction:column;align-items:center;gap:24px}
.foot img{height:28px;opacity:.7}
.foot__row{display:flex;gap:32px;font-size:11px;letter-spacing:.2em;color:var(--mute);text-transform:uppercase;flex-wrap:wrap;justify-content:center}

/* reveal-on-scroll */
.reveal-up{opacity:0;transform:translateY(40px);transition:opacity .9s cubic-bezier(.2,.8,.2,1),transform .9s cubic-bezier(.2,.8,.2,1)}
.reveal-up.is-in{opacity:1;transform:translateY(0)}

@media (max-width:520px){
  .hero{padding:120px 18px 60px}
  .section{padding:80px 18px}
  .hero__stats{gap:28px;margin-top:40px}
  .hero__stats strong{font-size:28px}
}

/* ===== BURGER ===== */
.nav__burger{display:none;width:42px;height:42px;border:1px solid var(--line);background:rgba(0,0,0,.4);border-radius:12px;padding:0;cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.nav__burger span{display:block;width:18px;height:2px;background:#fff;border-radius:2px;transition:transform .3s,opacity .3s}
@media (max-width:780px){
  .nav__burger{display:flex}
  .nav__cta{display:none}
}

/* ===== MOBILE MENU ===== */
.menu{position:fixed;top:0;right:0;bottom:0;width:min(420px,88vw);z-index:400;background:#0a0a0d;border-left:1px solid var(--line);transform:translateX(100%);transition:transform .45s cubic-bezier(.6,.0,.2,1);overflow-y:auto;visibility:hidden}
.menu.is-open{transform:translateX(0);visibility:visible}
body.menu-open{overflow:hidden}
.menu__backdrop{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);z-index:399;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.menu__backdrop.is-open{opacity:1;visibility:visible}
.menu__inner{padding:28px 28px 40px;min-height:100%;display:flex;flex-direction:column}
.menu__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:48px}
.menu__top img{height:22px}
.menu__close{width:42px;height:42px;border:1px solid var(--line);background:transparent;border-radius:12px;color:#fff;cursor:pointer;display:grid;place-items:center}
.menu__close:hover{background:var(--pink);color:#000;border-color:var(--pink)}
.menu__links{display:flex;flex-direction:column;gap:4px;margin-bottom:32px}
.menu__links a{display:flex;align-items:baseline;justify-content:space-between;padding:16px 4px;border-bottom:1px solid var(--line);font-family:"Miratrix","Firs";font-weight:400;font-size:30px;letter-spacing:.01em;transition:padding .3s,color .3s;text-transform:uppercase}
.menu__links a em{font-style:normal;font-size:11px;letter-spacing:.3em;color:var(--mute);font-weight:500}
.menu__links a:hover,.menu__links a:active{padding-left:14px;color:var(--c-magenta)}
.menu__cta{margin-bottom:32px}
.menu__cta .btn{width:100%;justify-content:center}
.menu__socials{display:flex;flex-direction:column;gap:14px;padding-top:24px;border-top:1px solid var(--line)}
.menu__socials a{font-size:14px;letter-spacing:.06em;color:#ddd;transition:color .2s}
.menu__socials a:hover{color:var(--c-magenta)}
.menu__foot{margin-top:auto;padding-top:32px;font-size:11px;letter-spacing:.3em;color:var(--mute);text-align:center}

/* burger animation when open */
.nav__burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger.is-open span:nth-child(2){opacity:0}
.nav__burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== PLAYLIST MOSAIC TILE ===== */
.release__mosaic{position:absolute;inset:0;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:2px;background:#000}
.release__mosaic img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s cubic-bezier(.2,.8,.2,1)}
.release--playlist:hover .release__mosaic img{transform:scale(1.05)}
.release__badge{position:absolute;top:12px;left:12px;padding:6px 10px;font-size:10px;letter-spacing:.25em;font-weight:700;background:var(--accent);color:#000;border-radius:6px;z-index:2}

/* ===== VIEW MORE ===== */
.btn--viewmore{display:none;margin-bottom:16px;background:var(--c-magenta);color:#000;border:none}
.btn--viewmore:hover{background:var(--c-orange)}
.releases.is-collapsed .release--extra{display:none}

@media (max-width:780px){
  .btn--viewmore{display:inline-flex}
  .section__foot{display:flex;flex-direction:column;gap:14px;align-items:center}
}
