:root {
  --bg-1: #ffef84;
  --bg-2: #ff8a00;
  --bg-3: #ff395e;
  --bg-4: #0f8bff;
  --ink: #17101a;
  --cream: #fff7df;
  --outline: #231629;
  --cyan: #20f6ff;
  --lime: #d5ff3f;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
}

body {
  overflow: hidden;
  font-family: Impact, Haettenschweiler, "Arial Black", sans-serif;
  color: var(--cream);
  background:
    radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.35), transparent 14%),
    radial-gradient(circle at 80% 15%, rgba(255, 245, 133, 0.5), transparent 18%),
    radial-gradient(circle at center, rgba(255, 255, 255, 0.18), transparent 25%),
    linear-gradient(120deg, var(--bg-1) 0%, var(--bg-2) 25%, var(--bg-3) 60%, var(--bg-4) 100%);
  background-size: 120% 120%;
  animation: backgroundPulse 6s linear infinite;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  background:
    radial-gradient(circle, rgba(255, 255, 255, 0.32) 0 7%, transparent 8% 100%),
    radial-gradient(circle, rgba(255, 215, 0, 0.24) 0 9%, transparent 10% 100%);
  background-position: 0 0, 12px 12px;
  background-size: 24px 24px;
  mix-blend-mode: soft-light;
  opacity: 0.35;
  pointer-events: none;
}

body::after {
  content: "";
  position: fixed;
  inset: -12%;
  z-index: 0;
  background:
    radial-gradient(circle at center, rgba(255, 255, 255, 0.3) 0 12%, transparent 18%),
    repeating-conic-gradient(
      from 0deg,
      rgba(255, 255, 255, 0.12) 0 12deg,
      transparent 12deg 28deg,
      rgba(255, 90, 125, 0.11) 28deg 36deg,
      transparent 36deg 56deg
    );
  mix-blend-mode: screen;
  opacity: 0.22;
  pointer-events: none;
  animation: overlaySpin 8s linear infinite, overlayFlash 1.2s steps(2) infinite;
}

#particles,
.noise,
.scanlines,
.corner {
  position: fixed;
  inset: 0;
  pointer-events: none;
}

#particles {
  z-index: 1;
}

.noise {
  z-index: 4;
  opacity: 0.18;
  background-image:
    radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.8) 0 1px, transparent 2px),
    radial-gradient(circle at 60% 80%, rgba(0, 0, 0, 0.7) 0 1px, transparent 2px),
    radial-gradient(circle at 80% 30%, rgba(255, 255, 255, 0.7) 0 1px, transparent 2px);
  background-size: 20px 20px, 17px 17px, 13px 13px;
  animation: noiseShift 0.25s steps(2) infinite;
}

.scanlines {
  z-index: 5;
  background:
    repeating-linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.14) 0 2px,
      rgba(0, 0, 0, 0.08) 2px 4px
    );
  mix-blend-mode: overlay;
  opacity: 0.22;
}

.corner {
  z-index: 2;
  width: 24vmin;
  height: 24vmin;
  border: 1.2vmin solid rgba(255, 247, 223, 0.42);
  filter: drop-shadow(0 0 20px rgba(255, 255, 255, 0.5));
}

.corner-left {
  inset: 2rem auto auto 2rem;
  clip-path: polygon(0 0, 100% 0, 100% 14%, 14% 14%, 14% 100%, 0 100%);
  animation: cornerFlicker 2.4s steps(2) infinite;
}

.corner-right {
  inset: auto 2rem 2rem auto;
  clip-path: polygon(86% 0, 100% 0, 100% 100%, 0 100%, 0 86%, 86% 86%);
  animation: cornerFlicker 2.4s steps(2) infinite reverse;
}

.intro-shell {
  position: relative;
  z-index: 3;
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 1.2rem;
  isolation: isolate;
}

.stage {
  position: relative;
  width: min(94vw, 1100px);
  display: grid;
  place-items: center;
  gap: 0.8rem;
  text-align: center;
  transform-origin: center;
  animation: stageLoop 4.6s ease-in-out infinite;
}

.stage::before,
.stage::after {
  content: "";
  position: absolute;
  inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
}

.stage::before {
  width: min(90vmin, 760px);
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(255, 250, 214, 0.3) 0 22%, transparent 45%),
    repeating-conic-gradient(
      from 0deg,
      rgba(255, 255, 255, 0.18) 0 7deg,
      transparent 7deg 16deg,
      rgba(32, 246, 255, 0.16) 16deg 20deg,
      transparent 20deg 30deg
    );
  mix-blend-mode: soft-light;
  opacity: 0.75;
  animation: stageBurstSpin 7s linear infinite;
  z-index: -2;
}

.stage::after {
  width: min(72vmin, 560px);
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.26), transparent 66%);
  filter: blur(24px);
  animation: stageFlash 1.4s ease-in-out infinite;
  z-index: -1;
}

.eyebrow,
.subhead,
.callouts span,
.orbit span {
  letter-spacing: 0.14em;
}

.eyebrow {
  margin: 0;
  font-size: clamp(0.8rem, 1.5vw, 1.3rem);
  color: var(--lime);
  text-shadow:
    3px 3px 0 #000,
    -3px -3px 0 rgba(32, 246, 255, 0.75);
  animation: eyebrowKick 0.7s steps(2) infinite;
}

.headline {
  position: relative;
  margin: 0;
  font-size: clamp(3rem, 10vw, 8.5rem);
  line-height: 0.9;
  color: #fff6d0;
  text-transform: uppercase;
  text-shadow:
    0 0 10px rgba(255, 255, 255, 0.35),
    0.08em 0.08em 0 var(--outline),
    -0.06em -0.05em 0 var(--cyan),
    0.04em 0.03em 0 #ff2b61;
  animation: titleJitter 0.42s steps(2) infinite;
}

.headline::before,
.headline::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  opacity: 0.8;
}

.headline::before {
  transform: translate(-0.03em, -0.02em);
  color: var(--cyan);
  mix-blend-mode: screen;
}

.headline::after {
  transform: translate(0.04em, 0.03em);
  color: #ff2b61;
  mix-blend-mode: multiply;
}

.subhead {
  max-width: 36rem;
  margin: 0;
  font-size: clamp(0.85rem, 2vw, 1.35rem);
  color: #fffce7;
  text-transform: uppercase;
  text-shadow: 2px 2px 0 rgba(35, 22, 41, 0.8);
  animation: subheadBounce 2.3s ease-in-out infinite;
}

.hero {
  position: relative;
  width: min(80vmin, 650px);
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  animation: heroFloat 1.8s ease-in-out infinite alternate;
}

.hero::before,
.hero::after {
  content: "";
  position: absolute;
  inset: 12%;
  border-radius: 50%;
  pointer-events: none;
}

.hero::before {
  background:
    repeating-conic-gradient(
      from 0deg,
      rgba(255, 246, 186, 0.55) 0 7deg,
      transparent 7deg 15deg,
      rgba(255, 93, 125, 0.4) 15deg 19deg,
      transparent 19deg 30deg
    );
  opacity: 0.42;
  mix-blend-mode: screen;
  animation: burstSpin 3.6s linear infinite;
}

.hero::after {
  inset: 18%;
  border: 0.9vmin dotted rgba(255, 255, 255, 0.68);
  box-shadow: 0 0 0 0.8vmin rgba(32, 246, 255, 0.2);
  animation: haloPulse 1.7s ease-in-out infinite;
}

.hero-glow,
.shock,
.spark-ring {
  position: absolute;
  inset: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
}

.hero-glow {
  width: 88%;
  height: 88%;
  background:
    radial-gradient(circle, rgba(255, 255, 255, 0.7) 0 12%, rgba(255, 230, 92, 0.36) 22%, rgba(255, 57, 94, 0.2) 46%, transparent 72%);
  filter: blur(16px);
  animation: glowLoop 3s ease-in-out infinite;
}

.shock {
  width: 100%;
  height: 100%;
  border: 1.2vmin dashed rgba(255, 247, 223, 0.7);
  box-shadow:
    0 0 0 0.9vmin rgba(255, 214, 71, 0.4),
    0 0 44px rgba(255, 255, 255, 0.38);
}

.shock-a {
  animation: shockExpand 1.8s ease-out infinite;
}

.shock-b {
  animation: shockExpand 1.8s ease-out infinite 0.9s;
}

.spin-burst {
  position: absolute;
  inset: 10%;
  border-radius: 50%;
  background:
    repeating-conic-gradient(
      from 0deg,
      rgba(255, 255, 255, 0.34) 0 9deg,
      transparent 9deg 18deg,
      rgba(213, 255, 63, 0.26) 18deg 22deg,
      transparent 22deg 32deg
    );
  mix-blend-mode: screen;
  opacity: 0.45;
  animation: burstSpinReverse 2.9s linear infinite;
}

.spark-ring {
  border: 0.9vmin dotted rgba(255, 255, 255, 0.72);
  opacity: 0;
}

.spark-ring-a {
  width: 92%;
  height: 92%;
  animation: sparkExpand 1.7s linear infinite;
}

.spark-ring-b {
  width: 92%;
  height: 92%;
  animation: sparkExpand 1.7s linear infinite 0.85s;
}

.laser {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 156%;
  height: 1.1rem;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.95), transparent);
  mix-blend-mode: screen;
  opacity: 0.45;
  filter: blur(1px);
}

.laser-a {
  transform: translate(-50%, -50%) rotate(27deg);
  animation: laserSweepA 2.2s ease-in-out infinite;
}

.laser-b {
  transform: translate(-50%, -50%) rotate(-31deg);
  animation: laserSweepB 1.8s ease-in-out infinite;
}

.hero-beer {
  position: relative;
  animation: beerPop 2.9s ease-in-out infinite;
}

.hero-tilt {
  animation: beerTilt 0.9s ease-in-out infinite alternate;
}

.hero-glyph {
  font-size: clamp(10rem, 32vmin, 20rem);
  line-height: 1;
  filter:
    drop-shadow(0 0 12px rgba(255, 255, 255, 0.55))
    drop-shadow(0 0 24px rgba(255, 185, 44, 0.5))
    drop-shadow(14px 18px 0 rgba(35, 22, 41, 0.5));
  transform-origin: 50% 56%;
  animation: beerSpin 2.1s linear infinite;
}

.orbit {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
}

.orbit span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 5.5rem;
  padding: 0.55rem 0.9rem 0.4rem;
  border: 4px solid var(--outline);
  border-radius: 999px;
  background: linear-gradient(180deg, #fff8d7 0%, #ffd136 100%);
  color: var(--outline);
  font-size: clamp(0.9rem, 1.6vw, 1.15rem);
  transform: translateY(-40%);
  box-shadow: 0 8px 0 rgba(35, 22, 41, 0.65);
  animation: orbitBadgeFlash 0.9s ease-in-out infinite alternate;
}

.orbit-a {
  animation: orbitSpin 4.2s linear infinite;
}

.orbit-b {
  animation: orbitSpin 3.8s linear infinite reverse;
}

.orbit-c {
  animation: orbitSpin 4.8s linear infinite;
}

.orbit-a span {
  transform: rotate(0deg) translateY(-230%) rotate(0deg);
}

.orbit-b span {
  transform: rotate(120deg) translateY(-235%) rotate(-120deg);
}

.orbit-c span {
  transform: rotate(240deg) translateY(-245%) rotate(-240deg);
}

.callouts {
  display: flex;
  gap: 0.8rem;
  flex-wrap: wrap;
  justify-content: center;
  max-width: 48rem;
}

.callouts span {
  padding: 0.55rem 1rem 0.45rem;
  background: #fff6d8;
  color: #1d1320;
  border: 4px solid #1d1320;
  box-shadow: 0 8px 0 rgba(29, 19, 32, 0.6);
  font-size: clamp(0.85rem, 1.7vw, 1.1rem);
  text-transform: uppercase;
  animation: badgeBounce 0.6s ease-in-out infinite alternate, badgeFlash 0.9s steps(2) infinite;
}

.callouts span:nth-child(2) {
  animation-delay: 0.15s;
}

.callouts span:nth-child(3) {
  animation-delay: 0.3s;
}

.callouts span:nth-child(4) {
  animation-delay: 0.45s;
}

.callouts span:nth-child(5) {
  animation-delay: 0.6s;
}

.ribbon {
  position: absolute;
  z-index: 6;
  width: min(80vw, 34rem);
  overflow: hidden;
  border: 5px solid rgba(23, 16, 26, 0.95);
  background: linear-gradient(90deg, #fff6c8 0%, #ffd33b 52%, #ff9d18 100%);
  box-shadow:
    0 10px 0 rgba(23, 16, 26, 0.55),
    0 0 24px rgba(255, 255, 255, 0.3);
}

.ribbon::before,
.ribbon::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 1.8rem;
  height: calc(100% - 0.55rem);
  transform: translateY(-50%);
  background: inherit;
  border: 5px solid rgba(23, 16, 26, 0.95);
}

.ribbon::before {
  left: -1.2rem;
  clip-path: polygon(100% 0, 0 50%, 100% 100%);
}

.ribbon::after {
  right: -1.2rem;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}

.ribbon-top {
  top: 4.5vh;
  left: max(1rem, 4vw);
  transform: rotate(-8deg);
  animation: ribbonSwingTop 1.8s ease-in-out infinite alternate;
}

.ribbon-bottom {
  right: max(1rem, 4vw);
  bottom: 5vh;
  transform: rotate(7deg);
  background: linear-gradient(90deg, #d9ff52 0%, #20f6ff 50%, #7fa8ff 100%);
  animation: ribbonSwingBottom 1.5s ease-in-out infinite alternate;
}

.ribbon-track {
  display: flex;
  width: max-content;
  animation: ribbonSlide 4.4s linear infinite;
}

.ribbon-bottom .ribbon-track {
  animation-duration: 3.7s;
  animation-direction: reverse;
}

.ribbon-track span {
  flex: none;
  padding: 0.45rem 1.35rem;
  color: var(--ink);
  font-size: clamp(0.95rem, 1.8vw, 1.25rem);
  white-space: nowrap;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  text-shadow: 2px 2px 0 rgba(255, 255, 255, 0.35);
}

@keyframes backgroundPulse {
  0%,
  100% {
    background-position: 0% 50%;
    filter: saturate(1) contrast(1);
  }
  35% {
    background-position: 100% 40%;
    filter: saturate(1.25) contrast(1.08);
  }
  70% {
    background-position: 30% 100%;
    filter: saturate(1.1) contrast(1.12);
  }
}

@keyframes overlaySpin {
  from {
    transform: rotate(0deg) scale(1);
  }
  to {
    transform: rotate(360deg) scale(1.08);
  }
}

@keyframes overlayFlash {
  0%,
  100% {
    opacity: 0.16;
  }
  50% {
    opacity: 0.28;
  }
}

@keyframes noiseShift {
  0% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(4px, -3px);
  }
  100% {
    transform: translate(-3px, 3px);
  }
}

@keyframes cornerFlicker {
  0%,
  100% {
    opacity: 0.65;
  }
  50% {
    opacity: 0.95;
  }
}

@keyframes stageBurstSpin {
  from {
    transform: translate(-50%, -50%) rotate(0deg) scale(1);
  }
  to {
    transform: translate(-50%, -50%) rotate(360deg) scale(1.06);
  }
}

@keyframes stageFlash {
  0%,
  100% {
    opacity: 0.26;
  }
  40% {
    opacity: 0.55;
  }
  52% {
    opacity: 0.14;
  }
  62% {
    opacity: 0.6;
  }
}

@keyframes stageLoop {
  0%,
  100% {
    transform: scale(1) rotate(0deg);
  }
  14% {
    transform: scale(1.08) rotate(-1.5deg);
  }
  28% {
    transform: scale(0.96) rotate(1.2deg);
  }
  42% {
    transform: scale(1.15) rotate(-2.2deg);
  }
  58% {
    transform: scale(1.01) rotate(1.4deg);
  }
  76% {
    transform: scale(1.11) rotate(-1.8deg);
  }
}

@keyframes eyebrowKick {
  0%,
  100% {
    transform: translate(0, 0);
  }
  35% {
    transform: translate(2px, -2px);
  }
  50% {
    transform: translate(-2px, 1px);
  }
  80% {
    transform: translate(1px, 2px);
  }
}

@keyframes titleJitter {
  0%,
  100% {
    transform: translate(0, 0);
  }
  25% {
    transform: translate(-2px, 1px);
  }
  50% {
    transform: translate(2px, -2px);
  }
  75% {
    transform: translate(-1px, 2px);
  }
}

@keyframes subheadBounce {
  0%,
  100% {
    transform: scale(1);
  }
  45% {
    transform: scale(1.08);
  }
  60% {
    transform: scale(0.96);
  }
}

@keyframes heroFloat {
  from {
    transform: translateY(-8px) rotate(-1deg);
  }
  to {
    transform: translateY(10px) rotate(1.2deg);
  }
}

@keyframes glowLoop {
  0%,
  100% {
    transform: translate(-50%, -50%) scale(1);
    opacity: 0.88;
  }
  50% {
    transform: translate(-50%, -50%) scale(1.14);
    opacity: 1;
  }
}

@keyframes burstSpin {
  from {
    transform: rotate(0deg) scale(1);
  }
  to {
    transform: rotate(360deg) scale(1.06);
  }
}

@keyframes burstSpinReverse {
  from {
    transform: rotate(360deg) scale(0.96);
  }
  to {
    transform: rotate(0deg) scale(1.04);
  }
}

@keyframes haloPulse {
  0%,
  100% {
    transform: scale(0.95);
    opacity: 0.35;
  }
  50% {
    transform: scale(1.08);
    opacity: 0.8;
  }
}

@keyframes shockExpand {
  0% {
    transform: translate(-50%, -50%) scale(0.7);
    opacity: 0;
  }
  18% {
    opacity: 1;
  }
  100% {
    transform: translate(-50%, -50%) scale(1.22);
    opacity: 0;
  }
}

@keyframes sparkExpand {
  0% {
    transform: translate(-50%, -50%) scale(0.45);
    opacity: 0;
  }
  18% {
    opacity: 0.85;
  }
  100% {
    transform: translate(-50%, -50%) scale(1.34);
    opacity: 0;
  }
}

@keyframes laserSweepA {
  0%,
  100% {
    opacity: 0.2;
    transform: translate(-50%, -50%) rotate(27deg) scaleX(0.8);
  }
  50% {
    opacity: 0.75;
    transform: translate(-50%, -50%) rotate(35deg) scaleX(1.12);
  }
}

@keyframes laserSweepB {
  0%,
  100% {
    opacity: 0.18;
    transform: translate(-50%, -50%) rotate(-31deg) scaleX(0.82);
  }
  50% {
    opacity: 0.68;
    transform: translate(-50%, -50%) rotate(-42deg) scaleX(1.1);
  }
}

@keyframes beerSpin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

@keyframes beerPop {
  0%,
  100% {
    transform: scale(0.9);
  }
  18% {
    transform: scale(1.12);
  }
  32% {
    transform: scale(0.98);
  }
  48% {
    transform: scale(1.2);
  }
  62% {
    transform: scale(1.03);
  }
  78% {
    transform: scale(1.16);
  }
}

@keyframes beerTilt {
  from {
    transform: rotate(-8deg);
  }
  to {
    transform: rotate(10deg);
  }
}

@keyframes orbitSpin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

@keyframes orbitBadgeFlash {
  from {
    box-shadow: 0 8px 0 rgba(35, 22, 41, 0.65);
    filter: saturate(1);
  }
  to {
    box-shadow:
      0 10px 0 rgba(35, 22, 41, 0.65),
      0 0 18px rgba(255, 255, 255, 0.45);
    filter: saturate(1.12);
  }
}

@keyframes badgeBounce {
  from {
    transform: translateY(0) rotate(-2deg);
  }
  to {
    transform: translateY(-11px) rotate(3deg);
  }
}

@keyframes badgeFlash {
  0%,
  100% {
    filter: saturate(1) brightness(1);
  }
  50% {
    filter: saturate(1.18) brightness(1.08);
  }
}

@keyframes ribbonSlide {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

@keyframes ribbonSwingTop {
  from {
    transform: rotate(-8deg) translateY(0);
  }
  to {
    transform: rotate(-5deg) translateY(8px);
  }
}

@keyframes ribbonSwingBottom {
  from {
    transform: rotate(7deg) translateY(0);
  }
  to {
    transform: rotate(3deg) translateY(-8px);
  }
}

@media (max-width: 700px) {
  .corner {
    width: 28vmin;
    height: 28vmin;
    border-width: 1.6vmin;
  }

  .corner-left {
    inset: 1rem auto auto 1rem;
  }

  .corner-right {
    inset: auto 1rem 1rem auto;
  }

  .ribbon {
    width: min(88vw, 28rem);
    border-width: 4px;
  }

  .ribbon::before,
  .ribbon::after {
    border-width: 4px;
    width: 1.45rem;
  }

  .ribbon-top {
    top: 2.5vh;
  }

  .ribbon-bottom {
    bottom: 3vh;
  }

  .callouts {
    gap: 0.5rem;
  }

  .callouts span {
    border-width: 3px;
    box-shadow: 0 6px 0 rgba(29, 19, 32, 0.6);
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
