/* ============================================================
   ZEITREISE — geschichte.html
   Dunkle Kino-Bühne: die Seite ist der Saal, der Zeitstrahl
   das Projektorlicht. Scroll-Driven Animations nativ (CSS),
   Fallback via IntersectionObserver (js/geschichte.js).
   Brand-Variablen kommen aus css/style.css (:root).
   ============================================================ */

/* iOS-Zoom-Falle: overflow-x:hidden verhindert das Layout-Aufblähen NICHT —
   clip schon. Ohne das zoomte Safari die ganze Seite heraus („alles riesig"),
   sobald irgendein Deko-Element (Geister-Jahr, Komet) rechts überstand. */
html:has(.zr-page), .zr-page { overflow-x: clip; }

.zr-page {
  --zr-bg:        #140a1a;             /* tiefer als --primary-dark */
  --zr-bg-soft:   #1d1024;
  --zr-ink:       #f5e9ee;
  --zr-ink-dim:   #c9a8bd;
  --zr-gold:      #e8b34b;             /* 1999/Projektor-Wärme */
  --zr-beam:      linear-gradient(180deg, var(--pink) 0%, var(--lila) 45%, var(--orange) 85%, var(--zr-gold) 100%);
  background: var(--zr-bg);
  color: var(--zr-ink);
  font-family: var(--font-body);
  /* KEIN overflow-x:hidden hier! hidden (≠ clip) macht body zum
     Scroll-Container → window.scrollY bleibt 0 und der Zeitstrahl-
     Scroll-Listener feuert nie (iPhone: Strahl+Komet eingefroren).
     Das overflow-x:clip oben erledigt die iOS-Zoom-Falle ohne das. */
}
.zr-page ::selection { background: var(--pink); color: #fff; }

/* Filmkorn — inline-SVG-Overlay (#zr-grain im HTML), kein externer Request */
.zr-grain {
  position: fixed; inset: -50%; width: 200%; height: 200%;
  pointer-events: none; z-index: 80; opacity: .05;
  animation: zrGrain 1.4s steps(4) infinite;
}
@keyframes zrGrain {
  0% { transform: translate(0,0); } 25% { transform: translate(-2%,1%); }
  50% { transform: translate(1%,-2%); } 75% { transform: translate(-1%,2%); }
  100% { transform: translate(0,0); }
}

/* ── HERO: der Saal wird dunkel, der Projektor geht an ────── */
.zr-hero {
  position: relative; min-height: 96svh;
  display: flex; flex-direction: column;
  padding: 26px clamp(18px, 4vw, 48px) 64px;
}
.zr-hero-beam {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(58% 42% at 50% -6%, rgba(232,179,75,.20) 0%, transparent 60%),
    conic-gradient(from 168deg at 50% -12%, transparent 41%, rgba(216,49,138,.16) 47%, rgba(158,63,224,.20) 50%, rgba(216,49,138,.16) 53%, transparent 59%),
    radial-gradient(120% 90% at 50% 110%, rgba(46,26,51,.85) 0%, transparent 60%);
  animation: zrBeamFlicker 7s ease-in-out infinite;
}
@keyframes zrBeamFlicker {
  0%, 100% { opacity: 1; } 48% { opacity: .82; }
  52% { opacity: .95; } 67% { opacity: .78; } 71% { opacity: 1; }
}
.zr-top { display: flex; justify-content: space-between; align-items: center; position: relative; z-index: 2; }
.zr-back {
  display: inline-flex; align-items: center; gap: 7px; text-decoration: none;
  color: #f2cfe0; font-weight: 600; font-size: .92rem;
  padding: 7px 14px 7px 11px; border-radius: 999px;
  border: 1px solid rgba(255,255,255,.16); background: rgba(255,255,255,.04);
  transition: background .2s ease, border-color .2s ease, color .2s ease;
}
.zr-back:hover { background: rgba(255,255,255,.10); border-color: rgba(255,255,255,.4); color: #fff; }
.zr-top-star img { width: 36px; height: 36px; opacity: .9; }

.zr-hero-copy {
  margin: auto; text-align: center; position: relative; z-index: 2;
  max-width: 880px; padding-top: 4vh;
}
.zr-kicker {
  font-size: .82rem; font-weight: 700; letter-spacing: .26em;
  text-transform: uppercase; color: var(--zr-gold); margin: 0 0 18px;
}
.zr-hero h1 {
  font-family: var(--font-head); font-style: italic; font-weight: 700;
  font-size: clamp(3rem, 11vw, 7.5rem); line-height: .96; margin: 0;
  color: #fff; letter-spacing: .01em;
  text-shadow: 0 0 80px rgba(216,49,138,.45), 0 0 26px rgba(158,63,224,.30);
}
.zr-hero h1 em {
  font-style: italic; color: transparent;
  background: linear-gradient(100deg, var(--pink) 10%, var(--lila) 50%, var(--orange) 90%);
  -webkit-background-clip: text; background-clip: text;
}
.zr-lead {
  margin: 26px auto 0; max-width: 52ch; font-size: 1.12rem; line-height: 1.7;
  color: var(--zr-ink-dim);
}
.zr-lead strong { color: var(--zr-ink); font-weight: 600; }

/* „In Arbeit"-Hinweis im Hero: dezente Glas-Pille */
.zr-wip {
  display: inline-block; margin: 22px auto 0; padding: 8px 18px;
  border-radius: 999px; font-size: .88rem; line-height: 1.5;
  color: var(--zr-ink-dim); background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.14);
}

.zr-scrollcue {
  position: relative; z-index: 2; align-self: center; margin-top: 40px;
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  color: var(--zr-ink-dim); font-size: .8rem; letter-spacing: .22em; text-transform: uppercase;
}
.zr-scrollcue::after {
  content: ""; width: 1px; height: 56px;
  background: linear-gradient(180deg, var(--pink), transparent);
  animation: zrCue 2.2s ease-in-out infinite;
}
@keyframes zrCue { 0%,100% { opacity: .25; transform: scaleY(.6); transform-origin: top; } 50% { opacity: 1; transform: scaleY(1); } }

/* ── ZEITSTRAHL: S-Kurve durch den Hintergrund ───────────── */
.zr-tl {
  position: relative; padding: 26vh 0 0; /* Raum für den ersten Schwung des Strahls */
  /* dezentes Punktraster wie auf einer Sternkarte */
  background-image: radial-gradient(rgba(245,233,238,.05) 1px, transparent 1.2px);
  background-size: 28px 28px;
}
.zr-path {
  position: absolute; inset: 0; width: 100%; height: 100%;
  pointer-events: none; overflow: visible;
  /* Der Lichtstrahl läuft am Ende der Reise weich aus */
  -webkit-mask-image: linear-gradient(180deg, #000 0%, #000 86%, transparent 100%);
  mask-image: linear-gradient(180deg, #000 0%, #000 86%, transparent 100%);
}
.zr-path-base {
  fill: none; stroke: rgba(245,233,238,.08); stroke-width: 2;
}
/* 🚨 KEIN CSS filter:drop-shadow auf SVG-Pfaden — Safari (macOS+iOS) rendert
   ihn nicht zuverlässig → dort glühte gar nichts. Der Schein entsteht statt-
   dessen aus überlagerten, breiteren halbtransparenten Stroke-Kopien. */
.zr-path-glow {
  fill: none; stroke: url(#zrBeamGrad); stroke-width: 3; stroke-linecap: round;
  /* Gedimmter Grundstrahl: Hinter dem Leser verblasst die Spur — das volle
     Glühen sitzt in den Kopf-Segmenten direkt am Stern (Maximes Wunsch). */
  opacity: .5;
  /* Zeichnen steuert js/geschichte.js: y→Pfadlänge-Mapping an der
     Viewport-Position (die S-Kurve ist horizontal geschwungen — lineare
     Scroll-Animation würde der Seite voraus- oder hinterherlaufen). */
  stroke-dasharray: 1; stroke-dashoffset: 1;
}
/* Sanftes Dauerglühen der ganzen zurückgelegten Schlange */
.zr-path-halo {
  fill: none; stroke: url(#zrBeamGrad); stroke-width: 10; stroke-linecap: round;
  opacity: .12; stroke-dasharray: 1; stroke-dashoffset: 1;
}

/* ── KOMET: der Stern reist die Kurve entlang ─────────────── */
.zr-comet {
  position: absolute; top: 0; left: 0; width: 42px; height: 42px;
  z-index: 3; pointer-events: none; visibility: hidden;
  offset-rotate: 0deg;                 /* Stern bleibt aufrecht */
  /* offset-path = exakt der Strahl-Pfad; offset-distance steuert
     js/geschichte.js synchron zum Strahlkopf (y→Pfadlänge-Mapping). */
  offset-distance: 0%;
  filter: drop-shadow(0 0 10px rgba(216,49,138,.95)) drop-shadow(0 0 32px rgba(158,63,224,.55));
}
.zr-tl.has-path .zr-comet { visibility: visible; }
.zr-comet img { width: 100%; height: 100%; animation: zrCometSpin 16s linear infinite; }
@keyframes zrCometSpin { to { transform: rotate(360deg); } }

/* Heller werdender Verlauf zum Strahlkopf: zwei kurze Segmente direkt
   hinter dem Stern (außen weich, innen fast weiß) — Offsets steuert
   js/geschichte.js synchron zum Strahlkopf. Die große Gap (2) sorgt
   dafür, dass das Dash-Muster nicht am Pfadende erneut auftaucht. */
/* Glüh-Kegel am Stern: vier Stufen, alle enden am Kopf und beginnen
   unterschiedlich weit hinten — die Überlagerung steigt sanft an
   (kein abrupter Abbruch), s0 = heller Kern direkt am Stern.
   Gap ≥2 in jeder dasharray verhindert ein Echo am Pfadende. */
.zr-seg { fill: none; stroke: url(#zrBeamGrad); stroke-linecap: round; }
.zr-seg.s3 { stroke-width: 6;   opacity: .12; stroke-dasharray: 0.30 2; stroke-dashoffset: 0.30; }
.zr-seg.s2 { stroke-width: 8;   opacity: .16; stroke-dasharray: 0.16 2; stroke-dashoffset: 0.16; }
.zr-seg.s1 { stroke-width: 10;  opacity: .20; stroke-dasharray: 0.08 2; stroke-dashoffset: 0.08; }
.zr-seg.s0 { stroke-width: 4.5; opacity: .9;  stroke-dasharray: 0.03 2; stroke-dashoffset: 0.03; }

/* Schweif-Sternchen: sprühen entgegen der Scroll-Richtung vom Stern weg,
   sinken zum Schluss leicht ab (Funkenregen) und verglühen. Spawn +
   Drift-Richtung (--tx/--ty) setzt js/geschichte.js pro Partikel. */
.zr-trail-star {
  position: absolute; z-index: 2; pointer-events: none; user-select: none;
  left: 0; top: 0; line-height: 1; color: var(--c, #e8b34b);
  text-shadow: 0 0 7px currentColor, 0 0 18px currentColor;
  animation: zrTrail var(--dur, .95s) ease-out forwards;
  will-change: transform, opacity;
}
@keyframes zrTrail {
  0%   { opacity: 1; transform: translate(-50%, -50%) scale(1) rotate(0deg); }
  60%  { opacity: .85; transform: translate(calc(-50% + var(--tx) * .8), calc(-50% + var(--ty) * .9)) scale(.7) rotate(120deg); }
  100% { opacity: 0; transform: translate(calc(-50% + var(--tx)), calc(-50% + var(--ty) + 26px)) scale(.25) rotate(200deg); }
}

/* Station = ein Jahr. Geisterzahl + Marker + Inhaltskarte */
.zr-station { position: relative; padding: 13vh clamp(18px, 4vw, 48px) 9vh; }
.zr-year {
  position: absolute; top: 2vh; left: 50%; transform: translateX(-50%);
  font-family: var(--font-head); font-style: italic; font-weight: 700;
  font-size: clamp(7rem, 24vw, 19rem); line-height: 1;
  color: rgba(245,233,238,.07); -webkit-text-stroke: 1.5px rgba(245,233,238,.32);
  user-select: none; pointer-events: none; z-index: 0;
  animation: zrIgnite linear both;
  animation-timeline: view();
  animation-range: entry 0% cover 38%;
}
@keyframes zrIgnite {
  from { opacity: .12; filter: blur(3px); letter-spacing: .06em; }
  to   { opacity: .9;  filter: blur(0);  letter-spacing: 0; }
}
.zr-marker {
  position: absolute; left: 50%; top: 0; transform: translate(-50%,-50%);
  width: 18px; height: 18px; border-radius: 50%; z-index: 2;
  background: var(--zr-bg); border: 2px solid var(--era, var(--pink));
  animation: zrMarker linear both; animation-timeline: view();
  animation-range: entry 0% entry 30%;
}
@keyframes zrMarker {
  from { box-shadow: 0 0 0 0 transparent; background: var(--zr-bg); }
  to   { box-shadow: 0 0 22px 4px var(--era, var(--pink)); background: var(--era, var(--pink)); }
}

.zr-card { position: relative; z-index: 1; max-width: 980px; margin: 0 auto; padding-top: clamp(4rem, 12vw, 9rem); }
.zr-era-tag {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: .78rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase;
  color: var(--era, var(--pink)); margin-bottom: 14px;
}
.zr-era-tag::before { content: ""; width: 26px; height: 2px; background: var(--era, var(--pink)); box-shadow: 0 0 8px var(--era, var(--pink)); }
.zr-card h2 {
  font-family: var(--font-head); font-style: italic; font-weight: 700;
  font-size: clamp(1.9rem, 4.6vw, 3.1rem); line-height: 1.06; margin: 0 0 16px; color: #fff;
}
.zr-card .zr-text { max-width: 62ch; color: var(--zr-ink-dim); line-height: 1.75; font-size: 1.04rem; }
.zr-text strong { color: var(--zr-ink); font-weight: 600; }
.zr-note { font-size: .86rem; color: rgba(201,168,189,.6); font-style: italic; margin-top: 14px; }

/* Scroll-Reveal für Kartonelemente */
.zr-anim {
  animation: zrRise linear both; animation-timeline: view();
  animation-range: entry 0% entry 55%;
}
@keyframes zrRise { from { opacity: 0; transform: translateY(44px); } to { opacity: 1; transform: none; } }

/* ── FEATURE-FILM: Filmstreifen-Rahmen + Credit-Roll ─────── */
.zr-feature { display: grid; grid-template-columns: minmax(0, 1.5fr) minmax(220px, 1fr); gap: 28px; margin-top: 38px; align-items: stretch; }
.zr-screen {
  position: relative; border-radius: 14px; overflow: hidden;
  background: #000; padding: 0 26px;
  box-shadow: 0 24px 70px rgba(0,0,0,.55), 0 0 0 1px rgba(255,255,255,.07), 0 0 50px rgba(216,49,138,.14);
}
/* Perforation links/rechts wie ein 35mm-Streifen */
.zr-screen::before, .zr-screen::after {
  content: ""; position: absolute; top: 0; bottom: 0; width: 26px; z-index: 3;
  background:
    repeating-linear-gradient(180deg,
      transparent 0 9px, rgba(245,233,238,.16) 9px 17px, transparent 17px 26px);
  background-color: #0a0510;
}
.zr-screen::before { left: 0; } .zr-screen::after { right: 0; }
.zr-player { position: relative; aspect-ratio: 16 / 9; }
.zr-player iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }

/* Facade: Thumbnail + Play, iframe lädt erst beim Klick */
.zr-play {
  position: absolute; inset: 0; width: 100%; height: 100%;
  border: 0; padding: 0; cursor: pointer; display: block; background: #000;
}
.zr-play img { width: 100%; height: 100%; object-fit: cover; opacity: .82; transition: opacity .3s ease, transform .6s cubic-bezier(.2,.7,.2,1); }
.zr-play:hover img, .zr-play:focus-visible img { opacity: 1; transform: scale(1.03); }
.zr-play .zr-playbtn {
  position: absolute; inset: 0; margin: auto; width: 76px; height: 76px;
  border-radius: 50%; display: grid; place-items: center;
  background: rgba(20,10,26,.72); border: 1px solid rgba(255,255,255,.3);
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
  box-shadow: 0 0 34px rgba(216,49,138,.5);
  transition: transform .25s ease, box-shadow .25s ease;
}
.zr-play:hover .zr-playbtn, .zr-play:focus-visible .zr-playbtn { transform: scale(1.1); box-shadow: 0 0 50px rgba(216,49,138,.8); }
.zr-playbtn svg { width: 26px; height: 26px; fill: #fff; margin-left: 4px; }

/* Credit-Roll — Abspann neben der Leinwand */
.zr-credits {
  border: 1px solid rgba(255,255,255,.09); border-radius: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,.045) 0%, rgba(255,255,255,.015) 100%);
  padding: 24px 24px 18px; display: flex; flex-direction: column;
}
.zr-credits-head {
  font-size: .72rem; font-weight: 700; letter-spacing: .24em; text-transform: uppercase;
  color: var(--zr-gold); margin: 0 0 6px;
}
.zr-credits-film { font-family: var(--font-head); font-style: italic; font-size: 1.3rem; color: #fff; margin: 0 0 18px; line-height: 1.2; }
.zr-credit { padding: 9px 0; border-top: 1px solid rgba(255,255,255,.07); }
.zr-credit dt { font-size: .68rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--zr-ink-dim); margin: 0 0 2px; }
.zr-credit dd { margin: 0; font-family: var(--font-head); font-size: 1.06rem; color: var(--zr-ink); }
/* Credit-Zeilen rollen wie ein Abspann nacheinander hoch */
.zr-credits .zr-credit { animation: zrRise linear both; animation-timeline: view(); }
.zr-credits .zr-credit:nth-child(odd)  { animation-range: entry 10% entry 60%; }
.zr-credits .zr-credit:nth-child(even) { animation-range: entry 20% entry 70%; }
.zr-credits-foot { margin-top: auto; padding-top: 14px; font-size: .82rem; color: rgba(201,168,189,.55); }

/* Weitere Filme des Jahres */
.zr-films { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 22px; }
.zr-film {
  position: relative; border-radius: 12px; overflow: hidden; cursor: pointer;
  border: 1px solid rgba(255,255,255,.08); background: #000; padding: 0; text-align: left;
  transition: transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease, border-color .35s ease;
}
.zr-film:hover, .zr-film:focus-visible { transform: translateY(-5px); border-color: rgba(216,49,138,.55); box-shadow: 0 16px 44px rgba(0,0,0,.5), 0 0 30px rgba(216,49,138,.22); }
.zr-film img { width: 100%; aspect-ratio: 16/9; object-fit: cover; display: block; opacity: .8; transition: opacity .3s ease; }
.zr-film:hover img { opacity: 1; }
.zr-film-meta { padding: 12px 14px 14px; background: linear-gradient(180deg, rgba(255,255,255,.03), transparent); }
.zr-film-title { display: block; font-family: var(--font-head); font-style: italic; font-size: 1.02rem; color: var(--zr-ink); line-height: 1.25; }
.zr-film-credit { display: block; margin-top: 4px; font-size: .8rem; color: var(--zr-ink-dim); }

/* ── 2015: Konstellation der Städte ───────────────────────── */
.zr-cities { display: flex; flex-wrap: wrap; gap: 10px 12px; margin-top: 30px; max-width: 760px; }
.zr-city {
  padding: 8px 16px; border-radius: 999px; font-size: .92rem; font-weight: 600;
  color: var(--zr-ink); border: 1px solid rgba(158,63,224,.4);
  background: rgba(158,63,224,.10);
  box-shadow: 0 0 14px rgba(158,63,224,.14), inset 0 0 12px rgba(158,63,224,.06);
  animation: zrTwinkle linear both; animation-timeline: view();
  animation-range: entry 0% entry 70%;
}
.zr-city.is-more { border-style: dashed; color: var(--zr-ink-dim); background: transparent; box-shadow: none; }
@keyframes zrTwinkle { from { opacity: 0; transform: translateY(14px) scale(.92); } to { opacity: 1; transform: none; } }
.zr-stat { display: flex; gap: clamp(20px, 6vw, 64px); margin-top: 34px; }
.zr-stat b { display: block; font-family: var(--font-head); font-style: italic; font-size: clamp(2.2rem, 5vw, 3.4rem); color: #fff; line-height: 1; text-shadow: 0 0 30px var(--era, var(--lila)); }
.zr-stat span { display: block; margin-top: 6px; font-size: .8rem; letter-spacing: .16em; text-transform: uppercase; color: var(--zr-ink-dim); }

/* ── ARCHIV: dynamische Mini-Stationen (js/geschichte.js) ──
   Echte historische Termine aus der DB — kleinerer Geister-
   Jahrgang, Era-Marker, kompakte Termin-Karten im Raster. */
.zr-mini { padding: 9vh clamp(18px, 4vw, 48px) 6vh; }
.zr-mini .zr-year { font-size: clamp(3.4rem, 12vw, 9.5rem); /* ~50% der großen Jahre */ }
.zr-mini .zr-card { padding-top: clamp(3rem, 9vw, 5.5rem); }

/* Dezenter Zähler neben der Geister-Jahreszahl */
.zr-year-count {
  margin-left: clamp(10px, 2vw, 22px);
  font-family: var(--font-body); font-style: normal; font-weight: 600;
  font-size: .82rem; letter-spacing: .22em; text-transform: uppercase;
  color: rgba(201,168,189,.8); -webkit-text-stroke: 0;
  white-space: nowrap;
}

/* Raster der Termin-Karten — Mobile einspaltig */
.zr-mini-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 14px; margin-top: 18px;
}

/* Eine Karte pro Termin: Datum, Titel, Ort, Quelle —
   Optik zwischen .zr-city-Chip und .zr-credits */
.zr-mini-card {
  /* min-width:0: Grid-Items haben sonst min-width:auto — die Kino-Bühnen-
     Filmleiste blähte die Karte auf >2000px auf (Handy: Seite riesig/zoombar) */
  min-width: 0; max-width: 100%;
  position: relative; border-radius: 12px; padding: 14px 16px 13px;
  border: 1px solid rgba(255,255,255,.10);
  border-color: color-mix(in srgb, var(--era, var(--pink)) 30%, rgba(255,255,255,.10));
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.012));
  box-shadow: 0 0 14px rgba(0,0,0,.25);
  box-shadow: 0 0 14px color-mix(in srgb, var(--era, var(--pink)) 10%, transparent),
              inset 0 0 14px color-mix(in srgb, var(--era, var(--pink)) 5%, transparent);
}
.zr-mini-date {
  margin: 0 0 6px; font-size: .7rem; font-weight: 700;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--era, var(--pink));
}
.zr-mini-title {
  margin: 0; font-family: var(--font-head); font-style: italic; font-weight: 700;
  font-size: 1.05rem; line-height: 1.25; color: #fff;
}
.zr-mini-place { margin: 4px 0 0; font-size: .85rem; color: var(--zr-ink-dim); }
.zr-mini-src {
  display: inline-block; margin-top: 10px; font-size: .78rem;
  color: rgba(201,168,189,.65);
  text-decoration: underline dotted; text-underline-offset: 3px;
  transition: color .2s ease;
}
.zr-mini-src:hover, .zr-mini-src:focus-visible { color: #fff; }

/* Verzahnung: Link vom Zeitreise-Termin zum Kalender (gleicher Termin dort) */
.zr-mini-cal {
  display: inline-block; margin: 10px 12px 0 0; font-size: .78rem;
  color: rgba(201,168,189,.65);
  text-decoration: underline dotted; text-underline-offset: 3px;
  transition: color .2s ease;
}
.zr-mini-cal:hover, .zr-mini-cal:focus-visible { color: #fff; }

/* Kollisions-Jahre (2024, 2015): kompakte Liste IN der großen Karte */
.zr-mini-block { margin-top: 42px; border-top: 1px solid rgba(255,255,255,.08); padding-top: 24px; }
.zr-mini-head {
  margin: 0; display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap;
  font-size: .72rem; font-weight: 700; letter-spacing: .24em;
  text-transform: uppercase; color: var(--zr-gold);
}
.zr-mini-headcount { color: var(--zr-ink-dim); font-weight: 600; letter-spacing: .16em; }

/* ── 1999: Ursprung / Abspann der Reise ──────────────────── */
.zr-origin { text-align: center; padding-bottom: 16vh; }
.zr-origin .zr-card { max-width: 760px; }
.zr-motto {
  margin: 36px auto 0; padding: 0; border: 0; max-width: 30ch;
  font-family: var(--font-head); font-style: italic; font-weight: 700;
  font-size: clamp(1.5rem, 3.6vw, 2.3rem); line-height: 1.35; color: #fff;
  text-shadow: 0 0 50px rgba(232,179,75,.4);
}
.zr-motto footer { margin-top: 18px; font-family: var(--font-body); font-style: normal; font-weight: 400; font-size: .92rem; color: var(--zr-ink-dim); }

/* ── CTA: das wachsende Archiv ────────────────────────────── */
.zr-cta {
  position: relative; margin: 0 clamp(18px, 4vw, 48px) 90px; padding: clamp(32px, 6vw, 56px);
  max-width: 980px; border-radius: 18px; text-align: center;
  background:
    radial-gradient(120% 160% at 50% -20%, rgba(216,49,138,.18) 0%, transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.015));
  border: 1px solid rgba(255,255,255,.1);
}
@media (min-width: 1080px) { .zr-cta { margin-left: auto; margin-right: auto; } }
.zr-cta h2 { font-family: var(--font-head); font-style: italic; font-size: clamp(1.7rem, 4vw, 2.5rem); margin: 0 0 12px; color: #fff; }
.zr-cta p { max-width: 56ch; margin: 0 auto; color: var(--zr-ink-dim); line-height: 1.7; }
.zr-cta-btn {
  display: inline-block; margin-top: 24px; padding: 17px 44px; border-radius: 999px;
  font-weight: 700; font-size: 1.08rem; letter-spacing: .01em; text-decoration: none; color: #fff;
  background: linear-gradient(120deg, var(--pink), var(--lila));
  box-shadow: 0 14px 44px rgba(216,49,138,.5);
  transition: transform .25s ease, box-shadow .25s ease;
}
.zr-cta-btn:hover { transform: translateY(-2px); box-shadow: 0 18px 52px rgba(216,49,138,.65); }

/* Flagge in der Archiv-Karte: klein, neben dem Datum */
.zr-mini-flag {
  display: inline-block; width: 18px; height: auto; vertical-align: -2px;
  margin-right: 7px; border-radius: 2px;
  box-shadow: 0 0 0 1px rgba(245,233,238,.22);
}

/* ── MEDIEN an den Archiv-Karten (kabaret_media) ───────────
   4-Foto-Galerie + Filme: bis 4 als ruhige Reihe, ab 5 als
   durchlaufender Filmstreifen (Marquee, Hover pausiert). */
.zr-mini-gallery { display: grid; gap: 6px; margin-top: 12px; grid-template-columns: repeat(2, 1fr); }
.zr-mini-gallery.zr-g1 { grid-template-columns: 1fr; }
.zr-mini-gallery.zr-g3 .zr-gal-item:first-child { grid-column: 1 / -1; }
.zr-gal-item {
  display: block; padding: 0; border: 0; cursor: zoom-in;
  border-radius: 8px; overflow: hidden; aspect-ratio: 3 / 2;
  background: rgba(255,255,255,.05);
  outline-offset: 2px;
}
.zr-gal-item img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  filter: saturate(.92) contrast(1.02);
  transition: transform .35s ease, filter .35s ease;
}
.zr-gal-item:hover img, .zr-gal-item:focus-visible img { transform: scale(1.04); filter: saturate(1.05); }

/* Plakate von damals — kleine Papier-Reihe, leicht gekippt, Klick = Lightbox */
.zr-plakate { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 12px; }
.zr-plakat {
  display: block; flex: 0 0 auto; width: 86px; aspect-ratio: 2 / 3;
  padding: 0; border: 1px solid rgba(255,255,255,.18); border-radius: 4px;
  overflow: hidden; cursor: zoom-in; background: rgba(255,255,255,.06);
  box-shadow: 0 3px 10px rgba(0,0,0,.35);
  transform: rotate(-1.2deg);
  transition: transform .3s ease, box-shadow .3s ease;
  outline-offset: 2px;
}
.zr-plakat:nth-child(2n) { transform: rotate(1.4deg); }
.zr-plakat img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  filter: saturate(.9) contrast(1.03);
}
.zr-plakat:hover, .zr-plakat:focus-visible {
  transform: rotate(0deg) scale(1.07);
  box-shadow: 0 8px 22px rgba(0,0,0,.45);
  position: relative; z-index: 5;
}
/* Desktop (echte Maus): Plakat ist zunächst UNSICHTBAR und nimmt keinen Platz
   weg (Text volle Breite). Es poppt erst groß auf, wenn die Maus über das
   KABARET (die ganze Karte) fährt — nicht nur über das Plakat (Maxime 15.06.).
   Origin oben-links: wächst in die Karte hinein statt aus dem Viewport.
   Höhere Spezifität (.zr-mini-card …) überschreibt den Touch-Float weiter unten.
   🚨 NUR (hover:hover) — NICHT zusätzlich (pointer:fine)! Hybrid-Geräte
   (Touchscreen-Laptop, iPad+Maus) melden oft pointer:coarse und fielen sonst
   raus → Plakat blieb dort sichtbar (Maxime 15.06.: „auf beiden zu sehen").
   Reine Touch-Geräte (hover:none) bekommen unten den dezenten Tipp-Pin. */
@media (hover: hover) {
  .zr-mini-card .zr-plakate-side {
    position: absolute; top: 6px; left: 12px; margin: 0; float: none; z-index: 6;
    pointer-events: none;
  }
  .zr-mini-card .zr-plakate-side .zr-plakat {
    width: 118px; transform-origin: top left;
    opacity: 0; visibility: hidden;
    transform: rotate(-1.2deg) scale(.72);
    transition: opacity .26s ease, visibility .26s,
                transform .34s cubic-bezier(.2,.8,.25,1), box-shadow .3s ease;
  }
  /* Trigger NUR der Titel — nicht die ganze Karte. Sonst poppt das Plakat
     schon beim Hover über den Vimeo-Player auf und verdeckt den Play-Button
     (Maxime 15.06.). pointer-events bleibt none (s.o.), damit der Titel-Hover
     beim Aufpoppen nicht abbricht (kein Flackern) und der Player frei bleibt. */
  .zr-mini-card:has(.zr-mini-title:hover) .zr-plakate-side .zr-plakat {
    opacity: 1; visibility: visible;
    transform: rotate(0deg) scale(2.2);
    box-shadow: 0 22px 54px rgba(0,0,0,.7);
  }
}

/* Plakat LINKS neben dem Eintrag (float links) — Flagge/Datum/Titel/Ort fließen
   rechts daneben (Dave 14.06.). Beide Orientierungen: feste Breite, Höhe folgt
   dem Bild (kein 2:3-Zwang → Quer-Plakate werden nicht mehr zu Hochkant
   gequetscht). Kein Plakat → kein Float → Text nutzt volle Breite (keine
   leeren Felder, Karte nicht aufgebläht). */
/* Plakat sitzt an der oberen LINKEN Kartenkante (negative Margins gleichen das
   Karten-Padding 14px/16px aus) — wirkt angeheftet statt „reingedrückt" (Maxime
   14.06.). Leicht gekippt + Schatten = Papier auf der Ecke. */
.zr-plakate-side { float: left; margin: -14px 14px 8px -16px; }
.zr-plakate-side .zr-plakat { width: 96px; aspect-ratio: auto; border-radius: 4px; }
.zr-plakate-side .zr-plakat img { height: auto; object-fit: contain; }
/* Touch (kein Hover): kein „Aufpoppen" möglich → Plakat als kleiner, dezenter
   Eck-Pin (statt großer 96px-Kachel). Antippen öffnet die große Ansicht
   (Lightbox). So bleibt die Zeitreise auch am Handy aufgeräumt, das Plakat ist
   aber per Tipp erreichbar (Maxime 15.06.). 52px = bequemes Tap-Ziel. */
@media (hover: none) {
  .zr-plakate-side { margin: -6px 12px 4px -8px; }
  .zr-plakate-side .zr-plakat { width: 52px; box-shadow: 0 2px 8px rgba(0,0,0,.4); }
}
/* Galerie/Filmbühne starten unter dem Plakat-Float (nicht daneben) */
.zr-mini-gallery, .zr-mcin { clear: both; }
/* Quick-Look (Desktop) wächst nach rechts in die Karte — base transform-origin
   (left center) passt bereits, da das Plakat jetzt am linken Rand sitzt. */

/* Film-Thumbnail: Bild + Play-Glyphe + Titel-Schleier */
.zr-filmthumb {
  position: relative; flex: 0 0 auto; width: 138px; aspect-ratio: 16 / 9;
  padding: 0; border: 1px solid rgba(255,255,255,.12); border-radius: 8px;
  overflow: hidden; cursor: pointer; background: rgba(255,255,255,.05);
}
.zr-filmthumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.zr-filmthumb-play {
  position: absolute; inset: 0; display: grid; place-items: center;
  font-size: 1.05rem; color: #fff;
  background: radial-gradient(60% 60% at 50% 50%, rgba(10,4,8,.45), rgba(10,4,8,.12));
  text-shadow: 0 0 12px rgba(0,0,0,.8);
  transition: background .25s ease, transform .25s ease;
}
.zr-filmthumb:hover .zr-filmthumb-play { background: radial-gradient(60% 60% at 50% 50%, rgba(216,49,138,.5), rgba(10,4,8,.15)); }
.zr-filmthumb-title {
  position: absolute; left: 0; right: 0; bottom: 0; padding: 10px 7px 4px;
  font-size: .62rem; font-weight: 600; line-height: 1.25; color: rgba(255,255,255,.92);
  text-align: left; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  background: linear-gradient(180deg, transparent, rgba(8,3,6,.85));
}
.zr-films-row { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px; }

/* ── KINO-BÜHNE an Jahres-Kabarets mit vielen Filmen ───────
   Design der 2024er-Station: großer Player + Info-Spalte rechts,
   darunter eine horizontal scrollbare Filmleiste (kein Auto-Marquee). */
.zr-mini-card.zr-mini-cinema { grid-column: 1 / -1; }
.zr-mcin {
  display: grid; grid-template-columns: 1.7fr 1fr;
  gap: clamp(14px, 2.5vw, 26px); margin-top: 16px; align-items: start;
}
.zr-mcin-screen { min-width: 0; }
.zr-mcin .zr-player { aspect-ratio: 16 / 9; }
.zr-mcin-side { min-width: 0; }
.zr-mcin-meta {
  margin: 6px 0 0; font-size: .78rem; letter-spacing: .08em;
  text-transform: uppercase; color: var(--zr-ink-dim);
}
.zr-mcin-credits { margin-top: 12px; }
/* Original-Abspann (Vimeo-Beschreibung) — Zeilenumbrüche erhalten, scrollt bei Überlänge */
.zr-mcin-desc {
  margin: 0; white-space: pre-line; font-size: .85rem; line-height: 1.6;
  color: var(--zr-ink-dim); max-height: 300px; overflow-y: auto;
  scrollbar-width: thin; scrollbar-color: rgba(216,49,138,.5) transparent;
}
.zr-mcin-strip {
  display: flex; gap: 8px; margin-top: 14px;
  overflow-x: auto; padding-bottom: 8px;
  scroll-snap-type: x proximity; -webkit-overflow-scrolling: touch;
  scrollbar-width: thin; scrollbar-color: rgba(216,49,138,.5) transparent;
}
.zr-mcin-strip .zr-filmthumb { flex: 0 0 auto; width: 150px; scroll-snap-align: start; }
/* Pfeile + Leiste in einer Zeile — Pfeile dimmen an den Enden */
.zr-mcin-stripwrap { display: flex; align-items: center; gap: 8px; margin-top: 14px; min-width: 0; }
.zr-mcin-stripwrap .zr-mcin-strip { margin-top: 0; flex: 1 1 auto; min-width: 0; }
.zr-strip-arrow {
  flex: 0 0 auto; width: 38px; height: 38px; border-radius: 50%;
  border: 1px solid rgba(255,255,255,.22); background: rgba(255,255,255,.06);
  color: #fff; font-size: 1.3rem; line-height: 1; cursor: pointer;
  transition: background .2s ease, opacity .2s ease;
}
.zr-strip-arrow:hover:not(:disabled) { background: rgba(216,49,138,.45); }
.zr-strip-arrow:disabled { opacity: .22; cursor: default; }
/* Leiste passt komplett (1-4 Filme) → Pfeile ganz weg statt ausgegraut */
.zr-mcin-stripwrap.zr-no-scroll .zr-strip-arrow { display: none; }

.zr-mcin-strip .zr-filmthumb.is-active {
  outline: 2px solid var(--pink); outline-offset: 2px;
}
@media (max-width: 880px) {
  .zr-mcin { grid-template-columns: 1fr; }
}

/* Marquee: Spur enthält die Filme doppelt → Loop bei -50% ist nahtlos */
.zr-strip { margin-top: 12px; overflow: hidden; border-radius: 8px;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent); }
.zr-strip-track { display: flex; gap: 8px; width: max-content; animation: zrStrip linear infinite; }
.zr-strip:hover .zr-strip-track, .zr-strip:focus-within .zr-strip-track { animation-play-state: paused; }
@keyframes zrStrip { to { transform: translateX(calc(-50% - 4px)); } }
@media (prefers-reduced-motion: reduce) { .zr-strip-track { animation: none !important; flex-wrap: wrap; width: auto; } }

/* Lightbox: dunkles Vollbild-Overlay für Fotos + Vimeo-Player */
.zr-lightbox {
  position: fixed; inset: 0; z-index: 80; display: none;
  background: rgba(8, 3, 6, .92); backdrop-filter: blur(6px);
  padding: clamp(14px, 4vw, 48px);
}
.zr-lightbox.open { display: grid; place-items: center; }
.zr-lightbox-inner { position: relative; width: min(960px, 100%); }
.zr-lightbox-stage { display: grid; place-items: center; }
.zr-lightbox-img { max-width: 100%; max-height: 78vh; border-radius: 10px; box-shadow: 0 30px 90px rgba(0,0,0,.7); }
.zr-lightbox-img--clickable { cursor: pointer; }
/* Blätter-Pfeile (nur im Galerie-Modus mit >1 Bild sichtbar) */
.zr-lightbox-nav { display: none; }
.zr-lightbox.has-gallery .zr-lightbox-nav {
  display: grid; place-items: center; position: absolute; top: 39vh;
  transform: translateY(-50%); width: 46px; height: 46px; z-index: 2;
  border: 1px solid rgba(255,255,255,.25); border-radius: 999px;
  background: rgba(8,3,6,.55); color: #fff; font-size: 1.7rem; line-height: 1;
  cursor: pointer; transition: background .2s ease, transform .2s ease;
}
.zr-lb-prev { left: -8px; }
.zr-lb-next { right: -8px; }
.zr-lightbox.has-gallery .zr-lightbox-nav:hover {
  background: rgba(216,49,138,.5); transform: translateY(-50%) scale(1.08);
}
@media (max-width: 560px) {
  .zr-lb-prev { left: 2px; }
  .zr-lb-next { right: 2px; }
}
.zr-lightbox-video { width: 100%; aspect-ratio: 16 / 9; border: 0; border-radius: 10px; box-shadow: 0 30px 90px rgba(0,0,0,.7); background: #000; }
.zr-lightbox-caption { margin: 12px 4px 0; min-height: 1.2em; font-size: .88rem; color: var(--zr-ink-dim); text-align: center; }
.zr-lightbox-close {
  position: absolute; top: -46px; right: 0; width: 36px; height: 36px;
  border: 1px solid rgba(255,255,255,.25); border-radius: 999px;
  background: rgba(255,255,255,.06); color: #fff; font-size: .95rem; cursor: pointer;
  transition: background .2s ease, transform .2s ease;
}
.zr-lightbox-close:hover { background: rgba(216,49,138,.4); transform: rotate(90deg); }

/* ── Fallback: Browser ohne Scroll-Driven Animations ─────── */
@supports not (animation-timeline: view()) {
  .zr-anim, .zr-year, .zr-marker, .zr-city, .zr-credits .zr-credit {
    animation: none; opacity: 0; transform: translateY(36px);
    transition: opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1);
  }
  .zr-year { transform: translateX(-50%) translateY(20px); }
  .in-view .zr-anim, .in-view.zr-anim,
  .in-view .zr-city, .in-view .zr-credit { opacity: 1; transform: none; }
  .in-view .zr-year { opacity: .9; transform: translateX(-50%); }
  .in-view .zr-marker { opacity: 1; transform: translate(-50%,-50%); background: var(--era, var(--pink)); box-shadow: 0 0 22px 4px var(--era, var(--pink)); }
  .zr-marker { transform: translate(-50%,-50%); }
}
@media (prefers-reduced-motion: reduce) {
  .zr-grain, .zr-hero-beam, .zr-scrollcue::after { animation: none; }
  .zr-anim, .zr-year, .zr-marker, .zr-city, .zr-credits .zr-credit {
    animation: none !important; transition: none !important;
    opacity: 1 !important; transform: none !important;
  }
  .zr-year { transform: translateX(-50%) !important; opacity: .7 !important; }
  .zr-marker { transform: translate(-50%,-50%) !important; }
  .zr-path-glow { animation: none !important; stroke-dashoffset: 0 !important; }
  .zr-comet, .zr-seg, .zr-path-halo, .zr-trail-star { display: none !important; }
  .zr-path-glow { opacity: 1 !important; }
}

/* ── RESPONSIVE ───────────────────────────────────────────── */
@media (max-width: 880px) {
  .zr-year { left: 56%; width: 100%; text-align: center; font-size: clamp(5rem, 26vw, 9rem); }
  .zr-marker { left: 22px; }
  .zr-station { padding-left: 52px; padding-right: 20px; }
  .zr-card { padding-top: clamp(3rem, 18vw, 6rem); }
  .zr-feature { grid-template-columns: 1fr; }
  .zr-films { grid-template-columns: 1fr 1fr; }
  .zr-screen { padding: 0 18px; }
  .zr-screen::before, .zr-screen::after { width: 18px; }
}
@media (max-width: 560px) {
  .zr-films { grid-template-columns: 1fr; }
  .zr-stat { flex-wrap: wrap; gap: 18px 32px; }
  .zr-mini-grid { grid-template-columns: 1fr; }
  .zr-year-count { display: block; margin: 6px 0 0; }
}

/* ── Film-Credits im Lightbox (Abspann-OCR, film_credits) ─────────────── */
.zr-filmcredits {
  margin: 14px auto 0; max-width: 640px; text-align: left;
  display: grid; grid-template-columns: auto 1fr; gap: 4px 14px;
  font-size: .82rem; color: var(--zr-ink-dim);
}
.zr-filmcredits dt {
  font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
  font-size: .72rem; color: rgba(255,255,255,.55); align-self: baseline;
  padding-top: .12em;
}
.zr-filmcredits dd { margin: 0; color: rgba(255,255,255,.85); }
