* {
  box-sizing: border-box;
}

:root {
  --gold: #fbcc3c;
  --red: #f53030;
  --pink: #ff4ed8;
  --blue: #6cd8ff;
  --gray: #666;
  --soft: #c7c6c6;
  --ink: #050505;
  --cursor-x: 50vw;
  --cursor-y: 50vh;
  --cursor-drift-x: 0px;
  --cursor-drift-y: 0px;
}

html,
body {
  width: 100%;
  min-height: 100%;
  margin: 0;
  padding: 0;
  overflow-x: hidden;
  background: #000;
  color: #fff;
  scroll-behavior: smooth;
}

html {
  scrollbar-color: var(--pink) #050505;
  scrollbar-width: thin;
}

html::-webkit-scrollbar {
  width: clamp(0.72rem, 1vw, 0.95rem);
}

html::-webkit-scrollbar-track {
  background:
    linear-gradient(180deg, #f7fbff 0%, #071832 42%, #000 100%),
    #050505;
  border-left: 2px solid #000;
}

html::-webkit-scrollbar-thumb {
  background:
    linear-gradient(180deg, var(--gold) 0%, var(--pink) 48%, var(--blue) 100%);
  border: 2px solid #000;
  border-radius: 0;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.55),
    0 0 14px rgba(255, 78, 216, 0.42);
}

html::-webkit-scrollbar-thumb:hover {
  background:
    linear-gradient(180deg, #fff 0%, var(--gold) 24%, var(--pink) 62%, var(--blue) 100%);
}

html::-webkit-scrollbar-thumb:active {
  background:
    linear-gradient(180deg, var(--blue) 0%, var(--pink) 52%, var(--red) 100%);
}

html::-webkit-scrollbar-corner {
  background: #000;
}

body {
  font-family: Inter, Arial, sans-serif;
  background: #000;
}

a {
  color: inherit;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.22em;
  cursor: pointer;
  transition: color 180ms ease, text-decoration-color 180ms ease, opacity 180ms ease;
}

img {
  max-width: 100%;
  cursor: default;
}

a img {
  cursor: pointer;
}

main {
  position: relative;
  isolation: isolate;
  min-height: 100vh;
  background:
    linear-gradient(112deg, rgba(255, 78, 216, 0.16) 0%, rgba(255, 78, 216, 0) 28%),
    linear-gradient(68deg, rgba(108, 216, 255, 0) 30%, rgba(108, 216, 255, 0.22) 45%, rgba(108, 216, 255, 0) 63%),
    linear-gradient(180deg, #f7fbff 0%, #e3fdff 18%, #93b8c2 34%, #071832 48%, #02040d 68%, #000 100%);
}

main::before,
main::after {
  content: "";
  pointer-events: none;
}

main::before {
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: 0.74;
  background-image:
    repeating-linear-gradient(90deg, transparent 0 34px, rgba(50, 70, 92, 0.2) 35px 36px),
    repeating-linear-gradient(0deg, transparent 0 44px, rgba(50, 70, 92, 0.14) 45px 46px),
    repeating-linear-gradient(158deg, rgba(255, 78, 216, 0.12) 0 12px, transparent 12px 42px),
    linear-gradient(180deg, rgba(255, 255, 255, 0.2), rgba(0, 18, 55, 0.32) 45%, rgba(0, 0, 0, 0.42));
  mix-blend-mode: multiply;
}

main::after {
  position: fixed;
  inset: 0;
  z-index: 1;
  opacity: 0.68;
  background-image:
    radial-gradient(circle at var(--cursor-x) var(--cursor-y), rgba(255, 255, 255, 0.32), transparent 11rem),
    repeating-linear-gradient(90deg, transparent 0 26px, rgba(255, 255, 255, 0.46) 27px 28px),
    repeating-linear-gradient(0deg, transparent 0 32px, rgba(108, 216, 255, 0.28) 33px 34px),
    repeating-linear-gradient(118deg, transparent 0 44px, rgba(255, 78, 216, 0.24) 45px 47px);
  background-position:
    0 0,
    var(--cursor-drift-x) 0,
    0 var(--cursor-drift-y),
    var(--cursor-drift-x) var(--cursor-drift-y);
  -webkit-mask-image: radial-gradient(circle at var(--cursor-x) var(--cursor-y), #000 0 8rem, rgba(0, 0, 0, 0.72) 15rem, transparent 34rem);
  mask-image: radial-gradient(circle at var(--cursor-x) var(--cursor-y), #000 0 8rem, rgba(0, 0, 0, 0.72) 15rem, transparent 34rem);
  mix-blend-mode: screen;
  transition: opacity 160ms ease, filter 160ms ease;
}

body.is-cursor-pressing main::after {
  opacity: 0.92;
  filter: saturate(1.4) contrast(1.08);
}

.fixed-name {
  position: fixed;
  top: 1.25vw;
  left: 4.5vw;
  z-index: 35;
  color: rgb(var(--fixed-name-color, 5 5 5));
  font: 800 clamp(2.25rem, 7vw, 7.8rem)/0.86 Inter, Arial, sans-serif;
  letter-spacing: 0.04em;
  opacity: var(--fixed-name-opacity, 1);
  text-shadow:
    0 0 14px rgb(var(--fixed-name-shadow, 255 255 255) / 0.72),
    6px 8px 0 rgb(var(--fixed-name-accent, 255 78 216) / 0.35);
  pointer-events: none;
  transition: color 120ms linear, text-shadow 120ms linear, opacity 120ms linear;
}

.hero-text-section {
  position: relative;
  width: 100%;
  min-height: 55vh;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 7vh 5vw 2vh;
  z-index: 20;
  background: transparent;
}

.hero-text-wrapper {
  width: min(720px, 90vw);
  margin-top: 16vh;
  text-align: right;
}

.hero-text-comment {
  margin: 0;
  color: rgba(255, 255, 255, 0.72);
  font: 600 clamp(1rem, 2.4vw, 2.5rem)/1.5 Inter, Arial, sans-serif;
}

.hero-text-title {
  margin: 0.6rem 0;
  color: var(--gold);
  font: 300 clamp(2.25rem, 4.2vw, 4.5rem)/1.05 Inter, Arial, sans-serif;
  letter-spacing: 0.03em;
}

.hero-text-copy {
  margin: 0;
  color: rgba(255, 255, 255, 0.9);
  font: 400 clamp(1rem, 1.55vw, 1.75rem)/1.95 Inter, Arial, sans-serif;
}

.hero-text-copy span {
  color: var(--gold);
}

.hero-text-copy.warning {
  margin-top: 0.8rem;
  color: var(--red);
}

.content-section {
  position: relative;
  z-index: 30;
  min-height: 120vh;
  padding: 10vw 0 clamp(18rem, 32vw, 32rem);
  overflow: hidden;
  background: transparent;
}

.content-section::before {
  content: none;
  position: absolute;
  inset: 0;
  z-index: -1;
  opacity: 0.35;
  background-image:
    linear-gradient(115deg, transparent 0 35%, rgba(0, 0, 0, 0.28) 35% 37%, transparent 37% 100%),
    repeating-linear-gradient(160deg, rgba(255, 78, 216, 0.18) 0 12px, transparent 12px 38px);
}

.content-section::after {
  content: none;
  position: absolute;
  right: 0;
  bottom: -70px;
  left: 0;
  z-index: 0;
  height: clamp(360px, 42vw, 680px);
  opacity: 0.95;
  pointer-events: none;
  transform: scaleY(1.08);
  background:
    radial-gradient(ellipse at 74% 20%, rgba(108, 216, 255, 0.26), transparent 46%),
    radial-gradient(ellipse at 18% 52%, rgba(255, 78, 216, 0.18), transparent 48%),
    repeating-linear-gradient(90deg, transparent 0 34px, rgba(255, 255, 255, 0.09) 35px 36px),
    linear-gradient(180deg, rgba(215, 250, 255, 0), rgba(4, 21, 48, 0.62) 44%, #02040d 100%);
}

.content-wrapper {
  position: relative;
  z-index: 2;
  width: min(720px, 88vw);
  margin: 18vh 5vw 0 auto;
  color: #060606;
  font: 700 clamp(1.15rem, 1.45vw, 2.4rem)/1.26 Courier, monospace;
}

.content-wrapper h2 {
  margin: 0 0 0.8rem;
  font: 800 clamp(2.35rem, 5vw, 6rem)/0.9 Inter, Arial, sans-serif;
  letter-spacing: 0.02em;
}

.content-wrapper p {
  margin: 0;
}

.content-wrapper > img {
  display: block;
  width: min(340px, 82vw);
  margin: 2rem 0 0 auto;
  border: 4px solid #000;
}

.info-panel {
  position: relative;
  max-width: 720px;
  margin: 3rem 0 0;
  padding: 2rem clamp(1.2rem, 3vw, 2.5rem);
  color: #fff;
  background: rgba(7, 7, 7, 0.64);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 14px;
  backdrop-filter: blur(12px) saturate(160%);
}

.info-panel h3 {
  margin: 0 0 0.65rem;
  color: var(--red);
  font: 700 clamp(1.2rem, 2.6vw, 3rem)/1.2 Courier, monospace;
}

.info-panel p {
  color: #fff;
  font: 700 clamp(1rem, 1.45vw, 2.1rem)/1.5 Courier, monospace;
}

.info-panel span {
  color: var(--pink);
}

.collage-container {
  position: relative;
  z-index: 25;
  display: grid;
  grid-template-columns: minmax(1rem, 1fr) minmax(0, min(92rem, calc(100% - 2rem))) minmax(1rem, 1fr);
  row-gap: clamp(4rem, 7vw, 7rem);
  min-height: 0;
  margin-top: 0;
  padding: clamp(8rem, 13vw, 14rem) 0 clamp(7rem, 12vw, 14rem);
  overflow: visible;
  background: transparent;
}

.collage-container > *:not(.collage-background):not(.top-info-img) {
  grid-column: 2;
}

.collage-container::before,
.collage-container::after {
  content: none;
  position: absolute;
  right: 0;
  left: 0;
  z-index: 1;
  pointer-events: none;
}

.collage-container::before {
  top: -130px;
  height: clamp(620px, 52vw, 900px);
  opacity: 0.92;
  transform: scale(1.04);
  background:
    radial-gradient(ellipse at 74% 10%, rgba(108, 216, 255, 0.18), transparent 48%),
    radial-gradient(ellipse at 20% 60%, rgba(255, 78, 216, 0.13), transparent 50%),
    linear-gradient(180deg, rgba(2, 4, 13, 0.92) 0%, rgba(5, 22, 48, 0.55) 52%, rgba(2, 4, 13, 0) 100%);
  -webkit-mask-image: linear-gradient(180deg, #000 0%, #000 70%, transparent 100%);
  mask-image: linear-gradient(180deg, #000 0%, #000 70%, transparent 100%);
}

.collage-container::after {
  bottom: -150px;
  height: clamp(620px, 46vw, 840px);
  opacity: 0.96;
  transform: scale(1.04);
  background:
    radial-gradient(ellipse at 72% 22%, rgba(251, 204, 60, 0.08), transparent 44%),
    radial-gradient(ellipse at 22% 24%, rgba(255, 78, 216, 0.11), transparent 46%),
    linear-gradient(180deg, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.72) 54%, #000 100%);
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 30%, #000 100%);
  mask-image: linear-gradient(180deg, transparent 0%, #000 30%, #000 100%);
}

.collage-background {
  position: absolute;
  inset: 0;
  background: transparent;
}

.collage-background::after {
  content: none;
  position: absolute;
  inset: 0;
  opacity: 0.34;
  background:
    repeating-linear-gradient(90deg, transparent 0 34px, rgba(255, 255, 255, 0.16) 35px 36px),
    repeating-linear-gradient(0deg, transparent 0 44px, rgba(255, 255, 255, 0.08) 45px 46px);
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, transparent 18%, #000 36%, #000 68%, transparent 96%);
  mask-image: linear-gradient(180deg, transparent 0%, transparent 18%, #000 36%, #000 68%, transparent 96%);
}

.top-info-img {
  position: absolute;
  top: clamp(4rem, 9vw, 9rem);
  left: max(-4rem, -4vw);
  z-index: 1;
  width: min(56rem, 70vw);
  opacity: 0.3;
  transform: rotate(-8deg);
  filter: contrast(1.25) saturate(1.2);
  pointer-events: none;
}

.release-collage {
  position: relative;
  z-index: 4;
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-template-rows: repeat(14, minmax(0, 1fr));
  min-height: clamp(50rem, 82vw, 76rem);
}

.release-card {
  position: relative;
  z-index: 4;
  min-width: 0;
  margin: 0;
}

.release-card-one {
  grid-column: 4 / span 4;
  grid-row: 5 / span 5;
  align-self: start;
  justify-self: center;
  width: min(100%, 27rem);
}

.release-card-two {
  grid-column: 7 / span 4;
  grid-row: 8 / span 5;
  align-self: start;
  justify-self: center;
  width: min(100%, 24rem);
  transform: rotate(3deg);
}

.release-card-three {
  grid-column: 4 / span 5;
  grid-row: 11 / span 4;
  align-self: start;
  justify-self: center;
  width: min(100%, 28rem);
  transform: rotate(-5deg);
}

.release-card-four {
  grid-column: 6 / span 4;
  grid-row: 1 / span 4;
  align-self: start;
  justify-self: center;
  width: min(100%, 24rem);
  transform: rotate(-4deg);
}

.release,
.surf-bear {
  position: relative;
  display: block;
  z-index: 5;
  width: 100%;
  height: auto;
  border: 4px solid rgba(255, 255, 255, 0.86);
  box-shadow: 0 0 0 2px #000;
  opacity: 1;
  clip-path: inset(0 0 100% 0);
  transform: translateY(18px);
  transition: clip-path 900ms cubic-bezier(.2, .8, .2, 1), transform 900ms cubic-bezier(.2, .8, .2, 1);
  transition-delay: var(--reveal-delay, 0ms);
}

.release.is-visible,
.surf-bear.is-visible {
  clip-path: inset(0);
  transform: translateY(0);
}

.release-one {
  width: 100%;
}

.release-two {
  width: 100%;
  transform: translateY(18px);
}

.release-two.is-visible {
  clip-path: inset(0);
  transform: translateY(0);
}

.release-three {
  width: 100%;
  transform: translateY(18px);
}

.release-three.is-visible {
  clip-path: inset(0);
  transform: translateY(0);
}

.release-four {
  width: 100%;
  transform: translateY(18px);
}

.release-four.is-visible {
  clip-path: inset(0);
  transform: translateY(0);
}

.surf-bear {
  justify-self: start;
  width: min(100%, 50rem);
  border-color: rgba(251, 204, 60, 0.92);
  opacity: 0;
  clip-path: none;
  transform: translateY(18px);
  transition: opacity 900ms cubic-bezier(.2, .8, .2, 1), transform 900ms cubic-bezier(.2, .8, .2, 1);
}

.surf-bear.is-visible {
  opacity: 1;
  clip-path: none;
  transform: translateY(0);
}

.release-label {
  position: absolute;
  z-index: 8;
  margin: 0;
  color: #fff;
  font: 800 clamp(1.1rem, 2.3vw, 2.3rem)/1 Courier, monospace;
  text-shadow: 5px 5px 0 rgba(0, 0, 0, 0.9);
}

.label-one {
  top: 8%;
  right: -1rem;
  left: auto;
}

.label-two {
  top: 10%;
  right: -1.2rem;
  left: auto;
}

.label-three {
  top: 9%;
  right: -1rem;
  left: auto;
}

.label-four {
  top: 8%;
  right: -1.4rem;
  left: auto;
}

.forever-layout {
  position: relative;
  z-index: 4;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(min(24rem, 100%), 0.62fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-top: clamp(1rem, 4vw, 4rem);
}

.forever-stack {
  display: grid;
  gap: clamp(1.4rem, 3vw, 3rem);
  align-items: start;
  min-width: 0;
}

.giant-title {
  position: relative;
  top: auto;
  left: auto;
  z-index: 2;
  width: min(100%, 75rem);
  color: white;
  font-family: Inter, Arial, sans-serif;
  text-shadow: 0 0 8px rgba(0, 0, 0, 0.85);
  opacity: 0.52;
  pointer-events: none;
}

.giant-title span {
  display: block;
  font-size: clamp(3rem, 9vw, 9rem);
  font-weight: 800;
  line-height: 0.82;
  letter-spacing: 0.06em;
}

.giant-title strong {
  display: block;
  margin-left: -1vw;
  font-size: clamp(5.5rem, 18vw, 18rem);
  font-weight: 100;
  line-height: 0.76;
}

.song-band {
  position: relative;
  inset: auto;
  z-index: 6;
  align-self: end;
  justify-self: end;
  width: min(100%, 36rem);
  margin-bottom: clamp(0rem, 3vw, 3rem);
  pointer-events: auto;
}

.song-block-text {
  position: relative;
  top: auto;
  right: auto;
  width: 100%;
  color: #fff;
  font: 700 clamp(1rem, 1.55vw, 2rem)/1.3 Courier, monospace;
  text-align: left;
}

.song-block-text h2 {
  margin: 0 0 0.8rem;
  color: var(--gold);
  font: inherit;
}

.song-block-text p {
  margin: 0;
}

.third-section {
  position: relative;
  z-index: 40;
  margin-top: 0;
  padding: clamp(9rem, 15vw, 15rem) 0 7vw;
  overflow: hidden;
  background: transparent;
}

.third-section::before {
  content: none;
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  z-index: 0;
  height: clamp(520px, 38vw, 720px);
  opacity: 0.75;
  pointer-events: none;
  background:
    repeating-linear-gradient(90deg, transparent 0 34px, rgba(255, 255, 255, 0.06) 35px 36px),
    linear-gradient(180deg, rgba(0, 18, 55, 0.3), rgba(0, 0, 0, 0));
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, transparent 24%, #000 62%, transparent 100%);
  mask-image: linear-gradient(180deg, transparent 0%, transparent 24%, #000 62%, transparent 100%);
}

.scroll-reveal {
  opacity: 0;
  transform: translateY(26px);
  transition: opacity 900ms ease, transform 900ms ease;
  transition-delay: var(--reveal-delay, 0ms);
}

.scroll-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.giant-title.scroll-reveal.is-visible {
  opacity: 0.45;
}

.third-wrapper {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(min(20rem, 100%), 0.86fr);
  gap: clamp(2rem, 5vw, 5rem);
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 6vw;
  color: #fff;
  font: 400 clamp(1.05rem, 1.5vw, 1.55rem)/1.28 Courier, monospace;
}

.third-wrapper h2 {
  margin: 0 0 1rem;
  color: #fff;
  font: 700 clamp(2rem, 3.6vw, 4.8rem)/0.95 Inter, Arial, sans-serif;
  letter-spacing: 0.03em;
}

.third-wrapper p {
  margin: 0 0 1.4rem;
}

.third-col.left {
  padding-left: 4vw;
}

.third-col.left img {
  display: block;
  width: min(360px, 80vw);
  margin: 2.5rem 0 0;
  border: 3px solid #fff;
}

.caption {
  margin-top: 0.8rem;
  color: rgba(255, 255, 255, 0.64);
  font-size: 0.9rem;
}

.third-col.right {
  color: #6688ff;
}

.third-col.right h2 {
  color: var(--gold);
  font-size: clamp(1.75rem, 3vw, 3.6rem);
}

.track-list,
.platform-list {
  font-weight: 800;
}

.platform-list a {
  color: #fff;
}

.song-trigger {
  cursor: pointer;
}

.song-trigger:focus-visible {
  outline: 3px solid var(--gold);
  outline-offset: 0.45rem;
}

.song-modal {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: grid;
  place-items: center;
  padding: clamp(1rem, 4vw, 3rem);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 180ms ease, visibility 180ms ease;
}

.song-modal.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.song-modal__backdrop {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 20%, rgba(255, 78, 216, 0.24), transparent 32%),
    radial-gradient(circle at 80% 70%, rgba(108, 216, 255, 0.2), transparent 34%),
    rgba(0, 0, 0, 0.84);
  backdrop-filter: blur(10px) saturate(140%);
}

.song-modal__panel {
  position: relative;
  z-index: 1;
  width: min(100%, 74rem);
  max-height: min(92vh, 54rem);
  overflow: auto;
  padding: clamp(1rem, 3vw, 2.4rem);
  color: #fff;
  background: rgba(3, 4, 10, 0.9);
  border: 2px solid rgba(255, 255, 255, 0.72);
  box-shadow:
    0 0 0 2px #000,
    0 28px 90px rgba(0, 0, 0, 0.7),
    10px 10px 0 rgba(255, 78, 216, 0.28);
}

.song-modal__close {
  position: absolute;
  top: clamp(0.75rem, 2vw, 1.2rem);
  right: clamp(0.75rem, 2vw, 1.2rem);
  z-index: 2;
  min-height: 2.5rem;
  padding: 0.55rem 0.85rem;
  color: #000;
  font: 900 0.85rem/1 Courier, monospace;
  text-transform: uppercase;
  background: var(--gold);
  border: 2px solid #000;
  box-shadow: 3px 3px 0 rgba(255, 78, 216, 0.72);
  cursor: pointer;
  transition: filter 180ms ease, transform 180ms ease;
}

.song-modal__content {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(min(16rem, 100%), 0.42fr);
  gap: clamp(1.5rem, 4vw, 3.2rem);
  align-items: center;
  width: min(100%, 66rem);
  margin: 0 auto;
  padding: clamp(2.6rem, 4vw, 3.6rem) 0 clamp(0.4rem, 1vw, 1rem);
}

.song-modal__main {
  display: grid;
  grid-template-columns: minmax(10rem, 18rem) minmax(18rem, 28rem);
  gap: clamp(1.2rem, 3vw, 2.4rem);
  align-items: center;
  justify-content: center;
  min-width: 0;
}

.song-modal__main img {
  display: block;
  justify-self: center;
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  border: 4px solid rgba(255, 255, 255, 0.86);
  box-shadow: 0 0 0 2px #000;
  cursor: default;
}

.song-modal__details {
  display: grid;
  justify-items: center;
  min-width: 0;
  text-align: center;
}

.song-modal__artist {
  margin: 0 0 0.4rem;
  color: var(--blue);
  font: 800 clamp(0.9rem, 1.4vw, 1.2rem)/1.2 Courier, monospace;
  text-transform: uppercase;
}

.song-modal h2 {
  margin: 0 0 1rem;
  color: #fff;
  font: 900 clamp(2.2rem, 5.5vw, 5.8rem)/0.85 Inter, Arial, sans-serif;
  letter-spacing: 0.02em;
  overflow-wrap: anywhere;
}

.song-modal p {
  max-width: 36rem;
  margin: 0;
  color: rgba(255, 255, 255, 0.84);
  font: 700 clamp(1rem, 1.45vw, 1.35rem)/1.5 Courier, monospace;
}

.song-modal__audio {
  display: none;
}

.song-player {
  display: grid;
  gap: 0.85rem;
  margin-top: clamp(1rem, 2.5vw, 1.6rem);
  padding: clamp(0.85rem, 2vw, 1.1rem);
  background:
    linear-gradient(135deg, rgba(255, 78, 216, 0.16), rgba(108, 216, 255, 0.1)),
    rgba(255, 255, 255, 0.07);
  border: 2px solid rgba(255, 255, 255, 0.7);
  box-shadow: 5px 5px 0 rgba(255, 78, 216, 0.34), 0 0 0 2px #000;
  width: min(100%, 29rem);
}

.song-player__top {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.6rem;
}

.song-player__button {
  min-height: 2.75rem;
  padding: 0.7rem 0.6rem;
  color: #fff;
  font: 900 clamp(0.82rem, 1.25vw, 1rem)/1 Courier, monospace;
  text-transform: uppercase;
  background: rgba(0, 0, 0, 0.74);
  border: 2px solid rgba(255, 255, 255, 0.72);
  box-shadow: 3px 3px 0 rgba(108, 216, 255, 0.36);
  cursor: pointer;
  transition: filter 180ms ease, transform 180ms ease;
}

.song-player__button--primary {
  color: #000;
  background: var(--gold);
  border-color: #000;
  box-shadow: 3px 3px 0 rgba(255, 78, 216, 0.72);
}

.song-player__progress,
.song-player__volume {
  display: grid;
  gap: 0.4rem;
  color: rgba(255, 255, 255, 0.86);
  font: 900 0.82rem/1 Courier, monospace;
  text-transform: uppercase;
}

.song-player input[type="range"] {
  appearance: none;
  width: 100%;
  height: 0.72rem;
  margin: 0;
  background: rgba(0, 0, 0, 0.78);
  border: 2px solid rgba(255, 255, 255, 0.72);
  box-shadow: 2px 2px 0 rgba(108, 216, 255, 0.32);
  accent-color: var(--gold);
  cursor: pointer;
}

.song-player input[type="range"]::-webkit-slider-thumb {
  appearance: none;
  width: 1.05rem;
  height: 1.05rem;
  background: var(--gold);
  border: 2px solid #000;
  box-shadow: 2px 2px 0 rgba(255, 78, 216, 0.72);
}

.song-player input[type="range"]::-moz-range-thumb {
  width: 1.05rem;
  height: 1.05rem;
  background: var(--gold);
  border: 2px solid #000;
  border-radius: 0;
  box-shadow: 2px 2px 0 rgba(255, 78, 216, 0.72);
}

.song-player input[type="range"]::-moz-range-track {
  height: 0.72rem;
  background: transparent;
}

.song-modal__links {
  min-width: 0;
  justify-self: center;
  width: min(100%, 18rem);
  padding-top: 0;
}

.song-modal__links h3 {
  margin: 0 0 0.9rem;
  color: var(--gold);
  font: 900 clamp(1.15rem, 2.2vw, 2rem)/1 Courier, monospace;
  text-align: center;
}

#song-modal-platforms {
  display: grid;
  gap: 0.55rem;
}

#song-modal-platforms a {
  display: block;
  padding: 0.72rem 0.85rem;
  color: #fff;
  font: 800 clamp(0.95rem, 1.4vw, 1.1rem)/1.1 Courier, monospace;
  text-align: center;
  text-decoration: none;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.2);
  transition: background 180ms ease, filter 180ms ease, transform 180ms ease;
}

body.song-modal-open,
body.welcome-audio-open {
  overflow: hidden;
}

.welcome-audio {
  position: fixed;
  inset: 0;
  z-index: 95;
  display: grid;
  place-items: center;
  padding: clamp(1rem, 5vw, 3rem);
  color: #fff;
  background:
    radial-gradient(circle at 20% 18%, rgba(255, 78, 216, 0.24), transparent 30%),
    radial-gradient(circle at 78% 70%, rgba(108, 216, 255, 0.22), transparent 34%),
    rgba(0, 0, 0, 0.88);
  backdrop-filter: blur(10px) saturate(145%);
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition: opacity 220ms ease, visibility 220ms ease;
  animation: welcomeOverlayIn 620ms cubic-bezier(0.2, 0.8, 0.2, 1) both;
}

.welcome-audio.is-dismissed {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  animation: none;
}

.welcome-audio__panel {
  width: min(100%, 34rem);
  padding: clamp(1.4rem, 5vw, 2.4rem);
  text-align: center;
  background: rgba(3, 4, 10, 0.94);
  border: 2px solid rgba(255, 255, 255, 0.74);
  box-shadow:
    0 0 0 2px #000,
    8px 8px 0 rgba(255, 78, 216, 0.38),
    -5px -5px 0 rgba(108, 216, 255, 0.24);
  transform-origin: center;
  animation: welcomePanelIn 720ms cubic-bezier(0.16, 1, 0.3, 1) 90ms both;
}

.welcome-audio__panel > * {
  animation: welcomeItemIn 520ms ease both;
}

.welcome-audio__panel > :nth-child(1) {
  animation-delay: 220ms;
}

.welcome-audio__panel > :nth-child(2) {
  animation-delay: 320ms;
}

.welcome-audio__panel > :nth-child(3) {
  animation-delay: 410ms;
}

.welcome-audio__eyebrow {
  margin: 0 0 0.7rem;
  color: var(--blue);
  font: 900 clamp(0.85rem, 2vw, 1rem)/1 Courier, monospace;
  text-transform: uppercase;
}

.welcome-audio h2 {
  margin: 0 0 0.8rem;
  color: #fff;
  font: 900 clamp(2.2rem, 8vw, 4.4rem)/0.86 Inter, Arial, sans-serif;
  letter-spacing: 0.02em;
}

.welcome-audio h2 span {
  display: block;
}

.welcome-audio p {
  margin: 0 auto 1.3rem;
  max-width: 27rem;
  color: rgba(255, 255, 255, 0.82);
  font: 800 clamp(1rem, 2.8vw, 1.25rem)/1.35 Courier, monospace;
}

.welcome-audio button {
  min-height: 3rem;
  padding: 0.8rem 1rem;
  color: #000;
  font: 900 1rem/1 Courier, monospace;
  text-transform: uppercase;
  background: var(--gold);
  border: 2px solid #000;
  box-shadow: 4px 4px 0 rgba(255, 78, 216, 0.72);
  cursor: pointer;
}

@keyframes welcomeOverlayIn {
  from {
    opacity: 0;
    backdrop-filter: blur(0) saturate(100%);
  }
  to {
    opacity: 1;
    backdrop-filter: blur(10px) saturate(145%);
  }
}

@keyframes welcomePanelIn {
  from {
    opacity: 0;
    transform: translateY(1.4rem) scale(0.95);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes welcomeItemIn {
  from {
    opacity: 0;
    transform: translateY(0.7rem);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.mini-logo {
  width: min(380px, 75vw);
  margin-top: 2rem;
  color: #fff;
  font: 900 clamp(5rem, 14vw, 13rem)/0.8 Inter, Arial, sans-serif;
  letter-spacing: -0.02em;
  opacity: 0.88;
  text-shadow: 10px 8px 0 rgba(255, 78, 216, 0.44), -6px -6px 0 rgba(108, 216, 255, 0.42);
}

.concert-info-wrapper {
  position: relative;
  z-index: 45;
  width: 100%;
  padding: 0 2rem 4rem;
  background: var(--gray);
  border: 1px dashed #fff;
}

.concert-info-title {
  max-width: 1400px;
  margin: 0 auto 0.5rem;
  padding: 2.5rem 2rem 2rem;
  text-align: center;
  color: #fff;
  font: 600 clamp(2rem, 3vw, 4rem)/1.1 Inter, Arial, sans-serif;
}

.two-column-wrapper {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 4rem;
  max-width: 1400px;
  margin: 0 auto;
  color: var(--soft);
  font: 400 clamp(1rem, 1.5vw, 1.25rem)/1.4 Inter, Arial, sans-serif;
}

.col {
  position: relative;
  min-height: 180px;
  padding: 2rem 2.6rem;
  background: #000;
  border-radius: 4px;
}

.highlight-word {
  display: inline-block;
  color: var(--gold);
  font-size: clamp(1.3rem, 1.75vw, 2rem);
  line-height: 1.2;
}

.soon-stamp {
  position: absolute;
  top: 0.4rem;
  right: 0.5rem;
  z-index: 3;
  padding: 0.3em 0.7em;
  color: #fff;
  background: rgba(255, 0, 0, 0.88);
  border-radius: 4px;
  font: 800 1.05rem/1 Inter, Arial, sans-serif;
  transform: rotate(-10deg);
  pointer-events: none;
}

.contact-section {
  position: relative;
  z-index: 50;
  display: grid;
  place-items: center;
  padding: 7vh 4vw 5vh;
  background:
    radial-gradient(circle at 20% 0%, rgba(255, 78, 216, 0.18), transparent 22%),
    #000;
}

.contact-panel {
  width: min(920px, 100%);
  padding: 2rem clamp(1rem, 3vw, 2.25rem);
  color: #fff;
  background: rgba(0, 0, 0, 0.62);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 16px;
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(8px);
}

.contact-title {
  margin: 0 0 1rem;
  color: #f1b80d;
  font: 400 clamp(1.6rem, 3.2vw, 2.4rem)/1.12 Courier, monospace;
  letter-spacing: 0.02em;
}

.contact-form {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  max-width: 720px;
  font-family: Courier, monospace;
}

.contact-form label {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  font-weight: 600;
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  padding: 0.85rem 1rem;
  color: #fff;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: 8px;
  outline: none;
  font: 600 1rem/1.3 Courier, monospace;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.contact-form input:focus,
.contact-form textarea:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(251, 204, 60, 0.2);
  background: rgba(255, 255, 255, 0.09);
}

.contact-btn {
  justify-self: start;
  padding: 0.9rem 1.25rem;
  color: #000;
  background: #f1b80d;
  border: 0;
  border-radius: 10px;
  box-shadow: 0 6px 18px rgba(251, 204, 60, 0.25);
  cursor: pointer;
  font: 800 1rem/1 Courier, monospace;
}

.contact-btn:hover {
  filter: brightness(1.2);
}

.contact-btn:active {
  transform: translateY(1px);
}

.form-note {
  margin: 0;
  color: rgba(255, 255, 255, 0.66);
  font-size: 0.9rem;
}

.form-note.sent {
  color: var(--gold);
}

.end-wrapper {
  width: min(1400px, 100%);
  margin: 4rem auto 0;
  text-align: center;
}

.end-wrapper p {
  margin: 0;
  color: var(--soft);
  font: 400 1rem/1.5 Inter, Arial, sans-serif;
}

.end-wrapper img {
  display: block;
  width: min(620px, 90vw);
  margin: 4rem auto 0;
  border: 3px solid rgba(255, 255, 255, 0.85);
}

@media (hover: hover) and (pointer: fine) {
  a:hover {
    color: var(--gold);
    text-decoration-color: var(--pink);
  }

  a:active {
    opacity: 0.72;
  }

  .contact-btn {
    transition: filter 180ms ease, transform 180ms ease, box-shadow 180ms ease;
  }

  .contact-btn:hover {
    box-shadow: 0 10px 28px rgba(251, 204, 60, 0.36);
    transform: translateY(-2px);
  }

  .release-card {
    transition: transform 260ms ease, filter 260ms ease;
  }

  .content-wrapper > img,
  .top-info-img,
  .release,
  .surf-bear,
  .third-col.left img,
  .end-wrapper img {
    cursor: default;
    transition:
      clip-path 900ms cubic-bezier(.2, .8, .2, 1),
      transform 260ms ease,
      filter 260ms ease,
      box-shadow 260ms ease;
  }

  .song-trigger,
  .song-trigger img,
  img.song-trigger {
    cursor: pointer;
  }

  .content-wrapper > img:hover,
  .third-col.left img:hover,
  .end-wrapper img:hover {
    filter: saturate(1.12) contrast(1.06);
    transform: translateY(-4px);
  }

  .top-info-img:hover {
    filter: contrast(1.3) saturate(1.35);
  }

  .release-card-one:hover .release-one,
  .release-card-one:hover .release-one.is-visible {
    transform: translateY(-4px);
  }

  .release-card-two:hover {
    transform: translateY(-4px) rotate(3deg);
  }

  .release-card-three:hover {
    transform: translateY(-4px) rotate(-5deg);
  }

  .release-card-four:hover {
    transform: translateY(-4px) rotate(-4deg);
  }

  .surf-bear:hover,
  .surf-bear.is-visible:hover {
    transform: translateY(-4px);
  }

  .song-modal__close:hover,
  .song-player__button:hover,
  .welcome-audio button:hover,
  #song-modal-platforms a:hover {
    filter: brightness(1.14);
    transform: translateY(-2px);
  }
}

@media (hover: none), (pointer: coarse) {
  main::after {
    display: none;
  }
}

@media (max-width: 920px) {
  .song-modal {
    padding: clamp(0.75rem, 4vw, 1.25rem);
  }

  .song-modal__panel {
    width: min(100%, 42rem);
    max-height: 92vh;
    padding: clamp(1rem, 4vw, 1.6rem);
  }

  .song-modal__close {
    position: relative;
    top: auto;
    right: auto;
    justify-self: end;
    margin: 0 0 1rem auto;
  }

  .song-modal__content,
  .song-modal__main {
    grid-template-columns: 1fr;
  }

  .song-modal__content {
    width: 100%;
    padding: 0;
    gap: clamp(1.2rem, 4vw, 2rem);
  }

  .song-modal__main {
    justify-items: center;
    text-align: center;
  }

  .song-modal__main img {
    width: min(100%, 18rem);
  }

  .song-modal__details,
  .song-modal__links {
    width: min(100%, 32rem);
  }
}

@media (max-width: 1024px) {
  .fixed-name {
    font-size: clamp(2rem, 9vw, 6rem);
  }

  .content-wrapper {
    margin-top: 8vh;
  }

  .collage-container {
    row-gap: clamp(3rem, 8vw, 6rem);
    padding-top: clamp(7rem, 15vw, 12rem);
  }

  .release-collage {
    min-height: clamp(48rem, 96vw, 72rem);
  }

  .release-card-one {
    grid-column: 3 / span 5;
    grid-row: 5 / span 5;
    width: min(100%, 25rem);
  }

  .release-card-two {
    grid-column: 7 / span 5;
    grid-row: 8 / span 5;
    width: min(100%, 23rem);
  }

  .release-card-three {
    grid-column: 2 / span 6;
    grid-row: 11 / span 4;
    width: min(100%, 27rem);
  }

  .release-card-four {
    grid-column: 5 / span 5;
    grid-row: 1 / span 4;
    width: min(100%, 22rem);
  }

  .forever-layout {
    grid-template-columns: minmax(0, 1fr) minmax(min(20rem, 100%), 0.72fr);
  }
}

@media (max-width: 800px) {
  .fixed-name {
    top: 1rem;
    left: 1rem;
    font-size: clamp(2rem, 13vw, 4.5rem);
  }

  .hero-text-section {
    min-height: 62vh;
    padding: 12vh 6vw 6vh;
    align-items: end;
  }

  .hero-text-wrapper {
    margin-top: 0;
  }

  .content-section {
    padding: clamp(12rem, 36vw, 18rem) 0 clamp(9rem, 28vw, 14rem);
    background: transparent;
  }

  .content-wrapper {
    width: min(92vw, 720px);
    margin: 0 auto;
  }

  .content-wrapper > img {
    margin-left: 0;
  }

  .collage-container {
    grid-template-columns: minmax(1rem, 1fr) minmax(0, calc(100% - 2rem)) minmax(1rem, 1fr);
    row-gap: clamp(3rem, 10vw, 5rem);
    padding: clamp(6rem, 22vw, 10rem) 0 clamp(6rem, 18vw, 10rem);
    margin-top: 0;
  }

  .top-info-img {
    top: clamp(5rem, 18vw, 8rem);
    left: -8vw;
    width: min(92vw, 34rem);
  }

  .release,
  .surf-bear {
    border-width: 3px;
    box-shadow: 0 0 0 2px #000;
  }

  .release-collage {
    grid-template-columns: repeat(6, minmax(0, 1fr));
    grid-template-rows: repeat(20, minmax(0, 1fr));
    min-height: clamp(62rem, 190vw, 76rem);
  }

  .release-card-one {
    grid-column: 2 / span 4;
    grid-row: 5 / span 4;
    width: min(100%, 20rem);
  }

  .release-card-two {
    grid-column: 3 / span 4;
    grid-row: 9 / span 4;
    width: min(100%, 18rem);
  }

  .release-card-three {
    grid-column: 1 / span 5;
    grid-row: 13 / span 5;
    width: min(100%, 20rem);
  }

  .release-card-four {
    grid-column: 3 / span 4;
    grid-row: 1 / span 4;
    width: min(100%, 18rem);
  }

  .label-one {
    top: 6%;
    right: -0.6rem;
    left: auto;
  }

  .label-two {
    top: 8%;
    right: -0.5rem;
    left: auto;
  }

  .label-three {
    top: 8%;
    right: -0.6rem;
    left: auto;
  }

  .label-four {
    top: 8%;
    right: 0.2rem;
    left: auto;
  }

  .forever-layout {
    grid-template-columns: 1fr;
    align-items: start;
    gap: clamp(2rem, 8vw, 4rem);
    margin-top: 0;
  }

  .surf-bear {
    justify-self: center;
    width: min(82vw, 26rem);
  }

  .song-band {
    justify-self: start;
    width: min(100%, 32rem);
    margin-bottom: 0;
  }

  .song-block-text {
    font-size: clamp(0.95rem, 4vw, 1.35rem);
  }

  .third-wrapper {
    grid-template-columns: 1fr;
    padding: 0 7vw;
  }

  .third-section {
    margin-top: 0;
    padding-top: clamp(7rem, 18vw, 11rem);
  }

  .third-col.left {
    padding-left: 0;
  }

  .song-modal {
    padding: 1rem;
  }

  .song-modal__panel {
    max-height: 90vh;
    padding: clamp(1rem, 5vw, 1.5rem);
  }

  .song-modal__close {
    position: relative;
    top: auto;
    right: auto;
    justify-self: end;
    margin: 0 0 1rem auto;
  }

  .song-modal__content,
  .song-modal__main {
    grid-template-columns: 1fr;
  }

  .song-modal__main {
    padding-right: 0;
  }

  .song-modal__main img {
    width: min(100%, 20rem);
  }

  .song-modal__links {
    padding-top: 0;
  }

  .two-column-wrapper {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .concert-info-wrapper {
    padding-inline: 1rem;
  }
}

@media (max-width: 520px) {
  .fixed-name {
    max-width: calc(100vw - 2rem);
    font-size: clamp(2.15rem, 11vw, 3.35rem);
    line-height: 0.9;
    overflow-wrap: anywhere;
  }

  .hero-text-section {
    min-height: 60vh;
    justify-content: center;
    padding: 11vh 1rem 5vh;
  }

  .hero-text-wrapper {
    width: calc(100vw - 2rem);
    max-width: none;
  }

  .hero-text-comment {
    font-size: 1rem;
  }

  .hero-text-title {
    font-size: clamp(2rem, 9vw, 2.65rem);
    overflow-wrap: anywhere;
  }

  .hero-text-copy {
    font-size: 1rem;
    line-height: 1.65;
  }

  .content-wrapper {
    width: calc(100vw - 2rem);
    font-size: 1rem;
    overflow-wrap: anywhere;
  }

  .content-wrapper h2 {
    font-size: clamp(2rem, 10vw, 2.8rem);
  }

  .content-wrapper > img {
    width: min(320px, 100%);
  }

  .info-panel {
    border-radius: 10px;
  }

  .song-modal__close {
    position: relative;
    top: auto;
    right: auto;
    justify-self: end;
    margin: 0 0 1rem auto;
  }

  .song-modal h2 {
    font-size: clamp(2rem, 14vw, 3.4rem);
  }

  .collage-container {
    min-height: 0;
    padding-top: clamp(5rem, 20vw, 8rem);
    margin-top: 0;
  }

  .release-collage {
    min-height: clamp(54rem, 210vw, 70rem);
  }

  .release-label {
    font-size: 1rem;
  }

  .giant-title span {
    font-size: clamp(2.4rem, 13vw, 4.2rem);
  }

  .giant-title strong {
    font-size: clamp(4.5rem, 25vw, 8rem);
  }

  .surf-bear {
    width: min(100%, 24rem);
  }

  .col {
    min-height: 0;
    padding: 2.3rem 1.25rem 1.4rem;
  }

  .contact-btn {
    justify-self: stretch;
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  .release,
  .surf-bear {
    transition: none;
  }

  main::after {
    transition: none;
  }

  a,
  .contact-btn,
  .release-card,
  .song-modal,
  .song-modal__close,
  .song-player__button,
  .welcome-audio,
  .welcome-audio button,
  #song-modal-platforms a,
  .content-wrapper > img,
  .top-info-img,
  .third-col.left img,
  .end-wrapper img {
    transition: none;
  }

  .content-wrapper > img:hover,
  .third-col.left img:hover,
  .end-wrapper img:hover {
    transform: none;
  }

  .release-card-one:hover .release-one,
  .release-card-one:hover .release-one.is-visible {
    transform: translateY(0);
  }

  .release-card-two:hover {
    transform: rotate(3deg);
  }

  .release-card-three:hover {
    transform: rotate(-5deg);
  }

  .release-card-four:hover {
    transform: rotate(-4deg);
  }

  .surf-bear:hover,
  .surf-bear.is-visible:hover {
    transform: translateY(0);
  }

  .welcome-audio,
  .welcome-audio__panel,
  .welcome-audio__panel > * {
    animation: none;
  }
}
