:root {
  --black: #030000;
  --black-soft: #080101;
  --red-deep: #2a0000;
  --red-blood: #880000;
  --red-glow: #ff0000;
  --red-hot: #ff2b22;
  --gold: #b2874a;
  --gold-soft: rgba(178, 135, 74, 0.48);
  --white: #f7eee6;
  --muted: #c6aaa2;
  --dim: #8f706b;
  --line: rgba(255, 0, 0, 0.2);
  --line-gold: rgba(178, 135, 74, 0.24);
  --max: 1180px;
  --pad: clamp(1.25rem, 3vw, 3rem);
  --anton: "Anton", Impact, Haettenschweiler, "Arial Narrow Bold", sans-serif;
  --sans: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  background: var(--black);
}

body {
  margin: 0;
  background:
    radial-gradient(circle at 20% 8%, rgba(255, 0, 0, 0.18), transparent 30rem),
    radial-gradient(circle at 82% 20%, rgba(136, 0, 0, 0.28), transparent 28rem),
    linear-gradient(180deg, #080000 0%, #030000 40%, #060101 100%);
  color: var(--white);
  font-family: var(--sans);
  line-height: 1.6;
  text-rendering: geometricPrecision;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

body.nav-open { overflow: hidden; }

img, svg { max-width: 100%; }

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

p {
  margin: 0;
  color: var(--muted);
}

p + p { margin-top: 1rem; }

h1, h2, h3 {
  margin: 0;
  line-height: 0.98;
}

h2 {
  font-family: var(--anton);
  font-size: clamp(2.6rem, 7vw, 6.5rem);
  font-weight: 400;
  letter-spacing: 0.025em;
  text-transform: uppercase;
  color: var(--white);
}

h3 {
  font-size: 0.88rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--white);
}

button, input, textarea, select { font: inherit; }

.skip-link {
  position: fixed;
  left: 1rem;
  top: 1rem;
  z-index: 999;
  background: var(--white);
  color: var(--black);
  padding: 0.65rem 0.9rem;
  transform: translateY(-180%);
  transition: transform 180ms ease;
}

.skip-link:focus { transform: translateY(0); }

.section-pad {
  width: min(var(--max), calc(100% - var(--pad) * 2));
  margin: 0 auto;
}

.site-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 50;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem clamp(1rem, 3vw, 2.5rem);
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.82), rgba(0, 0, 0, 0.26), transparent);
  transition: background 220ms ease, border-color 220ms ease;
  border-bottom: 1px solid transparent;
}

.site-header.is-scrolled {
  background: rgba(3, 0, 0, 0.84);
  backdrop-filter: blur(14px);
  border-bottom-color: rgba(255, 0, 0, 0.12);
}

.brand { display: inline-flex; }

.wordmark {
  font-family: var(--anton);
  font-weight: 400;
  color: var(--red-glow);
  line-height: 0.86;
  text-transform: uppercase;
  white-space: nowrap;
  text-shadow: 0 0 0.5rem rgba(255, 0, 0, 0.18), 0 0 1.8rem rgba(255, 0, 0, 0.14);
  font-kerning: none;
  font-feature-settings: "kern" 0, "liga" 0, "calt" 0;
}

.wordmark span {
  display: inline-block;
  transform: none !important;
  letter-spacing: 0;
}

/* Deliberate manual spacing prevents Anton browser kerning from merging E/I. */
.wordmark span + span { margin-left: 0.075em; }
.wordmark span:nth-child(3) { margin-left: 0.1em; }
.wordmark span:nth-child(4) { margin-left: 0.09em; }

.wordmark--nav { font-size: clamp(2rem, 4vw, 3.2rem); }
.wordmark--hero { font-size: clamp(6rem, 19vw, 17rem); margin: 0.08em 0 0.02em; }
.wordmark--footer { font-size: clamp(2.5rem, 6vw, 4.5rem); }

.site-nav {
  display: flex;
  gap: clamp(1rem, 3vw, 2.4rem);
  align-items: center;
}

.site-nav a {
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(247, 238, 230, 0.82);
  transition: color 160ms ease;
}

.site-nav a:hover,
.site-nav a:focus-visible { color: var(--red-hot); }

.nav-toggle {
  display: none;
  border: 1px solid var(--line);
  color: var(--white);
  background: rgba(0, 0, 0, 0.28);
  padding: 0.7rem 0.75rem;
  cursor: pointer;
}

.nav-toggle__line {
  display: block;
  width: 1.35rem;
  height: 1px;
  background: currentColor;
  margin: 0.28rem 0;
}

.nav-toggle__label {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
}

.hero {
  min-height: 100svh;
  position: relative;
  display: grid;
  place-items: center;
  overflow: hidden;
  isolation: isolate;
  border-bottom: 1px solid rgba(255, 0, 0, 0.16);
  background: #120000;
}

.curtain {
  position: absolute;
  inset: -10% -5%;
  pointer-events: none;
  z-index: -5;
}

.curtain--back {
  background:
    linear-gradient(90deg,
      rgba(0,0,0,0.72) 0%, rgba(136,0,0,0.3) 7%, rgba(0,0,0,0.45) 8%,
      rgba(255,0,0,0.18) 12%, rgba(0,0,0,0.5) 14%, rgba(136,0,0,0.45) 22%,
      rgba(0,0,0,0.55) 24%, rgba(255,0,0,0.28) 30%, rgba(0,0,0,0.56) 32%,
      rgba(136,0,0,0.55) 42%, rgba(0,0,0,0.5) 45%, rgba(255,0,0,0.24) 52%,
      rgba(0,0,0,0.55) 54%, rgba(136,0,0,0.48) 64%, rgba(0,0,0,0.5) 66%,
      rgba(255,0,0,0.2) 74%, rgba(0,0,0,0.55) 77%, rgba(136,0,0,0.42) 88%,
      rgba(0,0,0,0.7) 100%),
    radial-gradient(circle at 50% 28%, rgba(255, 0, 0, 0.72), transparent 38rem),
    linear-gradient(180deg, #5f0000 0%, #120000 62%, #030000 100%);
  filter: saturate(1.18) contrast(1.16);
}

.curtain--front {
  z-index: -2;
  opacity: 0.8;
  background:
    repeating-linear-gradient(86deg, rgba(0,0,0,0.16) 0 0.45rem, rgba(255,0,0,0.1) 0.45rem 0.78rem, rgba(0,0,0,0.35) 0.78rem 1.06rem),
    linear-gradient(115deg, transparent 0 20%, rgba(178, 135, 74, 0.12) 31%, transparent 43%),
    linear-gradient(67deg, transparent 0 23%, rgba(255, 0, 0, 0.19) 39%, transparent 55%);
  mix-blend-mode: multiply;
}

.body-shadows {
  position: absolute;
  inset: 0;
  z-index: -4;
  opacity: 0.72;
  pointer-events: none;
}

.shadow {
  position: absolute;
  bottom: 6%;
  width: clamp(4rem, 9vw, 8rem);
  height: clamp(14rem, 34vw, 29rem);
  background: rgba(0, 0, 0, 0.64);
  border-radius: 44% 44% 12% 12%;
  filter: blur(0.04rem);
}

.shadow::before {
  content: "";
  position: absolute;
  top: -11%;
  left: 50%;
  transform: translateX(-50%);
  width: 42%;
  aspect-ratio: 1;
  background: rgba(0, 0, 0, 0.64);
  border-radius: 50%;
}

.shadow--one { left: 7%; transform: scaleX(0.78); }
.shadow--two { left: 31%; transform: scaleX(0.9); height: clamp(16rem, 38vw, 33rem); }
.shadow--three { right: 27%; transform: scaleX(1.18); height: clamp(17rem, 39vw, 34rem); }
.shadow--four { right: 8%; transform: scaleX(0.86); }

.hero__scrim {
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 50% 40%, rgba(0,0,0,0.04), rgba(0,0,0,0.88) 70%),
    linear-gradient(180deg, rgba(0,0,0,0.12), rgba(0,0,0,0.46) 62%, rgba(0,0,0,0.94));
}

.hero__content {
  position: relative;
  z-index: 2;
  padding-top: 7rem;
  padding-bottom: 4rem;
  text-align: center;
}

.eyebrow,
.section-kicker {
  font-size: 0.75rem;
  font-weight: 900;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--gold);
}

.tagline {
  font-family: var(--anton);
  font-size: clamp(2rem, 6vw, 5.4rem);
  line-height: 0.98;
  letter-spacing: 0.035em;
  text-transform: uppercase;
  color: var(--red-glow);
  text-shadow: 0 0 1.6rem rgba(255, 0, 0, 0.18);
}

.hero__copy {
  max-width: 760px;
  margin: 1.25rem auto 0;
  color: rgba(247, 238, 230, 0.84);
  font-size: clamp(1rem, 2vw, 1.25rem);
}

.hero__actions {
  margin-top: 2rem;
  display: flex;
  justify-content: center;
  gap: 0.85rem;
  flex-wrap: wrap;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3rem;
  padding: 0.85rem 1.25rem;
  border: 1px solid var(--red-glow);
  font-size: 0.75rem;
  font-weight: 900;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  transition: background 160ms ease, color 160ms ease, border-color 160ms ease, transform 160ms ease;
}

.button:hover,
.button:focus-visible { transform: translateY(-1px); }

.button--primary {
  background: var(--red-glow);
  color: #130000;
  box-shadow: 0 0 1.4rem rgba(255, 0, 0, 0.18);
}

.button--primary:hover,
.button--primary:focus-visible { background: var(--white); border-color: var(--white); }

.button--ghost {
  background: rgba(0, 0, 0, 0.32);
  color: var(--white);
}

.button--ghost:hover,
.button--ghost:focus-visible { border-color: var(--gold); color: var(--gold); }

.event-line {
  margin-top: 1.3rem;
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(247, 238, 230, 0.58);
}

.intro,
.experience,
.etiquette,
.tickets,
.faq,
.site-footer {
  padding-top: clamp(4.5rem, 10vw, 8rem);
  padding-bottom: clamp(4.5rem, 10vw, 8rem);
}

.intro {
  border-bottom: 1px solid rgba(255, 0, 0, 0.12);
}

.intro__grid {
  margin-top: 1rem;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.82fr);
  gap: clamp(2rem, 6vw, 6rem);
  align-items: start;
}

.intro__copy {
  font-size: clamp(1.02rem, 1.45vw, 1.22rem);
}

.statement {
  color: var(--red-hot);
  font-weight: 800;
}

.section-heading {
  text-align: center;
  max-width: 760px;
  margin: 0 auto 2.5rem;
}

.section-heading h2 { margin-top: 0.7rem; }

.cards {
  display: grid;
  gap: 1px;
  background: linear-gradient(90deg, transparent, var(--line), var(--line-gold), transparent);
  border: 1px solid rgba(255, 0, 0, 0.1);
}

.cards--four { grid-template-columns: repeat(4, 1fr); }

.card {
  min-height: 18rem;
  padding: clamp(1.25rem, 3vw, 2rem);
  background:
    linear-gradient(180deg, rgba(255, 0, 0, 0.06), rgba(0, 0, 0, 0.1)),
    rgba(8, 1, 1, 0.88);
}

.card h3 { margin-top: 1.2rem; }
.card p { margin-top: 0.9rem; color: rgba(247, 238, 230, 0.68); }

.icon {
  width: 3rem;
  height: 3rem;
  position: relative;
}

.icon--glow {
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,0,0,0.95) 0 16%, transparent 17% 100%);
  box-shadow: 0 0 2rem rgba(255, 0, 0, 0.42);
}

.icon--glow::before,
.icon--glow::after {
  content: "";
  position: absolute;
  inset: 0.4rem;
  border: 1px solid rgba(255,0,0,0.7);
  border-radius: 50%;
}

.icon--glow::after { inset: 0.9rem; }

.icon--curtain {
  background: repeating-linear-gradient(90deg, rgba(255,0,0,0.9) 0 2px, transparent 2px 7px);
  transform: skewX(-8deg);
}

.icon--eye::before {
  content: "";
  position: absolute;
  inset: 0.85rem 0.2rem;
  border: 2px solid rgba(255,0,0,0.9);
  border-radius: 50% / 55%;
}

.icon--eye::after {
  content: "";
  position: absolute;
  width: 0.52rem;
  aspect-ratio: 1;
  border-radius: 50%;
  background: var(--red-glow);
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  box-shadow: 0 0 1rem rgba(255,0,0,0.55);
}

.icon--bag {
  border: 2px solid rgba(255,0,0,0.88);
  border-radius: 0.2rem 0.2rem 0.5rem 0.5rem;
  width: 2.6rem;
  height: 2.7rem;
  margin-top: 0.2rem;
}

.icon--bag::before {
  content: "";
  position: absolute;
  width: 1.2rem;
  height: 0.7rem;
  border: 2px solid rgba(255,0,0,0.88);
  border-bottom: 0;
  border-radius: 1rem 1rem 0 0;
  left: 0.7rem;
  top: -0.7rem;
}

.etiquette {
  position: relative;
  display: grid;
  grid-template-columns: 0.72fr 1fr;
  gap: clamp(2rem, 6vw, 6rem);
  align-items: center;
  border-top: 1px solid rgba(178, 135, 74, 0.16);
  border-bottom: 1px solid rgba(178, 135, 74, 0.16);
}

.etiquette__visual {
  position: relative;
  min-height: 32rem;
  background:
    radial-gradient(circle at 35% 42%, rgba(255,0,0,0.64), transparent 12rem),
    radial-gradient(circle at 62% 65%, rgba(178,135,74,0.2), transparent 14rem),
    linear-gradient(135deg, #170000, #030000 76%);
  overflow: hidden;
  border: 1px solid rgba(255,0,0,0.15);
}

.etiquette__visual::before {
  content: "";
  position: absolute;
  left: 36%;
  bottom: 0;
  width: 11rem;
  height: 24rem;
  background: rgba(0,0,0,0.62);
  border-radius: 48% 48% 12% 12%;
}

.etiquette__visual::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 24rem;
  width: 4.7rem;
  aspect-ratio: 1;
  transform: translateX(-50%);
  background: rgba(0,0,0,0.62);
  border-radius: 50%;
}

.veil-panel {
  position: absolute;
  inset: -15% auto -10% 0;
  width: 70%;
  background: linear-gradient(90deg, transparent, rgba(255,0,0,0.2), rgba(178,135,74,0.15), transparent);
  transform-origin: bottom left;
  mix-blend-mode: screen;
  filter: blur(0.2px);
}

.veil-panel--one { transform: rotate(-18deg) translateX(-10%); }
.veil-panel--two { transform: rotate(8deg) translateX(15%); opacity: 0.76; }
.veil-panel--three { transform: rotate(27deg) translateX(38%); opacity: 0.56; }

.etiquette__content h2 { margin-top: 0.7rem; }

.rules {
  margin-top: 2rem;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: rgba(255,0,0,0.15);
  border: 1px solid rgba(255,0,0,0.16);
}

.rules article {
  padding: 1.35rem;
  background: rgba(6, 0, 0, 0.9);
}

.rule-number {
  display: block;
  font-size: 0.72rem;
  font-weight: 900;
  color: var(--red-hot);
  letter-spacing: 0.16em;
  margin-bottom: 0.8rem;
}

.rules p { margin-top: 0.75rem; color: rgba(247,238,230,0.66); }

.tickets {
  background:
    linear-gradient(180deg, transparent, rgba(136,0,0,0.11), transparent),
    radial-gradient(circle at 88% 36%, rgba(255,0,0,0.18), transparent 20rem);
}

.ticket-card {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 2rem;
  align-items: center;
  padding: clamp(1.4rem, 4vw, 3rem);
  border: 1px solid rgba(255, 0, 0, 0.2);
  background:
    linear-gradient(90deg, rgba(255,0,0,0.11), rgba(178,135,74,0.06), rgba(0,0,0,0.38)),
    rgba(9, 1, 1, 0.78);
  box-shadow: 0 0 3rem rgba(0,0,0,0.32);
}

.ticket-card h2 {
  margin-top: 0.55rem;
  font-size: clamp(2.4rem, 5.5vw, 5.2rem);
}

.ticket-card p { max-width: 620px; margin-top: 1rem; }

.fine-print {
  color: var(--dim) !important;
  font-size: 0.82rem;
}

.accordion {
  max-width: 920px;
  margin: 0 auto;
  border-top: 1px solid rgba(255,0,0,0.18);
}

details {
  border-bottom: 1px solid rgba(255,0,0,0.18);
  background: rgba(0,0,0,0.16);
}

summary {
  list-style: none;
  cursor: pointer;
  padding: 1.1rem 0;
  display: flex;
  justify-content: space-between;
  gap: 1.5rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--white);
}

summary::-webkit-details-marker { display: none; }

summary::after {
  content: "+";
  color: var(--red-hot);
  font-size: 1.2rem;
  line-height: 1;
}

details[open] summary::after { content: "–"; }

details p {
  padding: 0 0 1.1rem;
  max-width: 760px;
}

.site-footer {
  border-top: 1px solid rgba(255,0,0,0.16);
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 2rem;
  align-items: end;
}

.site-footer p:nth-child(2) {
  font-weight: 900;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--white);
}

@media (max-width: 880px) {
  .nav-toggle { display: block; z-index: 52; }
  .site-nav {
    position: fixed;
    inset: 0;
    z-index: 51;
    display: grid;
    place-content: center;
    gap: 1.4rem;
    background: rgba(4, 0, 0, 0.96);
    transform: translateY(-100%);
    transition: transform 220ms ease;
  }
  .site-nav a { font-size: 1.1rem; text-align: center; }
  body.nav-open .site-nav { transform: translateY(0); }
  .intro__grid,
  .etiquette,
  .ticket-card,
  .site-footer { grid-template-columns: 1fr; }
  .cards--four { grid-template-columns: repeat(2, 1fr); }
  .etiquette__visual { min-height: 22rem; }
  .ticket-card .button { width: 100%; }
  .site-footer { align-items: start; }
}

@media (max-width: 560px) {
  :root { --pad: 1rem; }
  .hero__content { padding-top: 6.5rem; }
  .wordmark--hero { font-size: clamp(5.1rem, 24vw, 8rem); }
  .tagline { font-size: clamp(1.9rem, 10vw, 3rem); }
  .hero__actions { flex-direction: column; }
  .button { width: 100%; }
  .cards--four,
  .rules { grid-template-columns: 1fr; }
  .card { min-height: 14rem; }
  summary { font-size: 0.82rem; letter-spacing: 0.045em; }
  .shadow--one, .shadow--four { opacity: 0.45; }
  .shadow--two { left: 20%; }
  .shadow--three { right: 16%; }
}

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