@font-face {
  font-family: "Mainstage Trajan";
  src: url("/Fonts/TrajanPro-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Mainstage Trajan";
  src: url("/Fonts/TrajanPro-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Mainstage Ethnocentric";
  src: url("/Fonts/ethnocen.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

.mainstage-page {
  --mainstage-scroll: 0;
  --mainstage-light-sweep-1: 0;
  --mainstage-light-sweep-2: 0;
  --mainstage-light-sweep-3: 0;
  --mainstage-light-sweep-4: 0;
  --mainstage-blue: var(--accent, #7aa7ff);
  --mainstage-cyan: #7df0ff;
  --mainstage-green: #7ee0a1;
  --mainstage-gold: #d8c48a;
  --mainstage-ink: #050608;
  --mainstage-stage-width: 1620px;
  --mainstage-rig-inset: clamp(1.25rem, 4vw, 4rem);
  --mainstage-font-display: "Mainstage Trajan", Georgia, serif;
  position: relative;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-top: -1.5rem;
  overflow: hidden;
  color: var(--fg);
  background:
    radial-gradient(circle at 50% 15%, rgba(122, 167, 255, 0.24), transparent 32rem),
    radial-gradient(circle at 18% 38%, rgba(126, 224, 161, 0.16), transparent 22rem),
    linear-gradient(180deg, #020307 0%, #081013 38%, #06080d 72%, #020307 100%);
  isolation: isolate;
}

.mainstage-page::before,
.mainstage-page::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

.mainstage-page::before {
  background:
    linear-gradient(90deg, rgba(2, 3, 7, 0.92), transparent 18%, transparent 82%, rgba(2, 3, 7, 0.92)),
    url("/img/mosaic.webp") repeat;
  background-size: auto, 256px 256px;
  opacity: 0.23;
}

.mainstage-page::after {
  background:
    radial-gradient(circle at 50% 42%, transparent 0 23rem, rgba(2, 3, 7, 0.48) 44rem),
    linear-gradient(180deg, transparent 0%, rgba(2, 3, 7, 0.34) 80%);
}

.mainstage-center {
  position: relative;
  z-index: 3;
}

.mainstage-mountain-field {
  position: absolute;
  inset: 0;
  z-index: 1;
  overflow: hidden;
  pointer-events: none;
}

.mainstage-mountain-field__ridge {
  position: absolute;
  display: block;
  width: min(92rem, 92vw);
  height: clamp(14rem, 24vw, 26rem);
  opacity: 0.1;
  clip-path: polygon(0 100%, 0 62%, 9% 46%, 17% 66%, 30% 30%, 42% 68%, 52% 42%, 62% 63%, 74% 26%, 87% 68%, 100% 50%, 100% 100%);
  background: linear-gradient(180deg, rgba(122, 167, 255, 0.2), rgba(3, 6, 11, 0.18) 62%, transparent);
  filter: blur(0.6px);
}

.mainstage-mountain-field__ridge--one {
  top: 7%;
  left: -8%;
  transform: rotate(-4deg);
}

.mainstage-mountain-field__ridge--two {
  top: 28%;
  right: -12%;
  opacity: 0.085;
  transform: scaleX(-1) rotate(3deg);
  background: linear-gradient(180deg, rgba(126, 224, 161, 0.16), rgba(4, 8, 12, 0.14) 66%, transparent);
}

.mainstage-mountain-field__ridge--three {
  top: 53%;
  left: 4%;
  width: min(74rem, 78vw);
  opacity: 0.075;
  transform: rotate(2deg);
  background: linear-gradient(180deg, rgba(122, 167, 255, 0.16), rgba(4, 7, 12, 0.12) 64%, transparent);
}

.mainstage-mountain-field__ridge--four {
  top: 76%;
  right: 2%;
  width: min(68rem, 72vw);
  opacity: 0.06;
  transform: scaleX(-1) rotate(-3deg);
  background: linear-gradient(180deg, rgba(216, 196, 138, 0.13), rgba(4, 6, 10, 0.12) 62%, transparent);
}

.mainstage-particles {
  position: absolute;
  inset: 0;
  z-index: 1;
  overflow: hidden;
  pointer-events: none;
}

.mainstage-particle {
  position: absolute;
  left: var(--mainstage-particle-x);
  top: var(--mainstage-particle-y);
  width: var(--mainstage-particle-size);
  height: var(--mainstage-particle-size);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.92);
  opacity: var(--mainstage-particle-opacity);
  box-shadow: 0 0 calc(var(--mainstage-particle-size) * 5) rgba(255, 255, 255, 0.44);
  transform: translate(-50%, -50%) scale(0.68);
  animation: mainstage-particle-pulse var(--mainstage-particle-duration) ease-in-out infinite;
  animation-delay: var(--mainstage-particle-delay);
}

@keyframes mainstage-particle-pulse {
  0%,
  100% {
    opacity: calc(var(--mainstage-particle-opacity) * 0.34);
    transform: translate(-50%, -50%) scale(0.62);
  }

  48% {
    opacity: var(--mainstage-particle-opacity);
    transform: translate(-50%, -50%) scale(1);
  }
}

.mainstage-center {
  display: grid;
  justify-items: center;
  min-height: 100vh;
  min-height: 100dvh;
  padding: clamp(3.75rem, 7vh, 5.5rem) clamp(1.25rem, 5vw, 4rem) clamp(4rem, 8vw, 7rem);
  font-family: var(--mainstage-font-display);
  text-align: center;
}

.mainstage-center__inner {
  width: min(980px, calc(100vw - 3rem));
}

.mainstage-logo {
  display: block;
  width: min(350px, 60vw);
  aspect-ratio: 1;
  margin: 0 auto clamp(1.75rem, 4vw, 2.75rem);
  object-fit: contain;
  filter:
    drop-shadow(0 0 22px rgba(255, 255, 255, 0.14))
    drop-shadow(0 22px 60px rgba(0, 0, 0, 0.58));
}

.mainstage-center h1 {
  max-width: 16ch;
  margin: 0 auto;
  color: #fff;
  font-family: var(--mainstage-font-display);
  font-size: clamp(2.65rem, 7vw, 6.75rem);
  font-weight: 700;
  line-height: 0.98;
  letter-spacing: 0;
  text-shadow:
    0 0 26px rgba(125, 240, 255, 0.12),
    0 22px 60px rgba(0, 0, 0, 0.72);
}

.mainstage-date {
  margin: clamp(1rem, 2.2vw, 1.6rem) 0 0;
  color: rgba(242, 242, 243, 0.72);
  font-family: var(--mainstage-font-display);
  font-size: clamp(0.9rem, 1.6vw, 1.2rem);
  font-weight: 400;
  line-height: 1.5;
}

.mainstage-event-link {
  display: inline-block;
  margin-top: 0.55rem;
  color: #7df0ff;
  font-family: var(--mainstage-font-display);
  font-size: clamp(0.84rem, 1.35vw, 1rem);
  font-weight: 700;
  line-height: 1.4;
  text-decoration: none;
  text-shadow: 0 0 18px rgba(125, 240, 255, 0.28);
  transition:
    color 160ms ease,
    text-shadow 160ms ease;
}

.mainstage-event-link:hover,
.mainstage-event-link:focus-visible {
  color: #fff;
  text-shadow:
    0 0 18px rgba(125, 240, 255, 0.52),
    0 0 34px rgba(122, 167, 255, 0.3);
}

.mainstage-intro-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  align-items: center;
  gap: clamp(1rem, 3vw, 2rem);
  margin: clamp(2.25rem, 5vw, 4rem) auto 0;
  text-align: left;
}

.mainstage-placeholder-image {
  aspect-ratio: 16 / 9;
  min-height: auto;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 0.5rem;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.12), transparent 38%),
    radial-gradient(circle at 72% 22%, rgba(125, 240, 255, 0.14), transparent 14rem),
    linear-gradient(180deg, rgba(19, 25, 35, 0.88), rgba(7, 10, 16, 0.9));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.09),
    0 22px 60px rgba(0, 0, 0, 0.38);
}

.mainstage-placeholder-image img,
.mainstage-venue__image > img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: inherit;
  object-fit: cover;
}

.mainstage-placeholder-image img {
  object-position: 50% 50%;
  transform: rotate(3deg) scale(1.02);
  transform-origin: center;
}

.mainstage-lorem {
  color: rgba(242, 242, 243, 0.74);
  font-family: var(--mainstage-font-display);
  font-size: clamp(0.95rem, 1.45vw, 1.12rem);
  font-weight: 400;
  line-height: 1.72;
}

.mainstage-lorem p {
  margin: 0;
}

.mainstage-lorem p + p {
  margin-top: 1rem;
}

.mainstage-lineup {
  margin: clamp(3rem, 7vw, 5.5rem) auto 0;
  font-family: var(--mainstage-font-display);
  text-align: center;
}

.mainstage-lineup__intro {
  max-width: 820px;
  margin: 0 auto;
  color: rgba(242, 242, 243, 0.74);
  font-size: clamp(0.95rem, 1.45vw, 1.12rem);
  line-height: 1.72;
}

.mainstage-lineup h2 {
  margin: clamp(2rem, 4vw, 3rem) 0 clamp(1rem, 2.2vw, 1.5rem);
  color: #fff;
  font-size: clamp(2.1rem, 5vw, 4.4rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0;
  text-shadow: 0 18px 52px rgba(0, 0, 0, 0.62);
}

.mainstage-lineup__table-wrap {
  overflow-x: auto;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 0.5rem;
  background:
    radial-gradient(circle at 18% 0%, rgba(125, 240, 255, 0.1), transparent 18rem),
    linear-gradient(180deg, rgba(17, 22, 31, 0.76), rgba(7, 10, 16, 0.82));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 24px 68px rgba(0, 0, 0, 0.36);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.mainstage-lineup__table {
  width: 100%;
  min-width: 42rem;
  border-collapse: collapse;
  color: rgba(242, 242, 243, 0.78);
  text-align: left;
}

.mainstage-lineup__table th,
.mainstage-lineup__table td {
  padding: 1rem clamp(1rem, 2.2vw, 1.5rem);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  white-space: nowrap;
  vertical-align: middle;
}

.mainstage-lineup__table th {
  color: rgba(255, 255, 255, 0.94);
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
}

.mainstage-lineup__table td:first-child {
  color: #fff;
  font-weight: 700;
}

.mainstage-lineup__dj {
  --mainstage-lineup-logo-slot: clamp(3.7rem, 6vw, 4.35rem);
  display: inline-grid;
  grid-template-columns: var(--mainstage-lineup-logo-slot) auto;
  align-items: center;
  column-gap: 0.7rem;
  min-width: 0;
  line-height: 1;
  vertical-align: middle;
}

.mainstage-lineup__dj > span:not(.mainstage-lineup__birdbrain-glitch) {
  align-self: center;
  display: block;
  line-height: 1;
}

.mainstage-lineup__dj img,
.mainstage-lineup__logo-placeholder {
  width: 2.35rem;
  height: 1.65rem;
  flex: 0 0 auto;
}

.mainstage-lineup__dj > img,
.mainstage-lineup__dj > .mainstage-lineup__logo-placeholder {
  justify-self: center;
}

.mainstage-lineup__dj img {
  object-fit: contain;
  filter:
    drop-shadow(0 0 10px rgba(255, 255, 255, 0.14))
    drop-shadow(0 8px 14px rgba(0, 0, 0, 0.36));
}

.mainstage-lineup__dj .mainstage-lineup__wd40-logo {
  width: 100%;
  height: clamp(2.75rem, 4.6vw, 3.45rem);
  object-fit: contain;
}

.mainstage-lineup__dj .mainstage-lineup__birdbrain-logo {
  width: clamp(3.75rem, 6.25vw, 4.75rem);
  height: clamp(2.06rem, 3.5vw, 2.56rem);
  object-fit: cover;
  object-position: center;
}

.mainstage-lineup__oly-name {
  font-family: "Mainstage Ethnocentric", var(--mainstage-font-display);
  letter-spacing: 0;
}

.mainstage-lineup__secret-glitch {
  position: relative;
  display: inline-block;
  isolation: isolate;
  font-family: "Mainstage Ethnocentric", "Courier New", monospace;
  letter-spacing: 0;
  --mainstage-secret-glitch-x: 0px;
  --mainstage-secret-glitch-x-inverse: 0px;
  --mainstage-secret-glitch-y: 0px;
  --mainstage-secret-glitch-y-inverse: 0px;
  --mainstage-secret-glitch-duration: 120ms;
}

.mainstage-lineup__secret-glitch::before,
.mainstage-lineup__secret-glitch::after {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
  content: attr(data-mainstage-secret-glitch);
}

.mainstage-lineup__secret-glitch::before {
  color: rgba(255, 255, 255, 0.95);
  text-shadow:
    1px 0 rgba(125, 240, 255, 0.68),
    -1px 0 rgba(255, 255, 255, 0.38);
  transform:
    translate(
      var(--mainstage-secret-glitch-x),
      var(--mainstage-secret-glitch-y)
    )
    skewX(-7deg);
  clip-path: polygon(0 0, 100% 8%, 100% 44%, 0 34%);
}

.mainstage-lineup__secret-glitch::after {
  color: rgba(255, 255, 255, 0.72);
  text-shadow:
    2px 0 rgba(122, 167, 255, 0.48),
    -2px 0 rgba(255, 255, 255, 0.28);
  transform:
    translate(
      var(--mainstage-secret-glitch-x-inverse),
      var(--mainstage-secret-glitch-y-inverse)
    )
    skewX(9deg);
  clip-path: polygon(0 56%, 100% 44%, 100% 100%, 0 88%);
}

.mainstage-lineup__secret-glitch.mainstage-secret-glitching {
  color: #fff;
  text-shadow:
    2px 0 rgba(125, 240, 255, 0.52),
    -2px 0 rgba(255, 255, 255, 0.3),
    0 0 18px rgba(255, 255, 255, 0.34);
  filter: contrast(1.45) brightness(1.25);
  animation: mainstage-secret-glitch-core var(--mainstage-secret-glitch-duration) steps(2, end);
}

.mainstage-lineup__secret-glitch.mainstage-secret-glitching::before,
.mainstage-lineup__secret-glitch.mainstage-secret-glitching::after {
  animation: mainstage-secret-glitch-layer var(--mainstage-secret-glitch-duration) steps(2, end);
}

.mainstage-lineup__birdbrain-glitch {
  position: relative;
  display: inline-block;
  align-self: center;
  flex: 0 0 auto;
  width: clamp(8.2rem, 13vw, 10.4rem);
  height: clamp(1.65rem, 2.8vw, 2.05rem);
  overflow: hidden;
  isolation: isolate;
  --mainstage-birdbrain-glitch-x: 0px;
  --mainstage-birdbrain-glitch-x-inverse: 0px;
  --mainstage-birdbrain-glitch-x-half-inverse: 0px;
  --mainstage-birdbrain-glitch-y: 0%;
  --mainstage-birdbrain-glitch-slice: 42%;
  --mainstage-birdbrain-glitch-angle: 0deg;
  --mainstage-birdbrain-glitch-duration: 120ms;
}

.mainstage-lineup__dj .mainstage-lineup__birdbrain-wordmark {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.mainstage-lineup__birdbrain-glitch::before,
.mainstage-lineup__birdbrain-glitch::after {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
  content: "";
}

.mainstage-lineup__birdbrain-glitch::before {
  z-index: 1;
  background: url("/img/mainstage/DJLogos/Null_BirdBrain_RBN_Chapter_1.png") center / cover no-repeat;
  filter: brightness(2.6) contrast(2.3) blur(0.35px);
  mix-blend-mode: screen;
  transform:
    translateX(var(--mainstage-birdbrain-glitch-x))
    skewX(var(--mainstage-birdbrain-glitch-angle));
  clip-path: polygon(
    0 calc(var(--mainstage-birdbrain-glitch-y) + 5%),
    100% calc(var(--mainstage-birdbrain-glitch-y) + 0%),
    100% calc(var(--mainstage-birdbrain-glitch-y) + var(--mainstage-birdbrain-glitch-slice)),
    0 calc(var(--mainstage-birdbrain-glitch-y) + var(--mainstage-birdbrain-glitch-slice) + 8%)
  );
}

.mainstage-lineup__birdbrain-glitch::after {
  z-index: 2;
  background:
    repeating-linear-gradient(
      100deg,
      transparent 0 0.34rem,
      rgba(255, 255, 255, 0.95) 0.36rem 0.43rem,
      transparent 0.48rem 0.82rem
    ),
    repeating-linear-gradient(
      -7deg,
      transparent 0 0.42rem,
      rgba(255, 255, 255, 0.72) 0.46rem 0.52rem,
      transparent 0.58rem 1.04rem
    ),
    linear-gradient(90deg, transparent 0 12%, rgba(255, 255, 255, 0.85) 13% 14%, transparent 15% 37%, rgba(255, 255, 255, 0.62) 38% 39%, transparent 40%);
  background-position:
    var(--mainstage-birdbrain-glitch-x) var(--mainstage-birdbrain-glitch-y),
    var(--mainstage-birdbrain-glitch-x-inverse) var(--mainstage-birdbrain-glitch-y),
    0 0;
  filter: blur(0.15px) drop-shadow(0 0 5px rgba(255, 255, 255, 0.64));
  transform: translateX(var(--mainstage-birdbrain-glitch-x-half-inverse));
  clip-path: polygon(
    0 22%,
    11% 17%,
    19% 35%,
    31% 13%,
    43% 41%,
    54% 19%,
    66% 48%,
    78% 21%,
    92% 55%,
    100% 32%,
    100% 72%,
    88% 62%,
    77% 86%,
    63% 58%,
    50% 82%,
    37% 56%,
    26% 77%,
    14% 52%,
    0 68%
  );
}

.mainstage-lineup__birdbrain-glitch.mainstage-birdbrain-glitching::before {
  animation: mainstage-birdbrain-glitch-slice var(--mainstage-birdbrain-glitch-duration) steps(2, end);
}

.mainstage-lineup__birdbrain-glitch.mainstage-birdbrain-glitching::after {
  animation: mainstage-birdbrain-glitch-static var(--mainstage-birdbrain-glitch-duration) steps(2, end);
}

@keyframes mainstage-birdbrain-glitch-slice {
  0%,
  100% {
    opacity: 0;
  }

  18%,
  68% {
    opacity: 0.78;
  }
}

@keyframes mainstage-birdbrain-glitch-static {
  0%,
  100% {
    opacity: 0;
  }

  12%,
  54%,
  76% {
    opacity: 0.82;
  }
}

@keyframes mainstage-secret-glitch-core {
  0%,
  100% {
    transform: translateY(0);
  }

  24% {
    transform: translateY(-1px);
  }

  58% {
    transform: translateY(1px);
  }
}

@keyframes mainstage-secret-glitch-layer {
  0%,
  100% {
    opacity: 0;
  }

  18%,
  46%,
  74% {
    opacity: 0.88;
  }
}

.mainstage-lineup__dj--logo-only img,
.mainstage-lineup__lmfao-space-logo {
  width: clamp(6.4rem, 10vw, 8rem);
  height: 2rem;
  margin-left: 0.45rem;
}

.mainstage-lineup__dj--logo-only {
  align-items: center;
  display: inline-flex;
  margin-left: calc(var(--mainstage-lineup-logo-slot) + 0.7rem);
  line-height: 1;
  vertical-align: middle;
}

.mainstage-lineup__dj--logo-only .mainstage-lineup__lmfao-space-logo {
  margin-left: 0;
}

.mainstage-lineup__lmfao-space-logo {
  display: inline-block;
  flex: 0 0 auto;
  background:
    radial-gradient(circle at 18% 24%, rgba(255, 255, 255, 0.95) 0 1px, transparent 1.7px),
    radial-gradient(circle at 52% 18%, rgba(180, 210, 255, 0.95) 0 1.2px, transparent 2px),
    radial-gradient(circle at 78% 62%, rgba(255, 255, 255, 0.86) 0 1px, transparent 1.8px),
    radial-gradient(circle at 34% 72%, rgba(255, 190, 255, 0.9) 0 1.1px, transparent 1.9px),
    radial-gradient(ellipse at 15% 70%, rgba(196, 53, 255, 0.98) 0 10%, rgba(117, 24, 181, 0.74) 23%, transparent 52%),
    radial-gradient(ellipse at 86% 34%, rgba(226, 92, 255, 0.88) 0 9%, rgba(97, 23, 161, 0.78) 25%, transparent 55%),
    radial-gradient(ellipse at 52% 100%, rgba(124, 34, 214, 0.9) 0 18%, transparent 58%),
    linear-gradient(135deg, #050308 0%, #130621 34%, #020106 58%, #21063d 100%);
  background-size:
    2.9rem 2.1rem,
    3.7rem 2.4rem,
    4.3rem 2.8rem,
    3.2rem 2.5rem,
    11rem 5rem,
    12rem 5.5rem,
    10rem 4.8rem,
    14rem 7rem;
  filter:
    drop-shadow(0 0 6px rgba(190, 70, 255, 0.55))
    drop-shadow(0 0 14px rgba(255, 255, 255, 0.14));
  mask: url("/img/mainstage/DJLogos/LMFAOLOGO.svg") center / contain no-repeat;
  -webkit-mask: url("/img/mainstage/DJLogos/LMFAOLOGO.svg") center / contain no-repeat;
  animation: mainstage-lmfao-space-pan 7s linear infinite;
}

@keyframes mainstage-lmfao-space-pan {
  0% {
    background-position:
      0 0,
      0.5rem 0.2rem,
      1rem 0.7rem,
      1.5rem 0,
      0 0,
      2rem 0.6rem,
      1rem 0,
      0 0;
  }

  100% {
    background-position:
      2.9rem -2.1rem,
      -3.2rem 2.6rem,
      5.3rem -2.1rem,
      -1.7rem 2.5rem,
      -11rem 5rem,
      14rem -4.9rem,
      -9rem 4.8rem,
      0 0;
  }
}

.mainstage-lineup__logo-placeholder {
  display: inline-block;
  border: 1px solid rgba(255, 255, 255, 0.13);
  border-radius: 0.35rem;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.1), transparent 42%),
    radial-gradient(circle at 70% 20%, rgba(125, 240, 255, 0.12), transparent 1.4rem),
    rgba(9, 14, 20, 0.72);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 8px 14px rgba(0, 0, 0, 0.28);
}

.mainstage-lineup__table td:nth-child(2) {
  color: rgba(125, 240, 255, 0.86);
}

.mainstage-lineup__table tr:last-child td {
  border-bottom: 0;
}

.mainstage-venue {
  margin: clamp(3.5rem, 8vw, 6.5rem) auto 0;
  font-family: var(--mainstage-font-display);
  text-align: center;
}

.mainstage-venue h2 {
  margin: 0 0 clamp(1.25rem, 3vw, 2rem);
  color: #fff;
  font-size: clamp(2.1rem, 5vw, 4.4rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0;
  text-shadow: 0 18px 52px rgba(0, 0, 0, 0.62);
}

.mainstage-venue__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  align-items: center;
  gap: clamp(1rem, 3vw, 2rem);
  text-align: left;
}

.mainstage-venue__image {
  min-height: clamp(14rem, 26vw, 22rem);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 0.5rem;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.12), transparent 38%),
    radial-gradient(circle at 26% 18%, rgba(126, 224, 161, 0.13), transparent 14rem),
    linear-gradient(180deg, rgba(19, 25, 35, 0.88), rgba(7, 10, 16, 0.9));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.09),
    0 22px 60px rgba(0, 0, 0, 0.38);
}

.mainstage-venue__image--alt {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.1), transparent 42%),
    radial-gradient(circle at 74% 24%, rgba(122, 167, 255, 0.14), transparent 14rem),
    linear-gradient(180deg, rgba(18, 23, 34, 0.88), rgba(7, 10, 16, 0.9));
}

.mainstage-venue__video-frame {
  position: relative;
  overflow: hidden;
  background: #050608;
}

.mainstage-venue__video-frame video {
  display: block;
  width: 100%;
  height: 100%;
  min-height: inherit;
  object-fit: cover;
}

.mainstage-venue__copy {
  color: rgba(242, 242, 243, 0.74);
  font-size: clamp(0.95rem, 1.45vw, 1.12rem);
  line-height: 1.72;
}

.mainstage-venue__copy p {
  margin: 0;
}

.mainstage-venue__link {
  display: inline-block;
  margin-top: 1.1rem;
  color: #7df0ff;
  font-weight: 700;
  text-decoration: none;
  text-shadow: 0 0 18px rgba(125, 240, 255, 0.18);
}

.mainstage-venue__link:hover,
.mainstage-venue__link:focus-visible {
  color: #fff;
  text-decoration: underline;
}

.mainstage-static-target {
  position: relative;
  display: inline-block;
}

.mainstage-static-target.mainstage-static-flash {
  position: relative;
  color: #fff;
  text-shadow:
    2px 0 rgba(125, 240, 255, 0.58),
    -2px 0 rgba(255, 255, 255, 0.34),
    0 0 18px rgba(255, 255, 255, 0.46);
  filter: contrast(1.45) brightness(1.35);
}

.mainstage-static-target.mainstage-static-flash::after {
  content: attr(data-mainstage-static);
  position: absolute;
  top: 0;
  left: var(--mainstage-static-offset, 14px);
  overflow: hidden;
  color: rgba(255, 255, 255, 0.86);
  text-shadow:
    2px 0 rgba(125, 240, 255, 0.46),
    -2px 0 rgba(122, 167, 255, 0.34);
  clip-path: polygon(0 20%, 100% 12%, 100% 44%, 0 52%);
  pointer-events: none;
}

.mainstage-rig {
  position: fixed;
  top: 0;
  bottom: auto;
  width: clamp(8rem, 10vw, 11.5rem);
  height: 100vh;
  height: 100dvh;
  z-index: 4;
  pointer-events: none;
  opacity: 1;
  transition: opacity 180ms ease;
}

.mainstage-rig::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("/img/mainstage/stage-truss.svg");
  background-repeat: repeat-y;
  background-position: center top;
  background-size: 100% 40vh;
  filter:
    drop-shadow(0 0 12px rgba(255, 255, 255, 0.12))
    drop-shadow(0 18px 28px rgba(0, 0, 0, 0.72));
}

.mainstage-rig--left {
  left: max(var(--mainstage-rig-inset), calc((100vw - var(--mainstage-stage-width)) / 2 + var(--mainstage-rig-inset)));
}

.mainstage-rig--right {
  right: max(var(--mainstage-rig-inset), calc((100vw - var(--mainstage-stage-width)) / 2 + var(--mainstage-rig-inset)));
}

.mainstage-rig__image {
  display: none;
}

.mainstage-rig--left .mainstage-rig__image {
  left: -0.35rem;
}

.mainstage-rig--right .mainstage-rig__image {
  right: -0.35rem;
}

.mainstage-rig__beam {
  position: absolute;
  top: var(--mainstage-beam-top);
  width: 42vw;
  height: 10.5rem;
  opacity: 0.28;
  filter: blur(2px);
  background: linear-gradient(90deg, rgba(125, 240, 255, 0.36), rgba(122, 167, 255, 0.04) 68%, transparent);
  clip-path: polygon(0 36%, 100% 0, 100% 100%, 0 64%);
  transform-origin: left center;
  will-change: transform, opacity;
}

.mainstage-rig--left .mainstage-rig__beam {
  left: calc(100% - 1.25rem);
  transform: rotate(calc(var(--mainstage-beam-angle) + (var(--mainstage-beam-sweep) * 34deg)));
}

.mainstage-rig--right .mainstage-rig__beam {
  left: auto;
  right: calc(100% - 1.25rem);
  transform-origin: right center;
  background: linear-gradient(270deg, rgba(125, 240, 255, 0.36), rgba(122, 167, 255, 0.04) 68%, transparent);
  clip-path: polygon(0 0, 100% 36%, 100% 64%, 0 100%);
  transform: rotate(calc(var(--mainstage-beam-angle) + (var(--mainstage-beam-sweep) * 34deg)));
}

.mainstage-rig__beam--one {
  --mainstage-beam-top: 14%;
  --mainstage-beam-angle: -16deg;
  --mainstage-beam-sweep: var(--mainstage-light-sweep-1);
}

.mainstage-rig__beam--two {
  --mainstage-beam-top: 35%;
  --mainstage-beam-angle: -5deg;
  --mainstage-beam-sweep: var(--mainstage-light-sweep-2);
  background: linear-gradient(90deg, rgba(126, 224, 161, 0.26), rgba(122, 167, 255, 0.03) 70%, transparent);
}

.mainstage-rig__beam--three {
  --mainstage-beam-top: 56%;
  --mainstage-beam-angle: 5deg;
  --mainstage-beam-sweep: var(--mainstage-light-sweep-3);
  background: linear-gradient(90deg, rgba(122, 167, 255, 0.28), rgba(125, 240, 255, 0.04) 70%, transparent);
}

.mainstage-rig__beam--four {
  --mainstage-beam-top: 77%;
  --mainstage-beam-angle: 16deg;
  --mainstage-beam-sweep: var(--mainstage-light-sweep-4);
  background: linear-gradient(90deg, rgba(216, 196, 138, 0.22), rgba(122, 167, 255, 0.03) 70%, transparent);
}

.mainstage-rig--right .mainstage-rig__beam--two {
  background: linear-gradient(270deg, rgba(126, 224, 161, 0.26), rgba(122, 167, 255, 0.03) 70%, transparent);
}

.mainstage-rig--right .mainstage-rig__beam--three {
  background: linear-gradient(270deg, rgba(122, 167, 255, 0.28), rgba(125, 240, 255, 0.04) 70%, transparent);
}

.mainstage-rig--right .mainstage-rig__beam--four {
  background: linear-gradient(270deg, rgba(216, 196, 138, 0.22), rgba(122, 167, 255, 0.03) 70%, transparent);
}

@media (max-width: 920px) {
  .mainstage-rig {
    width: 7rem;
    opacity: 0.74;
  }

  .mainstage-rig__beam {
    width: 52vw;
  }

  .mainstage-intro-grid {
    grid-template-columns: 1fr;
    max-width: 36rem;
    text-align: center;
  }

  .mainstage-venue__grid {
    grid-template-columns: 1fr;
    max-width: 36rem;
    margin: 0 auto;
    text-align: center;
  }

  .mainstage-venue__copy:nth-child(3) {
    order: 4;
  }

  .mainstage-venue__image--alt {
    order: 3;
  }
}

@media (max-width: 640px) {
  .mainstage-page {
    --mainstage-rig-inset: 0.15rem;
    margin-top: -1rem;
  }

  .mainstage-center {
    padding-left: clamp(1.25rem, 7vw, 2rem);
    padding-right: clamp(1.25rem, 7vw, 2rem);
  }

  .mainstage-rig {
    width: clamp(3.25rem, 13vw, 4.6rem);
    z-index: 4;
    opacity: 0.68;
  }

  .mainstage-rig__beam {
    display: block;
    width: 58vw;
    height: 6.2rem;
    opacity: 0.14;
    filter: blur(1.5px);
  }

  .mainstage-logo {
    width: min(275px, 72vw);
  }
}

@media (prefers-reduced-motion: reduce) {
  .mainstage-page {
    --mainstage-scroll: 0;
    --mainstage-light-sweep-1: 0;
    --mainstage-light-sweep-2: 0;
    --mainstage-light-sweep-3: 0;
    --mainstage-light-sweep-4: 0;
  }

  .mainstage-rig,
  .mainstage-rig__beam,
  .mainstage-static-target.mainstage-static-flash,
  .mainstage-lineup__secret-glitch.mainstage-secret-glitching,
  .mainstage-lineup__birdbrain-glitch.mainstage-birdbrain-glitching,
  .mainstage-lineup__lmfao-space-logo,
  .mainstage-particle {
    animation: none;
    transition: none;
    transform: none;
    filter: none;
    text-shadow: none;
  }

  .mainstage-static-target.mainstage-static-flash::after {
    content: none;
  }

  .mainstage-lineup__secret-glitch::before,
  .mainstage-lineup__secret-glitch::after {
    content: none;
  }

  .mainstage-lineup__birdbrain-glitch::before,
  .mainstage-lineup__birdbrain-glitch::after {
    content: none;
  }

  .mainstage-particle {
    opacity: calc(var(--mainstage-particle-opacity) * 0.58);
  }

  .mainstage-vine {
    clip-path: none;
  }

  .mainstage-vine--stem,
  .mainstage-vine--leaves,
  .mainstage-vine--tendrils {
    opacity: 0.44;
  }

  .mainstage-vine--top {
    opacity: 0.28;
  }

  .mainstage-vine--content-left,
  .mainstage-vine--content-right {
    opacity: 0.28;
  }
}

.mainstage-vines {
  position: absolute;
  inset: 0;
  z-index: 2;
  overflow: hidden;
  pointer-events: none;
}

.mainstage-vine {
  position: absolute;
  display: block;
  opacity: 0.5;
  filter:
    drop-shadow(0 0 12px rgba(126, 224, 161, 0.16))
    drop-shadow(0 18px 28px rgba(0, 0, 0, 0.48));
  pointer-events: none;
}

.mainstage-vine--left,
.mainstage-vine--right {
  position: fixed;
  top: -2vh;
  width: clamp(5.5rem, 7vw, 8.25rem);
  height: 104vh;
  height: 104dvh;
  background: url("/img/mainstage/vine-climb.svg") center top / 100% auto repeat-y;
  opacity: 0;
  --mainstage-vine-visible: clamp(0%, calc((var(--mainstage-scroll) * 135%) - var(--mainstage-vine-delay)), 100%);
  clip-path: polygon(0 calc(100% - var(--mainstage-vine-visible)), 100% calc(100% - var(--mainstage-vine-visible)), 100% 100%, 0 100%);
}

.mainstage-vine--left {
  left: max(calc(var(--mainstage-rig-inset) + 2.4rem), calc((100vw - var(--mainstage-stage-width)) / 2 + var(--mainstage-rig-inset) + 2.4rem));
  transform: rotate(-2deg) translateY(calc((1 - var(--mainstage-scroll)) * 2rem));
}

.mainstage-vine--right {
  right: max(calc(var(--mainstage-rig-inset) + 2.1rem), calc((100vw - var(--mainstage-stage-width)) / 2 + var(--mainstage-rig-inset) + 2.1rem));
  transform: scaleX(-1) rotate(-2deg) translateY(calc((1 - var(--mainstage-scroll)) * 2rem));
}

.mainstage-vine--stem {
  --mainstage-vine-delay: 0%;
  opacity: 0.48;
  filter:
    drop-shadow(0 0 10px rgba(126, 224, 161, 0.16))
    drop-shadow(0 18px 28px rgba(0, 0, 0, 0.48))
    saturate(1.16) brightness(1.15);
}

.mainstage-vine--leaves {
  --mainstage-vine-delay: 12%;
  opacity: 0.58;
  width: clamp(6.4rem, 8vw, 9.25rem);
  background-position: center 2.5rem;
  filter:
    drop-shadow(0 0 14px rgba(126, 224, 161, 0.2))
    drop-shadow(0 18px 28px rgba(0, 0, 0, 0.48))
    saturate(1.28) brightness(1.22);
}

.mainstage-vine--tendrils {
  --mainstage-vine-delay: 24%;
  opacity: 0.44;
  width: clamp(5rem, 6.3vw, 7.5rem);
  background-position: center 5rem;
  filter:
    drop-shadow(0 0 12px rgba(120, 212, 211, 0.18))
    drop-shadow(0 18px 28px rgba(0, 0, 0, 0.48))
    saturate(1.18) brightness(1.18);
}

.mainstage-vine--left.mainstage-vine--leaves {
  transform: rotate(3deg) translateY(calc((1 - var(--mainstage-scroll)) * 1.4rem));
}

.mainstage-vine--left.mainstage-vine--tendrils {
  transform: rotate(-7deg) translateX(0.55rem) translateY(calc((1 - var(--mainstage-scroll)) * 1rem));
}

.mainstage-vine--right.mainstage-vine--leaves {
  transform: scaleX(-1) rotate(3deg) translateY(calc((1 - var(--mainstage-scroll)) * 1.4rem));
}

.mainstage-vine--right.mainstage-vine--tendrils {
  transform: scaleX(-1) rotate(-7deg) translateX(0.55rem) translateY(calc((1 - var(--mainstage-scroll)) * 1rem));
}

.mainstage-vine--top {
  top: clamp(3.2rem, 7vh, 5.4rem);
  left: 50%;
  width: min(48rem, 64vw);
  height: clamp(7rem, 14vw, 12rem);
  background: url("/img/mainstage/vine-hanging.svg") center top / contain no-repeat;
  opacity: clamp(0.16, calc(var(--mainstage-scroll) * 0.5), 0.34);
  transform: translateX(-50%);
  clip-path: polygon(0 0, 100% 0, 100% clamp(22%, calc(var(--mainstage-scroll) * 180%), 100%), 0 clamp(22%, calc(var(--mainstage-scroll) * 180%), 100%));
}

.mainstage-vine--content-left,
.mainstage-vine--content-right {
  width: clamp(9rem, 18vw, 15rem);
  height: clamp(15rem, 28vw, 23rem);
  background: url("/img/mainstage/vine-climb.svg") center top / contain no-repeat;
  opacity: clamp(0.1, calc(var(--mainstage-scroll) * 0.38), 0.34);
  filter:
    drop-shadow(0 0 14px rgba(126, 224, 161, 0.16))
    drop-shadow(0 18px 28px rgba(0, 0, 0, 0.48))
    saturate(1.22) brightness(1.18);
}

.mainstage-vine--content-left {
  top: clamp(45rem, 92vh, 61rem);
  left: max(2rem, calc((100vw - 980px) / 2 - 4rem));
  transform: rotate(78deg);
}

.mainstage-vine--content-right {
  top: clamp(49rem, 98vh, 65rem);
  right: max(2rem, calc((100vw - 980px) / 2 - 4rem));
  transform: scaleX(-1) rotate(96deg);
}

.mainstage-page--reduced-effects .mainstage-particle {
  animation: none;
  box-shadow: none;
  opacity: calc(var(--mainstage-particle-opacity) * 0.58);
  transform: translate(-50%, -50%) scale(0.75);
}

.mainstage-page--reduced-effects .mainstage-lineup__table-wrap {
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.mainstage-page--reduced-effects .mainstage-logo,
.mainstage-page--reduced-effects .mainstage-lineup__dj img,
.mainstage-page--reduced-effects .mainstage-lineup__lmfao-space-logo,
.mainstage-page--reduced-effects .mainstage-rig::before,
.mainstage-page--reduced-effects .mainstage-rig__beam,
.mainstage-page--reduced-effects .mainstage-vine {
  filter: none;
}

.mainstage-page--reduced-effects .mainstage-lineup__lmfao-space-logo {
  animation: none;
}

.mainstage-page--reduced-effects .mainstage-lineup__birdbrain-glitch::before,
.mainstage-page--reduced-effects .mainstage-lineup__birdbrain-glitch::after {
  content: none;
}

.mainstage-page--reduced-effects .mainstage-lineup__secret-glitch.mainstage-secret-glitching {
  filter: none;
  text-shadow: none;
}

.mainstage-page--reduced-effects .mainstage-lineup__secret-glitch::before,
.mainstage-page--reduced-effects .mainstage-lineup__secret-glitch::after {
  content: none;
}

.mainstage-page--reduced-effects .mainstage-static-target.mainstage-static-flash {
  filter: none;
  text-shadow: none;
}

.mainstage-page--reduced-effects .mainstage-static-target.mainstage-static-flash::after {
  content: none;
}

.mainstage-page--reduced-effects .mainstage-rig__beam {
  opacity: 0.12;
  will-change: auto;
}

@media (max-width: 640px) {
  .mainstage-rig::before {
    background-size: 100% 26vh;
    filter:
      drop-shadow(0 0 9px rgba(255, 255, 255, 0.1))
      drop-shadow(0 12px 18px rgba(0, 0, 0, 0.7));
  }

  .mainstage-rig--left {
    left: var(--mainstage-rig-inset);
  }

  .mainstage-rig--right {
    right: var(--mainstage-rig-inset);
  }

  .mainstage-vines {
    z-index: 2;
  }

  .mainstage-vine--left,
  .mainstage-vine--right {
    top: -1vh;
    width: clamp(3.4rem, 14vw, 4.9rem);
    height: 102vh;
    height: 102dvh;
    background-size: 100% auto;
    --mainstage-vine-visible: clamp(0%, calc((var(--mainstage-scroll) * 150%) - var(--mainstage-vine-delay)), 100%);
  }

  .mainstage-vine--left {
    left: clamp(0.55rem, 2.4vw, 0.9rem);
  }

  .mainstage-vine--right {
    right: clamp(0.55rem, 2.4vw, 0.9rem);
  }

  .mainstage-vine--leaves {
    width: clamp(3.9rem, 16vw, 5.4rem);
    background-position: center 1.7rem;
  }

  .mainstage-vine--tendrils {
    width: clamp(3.1rem, 12vw, 4.3rem);
    background-position: center 3rem;
  }

  .mainstage-vine--left.mainstage-vine--tendrils {
    transform: rotate(-7deg) translateX(0.3rem) translateY(calc((1 - var(--mainstage-scroll)) * 0.8rem));
  }

  .mainstage-vine--right.mainstage-vine--tendrils {
    transform: scaleX(-1) rotate(-7deg) translateX(0.3rem) translateY(calc((1 - var(--mainstage-scroll)) * 0.8rem));
  }

  .mainstage-vine--top {
    width: min(24rem, 72vw);
    height: clamp(4.6rem, 18vw, 7rem);
    opacity: clamp(0.12, calc(var(--mainstage-scroll) * 0.42), 0.28);
  }

  .mainstage-vine--content-left,
  .mainstage-vine--content-right {
    display: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .mainstage-vine {
    clip-path: none;
  }

  .mainstage-vine--stem,
  .mainstage-vine--leaves,
  .mainstage-vine--tendrils {
    opacity: 0.44;
  }

  .mainstage-vine--top {
    opacity: 0.28;
  }

  .mainstage-vine--content-left,
  .mainstage-vine--content-right {
    opacity: 0.28;
  }
}
