/* ============================================================
   MELLI DORELLI — disco · cosmic coast · italo
   ============================================================ */
:root{
  --navy:#070b1f;
  --navy2:#0d1530;
  --teal:#0d2a3a;
  --coral:#ff6b35;
  --magenta:#ff2e7e;
  --pink:#ff77c6;
  --gold:#ffd166;
  --copper:#e8a87c;
  --cream:#fff4e6;
  --silver:#cfd6e6;
  --ink:#eaf0ff;
  --muted:#9aa6c4;
  --grad-hot:linear-gradient(100deg,#ff2e7e,#ff6b35 55%,#ffd166);
  --grad-cool:linear-gradient(120deg,#3b2bff,#ff2e7e 60%,#ff6b35);
  --shadow:0 20px 60px rgba(0,0,0,.5);
  --ease:cubic-bezier(.2,.7,.2,1);
  --maxw:1180px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Poppins',system-ui,sans-serif;
  background:var(--navy);
  color:var(--ink);
  overflow-x:hidden;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img,video{display:block;max-width:100%}
section{position:relative}
section[id]{scroll-margin-top:84px}   /* offset for fixed nav on anchor jumps */
em{font-family:'Playfair Display',serif;font-style:italic}

/* ---------- global FX overlays ---------- */
.grain{position:fixed;inset:0;z-index:9990;pointer-events:none;opacity:.06;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;animation:grain .6s steps(2) infinite}
@keyframes grain{0%{transform:translate(0,0)}50%{transform:translate(-4%,3%)}100%{transform:translate(3%,-2%)}}
.scanlines{position:fixed;inset:0;z-index:9989;pointer-events:none;opacity:.25;
  background:repeating-linear-gradient(to bottom,transparent 0 3px,rgba(0,0,0,.18) 3px 4px)}
#sparkles{position:fixed;inset:0;z-index:9988;pointer-events:none}
.spark{position:absolute;width:3px;height:3px;border-radius:50%;background:#fff;
  box-shadow:0 0 6px 1px #fff,0 0 12px 2px var(--pink);animation:twinkle linear infinite}
@keyframes twinkle{0%,100%{opacity:0;transform:scale(.4)}50%{opacity:1;transform:scale(1.2)}}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:'Poppins';font-weight:600;font-size:.95rem;letter-spacing:.03em;
  padding:.85em 1.6em;border-radius:999px;border:none;cursor:pointer;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),filter .25s;
}
.btn--glow{background:var(--grad-hot);color:#1a0010;box-shadow:0 8px 30px rgba(255,46,126,.5)}
.btn--glow:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 14px 44px rgba(255,107,53,.65);filter:saturate(1.2)}
.btn--ghost{background:rgba(255,255,255,.06);color:var(--ink);border:1px solid rgba(255,255,255,.25);backdrop-filter:blur(6px)}
.btn--ghost:hover{transform:translateY(-3px);border-color:var(--pink);box-shadow:0 0 24px rgba(255,119,198,.4)}

/* ---------- section heads ---------- */
.section-head{max-width:var(--maxw);margin:0 auto 2.5rem;padding:0 6vw}
.section-head--center{text-align:center}
.kicker{display:inline-block;font-weight:600;letter-spacing:.25em;text-transform:uppercase;
  font-size:.72rem;color:var(--pink);margin-bottom:.6rem}
.section-head h2{font-family:'Anton';font-weight:400;letter-spacing:.01em;line-height:.95;
  font-size:clamp(2.4rem,7vw,5rem);text-transform:uppercase;
  background:var(--grad-hot);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ============================================================ NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem 6vw;transition:background .4s,padding .4s,backdrop-filter .4s}
.nav.scrolled{background:rgba(7,11,31,.82);backdrop-filter:blur(14px);padding:.7rem 6vw;
  box-shadow:0 6px 30px rgba(0,0,0,.5)}
.nav__logo{font-family:'Anton';font-size:1.25rem;letter-spacing:.08em}
.nav__logo span{background:var(--grad-hot);-webkit-background-clip:text;background-clip:text;color:transparent}
.nav__links{display:flex;gap:1.35rem}
.nav__links a{font-weight:500;font-size:.9rem;position:relative;opacity:.85;transition:opacity .2s}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:2px;
  background:var(--grad-hot);transition:width .3s var(--ease)}
.nav__links a:hover{opacity:1}
.nav__links a:hover::after,.nav__links a.active::after{width:100%}
.nav__links a.active{opacity:1}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer}
.nav__burger span{width:26px;height:2px;background:var(--ink);transition:.3s}

/* ============================================================ HERO */
.hero{height:100svh;min-height:620px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;overflow:hidden}
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
  filter:saturate(1.15) contrast(1.05)}
.hero__veil{position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(120% 80% at 50% 0%,transparent,rgba(7,11,31,.4) 60%,var(--navy) 100%),
    linear-gradient(180deg,rgba(7,11,31,.55),rgba(7,11,31,.15) 40%,rgba(7,11,31,.9))}
.hero__content{position:relative;z-index:3;padding:0 6vw;animation:rise 1s var(--ease) both}
.hero__eyebrow{letter-spacing:.34em;font-size:.7rem;font-weight:600;color:var(--copper);
  text-transform:uppercase;margin-bottom:1.1rem;opacity:.9}
.hero__title{font-family:'Anton';line-height:.92;text-transform:uppercase;
  font-size:clamp(3.6rem,16vw,11rem);letter-spacing:.05em}
.hero__title .line{display:block;overflow:visible}
.hero__title .outline{padding-top:.06em}
.hero__title .line:first-child{background:var(--grad-hot);-webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 6px 30px rgba(255,46,126,.5))}
.hero__title .outline{color:transparent;-webkit-text-stroke:1.25px var(--cream);
  text-shadow:0 0 26px rgba(255,209,102,.28)}
.hero__tag{margin-top:1.2rem;font-size:clamp(1rem,2.4vw,1.4rem);color:var(--cream)}
.hero__tag em{color:var(--gold)}
.hero__cta{margin-top:2rem;display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* disco ball */
.discoball{position:absolute;top:9%;left:50%;transform:translateX(-50%);z-index:2;
  width:74px;height:74px;border-radius:50%;
  background:
    radial-gradient(circle at 32% 30%,#fff,rgba(255,255,255,.1) 40%,transparent 41%),
    conic-gradient(from 0deg,#ff77c6,#ffd166,#7ad0ff,#ff77c6,#ffd166,#7ad0ff,#ff77c6);
  background-size:auto,8px 8px;
  box-shadow:inset 0 0 20px rgba(0,0,0,.45),0 8px 22px rgba(0,0,0,.45);
  filter:saturate(1.15);animation:spin 8s linear infinite}
@keyframes spin{to{transform:translateX(-50%) rotate(360deg)}}

/* ticker */
.ticker{position:absolute;bottom:54px;left:0;right:0;z-index:3;overflow:hidden;
  border-top:1px solid rgba(255,255,255,.12);border-bottom:1px solid rgba(255,255,255,.12);
  background:rgba(255,46,126,.08);padding:.55rem 0}
.ticker__track{display:flex;white-space:nowrap;animation:marquee 22s linear infinite;will-change:transform}
.ticker__track span{font-family:'Anton';letter-spacing:.12em;font-size:1rem;color:var(--gold)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

.hero__scroll{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);z-index:3;
  font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}
.hero__scroll span{display:block;text-align:center;animation:bob 1.6s ease-in-out infinite;font-size:1rem}
@keyframes bob{50%{transform:translateY(6px)}}
@keyframes rise{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:none}}

/* ============================================================ OUT NOW / PLAYER */
.outnow{padding:7rem 0 6rem}
.player{max-width:var(--maxw);margin:0 auto;padding:0 6vw;
  display:grid;grid-template-columns:minmax(0,360px) 1fr;gap:3.2rem;align-items:center}
.player__art{position:relative}
.player__spin{position:absolute;top:50%;right:-46px;transform:translateY(-50%);
  width:120px;height:120px;border-radius:50%;z-index:-1;
  background:repeating-radial-gradient(circle,#111 0 6px,#1c1c1c 6px 8px);
  border:2px solid #000;box-shadow:0 10px 30px rgba(0,0,0,.6)}
.player__spin::after{content:"";position:absolute;inset:42px;border-radius:50%;
  background:var(--grad-hot)}
.player.playing .player__spin{animation:spin 3s linear infinite}
.player__cover{width:100%;border-radius:18px;box-shadow:var(--shadow);display:block;position:relative;z-index:1}
.player.playing .player__cover,.player.playing .cover-art{animation:pulse 2.2s ease-in-out infinite}
@keyframes pulse{50%{box-shadow:0 0 0 6px rgba(255,46,126,.18),var(--shadow)}}

/* CSS cover art — Madonna delle Onde */
.cover-art{position:relative;aspect-ratio:1;border-radius:18px;overflow:hidden;
  box-shadow:var(--shadow);background:linear-gradient(180deg,#0a1733,#14253f 40%,#0b1a2e)}
.cover-art--waves{}
.cover-art__moon{position:absolute;top:16%;left:50%;transform:translateX(-50%);
  width:78px;height:78px;border-radius:50%;
  background:radial-gradient(circle at 38% 35%,#fff6e0,#ffd166 60%,#e8a87c);
  box-shadow:0 0 50px 14px rgba(255,209,102,.6)}
.cover-art__waves{position:absolute;left:0;right:0;bottom:0;height:55%}
.cover-art__waves i{position:absolute;left:-20%;right:-20%;bottom:0;height:60%;border-radius:50%;
  background:linear-gradient(180deg,rgba(255,119,198,.5),rgba(59,43,255,.35));
  animation:wave 6s ease-in-out infinite}
.cover-art__waves i:nth-child(1){bottom:0;opacity:.9}
.cover-art__waves i:nth-child(2){bottom:18%;height:50%;opacity:.6;animation-duration:8s;animation-direction:reverse}
.cover-art__waves i:nth-child(3){bottom:34%;height:42%;opacity:.4;animation-duration:10s}
@keyframes wave{50%{transform:translateX(6%) translateY(-6%) scale(1.05)}}
.cover-art__title{position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:.1em;font-family:'Anton';
  text-transform:uppercase;letter-spacing:.08em;color:var(--cream);
  text-shadow:0 2px 18px rgba(0,0,0,.6);z-index:2}
.cover-art__title span{font-size:clamp(1.4rem,4vw,2.1rem);line-height:1}
.cover-art__title span:nth-child(2){font-size:1rem;color:var(--gold);letter-spacing:.3em}

.player__meta{letter-spacing:.2em;font-size:.72rem;color:var(--muted);text-transform:uppercase;margin-bottom:.4rem}
.player__track{font-family:'Anton';font-size:clamp(2rem,5vw,3.2rem);line-height:1;text-transform:uppercase}
.player__desc{color:var(--muted);max-width:46ch;margin:1rem 0 1.6rem}
.player__desc em{color:var(--gold)}

/* audio player widget */
.ap{display:flex;align-items:center;gap:1rem;background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:1rem 1.2rem;backdrop-filter:blur(8px)}
.ap__play{flex:none;width:58px;height:58px;border-radius:50%;border:none;cursor:pointer;
  background:var(--grad-hot);color:#1a0010;display:grid;place-items:center;
  box-shadow:0 8px 24px rgba(255,46,126,.45);transition:transform .2s}
.ap__play:hover{transform:scale(1.07)}
.ap__play svg{width:26px;height:26px;fill:#1a0010}
.ap__icon-pause{display:none}
.ap.playing .ap__icon-play{display:none}
.ap.playing .ap__icon-pause{display:block}
.ap__main{flex:1;min-width:0}
.ap__bars{display:flex;align-items:flex-end;gap:3px;height:26px;margin-bottom:.5rem}
.ap__bars i{flex:1;background:linear-gradient(var(--gold),var(--magenta));border-radius:3px;
  height:20%;transition:height .12s}
.ap__seek{height:6px;border-radius:6px;background:rgba(255,255,255,.14);cursor:pointer;position:relative}
.ap__seek-fill{height:100%;width:0;border-radius:6px;background:var(--grad-hot);position:relative}
.ap__seek-fill::after{content:"";position:absolute;right:-6px;top:50%;transform:translateY(-50%);
  width:12px;height:12px;border-radius:50%;background:#fff;box-shadow:0 0 10px var(--pink)}
.ap__time{display:flex;justify-content:space-between;font-size:.72rem;color:var(--muted);margin-top:.4rem}

.player__smartlink{margin-top:1.5rem}
.listen__smartlink{margin-top:1.4rem}
.listen__embed{max-width:680px;margin:0 auto 2.4rem;padding:0 6vw}
.listen__embed iframe{display:block;width:100%;border-radius:14px;box-shadow:var(--shadow)}
.streaming{display:flex;align-items:center;flex-wrap:wrap;gap:.6rem;margin-top:1.2rem}
.streaming__label{font-size:.78rem;color:var(--muted);margin-right:.2rem}
.chip{font-size:.82rem;font-weight:500;padding:.5em 1em;border-radius:999px;
  border:1px solid rgba(255,255,255,.2);transition:.25s;background:rgba(255,255,255,.03)}
.chip:hover{border-color:var(--pink);color:var(--pink);box-shadow:0 0 18px rgba(255,46,126,.3);transform:translateY(-2px)}
.chip.is-soon{opacity:.5;cursor:default}
.chip.is-soon:hover{transform:none;border-color:rgba(255,255,255,.2);color:inherit;box-shadow:none}

/* ============================================================ LISTEN EVERYWHERE */
.listen{padding:5.5rem 0 5rem;
  background:radial-gradient(70% 60% at 50% 0%,rgba(59,43,255,.10),transparent 60%)}
.listen__sub{color:var(--muted);margin-top:.5rem}
.listen__sub span{color:var(--pink);font-weight:600;white-space:nowrap}
.listen__grid{max-width:var(--maxw);margin:0 auto;padding:0 6vw;
  display:flex;flex-wrap:wrap;justify-content:center;gap:.7rem}
.plat{display:inline-flex;align-items:center;gap:.5rem;
  padding:.62em 1.1em;border-radius:999px;font-size:.9rem;font-weight:500;color:var(--silver);
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.14);
  transition:transform .22s var(--ease),border-color .22s,box-shadow .22s,color .22s,background .22s}
.plat:hover{transform:translateY(-3px);color:#fff;border-color:var(--pink);
  box-shadow:0 10px 26px rgba(255,46,126,.28)}
.plat__arrow{font-size:.85rem;opacity:.5;transition:opacity .22s,transform .22s}
.plat:hover .plat__arrow{opacity:1;transform:translate(2px,-2px)}
.plat--exact{background:linear-gradient(135deg,rgba(255,46,126,.16),rgba(255,107,53,.1));
  border-color:rgba(255,46,126,.45);color:var(--cream)}
.plat--exact:hover{box-shadow:0 10px 28px rgba(255,46,126,.4)}
.plat__tick{display:grid;place-items:center;width:18px;height:18px;border-radius:50%;
  background:var(--grad-hot);color:#1a0010;font-size:.7rem;font-weight:800}

/* ============================================================ DISCOGRAPHY */
.albums{padding:6rem 0 2rem}
.albums__grid{max-width:var(--maxw);margin:0 auto;padding:0 6vw;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.8rem;align-items:start}
.album-card{display:flex;flex-direction:column;border-radius:20px;overflow:hidden;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow);
  transition:transform .35s var(--ease),box-shadow .35s,border-color .35s}
.album-card:hover{transform:translateY(-6px);border-color:var(--pink);box-shadow:0 22px 56px rgba(255,46,126,.28)}
.album-card__art{position:relative;aspect-ratio:1;overflow:hidden}
.album-card__art img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.album-card:hover .album-card__art img{transform:scale(1.05)}
.album-card__badge{position:absolute;top:1rem;left:1rem;font-family:'Anton';letter-spacing:.1em;
  font-size:.72rem;padding:.35em .8em;border-radius:999px;background:var(--grad-hot);color:#1a0010;
  box-shadow:0 6px 18px rgba(255,46,126,.5)}
.album-card__body{padding:1.4rem 1.5rem 1.6rem;display:flex;flex-direction:column;flex:1}
.album-card__meta{letter-spacing:.2em;text-transform:uppercase;font-size:.68rem;color:var(--muted)}
.album-card__title{font-family:'Anton';text-transform:uppercase;font-size:clamp(1.8rem,4vw,2.6rem);
  line-height:1;margin:.3rem 0 1rem;background:var(--grad-hot);-webkit-background-clip:text;background-clip:text;color:transparent}
.album-card__feat{font-family:'Playfair Display';font-style:italic;color:var(--copper);margin:-.6rem 0 1rem;font-size:.95rem}
.album-card__blurb{color:var(--muted);font-size:.95rem;line-height:1.7;margin:0 0 1.3rem}
.album-card__list{list-style:none;display:grid;gap:.45rem;margin:0 0 1.4rem}
.album-card__list li{display:flex;align-items:baseline;gap:.7rem;font-size:.92rem;color:var(--silver);
  border-bottom:1px solid rgba(255,255,255,.07);padding-bottom:.45rem}
.album-card__num{font-family:'Anton';font-size:.85rem;color:var(--pink);min-width:1.6em;opacity:.8}
.album-card__cta{align-self:flex-start;margin-top:auto}

/* singles sub-grid (smaller cards) */
.albums__subhead{margin-top:3.5rem;margin-bottom:1.8rem}
.singles__grid{max-width:var(--maxw);margin:0 auto;padding:0 6vw;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:1.4rem;align-items:start}
.album-card--single .album-card__title{font-size:clamp(1.3rem,3vw,1.8rem)}
.album-card--single .album-card__body{padding:1.1rem 1.2rem 1.3rem}
.album-card--single .album-card__cta{font-size:.85rem;padding:.7em 1.3em}

/* ============================================================ ITALY ALBUM */
.italy{padding:7rem 0 7rem;overflow:hidden}
.italy__bg{position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(60% 50% at 80% 10%,rgba(255,46,126,.18),transparent 60%),
    radial-gradient(60% 50% at 15% 90%,rgba(59,43,255,.22),transparent 60%),
    linear-gradient(180deg,var(--navy),#0a1430 50%,var(--navy))}
.italy>*{position:relative;z-index:1}
.italy__title{font-size:clamp(4rem,18vw,12rem)!important;letter-spacing:.04em!important}
.italy__sub{color:var(--copper);font-family:'Playfair Display';font-style:italic;font-size:clamp(1rem,2.5vw,1.4rem);margin-top:.4rem}

/* countdown */
.countdown{max-width:640px;margin:0 auto 2.5rem;text-align:center;padding:0 6vw}
.countdown__label{letter-spacing:.25em;text-transform:uppercase;font-size:.72rem;color:var(--muted);margin-bottom:1rem}
.countdown__clock{display:flex;justify-content:center;gap:1rem}
.cd{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);border-radius:16px;
  padding:1rem 1.3rem;min-width:92px;backdrop-filter:blur(8px);box-shadow:var(--shadow)}
.cd span{display:block;font-family:'Anton';font-size:clamp(2rem,7vw,3.4rem);line-height:1;
  background:var(--grad-hot);-webkit-background-clip:text;background-clip:text;color:transparent}
.cd small{display:block;letter-spacing:.2em;text-transform:uppercase;font-size:.6rem;color:var(--muted);margin-top:.3rem}
.countdown__next{margin-top:1rem;font-family:'Playfair Display';font-style:italic;color:var(--gold);font-size:1.05rem;min-height:1.4em}
.countdown__presave{display:inline-flex;align-items:center;gap:.5em;margin-top:.9rem;
  padding:.6em 1.3em;border-radius:999px;font-weight:600;font-size:.9rem;color:#1a0010;
  background:var(--grad-hot);box-shadow:0 8px 24px rgba(255,46,126,.4);
  transition:transform .22s var(--ease),box-shadow .22s,filter .22s}
.countdown__presave:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(255,107,53,.55);filter:saturate(1.15)}
.countdown__hint{margin:.9rem auto 0;max-width:46ch;font-size:.82rem;color:var(--muted);line-height:1.6}
.countdown.complete .countdown__clock{display:none}

/* progress */
.album-progress{max-width:520px;margin:0 auto 3rem;text-align:center;padding:0 6vw}
.album-progress__bar{height:8px;border-radius:8px;background:rgba(255,255,255,.1);overflow:hidden}
.album-progress__fill{height:100%;width:0;border-radius:8px;background:var(--grad-hot);
  transition:width 1s var(--ease);box-shadow:0 0 14px rgba(255,46,126,.6)}
.album-progress__text{margin-top:.7rem;font-size:.82rem;color:var(--muted)}
.album-progress__text span{color:var(--gold);font-weight:700}

/* tracklist */
.tracklist{list-style:none;max-width:var(--maxw);margin:0 auto;padding:0 6vw;
  display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1rem;counter-reset:t}
.track{position:relative;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.03);padding:1.2rem;min-height:140px;
  display:flex;flex-direction:column;justify-content:space-between;
  transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;counter-increment:t}
.track::before{content:counter(t,decimal-leading-zero);position:absolute;top:.6rem;right:.9rem;
  font-family:'Anton';font-size:2.6rem;line-height:1;opacity:.12}
.track--out{border-color:rgba(255,46,126,.4);background:linear-gradient(135deg,rgba(255,46,126,.12),rgba(255,107,53,.06))}
.track--out:hover{transform:translateY(-6px);box-shadow:0 18px 44px rgba(255,46,126,.3);border-color:var(--pink)}
.track--today{box-shadow:0 0 0 2px var(--gold),0 16px 40px rgba(255,209,102,.25)}
.track--cover{background-size:cover!important;background-position:center!important}
.track--locked{filter:grayscale(.3)}
.track__status{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600}
.track--out .track__status{color:var(--pink)}
.track--locked .track__status{color:var(--muted)}
.track--today .track__status{color:var(--gold)}
.track--today{animation:todayGlow 2.6s ease-in-out infinite}
@keyframes todayGlow{0%,100%{box-shadow:0 0 0 2px var(--gold),0 16px 40px rgba(255,209,102,.2)}50%{box-shadow:0 0 0 2px var(--gold),0 16px 54px rgba(255,209,102,.5)}}
.track__name{font-family:'Anton';font-size:1.35rem;line-height:1.05;text-transform:uppercase;margin:.5rem 0 .2rem}
.track--locked .track__name{opacity:.8;color:var(--silver)}
.track__date{font-size:.72rem;color:var(--muted)}
.track__btn{margin-top:.8rem;align-self:flex-start;font-size:.78rem;font-weight:600;
  padding:.45em 1em;border-radius:999px;background:var(--grad-hot);color:#1a0010;border:none;cursor:pointer;
  transition:transform .2s}
.track__btn:hover{transform:scale(1.05)}
a.track__btn{text-decoration:none}
.track__btn--ghost{background:transparent;border:1px solid rgba(255,255,255,.28);color:var(--ink);margin-top:.55rem}
.track__btn--ghost:hover{border-color:var(--pink);color:var(--pink)}
.track__lock{margin-top:.8rem;font-size:.78rem;color:var(--muted)}
.track__lock::before{content:"🔒 ";}

/* ============================================================ BIO */
.bio{max-width:var(--maxw);margin:0 auto;padding:7rem 6vw;
  display:grid;grid-template-columns:0.9fr 1.1fr;gap:3.5rem;align-items:center}
.bio__photo{position:relative;border-radius:20px;overflow:hidden;box-shadow:var(--shadow)}
.bio__photo img{width:100%;height:100%;object-fit:cover;border-radius:20px}
.bio__glow{position:absolute;inset:0;border-radius:20px;pointer-events:none;
  box-shadow:inset 0 0 80px rgba(255,46,126,.25);
  background:linear-gradient(180deg,transparent 60%,rgba(7,11,31,.4))}
.bio__text h2{font-family:'Anton';font-weight:400;text-transform:uppercase;line-height:.95;
  font-size:clamp(2rem,5vw,3.4rem);margin:.4rem 0 1.2rem}
.bio__lead{font-size:1.12rem;color:var(--cream)}
.bio__text p{color:var(--muted);margin-bottom:1rem;max-width:54ch}
.bio__text p strong{color:var(--ink)}
.bio__sign{color:var(--ink)!important}
.bio__facts{list-style:none;display:grid;gap:.7rem;margin-top:1.6rem}
.bio__facts li{display:flex;gap:1rem;align-items:baseline;border-top:1px solid rgba(255,255,255,.1);padding-top:.7rem}
.bio__facts strong{min-width:70px;color:var(--pink);font-size:.72rem;letter-spacing:.15em;text-transform:uppercase}
.bio__facts span{color:var(--silver);font-size:.95rem}

/* ============================================================ STORIES */
.stories{padding:6rem 0 4rem;
  background:radial-gradient(70% 60% at 50% 0%,rgba(59,43,255,.12),transparent 60%)}
.stories__sub{color:var(--copper);font-family:'Playfair Display';font-style:italic;
  font-size:clamp(1rem,2.4vw,1.25rem);margin-top:.5rem}
.stories__grid{max-width:var(--maxw);margin:0 auto;padding:0 6vw;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.4rem}
.story-card{position:relative;border-radius:18px;padding:1.8rem 1.7rem;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow);
  transition:transform .35s var(--ease),border-color .35s,box-shadow .35s}
.story-card::before{content:"\201C";position:absolute;top:.2rem;right:1.1rem;
  font-family:'Playfair Display';font-size:5rem;line-height:1;color:var(--magenta);opacity:.18}
.story-card:hover{transform:translateY(-5px);border-color:var(--pink);box-shadow:0 18px 46px rgba(255,46,126,.22)}
.story-card__eyebrow{display:inline-block;letter-spacing:.18em;text-transform:uppercase;
  font-size:.66rem;font-weight:600;color:var(--pink);margin-bottom:.6rem}
.story-card__title{font-family:'Playfair Display';font-style:italic;font-weight:600;
  font-size:1.5rem;line-height:1.15;margin-bottom:.7rem;color:var(--cream)}
.story-card__body{color:var(--muted);font-size:.96rem;line-height:1.7}

/* ============================================================ HISTORY / TIMELINE */
.history{padding:6rem 0 6rem;
  background:radial-gradient(70% 60% at 50% 0%,rgba(255,46,126,.08),transparent 60%)}
.history__sub{color:var(--copper);font-family:'Playfair Display';font-style:italic;
  font-size:clamp(1rem,2.4vw,1.25rem);margin:.5rem auto 0;max-width:58ch}
.timeline{list-style:none;max-width:760px;margin:2.6rem auto 0;padding:0 6vw}
.tl__item{position:relative;padding:0 0 1.5rem 44px}
.tl__item::before{content:"";position:absolute;left:11px;top:16px;bottom:0;width:2px;
  background:linear-gradient(var(--magenta),var(--coral));opacity:.4}
.tl__item:last-child::before{display:none}
.tl__dot{position:absolute;left:4px;top:4px;width:16px;height:16px;border-radius:50%;
  background:var(--grad-hot);box-shadow:0 0 0 4px rgba(255,46,126,.14),0 0 14px rgba(255,46,126,.55);z-index:1}
.tl__card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);
  border-radius:14px;padding:1.1rem 1.3rem;box-shadow:0 8px 24px rgba(0,0,0,.22);
  transition:border-color .3s,transform .3s var(--ease)}
.tl__item:hover .tl__card{border-color:var(--pink);transform:translateX(3px)}
.tl__year{display:inline-block;font-family:'Anton';font-size:.95rem;letter-spacing:.05em;
  background:var(--grad-hot);-webkit-background-clip:text;background-clip:text;color:transparent}
.tl__title{font-family:'Anton';text-transform:uppercase;font-size:1.25rem;line-height:1;
  margin:.15rem 0 .5rem;color:var(--cream)}
.tl__body{color:var(--muted);font-size:.93rem;line-height:1.7;margin:0}

/* ============================================================ QUIZ */
.quiz{padding:5.5rem 0 6rem;
  background:radial-gradient(70% 60% at 50% 100%,rgba(59,43,255,.10),transparent 60%)}
.quiz__sub{color:var(--copper);font-family:'Playfair Display';font-style:italic;
  margin-top:.5rem;font-size:clamp(1rem,2.4vw,1.2rem)}
.quiz__card{max-width:640px;margin:2.4rem auto 0;padding:1.9rem 1.9rem 2rem;
  background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.12);border-radius:20px;box-shadow:var(--shadow);
  min-height:300px}
.quiz__progress{letter-spacing:.18em;text-transform:uppercase;font-size:.7rem;
  color:var(--pink);font-weight:600;margin-bottom:.8rem}
.quiz__q{font-weight:600;font-size:clamp(1.1rem,2.6vw,1.3rem);line-height:1.35;
  margin-bottom:1.3rem;color:var(--cream)}
.quiz__options{display:grid;gap:.7rem}
.quiz__opt{text-align:left;padding:.9em 1.1em;border-radius:12px;border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.04);color:var(--ink);font:inherit;cursor:pointer;
  transition:transform .2s var(--ease),border-color .2s,background .2s}
.quiz__opt:hover:not(:disabled){border-color:var(--pink);transform:translateX(3px)}
.quiz__opt:disabled{cursor:default}
.quiz__opt.is-correct{border-color:#39d98a;background:rgba(57,217,138,.16);color:#d7ffe9}
.quiz__opt.is-wrong{border-color:#ff5a7a;background:rgba(255,90,122,.16);color:#ffd7df}
.quiz__fact{margin-top:1.1rem;color:var(--muted);font-size:.9rem;line-height:1.65}
.quiz__next{margin-top:1.3rem}
.quiz__result{text-align:center;padding:.5rem 0}
.quiz__score{font-family:'Anton';font-size:4.2rem;line-height:1;
  background:var(--grad-hot);-webkit-background-clip:text;background-clip:text;color:transparent}
.quiz__score span{font-size:1.5rem;-webkit-text-fill-color:var(--muted);color:var(--muted)}
.quiz__tier{font-family:'Anton';text-transform:uppercase;font-size:1.7rem;margin:.5rem 0 .3rem;color:var(--cream)}
.quiz__resultmsg{color:var(--muted);font-family:'Playfair Display';font-style:italic}
.quiz__result-cta{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin-top:1.5rem}

/* ============================================================ FUN: confetti, toast, disco mode */
.confetti{position:fixed;top:-24px;z-index:9995;border-radius:2px;pointer-events:none;
  animation-name:confettiFall;animation-timing-function:cubic-bezier(.3,.6,.4,1);animation-fill-mode:forwards}
@keyframes confettiFall{to{transform:translateY(110vh) rotate(720deg);opacity:.85}}
.toast{position:fixed;bottom:84px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--grad-hot);color:#1a0010;font-weight:700;font-size:.9rem;letter-spacing:.02em;
  padding:.75em 1.4em;border-radius:999px;z-index:9996;box-shadow:0 10px 30px rgba(255,46,126,.5);
  opacity:0;transition:opacity .3s,transform .3s var(--ease);pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
body.disco-mode{animation:discoHue 5s linear infinite}
@keyframes discoHue{to{filter:hue-rotate(360deg)}}
body.disco-mode .discoball{display:block !important}

/* ============================================================ ITALO ALTER-EGO */
.namegen{padding:5.5rem 0 5rem;text-align:center}
.namegen__sub{color:var(--copper);font-family:'Playfair Display';font-style:italic;
  margin-top:.5rem;font-size:clamp(1rem,2.4vw,1.2rem)}
.namegen__box{max-width:520px;margin:2.2rem auto 0;padding:0 6vw;display:flex;gap:.6rem;flex-wrap:wrap;justify-content:center}
.namegen__box input{flex:1;min-width:200px;padding:.85em 1.2em;border-radius:999px;
  border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.05);color:var(--ink);font-family:inherit}
.namegen__box input:focus{outline:none;border-color:var(--pink);box-shadow:0 0 18px rgba(255,46,126,.3)}
.namegen__result{max-width:560px;margin:1.6rem auto 0;padding:1.6rem 1.8rem;
  background:linear-gradient(135deg,rgba(255,46,126,.12),rgba(255,107,53,.07));
  border:1px solid rgba(255,46,126,.4);border-radius:18px;box-shadow:var(--shadow);animation:rise .5s var(--ease)}
.namegen__lead{font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.namegen__name{font-family:'Anton';text-transform:uppercase;font-size:clamp(2rem,6vw,3rem);line-height:1;
  margin:.3rem 0 .5rem;background:var(--grad-hot);-webkit-background-clip:text;background-clip:text;color:transparent}
.namegen__hit{font-family:'Playfair Display';font-style:italic;color:var(--gold);font-size:1.1rem}
.namegen__line{color:var(--muted);margin-top:.6rem;font-size:.92rem}

/* ============================================================ WHICH TRACK / PERSONA */
.persona{padding:5rem 0 6rem}
.persona__sub{color:var(--copper);font-family:'Playfair Display';font-style:italic;
  margin-top:.5rem;font-size:clamp(1rem,2.4vw,1.2rem);text-align:center}
.persona__result{display:flex;gap:1.6rem;align-items:center;flex-wrap:wrap;justify-content:center;text-align:left}
.persona__cover{width:180px;height:180px;border-radius:16px;object-fit:cover;box-shadow:var(--shadow);flex:none}
.persona__info{flex:1;min-width:220px}
.persona__pre{font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.persona__track{font-family:'Anton';text-transform:uppercase;font-size:clamp(1.8rem,5vw,2.6rem);line-height:1;
  margin:.2rem 0 .5rem;background:var(--grad-hot);-webkit-background-clip:text;background-clip:text;color:transparent}
.persona__vibe{color:var(--silver);font-family:'Playfair Display';font-style:italic;font-size:1.05rem}
.persona__cta{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:1.2rem}

/* ============================================================ GALLERY */
.gallery{padding:5rem 0 7rem}
.gallery__grid{max-width:var(--maxw);margin:0 auto;padding:0 6vw;
  display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:1rem}
.g-item{position:relative;border-radius:16px;overflow:hidden;cursor:pointer;
  border:1px solid rgba(255,255,255,.08);box-shadow:var(--shadow)}
.g-item img,.g-item video{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease),filter .4s}
.g-item:hover img,.g-item:hover video{transform:scale(1.08);filter:saturate(1.2)}
.g-item--wide{grid-column:span 2}
.g-item--tall{grid-row:span 2}
.g-item--video{grid-column:span 2}
.g-item figcaption{position:absolute;left:0;right:0;bottom:0;padding:1rem;
  font-family:'Playfair Display';font-style:italic;font-size:.95rem;
  background:linear-gradient(transparent,rgba(7,11,31,.85));transform:translateY(8px);opacity:.9;transition:.3s}
.g-item:hover figcaption{transform:none;opacity:1}
.g-item__play{position:absolute;inset:0;display:grid;place-items:center;font-size:2.4rem;color:#fff;
  text-shadow:0 0 18px rgba(0,0,0,.7);pointer-events:none}

/* ============================================================ FAQ */
.faq{padding:5.5rem 0 6.5rem;
  background:radial-gradient(70% 60% at 50% 0%,rgba(255,46,126,.10),transparent 60%)}
.faq__list{max-width:920px;margin:0 auto;padding:0 6vw;
  columns:300px 2;column-gap:1.1rem;counter-reset:faq}
.faq__item{position:relative;border-radius:16px;overflow:hidden;counter-increment:faq;
  break-inside:avoid;-webkit-column-break-inside:avoid;margin:0 0 1.1rem;
  background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 26px rgba(0,0,0,.25);
  transition:border-color .35s,box-shadow .35s,transform .35s var(--ease)}
.faq__item::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--grad-hot);transform:scaleY(0);transform-origin:top;
  transition:transform .35s var(--ease)}
.faq__item:hover{border-color:rgba(255,119,198,.4);transform:translateY(-2px)}
.faq__item[open]{border-color:rgba(255,46,126,.5);box-shadow:0 16px 42px rgba(255,46,126,.18)}
.faq__item[open]::before{transform:scaleY(1)}
.faq__item summary{cursor:pointer;list-style:none;display:flex;align-items:center;gap:1.2rem;
  padding:1.35rem 1.6rem;font-weight:600;color:var(--cream);
  font-size:clamp(1.02rem,2.1vw,1.18rem);line-height:1.35}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::before{content:counter(faq,decimal-leading-zero);flex:none;min-width:1.5em;
  font-family:'Anton';font-size:1.05rem;line-height:1;opacity:.9;
  background:var(--grad-hot);-webkit-background-clip:text;background-clip:text;color:transparent}
.faq__item summary > span{flex:1}
.faq__item summary em{color:var(--gold)}
.faq__item summary::after{content:"+";flex:none;margin-left:auto;width:36px;height:36px;border-radius:50%;
  display:grid;place-items:center;background:var(--grad-hot);color:#1a0010;
  font-family:'Anton';font-size:1.5rem;line-height:1;
  box-shadow:0 6px 16px rgba(255,46,126,.4);
  transition:transform .4s var(--ease),filter .35s}
.faq__item summary:hover::after{filter:saturate(1.2) brightness(1.05)}
.faq__item[open] summary::after{transform:rotate(135deg)}
.faq__item p{color:var(--silver);margin:0;padding:0 1.6rem 1.5rem;line-height:1.8;max-width:64ch}
.faq__item[open] p{animation:faqIn .4s var(--ease)}
@keyframes faqIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.faq__item a{color:var(--pink);text-decoration:underline;text-underline-offset:3px;transition:color .2s}
.faq__item a:hover{color:var(--gold)}

/* ============================================================ CONNECT */
.connect{padding:6rem 6vw;text-align:center;
  background:radial-gradient(80% 100% at 50% 0%,rgba(255,46,126,.14),transparent 60%)}
.connect__inner{max-width:680px;margin:0 auto}
.connect h2{font-family:'Anton';font-weight:400;text-transform:uppercase;
  font-size:clamp(2.2rem,6vw,4rem);line-height:.95;margin:.4rem 0 1rem}
.connect p{color:var(--muted);margin-bottom:2rem}
.socials{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:2.5rem}
.social{display:inline-flex;align-items:center;gap:.6rem;padding:.9em 1.5em;border-radius:14px;
  border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.03);font-weight:600;transition:.25s}
.social small{color:var(--muted);font-weight:400}
.social:hover{transform:translateY(-3px);border-color:var(--pink);box-shadow:0 10px 30px rgba(255,46,126,.3)}
.social__ico{display:grid;place-items:center;width:30px;height:30px;border-radius:8px;
  background:var(--grad-hot);color:#1a0010;font-weight:800}
.news{max-width:480px;margin:0 auto}
.news__label{font-size:.85rem;color:var(--silver);margin-bottom:.8rem}
.news__row{display:flex;gap:.6rem;flex-wrap:wrap}
.news__row input{flex:1;min-width:200px;padding:.85em 1.2em;border-radius:999px;
  border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.05);color:var(--ink);font-family:inherit}
.news__row input:focus{outline:none;border-color:var(--pink);box-shadow:0 0 18px rgba(255,46,126,.3)}
.news__note{margin-top:.8rem;font-size:.85rem;color:var(--gold);min-height:1.2em}

/* ============================================================ FOOTER */
.footer{text-align:center;padding:3.5rem 6vw;border-top:1px solid rgba(255,255,255,.08)}
.footer__logo{font-family:'Anton';font-size:1.6rem;letter-spacing:.1em;
  background:var(--grad-hot);-webkit-background-clip:text;background-clip:text;color:transparent}
.footer__tag{font-family:'Playfair Display';font-style:italic;color:var(--copper);margin:.6rem 0}
.footer__copy{font-size:.78rem;color:var(--muted)}

/* ============================================================ BACK TO TOP */
.totop{position:fixed;right:18px;bottom:18px;z-index:1100;width:46px;height:46px;border-radius:50%;
  border:none;cursor:pointer;background:var(--grad-hot);color:#1a0010;font-size:1.3rem;line-height:1;
  box-shadow:0 10px 26px rgba(255,46,126,.45);opacity:0;transform:translateY(20px) scale(.9);
  pointer-events:none;transition:opacity .3s,transform .3s var(--ease),filter .2s}
.totop.show{opacity:1;transform:none;pointer-events:auto}
.totop:hover{filter:saturate(1.2) brightness(1.05)}

/* ============================================================ MINI PLAYER */
.miniplayer{position:fixed;bottom:18px;left:50%;transform:translateX(-50%) translateY(140%);
  z-index:1200;display:flex;align-items:center;gap:.9rem;
  background:rgba(13,21,48,.92);border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(14px);
  border-radius:999px;padding:.5rem .8rem .5rem .5rem;box-shadow:var(--shadow);
  transition:transform .4s var(--ease);min-width:280px}
.miniplayer.show{transform:translateX(-50%) translateY(0)}
.miniplayer__btn{width:42px;height:42px;border-radius:50%;border:none;cursor:pointer;
  background:var(--grad-hot);color:#1a0010;font-size:1rem;flex:none}
.miniplayer__info{flex:1;min-width:0;line-height:1.2}
.miniplayer__info strong{display:block;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.miniplayer__info span{font-size:.72rem;color:var(--muted)}
.miniplayer__bar{position:absolute;left:0;right:0;bottom:0;height:3px;background:rgba(255,255,255,.1);border-radius:0 0 999px 999px;overflow:hidden}
.miniplayer__bar div{height:100%;width:0;background:var(--grad-hot)}

/* ============================================================ LIGHTBOX */
.lightbox{position:fixed;inset:0;z-index:2000;display:none;place-items:center;
  background:rgba(4,6,16,.94);backdrop-filter:blur(8px);padding:5vw}
.lightbox.open{display:grid}
.lightbox__stage{max-width:92vw;max-height:88vh}
.lightbox__stage img,.lightbox__stage video{max-width:92vw;max-height:88vh;border-radius:14px;box-shadow:var(--shadow)}
.lightbox__close{position:absolute;top:4vw;right:5vw;width:46px;height:46px;border-radius:50%;
  border:1px solid rgba(255,255,255,.3);background:rgba(255,255,255,.06);color:#fff;font-size:1.2rem;cursor:pointer}
.lightbox__close:hover{border-color:var(--pink);color:var(--pink)}

/* ============================================================ SCROLL REVEAL */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ============================================================ RESPONSIVE */
@media(max-width:860px){
  .nav__links{position:fixed;inset:0 0 0 auto;width:min(78vw,320px);flex-direction:column;
    justify-content:center;gap:2rem;padding:2rem;background:rgba(7,11,31,.97);backdrop-filter:blur(16px);
    transform:translateX(100%);transition:transform .4s var(--ease)}
  .nav__links.open{transform:none}
  .nav__links a{font-size:1.3rem}
  .nav__burger{display:flex;z-index:1001}
  .player{grid-template-columns:1fr;gap:2rem}
  .player__art{max-width:340px;margin:0 auto}
  .player__spin{display:none}
  .bio{grid-template-columns:1fr;gap:2rem}
  .gallery__grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .g-item--wide,.g-item--video{grid-column:span 2}
  .g-item--tall{grid-row:span 1}
}
@media(max-width:520px){
  .cd{min-width:0;flex:1;padding:.8rem .4rem}
  .countdown__clock{gap:.5rem}
  .streaming{justify-content:flex-start}
  .ticker__track{animation-duration:14s}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}
