/* ==========================================================================
   h97a Landing Page — „Plakatwand an der Hafenstraße"
   ========================================================================== */

@font-face {
  font-family: 'Anton';
  src: url('fonts/Anton-Regular.ttf') format('truetype');
  font-weight: 400;
  font-display: swap;
}
@font-face {
  font-family: 'Barlow';
  src: url('fonts/barlow-latin-400-normal.woff2') format('woff2');
  font-weight: 400;
  font-display: swap;
}
@font-face {
  font-family: 'Barlow';
  src: url('fonts/barlow-latin-600-normal.woff2') format('woff2');
  font-weight: 600;
  font-display: swap;
}
@font-face {
  font-family: 'Barlow Condensed';
  src: url('fonts/barlow-condensed-latin-600-normal.woff2') format('woff2');
  font-weight: 600;
  font-display: swap;
}
@font-face {
  font-family: 'Barlow Condensed';
  src: url('fonts/barlow-condensed-latin-700-normal.woff2') format('woff2');
  font-weight: 700;
  font-display: swap;
}
@font-face {
  font-family: 'JetBrains Mono';
  src: url('fonts/jetbrains-mono-latin-700-normal.woff2') format('woff2');
  font-weight: 700;
  font-display: swap;
}

:root {
  --red: #c8102e;
  --red-deep: #8f0b20;
  --black: #0c0a0a;
  --coal: #161213;
  --paper: #f2ece4;
  --paper-dim: #d9d1c5;
  --display: 'Anton', sans-serif;
  --cond: 'Barlow Condensed', sans-serif;
  --body: 'Barlow', sans-serif;
  --mono: 'JetBrains Mono', monospace;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  /* horizontaler Overflow (Ticker-Scale, überstehende Wand-Fotos) darf nie
     scrollbar werden — muss auf html liegen, iOS Safari ignoriert es auf body.
     clip statt hidden: erzeugt keinen eigenen Scroll-Container. */
  overflow-x: hidden;
  overflow-x: clip;
}

body {
  background: var(--black);
  color: var(--paper);
  font-family: var(--body);
  font-size: 1.0625rem;
  line-height: 1.55;
  overflow-x: hidden;
  overflow-x: clip;
}

/* Grain über allem */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  z-index: 90;
  pointer-events: none;
  opacity: 0.07;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E");
}

img { display: block; max-width: 100%; height: auto; }

/* ==========================================================================
   Schnellfeuer-Frames (Hero + Mini)
   ========================================================================== */

.fire-frame {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
}
.fire-frame.is-visible { opacity: 1; }

/* ==========================================================================
   Hero
   ========================================================================== */

.hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
}

.hero__fire { position: absolute; inset: 0; }

.hero__scrim {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgb(12 10 10 / 0.55) 0%, rgb(12 10 10 / 0.25) 40%, rgb(12 10 10 / 0.82) 100%),
    radial-gradient(ellipse at 50% 60%, transparent 30%, rgb(12 10 10 / 0.45) 100%);
}

.hero__lockup {
  position: relative;
  z-index: 2;
  padding: 0 clamp(1.25rem, 5vw, 5rem);
  max-width: 70rem;
}

.hero__club {
  font-family: var(--cond);
  font-weight: 700;
  font-size: clamp(1.05rem, 2.4vw, 1.6rem);
  letter-spacing: 0.42em;
  text-transform: uppercase;
  color: var(--paper);
  text-shadow: 0 2px 18px rgb(12 10 10 / 0.8);
  margin-bottom: 0.4rem;
}

.hero__address {
  font-family: var(--display);
  font-weight: 400;
  text-transform: uppercase;
  font-size: clamp(3.4rem, 12.5vw, 10.5rem);
  line-height: 0.94;
  letter-spacing: 0.01em;
  color: var(--paper);
  text-shadow: 0 6px 40px rgb(12 10 10 / 0.85);
}

.no-caps { text-transform: none; }

.hero__no {
  text-transform: none;
  color: var(--red);
  text-shadow: 0 0 50px rgb(200 16 46 / 0.55), 0 6px 40px rgb(12 10 10 / 0.85);
}

.hero__sub {
  margin-top: 1.2rem;
  font-family: var(--cond);
  font-weight: 600;
  font-size: clamp(1.15rem, 2.6vw, 1.7rem);
  line-height: 1.3;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--paper-dim);
  text-shadow: 0 2px 14px rgb(12 10 10 / 0.9);
}

.hero__cta {
  display: inline-block;
  margin-top: 2rem;
  padding: 0.95rem 2.4rem;
  background: var(--red);
  color: var(--paper);
  font-family: var(--cond);
  font-weight: 700;
  font-size: 1.25rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  text-decoration: none;
  transform: rotate(-1.2deg);
  box-shadow: 0.45rem 0.45rem 0 rgb(12 10 10 / 0.9);
  transition: transform 120ms ease, box-shadow 120ms ease, background 120ms ease;
}
.hero__cta:hover,
.hero__cta:focus-visible {
  background: var(--red-deep);
  transform: rotate(-1.2deg) translate(0.15rem, 0.15rem);
  box-shadow: 0.25rem 0.25rem 0 rgb(12 10 10 / 0.9);
}

.hero__scroll {
  position: absolute;
  z-index: 2;
  bottom: 1.1rem;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--mono);
  font-size: 0.72rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--paper-dim);
  animation: bob 2.2s ease-in-out infinite;
}
@keyframes bob {
  0%, 100% { transform: translate(-50%, 0); }
  50% { transform: translate(-50%, 0.5rem); }
}

/* ==========================================================================
   Ticker
   ========================================================================== */

/* Klemmt den rotierten/skalierten Ticker horizontal ein. iOS Safari lässt
   trotz overflow-x:clip auf html/body horizontales Scrollen zu, wenn
   Transforms über den Viewport ragen — daher Clipping direkt am Element.
   Negativ-Margin + Padding lassen Rotation und Schatten vertikal Platz. */
.ticker-clip {
  overflow: hidden;
  overflow: clip;
  margin-block: -3rem;
  padding-block: 3rem;
}

.ticker {
  position: relative;
  z-index: 3;
  background: var(--red);
  transform: rotate(-1.3deg) scale(1.04);
  overflow: hidden;
  padding: 0.55rem 0;
  box-shadow: 0 10px 40px rgb(12 10 10 / 0.6);
}

.ticker__track {
  display: flex;
  width: max-content;
  animation: ticker 28s linear infinite;
}

.ticker__track span {
  font-family: var(--mono);
  font-weight: 700;
  font-size: 0.95rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--paper);
  white-space: nowrap;
  padding-right: 2rem;
}

@keyframes ticker {
  to { transform: translateX(-50%); }
}

/* ==========================================================================
   Teaser-Wand
   ========================================================================== */

.wall {
  position: relative;
  /* clip statt nur html-Level: iOS Safari scrollt sonst zu den
     überstehenden Wand-Fotos (negative left/right-Offsets) */
  overflow: hidden;
  overflow: clip;
  padding: clamp(5rem, 11vw, 9rem) clamp(1.25rem, 5vw, 5rem) clamp(4rem, 9vw, 8rem);
  background:
    radial-gradient(ellipse at 80% 10%, rgb(200 16 46 / 0.14), transparent 55%),
    radial-gradient(ellipse at 10% 80%, rgb(200 16 46 / 0.1), transparent 50%),
    var(--coal);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(20rem, 100%), 1fr));
  gap: clamp(2rem, 4vw, 3.5rem);
  align-items: start;
}

.wall__title {
  grid-column: 1 / -1;
  font-family: var(--display);
  font-weight: 400;
  text-transform: uppercase;
  font-size: clamp(2rem, 5.4vw, 4.2rem);
  line-height: 1.02;
  max-width: 18em;
  transform: rotate(-1deg);
  margin-bottom: clamp(1.5rem, 3vw, 3rem);
}
.wall__title em {
  font-style: normal;
  color: var(--red);
}

/* verstreute Fotos hinter den Karten */
.wall__photo {
  position: absolute;
  width: clamp(11rem, 22vw, 19rem);
  opacity: 0.55;
  filter: saturate(1.1) contrast(1.05);
  box-shadow: 0 16px 50px rgb(12 10 10 / 0.7);
  pointer-events: none;
}
.wall__photo {
  transform: rotate(var(--r, 0deg)) translateY(var(--py, 0px));
  will-change: transform;
}
.wall__photo--1 { top: 4%;  right: -3%; --r: 6deg; }
.wall__photo--2 { top: 42%; left: -4%;  --r: -7deg; }
.wall__photo--3 { bottom: 3%; right: 12%; --r: 3.5deg; }

/* Karten — wie angeklebte Flyer */
.card {
  position: relative;
  z-index: 2;
  background: var(--paper);
  color: var(--black);
  padding: 1.6rem 1.5rem 1.4rem;
  box-shadow: 0.6rem 0.6rem 0 rgb(12 10 10 / 0.85);
  transition: transform 150ms ease;
}
.card--news  { transform: rotate(-1.8deg); }
.card--rumor { transform: rotate(1.4deg); margin-top: clamp(0rem, 3vw, 2.5rem); }
.card--tipp  { transform: rotate(-1deg);  margin-top: clamp(0rem, 2vw, 1.25rem); }
.card:hover  { transform: rotate(0deg) scale(1.015); }

/* Klebeband oben */
.card::before {
  content: '';
  position: absolute;
  top: -0.7rem;
  left: 50%;
  width: 5.5rem;
  height: 1.4rem;
  transform: translateX(-50%) rotate(-2deg);
  background: rgb(242 236 228 / 0.45);
  border-inline: 1px dashed rgb(12 10 10 / 0.25);
}

.card__tag {
  display: inline-block;
  font-family: var(--cond);
  font-weight: 700;
  font-size: 0.85rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  background: var(--red);
  color: var(--paper);
  padding: 0.25rem 0.7rem;
  margin-bottom: 0.9rem;
  transform: rotate(-1deg);
}

.card__headline {
  font-family: var(--cond);
  font-weight: 700;
  font-size: 1.55rem;
  line-height: 1.12;
  text-transform: uppercase;
  margin-bottom: 0.7rem;
}

.card__body {
  font-size: 0.98rem;
  color: rgb(12 10 10 / 0.78);
}

/* News: Text läuft ins Nichts */
.card__body--fade {
  -webkit-mask-image: linear-gradient(180deg, #000 20%, transparent 95%);
  mask-image: linear-gradient(180deg, #000 20%, transparent 95%);
}

.card__gate {
  margin-top: 1.1rem;
  padding-top: 0.8rem;
  border-top: 2px dashed rgb(12 10 10 / 0.3);
  font-family: var(--cond);
  font-weight: 700;
  font-size: 1.02rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--red);
}

/* Geschwärzte Stellen */
.redacted {
  background: var(--black);
  color: transparent;
  user-select: none;
  padding: 0 0.3em;
  border-radius: 1px;
}

/* Tippzettel */
.tippzettel {
  border: 2px solid rgb(12 10 10 / 0.75);
  padding: 1rem 1.1rem;
  background: repeating-linear-gradient(180deg, transparent 0 1.9rem, rgb(12 10 10 / 0.07) 1.9rem 2rem);
}
.tippzettel__match {
  font-family: var(--cond);
  font-weight: 600;
  font-size: 1.2rem;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.tippzettel__meta {
  margin-top: 0.7rem;
  font-family: var(--mono);
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgb(12 10 10 / 0.6);
}
.tippzettel__box {
  display: inline-block;
  width: 1.7rem;
  height: 1.7rem;
  border: 2px solid var(--red);
  background: rgb(200 16 46 / 0.06);
}

/* Quiz-Karte */
.card--quiz { transform: rotate(1.6deg); margin-top: clamp(0rem, 2.5vw, 1.75rem); }

.quiz-options {
  list-style: none;
  counter-reset: quiz;
  display: grid;
  gap: 0.45rem;
}
.quiz-options li {
  counter-increment: quiz;
  font-family: var(--cond);
  font-weight: 600;
  font-size: 1.08rem;
  text-transform: uppercase;
  border: 2px solid rgb(12 10 10 / 0.7);
  padding: 0.4rem 0.7rem 0.4rem 2.4rem;
  position: relative;
  cursor: not-allowed;
}
.quiz-options li::before {
  content: counter(quiz, upper-alpha);
  position: absolute;
  left: 0.7rem;
  color: var(--red);
  font-weight: 700;
}

/* ==========================================================================
   An diesem Tag — Zeitungsschnipsel
   ========================================================================== */

.otd {
  background: var(--coal);
  padding: clamp(2.5rem, 6vw, 4.5rem) clamp(1.25rem, 5vw, 5rem);
  display: grid;
  place-items: center;
}

.otd__clip {
  background: linear-gradient(160deg, #efe6d3 0%, #e3d6bc 100%);
  color: var(--black);
  max-width: 42rem;
  width: 100%;
  padding: 1.6rem 2rem 1.4rem;
  transform: rotate(-0.9deg);
  box-shadow: 0.6rem 0.6rem 0 rgb(12 10 10 / 0.85);
  clip-path: polygon(0 4%, 3% 0, 97% 1%, 100% 6%, 99% 96%, 96% 100%, 4% 99%, 0 94%);
}

.otd__kicker {
  font-family: var(--mono);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--red-deep);
  margin-bottom: 0.5rem;
}

.otd__line {
  font-family: var(--cond);
  font-weight: 700;
  font-size: clamp(1.3rem, 3vw, 1.8rem);
  line-height: 1.15;
  text-transform: uppercase;
}

.otd__gate {
  margin-top: 0.7rem;
  padding-top: 0.6rem;
  border-top: 2px dashed rgb(12 10 10 / 0.3);
  font-family: var(--cond);
  font-weight: 600;
  font-size: 0.98rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--red);
}

/* ==========================================================================
   Zahlen-Brocken
   ========================================================================== */

.numbers {
  position: relative;
  padding: clamp(4rem, 9vw, 8rem) clamp(1.25rem, 5vw, 5rem);
  background: var(--black);
  display: flex;
  flex-direction: column;
  gap: clamp(1rem, 3vw, 2rem);
  overflow: hidden;
}

.numbers__item {
  font-family: var(--display);
  font-weight: 400;
  text-transform: uppercase;
  line-height: 0.95;
  font-size: clamp(2.6rem, 8.5vw, 7rem);
  color: var(--paper);
}
.numbers__item strong { font-weight: 400; color: var(--red); }

.numbers__item--1 { transform: rotate(-1.5deg); }
.numbers__item--2 {
  align-self: flex-end;
  transform: rotate(1deg);
  color: transparent;
  -webkit-text-stroke: 2px var(--paper-dim);
}
.numbers__item--2 strong {
  color: transparent;
  -webkit-text-stroke: 2px var(--red);
}
.numbers__item--3 { transform: rotate(-0.8deg); margin-left: clamp(0rem, 8vw, 7rem); }

/* ==========================================================================
   Download / Schild
   ========================================================================== */

.download {
  position: relative;
  padding: clamp(5rem, 10vw, 9rem) clamp(1.25rem, 5vw, 5rem);
  overflow: hidden;
  display: grid;
  place-items: center;
}

.download__fire { position: absolute; inset: 0; opacity: 0.4; }
.download__fire .fire-frame { filter: saturate(1.15); }

.download::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, var(--black) 0%, rgb(12 10 10 / 0.55) 30%, rgb(12 10 10 / 0.55) 70%, var(--black) 100%);
}

/* Das Schild — Emaille-Optik */
.download__sign {
  position: relative;
  z-index: 2;
  background: var(--paper);
  color: var(--black);
  border: 4px solid var(--black);
  outline: 6px solid var(--paper);
  outline-offset: -10px;
  padding: 2.4rem 2.6rem 2.2rem;
  max-width: 24rem;
  width: 100%;
  text-align: center;
  transform: rotate(-1.2deg);
  box-shadow: 0 30px 80px rgb(12 10 10 / 0.85);
}

.download__title {
  font-family: var(--display);
  font-weight: 400;
  text-transform: uppercase;
  font-size: clamp(1.9rem, 4.5vw, 2.6rem);
  line-height: 1;
  margin-bottom: 1.4rem;
}

.qr {
  width: 11rem;
  margin: 0 auto 1.4rem;
}
.qr__pattern {
  width: 11rem;
  height: 11rem;
  margin-bottom: 0.5rem;
  border: 4px solid var(--black);
  background:
    conic-gradient(var(--black) 0 25%, transparent 0 50%, var(--black) 0 75%, transparent 0) 0 0 / 1.4rem 1.4rem,
    var(--paper);
  filter: contrast(1.05);
  position: relative;
}
.qr__note {
  font-family: var(--mono);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgb(12 10 10 / 0.6);
}

.stores {
  display: flex;
  gap: 0.8rem;
  justify-content: center;
  flex-wrap: wrap;
}
.stores__badge {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
  background: var(--black);
  color: var(--paper);
  font-family: var(--cond);
  font-weight: 700;
  font-size: 1.05rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 0.6rem 1.2rem;
  cursor: not-allowed;
}
.stores__badge small {
  font-family: var(--mono);
  font-weight: 400;
  font-size: 0.6rem;
  letter-spacing: 0.14em;
  color: var(--paper-dim);
}

/* ==========================================================================
   Footer
   ========================================================================== */

.footer {
  background: var(--black);
  padding: 2.5rem clamp(1.25rem, 5vw, 5rem) 3rem;
  text-align: center;
  border-top: 1px solid rgb(242 236 228 / 0.12);
}

.footer__address {
  font-family: var(--cond);
  font-weight: 700;
  font-size: 1.05rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
}

.footer__note {
  margin-top: 0.6rem;
  font-size: 0.85rem;
  color: rgb(242 236 228 / 0.55);
}

.footer__nav {
  margin-top: 1.2rem;
  display: flex;
  gap: 1.6rem;
  justify-content: center;
}
.footer__nav a {
  color: var(--paper-dim);
  font-family: var(--mono);
  font-size: 0.75rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.footer__nav a:hover { color: var(--red); }

/* ==========================================================================
   Rechtsseiten (Impressum / Datenschutz) — Papierbogen auf Asphalt
   ========================================================================== */

.legal {
  min-height: 100svh;
  padding: clamp(3rem, 8vw, 6rem) clamp(1.25rem, 5vw, 5rem);
  display: grid;
  place-items: start center;
  background:
    radial-gradient(ellipse at 80% 0%, rgb(200 16 46 / 0.12), transparent 50%),
    var(--black);
}

.legal__sheet {
  background: var(--paper);
  color: var(--black);
  max-width: 46rem;
  width: 100%;
  padding: clamp(1.8rem, 4vw, 3rem) clamp(1.4rem, 4vw, 2.8rem);
  transform: rotate(-0.4deg);
  box-shadow: 0.6rem 0.6rem 0 rgb(12 10 10 / 0.85);
}

.legal__back {
  display: inline-block;
  font-family: var(--mono);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--red);
  text-decoration: none;
  margin-bottom: 1.6rem;
}
.legal__back:hover { text-decoration: underline; }

.legal__title {
  font-family: var(--display);
  font-weight: 400;
  text-transform: uppercase;
  font-size: clamp(2rem, 5vw, 3rem);
  line-height: 1;
  margin-bottom: 1.6rem;
}

.legal h2 {
  font-family: var(--cond);
  font-weight: 700;
  font-size: 1.25rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin: 1.8rem 0 0.5rem;
}

.legal p, .legal ul { margin-bottom: 0.8rem; font-size: 0.98rem; }
.legal ul { padding-left: 1.2rem; }
.legal a { color: var(--red); }

.legal__note {
  margin-top: 2rem;
  padding-top: 1rem;
  border-top: 2px dashed rgb(12 10 10 / 0.3);
  font-size: 0.85rem;
  color: rgb(12 10 10 / 0.65);
}

/* ==========================================================================
   Reduced Motion
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .ticker__track { animation: none; }
  .hero__scroll { animation: none; }
  .fire-frame { transition: opacity 1.2s ease; }
}

/* ==========================================================================
   Mobile-Anpassungen
   ========================================================================== */

@media (max-width: 720px) {
  .wall__photo--1 { right: -18%; opacity: 0.35; }
  .wall__photo--2 { left: -22%; opacity: 0.35; }
  .wall__photo--3 { display: none; }
  .download__sign { padding: 1.8rem 1.4rem 1.6rem; }
}
