:root {
  --ink: #080806;
  --soot: #151311;
  --paper: #f1ddaf;
  --acid: #c6ff25;
  --slime: #69df31;
  --warning: #ffcc1d;
  --hot: #ff4b18;
  --blood: #c91e1e;
  --blue: #00a6ff;
  --bone: #f7ead0;
  --muted: #a99983;
  --stroke: rgba(247, 234, 208, .18);
  --shadow: 0 26px 70px rgba(0, 0, 0, .48);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 7.5rem;
}

body {
  margin: 0;
  min-width: 320px;
  color: var(--bone);
  background:
    radial-gradient(circle at 20% 0%, rgba(255, 75, 24, .22), transparent 28rem),
    radial-gradient(circle at 80% 16%, rgba(0, 166, 255, .16), transparent 26rem),
    linear-gradient(135deg, #070706, #1b1713 46%, #0c0b09);
  font-family: Impact, Haettenschweiler, "Arial Narrow Bold", sans-serif;
  letter-spacing: 0;
  overflow-x: hidden;
}

body::before {
  position: fixed;
  inset: 0;
  z-index: -2;
  content: "";
  background-image: url("assets/generated/gooners-hero-lair.png");
  background-size: cover;
  background-position: center;
  opacity: .16;
  filter: saturate(.7) contrast(1.2);
}

body::after,
.noise {
  position: fixed;
  inset: 0;
  pointer-events: none;
  content: "";
}

body::after {
  z-index: -1;
  background: radial-gradient(circle, transparent 45%, rgba(0, 0, 0, .8));
}

.noise {
  z-index: 20;
  opacity: .08;
  mix-blend-mode: overlay;
  background-image:
    linear-gradient(90deg, rgba(255,255,255,.2) 1px, transparent 1px),
    linear-gradient(rgba(255,255,255,.12) 1px, transparent 1px);
  background-size: 7px 11px;
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input {
  font: inherit;
}

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 30;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-height: 96px;
  padding: .85rem clamp(1rem, 3vw, 2.25rem);
  background: linear-gradient(180deg, rgba(5, 5, 4, .94), rgba(5, 5, 4, .58));
  border-bottom: 1px solid rgba(247, 234, 208, .14);
  backdrop-filter: blur(16px);
}

.brand img {
  display: block;
  width: clamp(150px, 18vw, 260px);
  height: auto;
  filter: drop-shadow(0 8px 0 #000) drop-shadow(0 0 18px rgba(255, 204, 29, .42));
}

.header-actions {
  display: flex;
  align-items: center;
  gap: .7rem;
}

.social-x,
.sound-toggle,
.lyrics-toggle,
.menu-button,
.icon-button,
.modal-close {
  border: 2px solid #000;
  color: var(--bone);
  background: #111;
  box-shadow: 4px 4px 0 #000;
  cursor: pointer;
}

.social-x {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 42px;
  color: var(--warning);
  overflow: visible;
}

.social-icon svg {
  display: block;
  width: 30px;
  height: 30px;
  fill: var(--warning);
  filter: drop-shadow(4px 4px 0 var(--hot));
}

.social-game svg {
  width: 34px;
  height: 34px;
}

.sound-toggle {
  display: flex;
  align-items: center;
  gap: .55rem;
  min-height: 42px;
  padding: .55rem .8rem;
  text-transform: uppercase;
}

.sound-icon {
  display: none;
  align-items: center;
  justify-content: center;
  width: 2.1rem;
  height: 1.45rem;
  color: var(--ink);
  background: var(--warning);
  border: 2px solid #000;
  box-shadow: 2px 2px 0 #000;
  font-size: .72rem;
  line-height: 1;
}

.lyrics-toggle {
  min-height: 42px;
  padding: .55rem .8rem;
  color: var(--ink);
  background: var(--warning);
  text-transform: uppercase;
}

.sound-dot {
  width: .85rem;
  height: .85rem;
  border-radius: 50%;
  background: var(--blood);
  box-shadow: 0 0 0 transparent;
}

.sound-toggle[aria-pressed="true"] .sound-dot {
  background: var(--slime);
  box-shadow: 0 0 16px var(--slime);
}

.menu-button {
  display: grid;
  gap: 8px;
  width: 76px;
  height: 66px;
  padding: 13px;
}

.menu-button span {
  display: block;
  height: 8px;
  background: var(--warning);
  box-shadow: 2px 2px 0 var(--hot);
}

.drawer {
  position: absolute;
  top: calc(100% + 8px);
  right: clamp(1rem, 3vw, 2.25rem);
  display: grid;
  width: min(360px, calc(100vw - 2rem));
  padding: .8rem;
  background: rgba(7, 7, 6, .96);
  border: 2px solid #000;
  box-shadow: 9px 9px 0 #000;
  transform: translateY(-10px) rotate(-1deg);
  opacity: 0;
  pointer-events: none;
  transition: .2s ease;
}

.drawer.open {
  transform: translateY(0) rotate(-1deg);
  opacity: 1;
  pointer-events: auto;
}

.drawer a {
  padding: 1rem 1.1rem;
  color: var(--paper);
  border-bottom: 1px solid rgba(247, 234, 208, .16);
  font-size: clamp(1.35rem, 2.1vw, 2rem);
  line-height: 1;
  text-transform: uppercase;
}

.drawer a:hover {
  color: var(--ink);
  background: var(--warning);
}

.section,
.section-band {
  position: relative;
  padding: clamp(5.5rem, 9vw, 8rem) clamp(1rem, 4vw, 4rem);
  scroll-margin-top: 7.5rem;
}

.hero {
  min-height: 100svh;
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, .9fr);
  align-items: end;
  gap: clamp(2rem, 4vw, 5rem);
  padding-top: clamp(10rem, 13vw, 13rem);
  background:
    linear-gradient(180deg, rgba(0, 0, 0, .4), rgba(0, 0, 0, .15)),
    url("assets/generated/gooners-hero-lair.png") center / cover;
  overflow: hidden;
}

.hero::after,
.about::after,
.roadmap::after {
  position: absolute;
  inset: auto 0 0;
  height: 22px;
  content: "";
  background: repeating-linear-gradient(90deg, var(--warning) 0 34px, #000 34px 68px);
  border-block: 3px solid #000;
}

.swarm {
  position: fixed;
  inset: 0;
  z-index: 1;
  overflow: hidden;
  pointer-events: none;
}

.hero-swarm {
  position: absolute;
  inset: 0;
  z-index: 3;
  overflow: hidden;
  pointer-events: none;
}

.swarm img,
.hero-swarm img {
  position: absolute;
  width: clamp(64px, 6.5vw, 128px);
  height: auto;
  animation: streak var(--speed, 7s) linear infinite;
  opacity: .5;
  filter: drop-shadow(0 0 6px rgba(255, 255, 255, .22)) drop-shadow(5px 5px 0 rgba(0, 0, 0, .62));
  will-change: transform;
}

.hero-swarm img {
  width: clamp(88px, 9vw, 168px);
  opacity: .72;
}

main {
  position: relative;
  z-index: 2;
}

.hero-art,
.hero-copy {
  z-index: 4;
}

@keyframes streak {
  0% { transform: translate3d(var(--x0, -20vw), var(--y0, 20%), 0) rotate(var(--rot, 0deg)) scale(var(--scale, 1)); }
  48% { transform: translate3d(var(--xm, 50vw), var(--ym, 45%), 0) rotate(calc(var(--rot, 0deg) + 11deg)) scale(var(--scale, 1)); }
  100% { transform: translate3d(var(--x1, 120vw), var(--y1, 70%), 0) rotate(calc(var(--rot, 0deg) - 7deg)) scale(var(--scale, 1)); }
}

.hero-art {
  position: relative;
  min-height: 34rem;
}

.hero-logo {
  position: sticky;
  top: 8rem;
  width: min(100%, 900px);
  filter: drop-shadow(0 18px 0 #000) drop-shadow(0 0 36px rgba(255, 75, 24, .65));
  animation: logoPulse 2.8s ease-in-out infinite;
}

@keyframes logoPulse {
  0%, 100% { transform: rotate(-2deg) scale(1); }
  50% { transform: rotate(1deg) scale(1.035); }
}

.hero-copy,
.registration-panel,
.story-stack,
.mint-machine,
.faq-list details,
.event-callout,
.modal-card,
.event-hero {
  border: 3px solid #000;
  background: linear-gradient(145deg, rgba(24, 21, 18, .94), rgba(7, 7, 6, .9));
  box-shadow: var(--shadow), 8px 8px 0 #000;
}

.hero-copy {
  max-width: 640px;
  padding: clamp(1.2rem, 3vw, 2rem);
  margin-bottom: 3rem;
  transform: rotate(.8deg);
}

.kicker {
  margin: 0 0 .75rem;
  color: var(--acid);
  text-transform: uppercase;
  text-shadow: 2px 2px 0 #000;
}

h1,
h2 {
  margin: 0;
  line-height: .92;
  text-transform: uppercase;
  text-shadow: 4px 4px 0 #000, 0 0 18px rgba(255, 75, 24, .35);
}

h1 {
  font-size: clamp(2.8rem, 5.8vw, 5.8rem);
}

h2 {
  font-size: clamp(2.6rem, 6vw, 6rem);
}

p {
  font-family: "Arial Narrow", Arial, sans-serif;
  font-size: clamp(1.05rem, 1.7vw, 1.35rem);
  line-height: 1.48;
}

.hero-ctas,
.wallet-row,
.compact-row,
.event-callout {
  display: flex;
  align-items: center;
  gap: .9rem;
  flex-wrap: wrap;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: .85rem 1.1rem;
  border: 3px solid #000;
  box-shadow: 6px 6px 0 #000;
  font-family: Impact, Haettenschweiler, "Arial Narrow Bold", sans-serif;
  font-size: 1rem;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
  transition: .18s ease;
}

.button:hover,
.icon-button:hover,
.social-x:hover,
.sound-toggle:hover,
.menu-button:hover {
  transform: translate(-2px, -2px);
  box-shadow: 8px 8px 0 #000;
}

.button.primary {
  color: #100b03;
  background: linear-gradient(180deg, var(--warning), var(--hot));
}

.button.secondary {
  color: var(--bone);
  background: #111;
}

.is-hidden {
  display: none !important;
}

.section-grid {
  display: grid;
  grid-template-columns: minmax(260px, .75fr) minmax(320px, 1.25fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: start;
}

.section-lede {
  max-width: 560px;
  font-size: clamp(1.35rem, 2.5vw, 2.2rem);
}

.registration-panel {
  position: relative;
  padding: clamp(1rem, 3vw, 2rem);
}

.meter-copy {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 1rem;
  margin-bottom: .75rem;
  text-transform: uppercase;
}

.meter-copy strong {
  color: var(--warning);
  font-size: clamp(2rem, 5vw, 4.4rem);
  line-height: .9;
  text-shadow: 4px 4px 0 #000;
}

.meter {
  height: 34px;
  padding: 4px;
  background: #050505;
  border: 3px solid #000;
  overflow: hidden;
}

.meter-fill {
  width: 0%;
  height: 100%;
  background: linear-gradient(90deg, var(--slime), var(--warning) 62%, var(--blood));
  box-shadow: 0 0 20px rgba(198, 255, 37, .55);
  transition: width .35s ease;
}

.dates {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
  margin: 1.4rem 0;
}

.mint-dates {
  grid-template-columns: repeat(2, minmax(0, 240px));
  justify-content: center;
}

.dates div {
  padding: .85rem;
  background: rgba(0, 0, 0, .35);
  border: 1px solid var(--stroke);
}

.dates dt {
  color: var(--muted);
  font-family: "Arial Narrow", Arial, sans-serif;
  text-transform: uppercase;
}

.dates dd {
  margin: .25rem 0 0;
  color: var(--acid);
  text-transform: uppercase;
}

label {
  display: block;
  margin-bottom: .45rem;
  color: var(--paper);
  text-transform: uppercase;
}

input {
  min-width: 0;
  width: 100%;
  min-height: 52px;
  height: 52px;
  padding: .85rem 1rem;
  color: var(--bone);
  background: rgba(0, 0, 0, .62);
  border: 3px solid #000;
  outline: 1px solid rgba(247, 234, 208, .22);
}

input:focus {
  outline: 3px solid var(--warning);
}

.wallet-row input {
  flex: 1 1 280px;
}

.wallet-tools {
  display: grid;
  grid-template-columns: minmax(240px, .8fr) minmax(280px, 1fr);
  gap: 1rem;
  margin-top: 1.25rem;
}

.mint-dapp-section.is-locked .mint-panel > :not(.locked-overlay):not(.sold-out-overlay),
.mint-dapp-section.is-sold-out .mint-panel > :not(.sold-out-overlay) {
  filter: grayscale(1) brightness(.45);
  opacity: .5;
}

.whitelist-closed-overlay {
  position: absolute;
  inset: 0;
  z-index: 5;
  display: none;
  place-items: center;
  padding: 1rem;
  background: rgba(0, 0, 0, .58);
  pointer-events: auto;
}

.whitelist-closed-overlay span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: min(560px, 100%);
  min-height: 82px;
  padding: .85rem 1.1rem;
  color: #100b03;
  background: linear-gradient(180deg, var(--warning), var(--hot));
  border: 3px solid #000;
  box-shadow: 8px 8px 0 #000;
  font-size: clamp(1.8rem, 4vw, 3.4rem);
  text-align: center;
  text-transform: uppercase;
  transform: rotate(-1deg);
}

.whitelist-section.is-closed .whitelist-panel > :not(.whitelist-closed-overlay) {
  filter: grayscale(1) brightness(.45);
  opacity: .5;
}

.whitelist-section.is-closed .whitelist-closed-overlay {
  display: grid;
}

.locked-overlay,
.sold-out-overlay {
  position: absolute;
  inset: 0;
  z-index: 5;
  display: grid;
  place-items: center;
  padding: 1rem;
  background: rgba(0, 0, 0, .48);
  pointer-events: auto;
}

.sold-out-overlay {
  display: none;
}

.sold-out-overlay[hidden] {
  display: none !important;
}

.mint-dapp-section.is-sold-out .locked-overlay {
  display: none;
}

.mint-dapp-section.is-sold-out .sold-out-overlay {
  display: grid;
}

.mint-date-overlay {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: min(720px, 100%);
  min-height: 92px;
  padding: 1rem 1.25rem;
  color: #100b03;
  background: linear-gradient(180deg, var(--warning), var(--hot));
  border: 3px solid #000;
  box-shadow: 8px 8px 0 #000;
  font-family: Impact, Haettenschweiler, "Arial Narrow Bold", sans-serif;
  font-size: clamp(1.45rem, 3.4vw, 3rem);
  font-weight: 900;
  line-height: .95;
  text-align: center;
  text-transform: uppercase;
  transform: rotate(-1deg);
}

.lock-cta {
  width: min(560px, 100%);
  min-height: 82px;
  font-size: clamp(1.6rem, 4vw, 3.2rem);
  text-align: center;
  transform: rotate(-1deg);
}

.mint-controls {
  display: grid;
  grid-template-columns: minmax(170px, 240px) minmax(220px, 1fr);
  gap: .9rem;
  align-items: stretch;
}

.quantity-control {
  display: grid;
  grid-template-columns: 52px minmax(70px, 1fr) 52px;
  border: 3px solid #000;
  box-shadow: 6px 6px 0 #000;
}

.quantity-control button,
.quick-mint button {
  border: 0;
  color: #100b03;
  background: var(--warning);
  cursor: pointer;
}

.quantity-control button {
  font-size: 2rem;
}

.quantity-control input {
  height: 52px;
  text-align: center;
  border-block: 0;
  border-inline: 3px solid #000;
  outline: 0;
}

.quick-mint {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .55rem;
  margin-top: 1rem;
  text-transform: uppercase;
}

.quick-mint span {
  color: var(--warning);
  text-shadow: 2px 2px 0 #000;
}

.quick-mint button {
  min-width: 54px;
  min-height: 38px;
  padding: .45rem .7rem;
  border: 2px solid #000;
  box-shadow: 3px 3px 0 #000;
}

.quick-mint button:disabled {
  color: rgba(247, 234, 208, .45);
  background: #161412;
  cursor: not-allowed;
  opacity: .62;
}

.compact-row {
  flex-wrap: nowrap;
}

.icon-button {
  flex: 0 0 52px;
  height: 52px;
  color: #000;
  background: var(--acid);
}

.form-message,
.check-result {
  min-height: 1.7em;
  margin: .65rem 0 0;
  color: var(--warning);
}

.form-message .wallet-deeplink.button.primary,
.check-result .wallet-deeplink.button.primary,
.mint-message .wallet-deeplink.button.primary,
.event-status .wallet-deeplink.button.primary {
  margin: .7rem 0 0;
}

.form-message span,
.check-result span,
.mint-message span,
.event-status span {
  display: block;
}

.wallet-list {
  max-height: 260px;
  padding: .85rem;
  overflow: auto;
  background: rgba(0, 0, 0, .38);
  border: 1px solid var(--stroke);
}

.list-head {
  display: flex;
  justify-content: space-between;
  gap: .75rem;
  margin-bottom: .7rem;
  text-transform: uppercase;
}

.wallet-list ol {
  display: grid;
  gap: .45rem;
  margin: 0;
  padding-left: 1.4rem;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: .88rem;
  overflow-wrap: anywhere;
}

.about {
  display: grid;
  grid-template-columns: minmax(320px, 1fr) minmax(260px, .72fr);
  gap: clamp(2rem, 5vw, 5rem);
  background:
    linear-gradient(90deg, rgba(0, 0, 0, .55), rgba(0, 0, 0, .15)),
    url("assets/generated/gooners-mint-machine.png") center / cover;
}

.story-stack {
  padding: clamp(1rem, 3vw, 2rem);
}

.story-stack p {
  margin: 0 0 1rem;
}

.poster-stack {
  position: sticky;
  top: 9rem;
  display: grid;
  gap: 1.4rem;
  align-self: start;
}

.poster {
  position: relative;
  width: min(100%, 380px);
  padding: 1.3rem;
  border: 4px solid #000;
  color: var(--ink);
  font-size: clamp(2rem, 4vw, 4rem);
  line-height: .9;
  text-transform: uppercase;
  box-shadow: 8px 8px 0 #000;
}

.poster-one {
  background: var(--warning);
  transform: rotate(-7deg);
}

.poster-two {
  justify-self: end;
  background: var(--hot);
  transform: rotate(5deg);
}

.poster-three {
  background: var(--acid);
  transform: rotate(-2deg);
}

.mint-section {
  display: grid;
  grid-template-columns: minmax(290px, .8fr) minmax(320px, 1.1fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}

.mint-machine {
  padding: 1.2rem;
  background:
    linear-gradient(145deg, rgba(22, 21, 19, .95), rgba(8, 8, 7, .97)),
    url("assets/generated/gooners-mint-machine.png");
}

.machine-top,
.machine-gauge {
  display: flex;
  justify-content: space-between;
  gap: .7rem;
}

.machine-top span {
  width: 30%;
  height: 22px;
  background: var(--blood);
  border: 3px solid #000;
  animation: blink 1.2s infinite steps(2);
}

.machine-top span:nth-child(2) {
  background: var(--warning);
  animation-delay: .25s;
}

.machine-top span:nth-child(3) {
  background: var(--slime);
  animation-delay: .5s;
}

@keyframes blink {
  50% { opacity: .35; }
}

.machine-window {
  display: grid;
  place-items: center;
  min-height: 310px;
  margin: 1rem 0;
  background: radial-gradient(circle, rgba(255, 75, 24, .38), #050505 72%);
  border: 3px solid #000;
  overflow: hidden;
}

.machine-window img {
  width: 90%;
  animation: churn 4s linear infinite;
}

@keyframes churn {
  0%, 100% { transform: rotate(-2deg) translateY(0); }
  35% { transform: rotate(2deg) translateY(-10px); }
  65% { transform: rotate(-1deg) translateY(8px); }
}

.machine-gauge span {
  flex: 1;
  min-height: 64px;
  display: grid;
  place-items: center;
  padding: .7rem .4rem;
  color: #000;
  background: var(--paper);
  border: 3px solid #000;
  text-align: center;
  font-size: clamp(.9rem, 1.4vw, 1.25rem);
  line-height: .95;
}

.mint-copy p {
  max-width: 760px;
}

.faq-section {
  background:
    linear-gradient(rgba(0,0,0,.52), rgba(0,0,0,.68)),
    url("assets/generated/gooners-mint-machine.png") center / cover fixed;
}

.faq-list {
  display: grid;
  gap: .85rem;
  max-width: 980px;
  margin-top: 1.5rem;
}

.faq-list details {
  padding: 1rem 1.15rem;
}

.faq-list summary {
  cursor: pointer;
  color: var(--warning);
  font-size: clamp(1.25rem, 2.6vw, 2rem);
  text-transform: uppercase;
}

.faq-list details[open] {
  background: linear-gradient(145deg, rgba(40, 28, 16, .96), rgba(8, 8, 7, .96));
}

.roadmap {
  min-height: 56svh;
  display: grid;
  place-content: center;
  text-align: center;
  background:
    linear-gradient(rgba(0,0,0,.45), rgba(0,0,0,.52)),
    url("assets/generated/gooners-hero-lair.png") center / cover;
}

.roadmap h2 {
  color: var(--bone);
}

.roadmap-blast {
  margin: clamp(1.4rem, 2.5vw, 2.4rem) 0 0;
  color: var(--warning);
  font-family: Impact, Haettenschweiler, "Arial Narrow Bold", sans-serif;
  font-size: clamp(4rem, 14vw, 14rem);
  line-height: .85;
  text-transform: uppercase;
  text-shadow: 4px 4px 0 #000, 0 0 18px rgba(255, 75, 24, .35);
}

.event-callout {
  justify-content: space-between;
}

.share-modal {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: grid;
  place-items: center;
  padding: 1rem;
  background: rgba(0, 0, 0, .76);
}

.lyrics-modal {
  position: fixed;
  inset: 0;
  z-index: 55;
  display: grid;
  place-items: center;
  padding: 1rem;
  background: rgba(0, 0, 0, .8);
}

.lyrics-modal[hidden] {
  display: none;
}

.share-modal[hidden] {
  display: none;
}

.modal-card {
  position: relative;
  width: min(520px, 100%);
  padding: 2rem;
  text-align: center;
  background: linear-gradient(145deg, rgba(35, 27, 18, .98), rgba(8, 8, 7, .98));
  border: 3px solid #000;
  box-shadow: 12px 12px 0 #000;
}

.lyrics-card {
  width: min(780px, 100%);
  max-height: min(82vh, 900px);
  overflow: auto;
  text-align: left;
}

.lyrics-card h2 {
  margin-right: 2.5rem;
  font-size: clamp(2rem, 5vw, 4rem);
}

.lyrics-card pre {
  margin: 1rem 0 0;
  color: var(--paper);
  font-family: Impact, Haettenschweiler, "Arial Narrow Bold", sans-serif;
  font-size: clamp(1.05rem, 1.7vw, 1.45rem);
  line-height: 1.18;
  letter-spacing: 0;
  white-space: pre-wrap;
}

.modal-close {
  position: absolute;
  top: .75rem;
  right: .75rem;
  width: 38px;
  height: 38px;
}

.event-page::before {
  opacity: .26;
  background-image: url("assets/generated/gooners-mint-machine.png");
}

.event-shell {
  min-height: 100svh;
  display: grid;
  place-items: center;
  padding: 7rem 1rem 2rem;
}

.event-hero {
  position: relative;
  width: min(1050px, 100%);
  min-height: 610px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 1rem;
  padding: 2rem;
  text-align: center;
  overflow: hidden;
}

.event-hero h1 {
  color: var(--warning);
  font-size: clamp(4rem, 14vw, 13rem);
}

.factory-grid {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  padding: 1rem;
  opacity: .28;
}

.factory-grid span {
  border: 2px solid rgba(247,234,208,.35);
  background: repeating-linear-gradient(0deg, transparent 0 20px, rgba(198,255,37,.3) 20px 25px);
  animation: tankFill 3s ease-in-out infinite alternate;
}

.factory-grid span:nth-child(even) {
  animation-delay: .9s;
}

@keyframes tankFill {
  from { transform: scaleY(.45); transform-origin: bottom; }
  to { transform: scaleY(1); transform-origin: bottom; }
}

.event-status {
  min-height: 1.6em;
  color: var(--acid);
}

.game-page::before {
  opacity: .32;
  background-image: url("assets/backgrounds/crusty-bedroom.png");
}

.game-shell {
  min-height: 100svh;
  padding: clamp(10.5rem, 12vw, 12.25rem) clamp(1rem, 3vw, 2.5rem) 2.5rem;
}

.game-stage {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(250px, 340px);
  gap: clamp(1rem, 2.4vw, 2rem);
  align-items: start;
  width: min(1500px, 100%);
  margin: 0 auto;
}

.game-copy {
  grid-column: 1 / -1;
  display: grid;
  gap: .3rem;
  padding-top: .5rem;
}

.game-copy h1 {
  margin: 0;
  color: var(--warning);
  font-size: clamp(4.5rem, 11vw, 12rem);
  line-height: .9;
  text-transform: uppercase;
  text-shadow: 5px 5px 0 #000, 0 0 24px rgba(255, 75, 24, .45);
}

.game-copy p:last-child {
  max-width: 860px;
  margin: .25rem 0 0;
  color: var(--paper);
  font-size: clamp(1.2rem, 2vw, 1.7rem);
  line-height: 1.05;
}

.game-cabinet {
  position: relative;
  min-width: 0;
  align-self: stretch;
  padding: clamp(.7rem, 1.4vw, 1.1rem);
  background:
    linear-gradient(145deg, rgba(48, 31, 18, .98), rgba(5, 5, 4, .98)),
    repeating-linear-gradient(90deg, rgba(255,255,255,.05) 0 2px, transparent 2px 8px);
  border: 4px solid #000;
  box-shadow: 14px 14px 0 #000, 0 0 32px rgba(255, 75, 24, .2);
  transform: rotate(-.35deg);
}

.game-topbar,
.game-bottom {
  display: grid;
  gap: .65rem;
}

.game-topbar {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-bottom: .75rem;
}

.hud-tile,
.bar-meter,
.game-alert,
.game-panel {
  border: 3px solid #000;
  background: rgba(8, 8, 6, .9);
  box-shadow: 5px 5px 0 #000;
}

.hud-tile {
  min-height: 76px;
  display: grid;
  align-content: center;
  padding: .7rem;
}

.game-sound-button {
  font: inherit;
  text-align: left;
  cursor: pointer;
  text-transform: uppercase;
}

.game-sound-button[aria-pressed="false"] strong {
  color: var(--blood);
}

.game-sound-card {
  width: min(100%, 420px);
  justify-self: center;
  color: var(--bone);
  background: #111;
}

.game-sound-card[aria-pressed="false"] {
  color: #100b03;
  background: linear-gradient(180deg, var(--blood), var(--hot));
}

.game-sound-float {
  position: absolute;
  top: .8rem;
  right: .8rem;
  z-index: 4;
  min-height: 48px;
  padding: .55rem .85rem;
  color: #100b03;
  font: inherit;
  font-size: clamp(1rem, 1.4vw, 1.25rem);
  line-height: .9;
  text-transform: uppercase;
  cursor: pointer;
  background: linear-gradient(180deg, var(--warning), var(--hot));
  border: 3px solid #000;
  box-shadow: 5px 5px 0 #000;
}

.game-sound-float[aria-pressed="false"] {
  background: linear-gradient(180deg, var(--blood), var(--hot));
}

.hud-tile span,
.bar-meter span {
  color: var(--muted);
  font-size: clamp(.85rem, 1.1vw, 1.1rem);
  text-transform: uppercase;
}

.hud-tile strong {
  color: var(--warning);
  font-size: clamp(1.7rem, 3vw, 3rem);
  line-height: .9;
  text-shadow: 3px 3px 0 #000;
}

.game-screen-wrap {
  position: relative;
  overflow: hidden;
  background: #000;
  border: 4px solid #000;
  box-shadow: inset 0 0 0 3px rgba(247, 234, 208, .13);
}

#goonFestGame {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  height: auto;
  cursor: pointer;
  background: #080806;
  touch-action: none;
}

.game-overlay {
  position: absolute;
  inset: 0;
  display: none;
  place-items: center;
  padding: 1rem;
  overflow: auto;
  background:
    radial-gradient(circle at 50% 35%, rgba(255, 75, 24, .32), transparent 16rem),
    rgba(0, 0, 0, .72);
}

.game-overlay.is-visible {
  display: grid;
}

.game-card {
  width: min(620px, 100%);
  max-height: 100%;
  overflow: auto;
  display: grid;
  gap: .75rem;
  padding: clamp(1rem, 2.6vw, 2rem);
  text-align: center;
  background: linear-gradient(145deg, rgba(30, 22, 15, .98), rgba(5, 5, 4, .98));
  border: 4px solid #000;
  box-shadow: 12px 12px 0 #000;
}

.game-share {
  width: min(100%, 420px);
  justify-self: center;
}

.game-card h2 {
  margin: .2rem 0 .6rem;
  color: var(--warning);
  font-size: clamp(2.5rem, 6vw, 5.5rem);
  line-height: .82;
}

.game-card p:not(.kicker) {
  color: var(--paper);
  font-size: clamp(1rem, 1.8vw, 1.45rem);
  line-height: 1.1;
}

.game-bottom {
  grid-template-columns: 1fr 1fr;
  margin-top: .75rem;
}

.bar-meter {
  padding: .65rem;
}

.bar-meter i {
  display: block;
  height: 18px;
  margin-top: .35rem;
  overflow: hidden;
  background: #050504;
  border: 2px solid #000;
}

.bar-meter b {
  display: block;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, var(--slime), var(--acid));
}

.bar-meter.fatigue b {
  width: 0;
  background: linear-gradient(90deg, var(--warning), var(--hot), var(--blood));
}

.game-alert {
  grid-column: 1 / -1;
  min-height: 46px;
  display: grid;
  align-items: center;
  padding: .65rem .85rem;
  color: var(--acid);
  font-size: clamp(1rem, 1.45vw, 1.35rem);
  line-height: .95;
  text-transform: uppercase;
}

.game-side {
  display: grid;
  gap: 1rem;
}

.game-panel {
  padding: 1rem;
  background:
    linear-gradient(145deg, rgba(22, 20, 17, .95), rgba(5, 5, 4, .96)),
    repeating-linear-gradient(0deg, rgba(247,234,208,.06) 0 1px, transparent 1px 8px);
}

.game-panel h2 {
  margin: 0 0 .7rem;
  color: var(--warning);
  font-size: clamp(2rem, 3vw, 3.2rem);
}

.game-panel ul {
  display: grid;
  gap: .65rem;
  margin: 0;
  padding-left: 1.1rem;
  color: var(--paper);
  font-size: clamp(1.05rem, 1.55vw, 1.35rem);
  line-height: 1.02;
}

.game-panel li::marker {
  color: var(--hot);
}

.cursor-slime {
  position: fixed;
  width: 78px;
  height: 28px;
  z-index: 40;
  pointer-events: none;
  background: url("assets/generated/sperm/sperm-1.png") center / contain no-repeat;
  filter:
    drop-shadow(0 0 6px rgba(0, 166, 255, .95))
    drop-shadow(0 0 14px rgba(0, 166, 255, .75))
    drop-shadow(3px 3px 0 rgba(0, 0, 0, .82));
  transform: translate(-24px, -13px) rotate(-18deg);
  opacity: 0;
  transition: opacity .2s ease, transform .08s linear;
}

@media (max-width: 900px) {
  .hero,
  .section-grid,
  .about,
  .mint-section {
    grid-template-columns: 1fr;
  }

  .hero {
    align-items: center;
  }

  .hero-art {
    min-height: auto;
    order: -1;
  }

  .hero-copy {
    margin-bottom: 1.5rem;
  }

  .poster-stack {
    position: relative;
    top: 0;
    min-height: 0;
  }

  .wallet-tools,
  .dates {
    grid-template-columns: 1fr;
  }

  .mint-controls {
    grid-template-columns: 1fr;
  }

  .mint-dates {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .game-stage {
    grid-template-columns: 1fr;
  }

  .game-side {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 620px) {
  .site-header {
    align-items: center;
    flex-wrap: wrap;
    gap: .45rem;
    min-height: 118px;
    padding: .45rem .65rem .55rem;
  }

  .brand {
    width: 100%;
  }

  .brand img {
    width: 118px;
  }

  .header-actions {
    display: grid;
    grid-template-columns: 38px 38px 78px 76px;
    width: auto;
    margin-left: auto;
    align-items: center;
    padding-right: 0;
    gap: .35rem;
  }

  .sound-toggle {
    grid-column: 3;
    width: 78px;
    min-width: 48px;
    min-height: 38px;
    justify-content: center;
    gap: .35rem;
    padding: .35rem .45rem;
  }

  .social-x {
    width: 38px;
    height: 38px;
    flex: 0 0 38px;
  }

  .social-icon svg {
    width: 25px;
    height: 25px;
  }

  .social-game svg {
    width: 27px;
    height: 27px;
  }

  .sound-icon {
    display: inline-flex;
    width: 1.85rem;
    height: 1.25rem;
    font-size: .62rem;
  }

  .sound-dot {
    width: .6rem;
    height: .6rem;
  }

  .sound-label {
    display: none;
  }

  .lyrics-toggle {
    grid-column: 4;
    width: auto;
    min-height: 34px;
    padding: .32rem .4rem;
    font-size: .78rem;
    white-space: nowrap;
  }

  .menu-button {
    position: absolute;
    right: .65rem;
    top: .75rem;
    z-index: 5;
    display: grid;
    width: 46px;
    height: 40px;
    flex: 0 0 46px;
    gap: 5px;
    padding: 8px;
  }

  .menu-button span {
    height: 4px;
  }

  .hero {
    padding-top: 10rem;
  }

  .game-page .site-header {
    flex-wrap: nowrap;
    min-height: 70px;
    padding: .5rem .65rem;
  }

  .game-page .brand {
    width: auto;
    flex: 0 1 auto;
  }

  .game-page .brand img {
    width: 118px;
  }

  .game-page .site-header .button {
    width: auto;
    min-height: 42px;
    padding: .45rem .65rem;
    font-size: .9rem;
    white-space: nowrap;
  }

  .hero-ctas,
  .wallet-row,
  .event-callout {
    align-items: stretch;
    flex-direction: column;
  }

  .wallet-row {
    align-items: flex-start;
  }

  .button,
  .wallet-row input {
    width: 100%;
  }

  .game-page .site-header .button {
    position: absolute;
    top: .75rem;
    right: .65rem;
    width: auto;
    flex: 0 0 auto;
    min-height: 38px;
    padding: .4rem .55rem;
    font-size: .82rem;
    z-index: 2;
  }

  .wallet-row input {
    flex: 0 0 auto;
    height: 52px;
  }

  .meter-copy {
    align-items: flex-start;
    flex-direction: column;
  }

  .mint-dates {
    grid-template-columns: 1fr;
  }

  .lock-cta {
    min-height: 68px;
  }

  .game-shell {
    padding: 5.2rem .35rem 1.2rem;
    overflow-x: hidden;
  }

  .game-stage {
    width: calc(100vw - .7rem);
    max-width: calc(100vw - .7rem);
    gap: .65rem;
  }

  .game-copy {
    display: none;
  }

  .game-cabinet {
    order: 1;
    width: 100%;
    max-width: 100%;
    padding: .55rem;
    transform: none;
    border-width: 3px;
    box-shadow: 0 0 18px rgba(255, 75, 24, .18);
  }

  .game-screen-wrap {
    border-width: 3px;
    overflow: visible;
  }

  #goonFestGame {
    min-height: 0;
  }

  .game-topbar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .35rem;
    margin-bottom: .45rem;
  }

  .hud-tile {
    min-height: 42px;
    padding: .35rem .2rem;
    text-align: center;
    box-shadow: 3px 3px 0 #000;
  }

  .hud-tile span {
    font-size: .7rem;
  }

  .hud-tile strong {
    font-size: clamp(1rem, 6vw, 1.55rem);
    text-shadow: 2px 2px 0 #000;
  }

  .game-sound-button {
    text-align: center;
  }

  .game-sound-float {
    top: .45rem;
    right: .45rem;
    min-height: 34px;
    padding: .35rem .5rem;
    font-size: .8rem;
    border-width: 2px;
    box-shadow: 3px 3px 0 #000;
  }

  .game-overlay {
    padding: .35rem;
    overflow: visible;
  }

  .game-card {
    width: min(calc(100% - 1rem), 280px);
    max-height: none;
    overflow: visible;
    gap: .35rem;
    padding: .55rem;
    border-width: 3px;
    box-shadow: 3px 3px 0 #000;
  }

  .game-card .kicker,
  .game-sound-card {
    display: none;
  }

  .game-card p:not(.kicker) {
    font-size: .9rem;
    line-height: 1;
  }

  .game-card h2 {
    margin: 0;
    font-size: clamp(1.55rem, 8.5vw, 2.05rem);
  }

  .game-card .button {
    width: 100%;
    min-height: 42px;
    padding: .55rem .45rem;
    font-size: clamp(.82rem, 4.1vw, 1rem);
  }

  .game-bottom,
  .game-side {
    grid-template-columns: 1fr;
  }

  .game-bottom {
    gap: .45rem;
    margin-top: .45rem;
  }

  .bar-meter {
    padding: .45rem;
  }

  .bar-meter i {
    height: 12px;
  }

  .game-alert {
    min-height: 38px;
    padding: .45rem .55rem;
    font-size: .95rem;
  }

  .game-side {
    order: 3;
  }
}
