:root {
  --black: #030303;
  --ink: #080708;
  --steel: #121111;
  --white: #f3eee8;
  --muted: #a79d96;
  --red: #c20d19;
  --hot: #ff1728;
  --dark-red: #260305;
  --line: rgba(243, 238, 232, .18);
  --line-red: rgba(255, 23, 40, .55);
  --max: 1180px;
  --pad: clamp(18px, 5vw, 64px);
  --display: "Bebas Neue", "Barlow Condensed", Impact, "Arial Narrow", sans-serif;
  --condensed: "Barlow Condensed", "Arial Narrow", sans-serif;
  --mono: "Share Tech Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; width: 100%; max-width: 100%; overflow-x: hidden; }
body {
  width: 100%;
  max-width: 100%;
  margin: 0;
  color: var(--white);
  background:
    radial-gradient(circle at 75% 0%, rgba(194, 13, 25, .30), transparent 38rem),
    linear-gradient(180deg, #050505 0%, #030303 100%);
  font-family: var(--condensed);
  font-weight: 600;
  letter-spacing: .015em;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }

.skip-link {
  position: absolute;
  left: 1rem;
  top: -6rem;
  z-index: 999;
  padding: .8rem 1rem;
  background: var(--white);
  color: #000;
}
.skip-link:focus { top: 1rem; }

.grain,
.scanline {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}
.grain {
  opacity: .17;
  background-image:
    radial-gradient(circle at 20% 20%, rgba(255,255,255,.22) 0 1px, transparent 1px),
    radial-gradient(circle at 70% 60%, rgba(255,255,255,.14) 0 1px, transparent 1px);
  background-size: 13px 17px, 19px 23px;
  mix-blend-mode: overlay;
}
.scanline {
  opacity: .18;
  background: repeating-linear-gradient(0deg, rgba(255,255,255,.03) 0 1px, transparent 1px 8px);
}

.site-header {
  position: fixed;
  inset: 0 0 auto;
  z-index: 30;
  min-height: 74px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 12px var(--pad);
  border-bottom: 1px solid transparent;
  transition: background .2s ease, border-color .2s ease;
}
.site-header.is-scrolled {
  background: rgba(3,3,3,.88);
  border-color: var(--line-red);
  backdrop-filter: blur(12px);
}
.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}
.brand img {
  width: 54px;
  height: 54px;
  object-fit: contain;
  border-radius: 4px;
  border: 1px solid rgba(255, 23, 40, .32);
  box-shadow: 0 0 22px rgba(255, 23, 40, .14);
}
.brand span { display: grid; line-height: .86; }
.brand strong {
  font-family: var(--display);
  font-size: 1.65rem;
  letter-spacing: .08em;
}
.brand small {
  color: var(--muted);
  font-family: var(--mono);
  font-size: .64rem;
  letter-spacing: .14em;
}
.site-nav {
  display: flex;
  align-items: center;
  gap: clamp(18px, 3vw, 34px);
  font-family: var(--mono);
  font-size: .78rem;
  letter-spacing: .11em;
  text-transform: uppercase;
}
.site-nav a { color: rgba(243,238,232,.82); }
.site-nav a:hover { color: var(--hot); }
.nav-toggle { display: none; }

main, footer { position: relative; z-index: 1; }
.hero {
  min-height: 100svh;
  position: relative;
  display: grid;
  align-items: end;
  padding: 110px var(--pad) 42px;
  overflow: hidden;
  border-bottom: 1px solid var(--line-red);
  background:
    linear-gradient(90deg, rgba(0,0,0,.98) 0%, rgba(0,0,0,.70) 52%, rgba(68,3,7,.74) 100%),
    repeating-linear-gradient(90deg, transparent 0 72px, rgba(255,23,40,.12) 72px 73px),
    repeating-linear-gradient(0deg, transparent 0 44px, rgba(255,255,255,.045) 44px 45px);
}
.hero::before {
  content: "";
  position: absolute;
  right: -15vw;
  bottom: -20vh;
  width: min(80vw, 900px);
  aspect-ratio: 1;
  border: 1px solid rgba(255,23,40,.30);
  border-radius: 50%;
}
.hero::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 22vh;
  background: linear-gradient(0deg, #030303 0%, transparent 100%);
}
.container-shadow {
  position: absolute;
  right: clamp(-18px, 4vw, 70px);
  top: 14vh;
  color: transparent;
  -webkit-text-stroke: 1px rgba(255,23,40,.28);
  font-family: var(--display);
  font-size: clamp(22rem, 46vw, 44rem);
  line-height: .7;
  opacity: .7;
}
.hero-copyblock {
  position: relative;
  z-index: 2;
  width: min(100%, 1020px);
}
.stamp {
  margin: 0 0 14px;
  color: var(--hot);
  font-family: var(--mono);
  font-size: clamp(.72rem, 2vw, .88rem);
  letter-spacing: .16em;
  text-transform: uppercase;
}
h1, h2, h3, p { margin-top: 0; }
h1 {
  margin: 0;
  font-family: var(--display);
  font-size: clamp(6.4rem, 24vw, 18rem);
  font-weight: 400;
  line-height: .72;
  letter-spacing: .005em;
  text-transform: uppercase;
  text-wrap: balance;
}
h1 span { color: transparent; -webkit-text-stroke: clamp(1px, .18vw, 2px) var(--white); }
h2 {
  margin: 0 0 18px;
  max-width: 950px;
  font-family: var(--display);
  font-size: clamp(4.2rem, 13vw, 9.5rem);
  font-weight: 400;
  line-height: .78;
  letter-spacing: .005em;
  text-transform: uppercase;
}
h3 {
  margin: 0;
  font-family: var(--display);
  font-size: clamp(3.8rem, 11vw, 7.2rem);
  font-weight: 400;
  line-height: .78;
  letter-spacing: .01em;
  text-transform: uppercase;
}
.hero-line {
  margin: 18px 0 8px;
  color: var(--hot);
  font-family: var(--mono);
  font-size: clamp(.85rem, 2vw, 1rem);
  text-transform: uppercase;
}
.hero-text {
  max-width: 640px;
  margin-bottom: 0;
  color: var(--muted);
  font-size: clamp(1.16rem, 3.5vw, 1.55rem);
  line-height: 1.08;
}
.action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 26px;
}
.cta, .event-actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 13px 18px;
  border: 1px solid var(--line-red);
  font-family: var(--mono);
  font-size: .82rem;
  letter-spacing: .11em;
  text-transform: uppercase;
  transition: transform .15s ease, background .15s ease, color .15s ease;
  clip-path: polygon(10px 0, 100% 0, calc(100% - 10px) 100%, 0 100%);
}
.cta:hover, .event-actions a:hover { transform: translateY(-2px); }
.cta-red, .event-actions a:hover { background: var(--hot); color: #fff; }
.cta-line { background: rgba(0,0,0,.34); color: var(--white); border-color: var(--line); }
.next-strip {
  position: absolute;
  right: var(--pad);
  bottom: 52px;
  z-index: 3;
  display: grid;
  gap: 5px;
  min-width: min(380px, calc(100vw - 2 * var(--pad)));
  padding: 14px 0 14px 18px;
  border-left: 3px solid var(--hot);
  background: linear-gradient(90deg, rgba(0,0,0,.78), transparent);
}
.next-strip span, .event-tag { color: var(--hot); font-family: var(--mono); font-size: .75rem; letter-spacing: .13em; text-transform: uppercase; }
.next-strip strong { font-family: var(--display); font-size: 2rem; line-height: .85; }
.next-strip em { color: var(--muted); font-style: normal; font-family: var(--mono); }

.section {
  padding: clamp(70px, 12vw, 130px) var(--pad);
  border-bottom: 1px solid var(--line);
}
.section-title { max-width: var(--max); margin: 0 auto 36px; }
.narrow { max-width: 900px; margin-left: 0; }
.section-title p:not(.stamp), .press-copy p, .about-section .section-title > p:not(.stamp) {
  max-width: 720px;
  color: var(--muted);
  font-size: clamp(1.25rem, 3.2vw, 1.75rem);
  line-height: 1.08;
}
.events-section {
  background:
    linear-gradient(180deg, #030303, #090606),
    repeating-linear-gradient(90deg, transparent 0 90px, rgba(255,255,255,.03) 90px 91px);
}
.event-list {
  max-width: var(--max);
  margin: 0 auto;
  display: grid;
  gap: 18px;
}
.event-slab {
  position: relative;
  display: grid;
  grid-template-columns: 92px 1fr auto;
  gap: clamp(16px, 3vw, 34px);
  align-items: stretch;
  padding: clamp(18px, 4vw, 34px) 0;
  border-top: 1px solid var(--line-red);
  border-bottom: 1px solid var(--line);
  background:
    linear-gradient(90deg, rgba(255,23,40,.10), transparent 38%),
    repeating-linear-gradient(135deg, rgba(255,255,255,.04) 0 1px, transparent 1px 10px);
}
.event-slab::before,
.event-slab::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 10px;
  background: var(--red);
}
.event-slab::before { left: 0; }
.event-slab::after { right: 0; opacity: .5; }
.event-slab-red { background: linear-gradient(90deg, rgba(255,23,40,.17), rgba(255,23,40,.05) 52%, transparent), repeating-linear-gradient(135deg, rgba(255,255,255,.035) 0 1px, transparent 1px 10px); }
.event-date {
  display: grid;
  align-content: start;
  justify-items: center;
  gap: 8px;
  padding-left: 22px;
}
.event-date b { font-family: var(--display); font-size: 5rem; line-height: .75; color: var(--white); }
.event-date span { color: var(--muted); font-family: var(--mono); font-size: .72rem; text-align: center; }
.event-main { min-width: 0; }
.event-sub {
  margin: 8px 0 18px;
  color: var(--muted);
  font-size: clamp(1.15rem, 3vw, 1.55rem);
  line-height: 1;
}
.event-info {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  margin: 0 0 18px;
  background: var(--line);
}
.event-info span {
  min-height: 48px;
  display: flex;
  align-items: center;
  padding: 10px 12px;
  background: rgba(3,3,3,.78);
  color: var(--white);
  font-size: 1.05rem;
  line-height: 1.05;
}
.lineup-text {
  margin: 0;
  color: var(--white);
  font-family: var(--mono);
  font-size: clamp(.82rem, 2vw, .98rem);
  line-height: 1.45;
}
.event-actions {
  display: grid;
  align-content: end;
  gap: 10px;
  padding-right: 22px;
  min-width: 156px;
}
.event-actions a { min-height: 46px; white-space: nowrap; background: rgba(0,0,0,.34); }
.event-actions .wide { min-width: 220px; }

.about-section {
  background:
    radial-gradient(circle at 100% 10%, rgba(255,23,40,.16), transparent 28rem),
    #030303;
}
.proof-lines {
  max-width: var(--max);
  margin: 44px auto 0;
  border-top: 1px solid var(--line-red);
}
.proof-lines p {
  display: grid;
  grid-template-columns: 150px 1fr;
  gap: 20px;
  margin: 0;
  padding: 18px 0;
  border-bottom: 1px solid var(--line);
  color: var(--muted);
  font-size: clamp(1.05rem, 2.6vw, 1.35rem);
  line-height: 1.08;
}
.proof-lines span {
  color: var(--hot);
  font-family: var(--mono);
  font-size: .78rem;
  letter-spacing: .14em;
}
.marquee {
  overflow: hidden;
  border-block: 1px solid var(--line-red);
  background: var(--hot);
  color: #fff;
}
.marquee div {
  display: flex;
  gap: 34px;
  width: max-content;
  padding: 10px 0;
  font-family: var(--display);
  font-size: clamp(2.4rem, 8vw, 5.5rem);
  line-height: .85;
  animation: move 22s linear infinite;
}
.marquee span { white-space: nowrap; }
@keyframes move { to { transform: translateX(-50%); } }

.press-section {
  background:
    linear-gradient(110deg, #030303 0%, #030303 48%, #210306 100%),
    repeating-linear-gradient(90deg, transparent 0 70px, rgba(255,23,40,.12) 70px 71px);
}
.press-layout {
  max-width: var(--max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: .95fr .8fr;
  gap: clamp(28px, 7vw, 90px);
  align-items: start;
}
.press-copy ul {
  margin: 26px 0 28px;
  padding: 0;
  list-style: none;
  border-top: 1px solid var(--line-red);
}
.press-copy li {
  padding: 14px 0;
  border-bottom: 1px solid var(--line);
  color: var(--white);
  font-family: var(--mono);
  font-size: .92rem;
  text-transform: uppercase;
}
.press-copy li::before { content: "// "; color: var(--hot); }

.contact-section { min-height: 58vh; }
.contact-section h2 {
  max-width: 760px;
  font-size: clamp(3.6rem, 10vw, 8rem);
  line-height: .82;
}
.mail-link {
  display: inline-grid;
  gap: 0;
  margin-top: 18px;
  color: var(--hot);
  font-family: var(--display);
  font-size: clamp(4.2rem, 15vw, 11rem);
  line-height: .76;
  text-transform: uppercase;
}
.mail-link span { display: block; }
.social-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 26px;
  max-width: 720px;
}
.social-actions .cta {
  min-height: 54px;
  gap: 10px;
  clip-path: none;
  text-align: center;
}
.insta-btn svg {
  width: 20px;
  height: 20px;
  flex: 0 0 auto;
  fill: currentColor;
}
.insta-btn span { display: inline-block; }
.link-hub {
  display: block;
  margin-top: 22px;
  color: var(--muted);
  font-family: var(--mono);
  font-size: .95rem;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.site-footer {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  padding: 28px var(--pad);
  border-top: 1px solid var(--line);
  color: var(--muted);
  font-family: var(--mono);
  font-size: .82rem;
  text-transform: uppercase;
}
.site-footer nav { display: flex; gap: 18px; flex-wrap: wrap; }
.site-footer a:hover { color: var(--hot); }

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

@media (max-width: 980px) {
  .site-nav {
    position: fixed;
    inset: 0;
    z-index: 40;
    display: grid;
    align-content: center;
    justify-items: center;
    gap: 22px;
    background: rgba(3,3,3,.97);
    transform: translateX(100%);
    transition: transform .2s ease;
    font-size: 1rem;
  }
  body.nav-open { overflow: hidden; }
  body.nav-open .site-nav { transform: translateX(0); }
  .nav-toggle {
    display: grid;
    place-content: center;
    gap: 5px;
    position: relative;
    z-index: 50;
    width: 46px;
    height: 46px;
    border: 1px solid var(--line-red);
    background: rgba(0,0,0,.55);
    color: var(--white);
  }
  .nav-toggle span { display: block; width: 22px; height: 2px; background: currentColor; transition: transform .2s ease, opacity .2s ease; }
  body.nav-open .nav-toggle span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  body.nav-open .nav-toggle span:nth-child(2) { opacity: 0; }
  body.nav-open .nav-toggle span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
  .next-strip { position: relative; right: auto; bottom: auto; margin-top: 38px; }
  .hero { align-items: center; }
  .press-layout { grid-template-columns: 1fr; }
}

@media (max-width: 760px) {
  :root { --pad: 16px; }
  .site-header { min-height: 68px; padding-top: 9px; padding-bottom: 9px; }
  .brand img { width: 48px; height: 48px; }
  .brand strong { font-size: 1.36rem; }
  .brand small { font-size: .54rem; }
  .hero { min-height: auto; padding-top: 102px; padding-bottom: 34px; max-width: 100vw; }
  .hero-copyblock { width: calc(100vw - 2 * var(--pad)); max-width: calc(100vw - 2 * var(--pad)); overflow: hidden; }
  h1 { font-size: clamp(4.6rem, 20vw, 5.6rem); line-height: .76; max-width: 100%; }
  h1 span { font-size: .62em; letter-spacing: .02em; }
  h2 { font-size: clamp(3.2rem, 15vw, 4.8rem); line-height: .82; }
  h3 { font-size: clamp(3rem, 15vw, 4.6rem); }
  .hero-text { max-width: 310px; }
  .action-row { display: grid; grid-template-columns: 1fr; }
  .cta { width: 100%; min-height: 54px; }
  .social-actions { display: grid; grid-template-columns: 1fr; }
  .container-shadow { top: 20vh; right: -24vw; font-size: 28rem; opacity: .44; }
  .section { padding-inline: 1rem; }
  .event-slab {
    grid-template-columns: 72px 1fr;
    gap: 14px;
    padding: 18px 0 22px;
  }
  .event-slab::before, .event-slab::after { width: 6px; }
  .event-date { padding-left: 11px; }
  .event-date b { font-size: 4.1rem; }
  .event-actions {
    grid-column: 1 / -1;
    grid-template-columns: 1fr;
    padding: 0 12px;
  }
  .event-actions a, .event-actions .wide { width: 100%; min-width: 0; }
  .event-info { grid-template-columns: 1fr; }
  .proof-lines p { grid-template-columns: 1fr; gap: 7px; }
  .marquee div { animation-duration: 13s; }
  .mail-link { font-size: clamp(4rem, 21vw, 7rem); }
  .site-footer { flex-direction: column; }
}

@media (max-width: 420px) {
  .brand span { max-width: 150px; }
  .brand strong { letter-spacing: .05em; }
  .hero-line { line-height: 1.35; font-size: .78rem; }
  .hero .stamp { font-size: .66rem; line-height: 1.35; max-width: 100%; }
  .next-strip { min-width: 0; width: 100%; }
}
