/* ===========================================================
   EMS21.de — Birthday Night One-Pager
   Dark · Neon · Club · Glas · Premium · Audio-Reactive
   =========================================================== */

:root{
  --bg-0:#05030c;
  --bg-1:#0b0718;
  --bg-2:#140a2e;
  --ink:#f5f3ff;
  --ink-dim:#b7b0d6;
  --ink-faint:#7a7397;

  --pink:#ff2ea6;
  --violet:#8b5cff;
  --blue:#21d4fd;
  --gold:#ffcf5c;

  --glass:rgba(255,255,255,.05);
  --glass-2:rgba(255,255,255,.08);
  --stroke:rgba(255,255,255,.12);
  --stroke-2:rgba(255,255,255,.22);

  --glow-pink:0 0 24px rgba(255,46,166,.55);
  --glow-blue:0 0 24px rgba(33,212,253,.45);
  --radius:22px;
  --maxw:1100px;

  /* Audio-reaktiv: werden per JS gesetzt (0..1) */
  --beat:0;        /* Bass-Energie */
  --level:0;       /* Gesamtpegel */

  --font-display:"Space Grotesk","Segoe UI",system-ui,sans-serif;
  --font-body:"Inter","Segoe UI",system-ui,-apple-system,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg-0);
  line-height:1.55;
  overflow-x:hidden;
  width:100%;
  max-width:100%;
  position:relative;
  min-height:100vh;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
:focus-visible{outline:2px solid var(--blue);outline-offset:3px}

/* ============ HINTERGRUND-EBENEN ============ */
.bg-stage{position:fixed;inset:0;z-index:-5;background:
  radial-gradient(120% 120% at 50% -10%, #1a0f3d 0%, var(--bg-1) 45%, var(--bg-0) 100%);}

/* Aurora-Mesh: mehrere driftende Farbwolken + Hue-Rotation */
.aurora{position:fixed;inset:-30%;z-index:-4;pointer-events:none;filter:blur(40px) saturate(1.3);
  opacity:calc(.55 + var(--level)*.4);
  background:
    radial-gradient(35% 35% at 22% 28%, rgba(139,92,255,.55), transparent 60%),
    radial-gradient(30% 30% at 78% 22%, rgba(255,46,166,.5), transparent 60%),
    radial-gradient(40% 40% at 62% 78%, rgba(33,212,253,.45), transparent 60%),
    radial-gradient(30% 30% at 30% 80%, rgba(255,207,92,.25), transparent 60%);
  animation:aurora 24s ease-in-out infinite alternate, hue 18s linear infinite;
}
@keyframes aurora{
  0%{transform:translate3d(-3%,-2%,0) scale(1.05) rotate(0deg)}
  100%{transform:translate3d(4%,3%,0) scale(1.18) rotate(8deg)}
}
@keyframes hue{to{filter:blur(40px) saturate(1.3) hue-rotate(360deg)}}

/* Rotierende Club-Spotlights (conic) */
.spotlights{position:fixed;inset:0;z-index:-4;pointer-events:none;mix-blend-mode:screen;overflow:hidden;
  opacity:calc(.4 + var(--beat)*.5)}
.spotlights i{position:absolute;width:140vmax;height:140vmax;left:50%;top:30%;border-radius:50%;
  transform-origin:center;will-change:transform}
.spotlights i:nth-child(1){background:conic-gradient(from 0deg, transparent 0 12deg, rgba(255,46,166,.18) 16deg, transparent 22deg, transparent 360deg);animation:spin 26s linear infinite}
.spotlights i:nth-child(2){background:conic-gradient(from 120deg, transparent 0 10deg, rgba(33,212,253,.16) 14deg, transparent 20deg, transparent 360deg);animation:spin 34s linear infinite reverse}
.spotlights i:nth-child(3){background:conic-gradient(from 240deg, transparent 0 8deg, rgba(139,92,255,.16) 12deg, transparent 18deg, transparent 360deg);animation:spin 30s linear infinite}
@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}

/* Lichtkegel (vertikal) */
.beams{position:fixed;inset:0;z-index:-4;pointer-events:none;mix-blend-mode:screen;opacity:.55}
.beams span{position:absolute;top:-20%;width:30vw;height:140vh;
  background:linear-gradient(to bottom, rgba(255,255,255,.10), transparent 70%);
  filter:blur(8px);transform-origin:top center;}
.beams span:nth-child(1){left:8%;transform:rotate(8deg);animation:sway 11s ease-in-out infinite}
.beams span:nth-child(2){left:46%;transform:rotate(-6deg);animation:sway 14s ease-in-out infinite reverse}
.beams span:nth-child(3){left:78%;transform:rotate(10deg);animation:sway 9s ease-in-out infinite}
@keyframes sway{0%,100%{opacity:.25}50%{opacity:.7}}

/* Audio-Visualizer (Vollbild, hinter Inhalt) */
#viz{position:fixed;inset:0;z-index:-3;pointer-events:none;opacity:.9;mix-blend-mode:screen}
/* Partikel */
#particles{position:fixed;inset:0;z-index:-2;pointer-events:none}

/* Film-Grain */
.grain{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* "21" Wasserzeichen */
.watermark21{position:fixed;right:-2vw;bottom:-6vh;z-index:-2;
  font-family:var(--font-display);font-weight:700;font-size:42vw;line-height:.8;
  color:rgba(255,255,255,.022);pointer-events:none;user-select:none;
  transform:scale(calc(1 + var(--beat)*.04));transition:transform .08s linear;}

/* Konfetti-Canvas */
#confetti{position:fixed;inset:0;z-index:60;pointer-events:none}

/* ===================== COUNTDOWN GATE ===================== */
body.locked{overflow:hidden}
.gate{position:fixed;inset:0;z-index:80;display:flex;align-items:center;justify-content:center;
  text-align:center;padding:2rem;
  background:radial-gradient(90% 90% at 50% 35%, rgba(20,10,46,.78), rgba(5,3,12,.96));
  backdrop-filter:blur(10px);transition:opacity .8s ease, transform .8s ease;}
.gate.open{opacity:0;transform:scale(1.04);pointer-events:none}
.gate__inner{max-width:640px}
.gate__eyebrow{letter-spacing:.45em;text-transform:uppercase;font-size:.72rem;color:var(--ink-dim);margin-bottom:1rem}
.gate__title{font-family:var(--font-display);font-weight:700;line-height:.9;
  font-size:clamp(3.5rem,18vw,8rem);
  background:linear-gradient(120deg,#fff,var(--pink) 40%,var(--violet) 65%,var(--blue));
  background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 30px rgba(139,92,255,.5));animation:shine 6s linear infinite}
.gate__lead{margin-top:.6rem;color:var(--ink);font-size:clamp(1rem,3.5vw,1.3rem)}
.gate__lead b{color:var(--gold)}
.countdown{display:flex;justify-content:center;gap:clamp(.5rem,2.5vw,1.1rem);margin:2rem 0 1.2rem}
.cd{min-width:clamp(64px,18vw,104px);padding:1rem .6rem;border-radius:18px;
  background:linear-gradient(160deg,var(--glass-2),var(--glass));border:1px solid var(--stroke);
  backdrop-filter:blur(12px);box-shadow:0 14px 40px rgba(0,0,0,.45)}
.cd span{display:block;font-family:var(--font-display);font-weight:700;line-height:1;
  font-size:clamp(2rem,8vw,3.4rem);font-variant-numeric:tabular-nums;
  background:linear-gradient(120deg,var(--blue),var(--pink));-webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 0 20px rgba(255,46,166,.25)}
.cd small{display:block;margin-top:.5rem;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint)}
.gate__hint{color:var(--ink-faint);font-size:.85rem}

/* ===================== TAP-TO-START OVERLAY ===================== */
.overlay{position:fixed;inset:0;z-index:50;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;gap:1.4rem;padding:2rem;
  background:radial-gradient(80% 80% at 50% 40%, rgba(20,10,46,.55), rgba(5,3,12,.92));
  backdrop-filter:blur(8px);transition:opacity .7s ease, visibility .7s ease;}
.overlay.hidden{opacity:0;visibility:hidden}
.overlay__eyebrow{letter-spacing:.5em;text-transform:uppercase;font-size:.72rem;color:var(--ink-dim)}
.overlay__title{font-family:var(--font-display);font-weight:700;
  font-size:clamp(3.5rem,18vw,9rem);line-height:.9;
  background:linear-gradient(120deg,var(--pink),var(--violet) 45%,var(--blue));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 26px rgba(139,92,255,.5));}
.tap-btn{margin-top:.4rem;padding:1rem 2.4rem;border-radius:999px;
  font-family:var(--font-display);font-weight:600;font-size:1.05rem;letter-spacing:.02em;
  color:#fff;background:linear-gradient(120deg,var(--pink),var(--violet));
  box-shadow:var(--glow-pink), inset 0 0 0 1px rgba(255,255,255,.25);
  animation:pulse 2.6s ease-in-out infinite;}
.tap-btn:hover{transform:translateY(-2px)}
@keyframes pulse{0%,100%{box-shadow:0 0 0 rgba(255,46,166,.0),var(--glow-pink)}50%{box-shadow:0 0 46px rgba(255,46,166,.75)}}
.overlay__hint{font-size:.85rem;color:var(--ink-faint)}

/* ===================== LAYOUT ===================== */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.1rem,4vw,2.2rem)}
section{padding:clamp(3rem,8vw,6rem) 0}
.section-title{font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.6rem,5vw,2.6rem);margin-bottom:.4rem;}
.section-sub{color:var(--ink-dim);margin-bottom:2rem;max-width:46ch}

/* Reveal-on-scroll */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* ===================== HERO ===================== */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;
  padding-top:clamp(4rem,10vh,7rem);padding-bottom:3rem;perspective:1000px;overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:-1;overflow:hidden;
  transform:translate3d(var(--px,0),var(--py,0),0) scale(1.08);transition:transform .25s ease-out;}
.hero__media img,.hero__media video{width:100%;height:100%;object-fit:cover;object-position:50% 28%;
  filter:saturate(1.1) contrast(1.05);opacity:.42;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.9) 30%, transparent 92%);
  -webkit-mask-image:linear-gradient(to bottom, rgba(0,0,0,.9) 30%, transparent 92%);}
.hero__inner{position:relative;transform:translate3d(calc(var(--px,0)*-.4),calc(var(--py,0)*-.4),0);}

.hero__eyebrow{display:inline-flex;align-items:center;gap:.6rem;padding:.45rem 1rem;border-radius:999px;
  border:1px solid var(--stroke);background:var(--glass);
  font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:1.4rem;}
.dot{width:8px;height:8px;border-radius:50%;background:var(--pink);box-shadow:var(--glow-pink);
  transform:scale(calc(1 + var(--beat)));}

/* Hero-Title: Verlauf + Glitch-Layer + Shine + Beat-Glow */
.hero__title{position:relative;font-family:var(--font-display);font-weight:700;
  font-size:clamp(4.2rem,24vw,13rem);line-height:.82;letter-spacing:-.02em;
  background:linear-gradient(115deg,#fff 0%,var(--pink) 38%,var(--violet) 62%,var(--blue) 100%);
  background-size:200% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 calc(22px + var(--beat)*40px) rgba(255,46,166,calc(.35 + var(--beat)*.4)));
  animation:shine 6s linear infinite, glowpulse 4.5s ease-in-out infinite;}
@keyframes shine{to{background-position:200% 0}}
@keyframes glowpulse{0%,100%{filter:drop-shadow(0 0 22px rgba(139,92,255,.35))}50%{filter:drop-shadow(0 0 44px rgba(255,46,166,.55))}}
.hero__title::before,.hero__title::after{content:attr(data-text);position:absolute;inset:0;
  background:inherit;-webkit-background-clip:text;background-clip:text;color:transparent;
  opacity:0;mix-blend-mode:screen;pointer-events:none;}
.hero__title::before{animation:glitchA 5.5s steps(2,end) infinite;color:var(--blue);-webkit-text-fill-color:rgba(33,212,253,.7)}
.hero__title::after{animation:glitchB 5.5s steps(2,end) infinite;color:var(--pink);-webkit-text-fill-color:rgba(255,46,166,.7)}
@keyframes glitchA{0%,92%,100%{opacity:0;transform:none}93%{opacity:.8;transform:translate(-3px,1px)}96%{opacity:.6;transform:translate(2px,-1px)}}
@keyframes glitchB{0%,92%,100%{opacity:0;transform:none}94%{opacity:.7;transform:translate(3px,-1px)}97%{opacity:.5;transform:translate(-2px,1px)}}

.hero__subline{font-family:var(--font-display);font-weight:500;font-size:clamp(1.3rem,5vw,2rem);margin-top:.3rem}
.hero__meta{margin-top:1rem;color:var(--ink-dim);letter-spacing:.04em;font-size:clamp(.85rem,2.6vw,1.05rem)}
.hero__cta{margin-top:2.2rem;display:flex;gap:.9rem;flex-wrap:wrap}

.btn{display:inline-flex;align-items:center;gap:.6rem;padding:.95rem 1.8rem;border-radius:999px;
  font-weight:600;font-size:1rem;transition:transform .2s ease, box-shadow .25s ease;position:relative}
.btn--primary{color:#fff;background:linear-gradient(120deg,var(--pink),var(--violet));box-shadow:var(--glow-pink)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 0 40px rgba(255,46,166,.7)}
/* animierter Neon-Rand */
.btn--ghost{border:1px solid transparent;background:
  linear-gradient(var(--bg-1),var(--bg-1)) padding-box,
  conic-gradient(from var(--a,0deg), var(--pink),var(--blue),var(--violet),var(--pink)) border-box;color:var(--ink)}
.btn--ghost:hover{transform:translateY(-2px);box-shadow:var(--glow-blue)}
@property --a{syntax:'<angle>';inherits:false;initial-value:0deg}
.btn--ghost{animation:rot 4s linear infinite}
@keyframes rot{to{--a:360deg}}

.scroll-cue{position:absolute;left:50%;bottom:1.6rem;transform:translateX(-50%);color:var(--ink-faint);
  font-size:.75rem;letter-spacing:.3em;text-transform:uppercase;animation:bob 2.4s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ===================== MARQUEE ===================== */
.marquee{overflow:hidden;border-top:1px solid var(--stroke);border-bottom:1px solid var(--stroke);
  padding:.9rem 0;background:linear-gradient(90deg,rgba(255,46,166,.06),rgba(33,212,253,.06));
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);}
.marquee__track{display:inline-flex;align-items:center;gap:1.4rem;white-space:nowrap;
  font-family:var(--font-display);font-weight:700;font-size:clamp(1rem,3vw,1.5rem);
  letter-spacing:.08em;animation:scrollx 22s linear infinite;will-change:transform}
.marquee__track span{background:linear-gradient(120deg,#fff,var(--ink-dim));-webkit-background-clip:text;background-clip:text;color:transparent}
.marquee__track .m-dot{color:var(--pink);-webkit-text-fill-color:var(--pink)}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ===================== GLAS-CARD ===================== */
.glass{background:linear-gradient(160deg,var(--glass-2),var(--glass));border:1px solid var(--stroke);
  border-radius:var(--radius);backdrop-filter:blur(14px);box-shadow:0 24px 60px rgba(0,0,0,.45);}

/* ===================== PLAYER ===================== */
.player{display:grid;grid-template-columns:auto 1fr;gap:1.4rem;padding:1.4rem;align-items:center;position:relative;overflow:hidden}
.player.playing{box-shadow:0 0 0 1px var(--stroke),
  0 0 calc(40px + var(--beat)*60px) rgba(139,92,255,calc(.3 + var(--beat)*.4)), 0 24px 60px rgba(0,0,0,.5)}
.player__cover{position:relative;width:128px;height:128px;border-radius:18px;overflow:hidden;flex:none;
  border:1px solid var(--stroke-2);transform:scale(calc(1 + var(--beat)*.05));transition:transform .08s linear}
.player__cover img{width:100%;height:100%;object-fit:cover}
.player__cover::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 30px rgba(0,0,0,.4)}
.eq{position:absolute;left:8px;bottom:8px;display:flex;gap:3px;align-items:flex-end;height:22px;opacity:0;transition:opacity .3s}
.player.playing .eq{opacity:1}
.eq i{width:4px;height:6px;background:var(--blue);border-radius:2px;animation:eqbar 1s ease-in-out infinite}
.eq i:nth-child(2){animation-delay:.15s}.eq i:nth-child(3){animation-delay:.3s}.eq i:nth-child(4){animation-delay:.45s}
@keyframes eqbar{0%,100%{height:5px}50%{height:20px}}

.player__main{min-width:0}
.player__nowtag{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-faint)}
.player__title{font-family:var(--font-display);font-weight:600;font-size:clamp(1.15rem,4vw,1.6rem);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.player__sub{color:var(--ink-dim);font-size:.92rem;margin-bottom:.7rem}

.progress{display:flex;align-items:center;gap:.7rem;font-variant-numeric:tabular-nums;color:var(--ink-dim);font-size:.8rem}
.bar{position:relative;flex:1;height:8px;border-radius:999px;background:rgba(255,255,255,.1);cursor:pointer;overflow:hidden}
.bar__fill{position:absolute;inset:0;width:0%;background:linear-gradient(90deg,var(--blue),var(--pink));box-shadow:0 0 14px rgba(255,46,166,.5)}

.controls{display:flex;align-items:center;gap:.5rem;margin-top:.9rem;flex-wrap:wrap}
.ctrl{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--stroke);background:var(--glass);transition:.2s}
.ctrl:hover{border-color:var(--blue);box-shadow:var(--glow-blue);transform:translateY(-1px)}
.ctrl svg{width:20px;height:20px;fill:var(--ink)}
.ctrl--play{width:60px;height:60px;background:linear-gradient(120deg,var(--pink),var(--violet));border:none;box-shadow:var(--glow-pink)}
.ctrl--play svg{width:26px;height:26px;fill:#fff}
.volume{display:flex;align-items:center;gap:.5rem;margin-left:auto}
.volume svg{width:18px;height:18px;fill:var(--ink-dim)}
input[type=range].vol{-webkit-appearance:none;appearance:none;width:90px;height:6px;border-radius:999px;background:rgba(255,255,255,.14)}
input[type=range].vol::-webkit-slider-thumb{-webkit-appearance:none;width:15px;height:15px;border-radius:50%;background:var(--blue);box-shadow:var(--glow-blue);cursor:pointer}
input[type=range].vol::-moz-range-thumb{width:15px;height:15px;border:none;border-radius:50%;background:var(--blue);cursor:pointer}
.counter{margin-top:.6rem;font-size:.78rem;color:var(--ink-faint);letter-spacing:.05em}

/* Reaktive Balken unter dem Player */
.bars-viz{display:block;width:100%;height:90px;margin-top:1.2rem;opacity:.95}

/* ===================== PLAYLIST ===================== */
.tracks{display:flex;flex-direction:column;gap:.7rem}
.track{display:grid;grid-template-columns:auto 1fr auto;gap:1rem;align-items:center;
  padding:.85rem 1rem;border-radius:16px;border:1px solid var(--stroke);background:var(--glass);transition:.2s;cursor:pointer}
.track:hover{border-color:var(--stroke-2);background:var(--glass-2);transform:translateY(-1px)}
.track.active{border-color:transparent;box-shadow:0 0 0 1px var(--pink), var(--glow-pink);
  background:linear-gradient(120deg,rgba(255,46,166,.12),rgba(139,92,255,.10))}
.track__num{font-family:var(--font-display);font-weight:700;color:var(--ink-faint);width:2ch;font-variant-numeric:tabular-nums}
.track.active .track__num{color:var(--pink)}
.track__body{min-width:0}
.track__title{font-weight:600;font-size:1.02rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.track__sub{color:var(--ink-dim);font-size:.84rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.track__actions{display:flex;align-items:center;gap:.5rem}
.track__time{color:var(--ink-faint);font-size:.78rem;font-variant-numeric:tabular-nums;margin-right:.2rem}
.iconbtn{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;border:1px solid var(--stroke);background:var(--glass);transition:.2s}
.iconbtn svg{width:17px;height:17px;fill:var(--ink)}
.iconbtn:hover{border-color:var(--blue);box-shadow:var(--glow-blue)}
.iconbtn--dl:hover{border-color:var(--gold);box-shadow:0 0 18px rgba(255,207,92,.5)}

/* ===================== MOMENTS (Slider) ===================== */
.slider{position:relative;margin-top:.5rem}
.slider__track{display:flex;gap:1rem;overflow-x:auto;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;scrollbar-width:none;padding:.4rem .2rem 1rem;overscroll-behavior-x:contain}
.slider__track::-webkit-scrollbar{display:none}
.slider__track .slide{flex:0 0 300px;scroll-snap-align:center}
.slider__nav{position:absolute;top:calc(50% - 30px);z-index:6;width:46px;height:46px;border-radius:50%;
  display:grid;place-items:center;background:rgba(11,7,24,.62);border:1px solid var(--stroke-2);
  backdrop-filter:blur(8px);color:#fff;font-size:1.7rem;line-height:1;padding-bottom:3px;transition:.2s}
.slider__nav:hover{border-color:var(--blue);box-shadow:var(--glow-blue)}
.slider__nav:disabled{opacity:.2;pointer-events:none}
.slider__prev{left:-8px}.slider__next{right:-8px}
.slider__dots{display:flex;justify-content:center;flex-wrap:wrap;gap:.5rem;margin-top:.9rem}
.dot-btn{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.22);border:none;cursor:pointer;transition:.2s}
.dot-btn.active{background:linear-gradient(120deg,var(--pink),var(--blue));box-shadow:var(--glow-pink);transform:scale(1.3)}

.moment{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--stroke);
  aspect-ratio:4/5;background:#0d0820;transform-style:preserve-3d;transition:transform .18s ease, box-shadow .25s ease}
.moment:hover{box-shadow:0 30px 70px rgba(0,0,0,.6), 0 0 30px rgba(139,92,255,.35)}
.moment img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;filter:saturate(1.05)}
.moment:hover img{transform:scale(1.08)}
.moment .glare{position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity .2s;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(255,255,255,.35), transparent 45%);mix-blend-mode:overlay}
.moment:hover .glare{opacity:1}
.moment__cap{position:absolute;left:0;right:0;bottom:0;padding:1rem;transform:translateZ(30px);
  background:linear-gradient(to top, rgba(5,3,12,.85), transparent);
  font-family:var(--font-display);font-weight:600;font-size:1.05rem}
.moment__tag{display:block;font-family:var(--font-body);font-weight:400;font-size:.78rem;color:var(--ink-dim);letter-spacing:.04em}

.moments-text{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-top:1.4rem}
.chip{padding:1.1rem 1.2rem;border-radius:16px}
.chip b{font-family:var(--font-display);display:block;font-size:1.05rem;margin-bottom:.2rem}
.chip span{color:var(--ink-dim);font-size:.88rem}
.bigtext{font-family:var(--font-display);font-weight:600;font-size:clamp(1.3rem,4.4vw,2rem);line-height:1.3;max-width:24ch}
.bigtext em{font-style:normal;background:linear-gradient(120deg,var(--pink),var(--blue));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ===================== DOWNLOAD ===================== */
.download-card{padding:1.6rem;display:flex;flex-wrap:wrap;align-items:center;gap:1.2rem;justify-content:space-between}
.download-card h3{font-family:var(--font-display);font-size:1.4rem}
.download-card p{color:var(--ink-dim);font-size:.9rem}
.dl-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.7rem;margin-top:1.2rem}
.dl-item{display:flex;align-items:center;gap:.7rem;padding:.8rem 1rem;border-radius:14px;border:1px solid var(--stroke);background:var(--glass);transition:.2s}
.dl-item:hover{border-color:var(--gold);box-shadow:0 0 20px rgba(255,207,92,.35);transform:translateY(-1px)}
.dl-item svg{width:18px;height:18px;fill:var(--gold);flex:none}
.dl-item span{font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ===================== FOOTER ===================== */
.footer{text-align:center;padding:3rem 0 4rem;color:var(--ink-faint)}
.footer .f-logo{font-family:var(--font-display);font-weight:700;font-size:1.6rem;
  background:linear-gradient(120deg,var(--pink),var(--violet),var(--blue));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.footer small{display:block;margin-top:.4rem;letter-spacing:.06em}

/* ===================== RESPONSIVE ===================== */
@media (max-width:640px){
  .player{grid-template-columns:1fr;text-align:center}
  .player__cover{width:112px;height:112px;margin:0 auto}
  .controls{justify-content:center}
  .volume{margin:.6rem auto 0}
  .track__sub{display:none}
  .download-card{flex-direction:column;align-items:stretch;text-align:center}
  .bars-viz{height:70px}
  .slider__track .slide{flex-basis:80%}
  .slider__nav{display:none}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  .aurora,.spotlights,.beams,#viz{opacity:.5}
}
