:root {
    --ink: #141414;
    --paper: #ffffff;
    --bg-base: #0d0d0d;
    --bg-soft: #1a1a1a;
    --bg-warm: #000000;
    --yellow: #ffd400;
    --pink: #e3261d;
    --line: #141414;
    --soft: rgba(255,255,255,.26);
    --shadow: 0 24px 70px rgba(17, 16, 15, .25);
    --radius: 28px;
    --content-max: 1500px;            /* einheitliche max. Inhaltsbreite (waechst bis hierhin mit) */
    --gutter: clamp(18px, 4vw, 72px);  /* einheitlicher Seitenabstand */
}

* { box-sizing: border-box; }

html {
    scroll-behavior: smooth;
    /* Sprungziele nicht unter den sticky Header (74px) schieben */
    scroll-padding-top: 92px;
}

body {
    margin: 0;
    min-width: 320px;
    color: var(--ink);
    font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    background: var(--paper);
    overflow-x: hidden;
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -2;
    background:
        linear-gradient(180deg, rgba(0, 0, 0, .82) 0%, rgba(0, 0, 0, .80) 55%, rgba(0, 0, 0, .62) 100%),
        var(--skyline-image, url("../img/bg-hamburg-skyline.webp")) center var(--skyline-y, bottom) / cover no-repeat,
        linear-gradient(135deg, #0a0a0a 0%, #161616 52%, #000000 100%);
}

body.background-up-half { --skyline-y: 45%; }

body::after {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    background:
        radial-gradient(circle at 16% 20%, rgba(255, 43, 191, .16), transparent 24rem),
        radial-gradient(circle at 78% 14%, rgba(2, 231, 255, .18), transparent 20rem),
        linear-gradient(180deg, rgba(255,255,255,.04), rgba(0,0,0,.18));
    mix-blend-mode: screen;
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 50;
    height: 140px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 28px;
    border: 4px solid var(--line);
    border-top: 0;
    border-radius: 0 0 12px 12px;
    background: rgba(246,243,239,.97);
    backdrop-filter: blur(10px);
}

.logo {
    height: 100%;
    padding: 8px 0;
    display: flex;
    align-items: center;
}

.logo img {
    height: 100%;
    width: auto;
    max-width: 100%;
    display: block;
    object-fit: contain;
}

.main-nav {
    display: flex;
    align-items: center;
    gap: 30px;
    text-transform: uppercase;
    font-size: 15px;
    font-weight: 900;
    letter-spacing: .04em;
}

.main-nav a {
    color: var(--ink);
    text-decoration: none;
}

.nav-pill {
    padding: 10px 22px;
    border: 3px solid var(--line);
    border-radius: 999px;
    background: var(--yellow);
    box-shadow: 0 2px 0 var(--line);
}

.nav-toggle {
    display: none;
    width: 44px;
    height: 38px;
    border: 3px solid var(--line);
    border-radius: 10px;
    background: var(--yellow);
}

.nav-toggle span {
    display: block;
    width: 22px;
    height: 3px;
    margin: 4px auto;
    background: var(--ink);
}

/* Marken-Auftakt: großes, beleuchtetes Logo über dem Hero */
.brand-stage {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: clamp(8px, 2vw, 22px) var(--gutter) clamp(2px, 0.6vw, 8px);
}
.brand-stage::before {
    content: "";
    position: absolute;
    inset: -10% 0 auto 0;
    height: 220%;
    background: radial-gradient(58% 80% at 50% 28%, rgba(255, 212, 0, .22), rgba(255, 212, 0, .06) 45%, transparent 72%);
    pointer-events: none;
    z-index: -1;
}
.brand-stage-logo {
    width: min(760px, 94vw);
    height: auto;
    display: block;
    border-radius: 16px;
    filter:
        drop-shadow(0 10px 30px rgba(0, 0, 0, .7))
        drop-shadow(0 0 1px rgba(255, 212, 0, .6));
}

.hero {
    display: grid;
    grid-template-columns: minmax(380px, 1.08fr) minmax(390px, .92fr);
    gap: clamp(24px, 4vw, 68px);
    align-items: start;
    padding: clamp(4px, 1vw, 12px) clamp(24px, 5vw, 96px) 64px;
    border-bottom: 3px solid var(--line);
}

.hero-art {
    position: relative;
    min-height: 660px;
    transform: translate(258px, 92px);
}

.coming {
    position: relative;
    z-index: 3;
    margin: 0 0 8px 7%;
    font-family: Anton, Impact, sans-serif;
    font-size: clamp(52px, 6.4vw, 96px);
    line-height: .95;
    letter-spacing: .03em;
}

.card-stack {
    position: relative;
    height: 610px;
    min-height: 560px;
}

.photo-card {
    position: relative;
    margin: 0;
    aspect-ratio: 4 / 5;
    border: 3px solid var(--line);
    border-radius: 16px;
    background: #111;
    overflow: hidden;
    box-shadow: var(--shadow);
}

.photo-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.photo-ribbon {
    position: absolute;
    z-index: 5;
    min-height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 8px 24px;
    border: 3px solid var(--line);
    font-size: clamp(14px, 1.25vw, 22px);
    font-weight: 1000;
    line-height: 1.05;
    letter-spacing: .02em;
    text-align: center;
    text-transform: uppercase;
    overflow-wrap: anywhere;
    box-shadow: 0 4px 0 var(--line);
}

.ribbon-color-yellow { background: var(--yellow); color: var(--ink); }
.ribbon-color-pink { background: #e6328c; color: #fff; }
.ribbon-color-cyan { background: #02e7ff; color: var(--ink); }

.ribbon-top-third,
.ribbon-bottom-third {
    left: -12px;
    right: -12px;
    transform: rotate(0deg);
}
.ribbon-top-third { top: 33%; }
.ribbon-bottom-third { bottom: 33%; }
.ribbon-corner {
    width: 78%;
    transform: rotate(35deg);
}
.ribbon-corner.ribbon-top-left { top: 34px; left: -72px; transform: rotate(-35deg); }
.ribbon-corner.ribbon-top-right { top: 34px; right: -72px; transform: rotate(35deg); }
.ribbon-corner.ribbon-bottom-left { bottom: 34px; left: -72px; transform: rotate(35deg); }
.ribbon-corner.ribbon-bottom-right { bottom: 34px; right: -72px; transform: rotate(-35deg); }

.photo-card.is-cancelled {
    z-index: 7;
}

/* Karten-Positionen, "Deal"-Animationen und die zugehörigen Keyframes
   wurden entfernt – das v24-Layout zeigt die Karten statisch im Fluss. */

.hero-copy {
    position: relative;
    min-height: 520px;
    display: flex;
    align-items: center;
    transform: translateY(130px);
}

.hero-copy::before,
.hero-copy::after {
    content: "";
    position: absolute;
    border: 3px solid rgba(17,16,15,.42);
    background: rgba(255, 248, 233, .64);
    box-shadow: 0 30px 90px rgba(0,0,0,.42), inset 0 0 0 3px rgba(255,255,255,.28), inset 0 0 0 6px rgba(17,16,15,.14);
    backdrop-filter: blur(9px) saturate(1.18);
}

.hero-copy::before {
    inset: 8px 3% 22px -8%;
}

.hero-copy::after {
    inset: 76px 9% 76px 1%;
}

.copy-panel {
    position: relative;
    z-index: 2;
    width: min(700px, 100%);
    margin-inline: auto;
    text-align: center;
    padding: clamp(28px, 4vw, 48px);
}

.sticker {
    display: inline-block;
    margin-bottom: 30px;
    padding: 7px 18px;
    border: 3px solid var(--line);
    border-radius: 7px;
    background: var(--yellow);
    font-size: clamp(16px, 1.45vw, 26px);
    font-weight: 800;
    letter-spacing: .05em;
    transform: rotate(-2deg);
}

h1, h2, h3, p { margin-top: 0; }

h1, h2 {
    font-family: Anton, Impact, sans-serif;
    font-weight: 400;
    letter-spacing: .035em;
}

h1 {
    margin-bottom: 24px;
    font-size: clamp(42px, 5.5vw, 76px);
    line-height: .98;
}

.copy-panel p {
    margin-inline: auto;
    max-width: 720px;
    font-size: clamp(16px, 1.45vw, 24px);
    line-height: 1.42;
    font-weight: 700;
}

.facts {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    margin: 28px auto 24px;
    max-width: 690px;
}

.facts span,
.small-pill {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 8px 18px;
    border: 3px solid var(--line);
    border-radius: 999px;
    background: rgba(246,243,239,.95);
    font-size: 14px;
    font-weight: 900;
    text-transform: uppercase;
    box-shadow: 0 2px 0 var(--line);
}

.hero-button,
.sticky-cta a,
.mini-button,
.outline-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    color: var(--ink);
    font-weight: 900;
}

.hero-button {
    width: min(640px, 100%);
    min-height: 72px;
    padding: 14px 34px;
    border: 5px solid var(--line);
    border-radius: 999px;
    background: var(--yellow);
    box-shadow: 0 7px 0 var(--line);
    font-size: clamp(18px, 1.5vw, 24px);
    line-height: 1.15;
    text-align: center;
    transition: transform .18s ease, box-shadow .18s ease;
}

.hero-button:hover,
.nav-pill:hover,
.mini-button:hover,
.outline-button:hover,
.sticky-cta a:hover {
    transform: translateY(2px);
    box-shadow: 0 3px 0 var(--line);
}

.section {
    padding: clamp(56px, 8vw, 110px) clamp(24px, 6vw, 120px);
    background: var(--paper);
}

.section-head {
    max-width: 920px;
    margin-bottom: 34px;
}

.section-head h2,
.press-box h2 {
    margin: 18px 0 12px;
    font-size: clamp(38px, 5vw, 78px);
    line-height: .98;
}

.section-head p,
.press-box p {
    font-size: clamp(17px, 1.5vw, 23px);
    line-height: 1.5;
    font-weight: 700;
}

.review-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 22px;
}

.review-card,
.date-row,
.press-box {
    border: 4px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    box-shadow: 8px 8px 0 var(--line);
}

.review-card {
    padding: 28px;
}

.stars {
    margin-bottom: 18px;
    color: var(--pink);
    font-size: 22px;
    letter-spacing: .1em;
}

.review-card p {
    font-size: 18px;
    line-height: 1.48;
    font-weight: 700;
    overflow-wrap: anywhere;
    word-break: break-word;
    hyphens: auto;
}

.date-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(520px, 1fr));
    gap: 20px;
}

.date-row {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 24px;
}
.date-topbar { order: 1; display: flex; justify-content: space-between; align-items: center; gap: 12px 18px; flex-wrap: wrap; }
.date-topbar .date-when { order: 0; }
.date-topbar-ticket { flex: 0 0 auto; order: 1; }
.date-row h3 { order: 2; }
.date-media { order: 3; align-self: center; margin: 6px 0 2px; }
/* Kleine Bildschirme (Handy): Termine einzeln untereinander, volle Breite (kein 520px-Mindestmaß) */
@media (max-width: 700px) {
    /* minmax(0,1fr) statt 1fr: Spalte darf unter die Inhaltsbreite schrumpfen,
       sonst zwingt die 322px-Medienbox die Karte über die Bildschirmbreite (Überlauf). */
    .date-list { grid-template-columns: minmax(0, 1fr); }
    /* Schlanke Ränder, damit das Act-Raster 2 Karten nebeneinander zeigt (statt 1). */
    .dates.section { padding-left: clamp(10px, 3vw, 24px); padding-right: clamp(10px, 3vw, 24px); }
    .date-row { padding: 16px 12px; }
    .date-media { width: 100%; max-width: 340px; margin-inline: auto; }
    .date-acts { max-width: 100%; gap: 12px; }
}

.date-row span {
    display: block;
    font-size: 14px;
    font-weight: 900;
    text-transform: uppercase;
}

.date-row strong {
    display: block;
    margin-top: 4px;
    font-size: 24px;
}

.date-row h3 {
    margin: 0;
    font-size: clamp(22px, 2vw, 34px);
}

.date-row h3 small {
    display: block;
    margin-top: 6px;
    font-family: Inter, sans-serif;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: 0;
    opacity: .72;
}

.venue-line {
    margin-top: 18px;
    font-size: 16px !important;
}

.mini-button,
.outline-button {
    min-height: 48px;
    padding: 12px 22px;
    border: 3px solid var(--line);
    border-radius: 999px;
    background: var(--yellow);
    box-shadow: 0 4px 0 var(--line);
}

/* „Tickets sichern" als echte Ticket-Form: Kerben links/rechts (mask),
   schwarzer Rand + harter Schatten über drop-shadow (folgt der Ticket-Silhouette). */
.mini-button,
.nav-ticket {
    position: relative;
    border: none !important;
    border-radius: 9px;
    background: var(--yellow);
    box-shadow: none !important;
    padding-left: 30px;
    padding-right: 30px;
    --notch: 8px;
    -webkit-mask:
        radial-gradient(circle var(--notch) at left center, #0000 96%, #000) ,
        radial-gradient(circle var(--notch) at right center, #0000 96%, #000);
    -webkit-mask-composite: source-in;
            mask-composite: intersect;
    filter:
        drop-shadow(2px 0 0 var(--line))
        drop-shadow(-2px 0 0 var(--line))
        drop-shadow(0 2px 0 var(--line))
        drop-shadow(0 -2px 0 var(--line))
        drop-shadow(0 5px 0 var(--line));
}
/* gestrichelte Abriss-Linie (Ticket-Stub) */
.mini-button::before,
.nav-ticket::before {
    content: "";
    position: absolute;
    top: 6px;
    bottom: 6px;
    left: 17px;
    border-left: 2px dashed rgba(21, 18, 15, .55);
    pointer-events: none;
}

.press {
    padding-bottom: 150px;
}

.press-box {
    max-width: 1000px;
    padding: clamp(28px, 5vw, 58px);
    background: linear-gradient(135deg, #fff 0%, #f8f7c6 100%);
}

.outline-button {
    background: #fff;
}

.sticky-cta {
    position: fixed;
    left: 50%;
    bottom: 20px;
    z-index: 70;            /* bleibt immer vor hervorgehobenen Hero-Karten */
    width: min(760px, calc(100% - 28px));
    display: grid;
    grid-template-columns: 1fr 56px 56px;
    gap: 14px;
    transform: translateX(-50%);
    pointer-events: none;
}

.sticky-cta a,
.sticky-cta button {
    min-height: 58px;
    border: 4px solid var(--line);
    border-radius: 999px;
    pointer-events: auto;
}

.sticky-cta a {
    background: var(--pink);
    color: #fff;
    box-shadow: 0 5px 0 var(--line);
    font-size: clamp(15px, 1.5vw, 21px);
}

.sticky-cta button {
    background: var(--paper);
    font-size: 22px;
    font-weight: 900;
}

/* Kurzlabel nur auf dem Handy zeigen; Standard = Langtext */
.cta-short { display: none; }
@media (max-width: 560px) {
    .sticky-cta { bottom: 10px; gap: 8px; grid-template-columns: 1fr 40px 40px; width: calc(100% - 24px); }
    .sticky-cta a, .sticky-cta button { min-height: 40px; border-width: 3px; }
    .sticky-cta a { font-size: 13px; box-shadow: 0 3px 0 var(--line); }
    .sticky-cta button { font-size: 16px; }
    .cta-full { display: none; }
    .cta-short { display: inline; }
}

/* Admin-Vorschau-Hinweis (nur bei ?preview_event=) */
.preview-banner {
    position: sticky;
    top: 0;
    z-index: 60;
    background: var(--pink);
    color: #fff;
    text-align: center;
    font-weight: 800;
    font-size: 14px;
    padding: 8px 14px;
}

.warning-ribbon {
    position: relative;       /* in den Seitenfluss geholt – überdeckt nichts mehr */
    margin: 16px auto 0;
    max-width: 720px;
    min-height: 54px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px 64px;
    border: 4px solid var(--line);
    border-radius: 12px;
    background: var(--yellow);
    color: var(--ink);
    box-shadow: 0 6px 0 var(--line);
    font-size: 15px;
    font-weight: 1000;
    letter-spacing: .02em;
    text-align: center;
    text-transform: uppercase;
    pointer-events: none;
}

.warning-ribbon::before,
.warning-ribbon::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: 18px;
    background: repeating-linear-gradient(45deg, var(--line) 0 6px, transparent 6px 12px);
    opacity: .95;
}

.warning-ribbon::before { left: 24px; }
.warning-ribbon::after { right: 24px; }

/* (Früherer @media (max-width:1100px)-Hero-Block entfernt – durch v24 ersetzt.) */

@media (max-width: 820px) {
    body::before {
        background-position: center top, center -80px, center center;
    }

    .site-header {
        height: 96px;
        padding-inline: 14px;
    }

    .logo { width: auto; height: 100%; padding: 8px 0; }

    .nav-toggle { display: block; }

    .main-nav {
        position: absolute;
        top: 66px;
        right: 12px;
        left: 12px;
        display: none;
        flex-direction: column;
        align-items: stretch;
        gap: 12px;
        padding: 18px;
        border: 3px solid var(--line);
        border-radius: 18px;
        background: var(--paper);
        box-shadow: 8px 8px 0 var(--line);
    }

    .main-nav.is-open { display: flex; }

    .main-nav a {
        padding: 12px 14px;
        border-bottom: 2px solid rgba(17,16,15,.12);
    }

    .nav-pill {
        text-align: center;
        border-bottom: 3px solid var(--line) !important;
    }

    .photo-card {
        border-radius: 12px;
    }

    .copy-panel {
        padding-inline: 0;
    }

    .facts {
        flex-direction: column;
        align-items: center;
    }

    .review-grid {
        grid-template-columns: 1fr;
    }

    .date-row {
        grid-template-columns: 1fr;
    }

    .mini-button {
        width: 100%;
    }
}

@media (max-width: 520px) {
    .warning-ribbon {
        padding: 10px 30px;
        font-size: 12px;
    }
    .warning-ribbon::before,
    .warning-ribbon::after { width: 12px; }

    .sticky-cta {
        grid-template-columns: 1fr 40px 40px;
        gap: 8px;
        bottom: 10px;
        width: calc(100% - 24px);
    }

    .sticky-cta a,
    .sticky-cta button {
        min-height: 40px;
        border-width: 3px;
    }
    .sticky-cta a { font-size: 13px; box-shadow: 0 3px 0 var(--line); }
    .sticky-cta button { font-size: 16px; }
}

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


/* v18: Host-Figur vor dem Coming-up-Text, Glow und erweiterte Ribbon-Optionen */
.coming{display:flex;align-items:flex-end;gap:14px;text-shadow:0 0 8px rgba(255,255,255,.92),0 0 2px rgba(255,255,255,1)}
.coming-speaker{display:block;height:1.08em;width:auto;flex:0 0 auto;filter:drop-shadow(0 2px 0 rgba(0,0,0,.45)) drop-shadow(0 0 8px rgba(255,255,255,.25))}
.photo-ribbon{padding:8px 20px}
.ribbon-color-lime{background:#9dff4a;color:var(--ink)}
.ribbon-color-orange{background:#ff9b2f;color:var(--ink)}
.ribbon-color-purple{background:#6d46ff;color:#fff}
.ribbon-color-red{background:#ff4f5e;color:#fff}
.ribbon-color-blue{background:#3d8bff;color:#fff}
.ribbon-color-mint{background:#5bf3c5;color:var(--ink)}
.ribbon-color-white{background:#fff;color:var(--ink)}
.ribbon-top,
.ribbon-top-third,
.ribbon-middle,
.ribbon-two-third-top,
.ribbon-bottom{left:-12px;right:-12px;width:auto}
.ribbon-top{top:14px;transform:none}
.ribbon-top-third{top:33%;transform:translateY(-50%)}
.ribbon-middle{top:50%;transform:translateY(-50%)}
.ribbon-two-third-top{top:66%;transform:translateY(-50%)}
.ribbon-bottom{bottom:14px;transform:none}
@media (max-width:820px){
  .coming{gap:10px}
  .coming-speaker{height:1em}
  .ribbon-top,.ribbon-top-third,.ribbon-middle,.ribbon-two-third-top,.ribbon-bottom{left:-8px;right:-8px}
}
@media (max-width:520px){
  .coming-speaker{height:.98em}
}


/* v19: größere Host-Figur, Absagekarten in die unteren Ecken und Ribbon-Mehrzeiligkeit */
.coming{align-items:center}
.coming-speaker{height:2.12em}
.coming span{display:block}
.card-stack{width:min(980px,100%)}
.photo-ribbon{white-space:pre-line; word-break:break-word; text-transform:uppercase}
.ribbon-case-raw{text-transform:none}
.photo-card.is-cancelled{width:clamp(112px,10.5vw,180px);top:auto}
.photo-card.is-cancelled.cancelled-bottom-left{left:-26px;right:auto;top:auto;bottom:4px}
.photo-card.is-cancelled.cancelled-bottom-right{right:-24px;left:auto;top:auto;bottom:4px}
.photo-card.is-cancelled .photo-ribbon{left:-8px;right:-8px}
@media (max-width:1100px){
  .coming-speaker{height:1.95em}
  .card-stack{width:100%}
  .photo-card.is-cancelled.cancelled-bottom-left{left:-8px;bottom:0}
  .photo-card.is-cancelled.cancelled-bottom-right{right:-8px;bottom:0}
}
@media (max-width:820px){
  .coming-speaker{height:1.8em}
  .photo-card.is-cancelled.cancelled-bottom-left{left:0;bottom:-6px}
  .photo-card.is-cancelled.cancelled-bottom-right{right:0;bottom:-6px}
}

/* v20: konfigurierbare Host-/Hero-Abstände, tiefere Extra-Fotos und besser zentrierte Schrägbanderolen */
.hero-art{transform:translate(258px, calc(92px + var(--hero-offset-px, 0px)))}
.hero-copy{transform:translateY(calc(130px + var(--hero-offset-px, 0px)))}
.coming-speaker{height:var(--host-size-px,190px)}
.ribbon-corner{display:flex;align-items:center;justify-content:center;text-align:center;min-height:58px;padding-top:9px;padding-bottom:9px;transform-origin:center center}
.photo-card.is-cancelled.cancelled-bottom-left{left:-26px;right:auto;bottom:-155px}
.photo-card.is-cancelled.cancelled-bottom-right{right:-24px;left:auto;bottom:-155px}
.photo-card.is-cancelled .ribbon-corner{min-height:34px;padding:5px 10px}
@media(max-width:1100px){.hero-art{transform:translate(0, var(--hero-offset-px,0px))}.hero-copy{transform:translateY(var(--hero-offset-px,0px))}.photo-card.is-cancelled.cancelled-bottom-left{left:-8px;bottom:-110px}.photo-card.is-cancelled.cancelled-bottom-right{right:-8px;bottom:-110px}}
@media(max-width:820px){.photo-card.is-cancelled.cancelled-bottom-left{left:0;bottom:-70px}.photo-card.is-cancelled.cancelled-bottom-right{right:0;bottom:-70px}}

/* (Frühere Blöcke v21 und v22 – absolute Hero-Bühne und rechter Deko-Kasten –
   wurden entfernt. Das zentrierte v24-Layout darunter ersetzt sie vollständig.) */

/* =========================================================================
   v24: Einheitliches, zentriertes Hero-Layout für ALLE Bildschirmgrößen.
   Host + "Coming up next" + die 3 Act-Karten bilden eine zentrale Bühne,
   darunter Headline/Infos/CTA. Ersetzt das alte, absolut positionierte
   2-Spalten-Desktoplayout (das auf kleineren Bildschirmen überlappte) und
   das separate Mobile-Layout durch EINE gemeinsame, mit clamp() skalierende
   Komposition – stabil vom Smartphone bis zum Beamer.
   ========================================================================= */
.hero {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-height: 0;
    grid-template-columns: none;
    gap: clamp(14px, 3vw, 38px);
    padding: clamp(18px, 3vw, 46px) clamp(16px, 5vw, 96px) clamp(46px, 6vw, 88px);
}

/* Bühne: aus absoluter Positionierung in den normalen, zentrierten Fluss */
.hero-art {
    position: relative;
    transform: none;
    min-height: 0;
    width: 100%;
    max-width: 1120px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(12px, 2.4vw, 28px);
}

/* Host-Figur oben, "Coming up next:" darunter – zentriert */
.coming {
    position: static;
    transform: none;
    margin: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: clamp(2px, .8vw, 10px);
    font-size: clamp(38px, 6vw, 86px);
    line-height: .95;
}
.coming span { display: block; }
.coming-speaker {
    height: auto;
    width: clamp(140px, 22vw, 300px);
}

/* Die 3 Act-Karten als eine zentrierte Reihe */
.card-stack {
    position: static;
    transform: none;
    width: 100%;
    height: auto;
    min-height: 0;
    display: flex;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: flex-start;
    gap: clamp(10px, 1.2vw, 18px);
    max-width: 100%;
    overflow-x: auto;
    padding-bottom: 8px;
    scroll-snap-type: x proximity;
}
.card-stack > .photo-card {
    /* Eine Reihe nebeneinander; auf 290px-Basis gerendert + skaliert, damit die
       CSS-Banderolen proportional bleiben. Mehr Karten -> horizontal wischen. */
    flex: 0 0 auto;
    width: 290px;
    zoom: .6;
    scroll-snap-align: start;
}
.photo-card.is-cancelled,
.photo-card.is-cancelled.cancelled-bottom-left,
.photo-card.is-cancelled.cancelled-bottom-right {
    position: relative;
    left: auto;
    right: auto;
    top: auto;
    bottom: auto;
    width: clamp(72px, 15vw, 170px);
}

/* Text/CTA zentriert unter der Bühne – auf dem hellen Panel (lesbarer Text) */
.hero-copy {
    position: relative;
    transform: none;
    min-height: 0;
    width: 100%;
    max-width: 760px;
    display: flex;
    justify-content: center;
}
.hero-copy::before { left: -10px; right: 4px; top: -8px; bottom: 10px; width: auto; }
.hero-copy::after  { left: 4px; right: -10px; top: 10px; bottom: -8px; width: auto; }
.copy-panel {
    width: 100%;
    max-width: 700px;
    margin-inline: auto;
}

@media (max-width: 520px) {
    .coming { font-size: clamp(32px, 11vw, 50px); }
    .coming-speaker { width: clamp(132px, 48vw, 200px); }
    .hero-copy::before,
    .hero-copy::after { left: 0; right: 0; }
}

/* Desktop/Tablet: Hero-Karten nicht "stinknormal" in Reih und Glied, sondern
   leicht gekippt; beim Überfahren/Fokus wird der jeweilige Act hervorgehoben
   (gerade gerichtet + vergrößert + vorn), die übrigen treten dezent zurück. */
@media (min-width: 561px) {
    .card-stack {
        justify-content: center;
        overflow: visible;          /* Neigung/Schatten nicht abschneiden */
        gap: clamp(10px, 1.4vw, 20px);
        width: 100%;
    }
    .card-stack > .photo-card {
        /* Karten füllen die volle Inhaltsbreite (so breit wie die Elemente
           darunter), statt schmal in der Mitte zu stehen. */
        flex: 1 1 0;
        width: auto;
        max-width: 300px;
        zoom: 1;
        transform-origin: center bottom;
        transition: transform .3s cubic-bezier(.2,.7,.2,1), filter .3s ease;
        filter: drop-shadow(0 12px 20px rgba(0,0,0,.45));
    }
    .card-stack > .photo-card:nth-child(4n+1) { transform: rotate(-4deg); }
    .card-stack > .photo-card:nth-child(4n+2) { transform: rotate(2.5deg); }
    .card-stack > .photo-card:nth-child(4n+3) { transform: rotate(-2deg); }
    .card-stack > .photo-card:nth-child(4n+4) { transform: rotate(3.5deg); }
    .card-stack > .photo-card:hover,
    .card-stack > .photo-card:focus-within {
        transform: rotate(0deg) scale(1.12);
        z-index: 6;
        filter: drop-shadow(0 22px 34px rgba(0,0,0,.6));
    }
    .card-stack:hover > .photo-card:not(:hover):not(:focus-within) {
        filter: drop-shadow(0 12px 20px rgba(0,0,0,.45)) brightness(.8);
    }
}

/* Handy: statt Scrollbalken oder verdeckendem Stapel liegen die Hero-Karten als
   kreativ gekippte Foto-Collage (2x2) – jedes Gesicht bleibt sichtbar, nur die
   Ecken überlappen leicht. Bei Tap (is-fanned) bzw. Hover richten sie sich
   ordentlich aus und rücken auseinander.
   Karten auf 290px-Basis + zoom, damit die CSS-Banderolen proportional bleiben. */
@media (max-width: 560px) {
    .card-stack {
        display: grid;
        grid-template-columns: repeat(2, auto);
        justify-content: center;
        justify-items: center;
        align-items: center;
        gap: 0;
        overflow: visible;          /* kein horizontaler Scrollbalken */
        padding-bottom: 6px;
        scroll-snap-type: none;
    }
    .card-stack > .photo-card {
        width: 290px;
        zoom: .5;                   /* ~145px – gut erkennbar */
        transform-origin: center;
        transition: transform .35s cubic-bezier(.2,.7,.2,1), filter .35s ease;
        filter: drop-shadow(0 10px 16px rgba(0,0,0,.5));
    }
    /* kreativ gekippt + minimale Eckenüberlappung; Gesichter (Mitte) frei */
    .card-stack > .photo-card:nth-child(4n+1) { transform: rotate(-6deg) translate(12px, 6px);  z-index: 2; }
    .card-stack > .photo-card:nth-child(4n+2) { transform: rotate(5deg)  translate(-12px, -4px); z-index: 1; }
    .card-stack > .photo-card:nth-child(4n+3) { transform: rotate(4deg)  translate(14px, -6px);  z-index: 1; }
    .card-stack > .photo-card:nth-child(4n+4) { transform: rotate(-5deg) translate(-14px, 5px);  z-index: 2; }
    /* Hover / Fokus / Tap: NUR den jeweiligen Act hervorheben – gerade richten,
       vorrücken und vergrößern; die übrigen treten dezent zurück. */
    .card-stack > .photo-card:hover,
    .card-stack > .photo-card:focus-within,
    .card-stack > .photo-card:active {
        transform: rotate(0deg) translate(0, 0) scale(1.18);
        z-index: 6;
        filter: drop-shadow(0 18px 28px rgba(0,0,0,.62));
    }
    .card-stack:hover > .photo-card:not(:hover):not(:focus-within) {
        filter: drop-shadow(0 10px 16px rgba(0,0,0,.5)) brightness(.78);
    }
}

/* Venue als dezenter Google-Maps-Link in der Terminliste */
.venue-link { color: inherit; text-decoration: underline; text-underline-offset: 2px; }
.venue-link:hover,
.venue-link:focus-visible { color: var(--pink); }

/* Gesamtbewertung über den Reviews (nur bei Live-Google-Daten) */
.reviews-rating { margin: 6px 0 0; font-weight: 800; }
.reviews-rating strong { font-size: 1.2em; }

/* Cookie-Consent-Banner – nur sichtbar, wenn Google-Ads-Tracking konfiguriert ist */
.consent-banner { position: fixed; left: 12px; right: 12px; bottom: 12px; z-index: 80; display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 12px; max-width: 760px; margin: 0 auto; padding: 14px 18px; border: 3px solid var(--line); border-radius: 16px; background: var(--paper); box-shadow: 0 12px 40px rgba(0,0,0,.35); }
.consent-banner[hidden] { display: none; }
.consent-banner p { margin: 0; flex: 1 1 240px; font-weight: 700; font-size: 14px; color: var(--ink); }
.consent-actions { display: flex; gap: 8px; }
.consent-banner button { padding: 9px 16px; border: 3px solid var(--line); border-radius: 999px; font: inherit; font-weight: 900; cursor: pointer; }
.consent-accept { background: var(--yellow); color: var(--ink); }
.consent-decline { background: #fff; color: var(--ink); }

/* Footer mit rechtlichen Links */
.site-footer { padding: 30px 18px 120px; text-align: center; }
.site-footer p { margin: 0; color: #fff; font-weight: 700; text-shadow: 0 1px 5px rgba(0,0,0,.55); }
.site-footer a { color: var(--yellow); text-decoration: underline; text-underline-offset: 2px; }
.site-footer a:hover,
.site-footer a:focus-visible { color: #fff; }

/* Rechtliche Seiten (Impressum, Datenschutz) */
.legal { max-width: 840px; margin: 0 auto; padding: clamp(20px, 4vw, 48px) clamp(16px, 4vw, 32px) 90px; }
.legal-card { padding: clamp(22px, 4vw, 44px); border: 3px solid var(--line); border-radius: var(--radius); background: var(--paper); box-shadow: 0 24px 70px rgba(0,0,0,.3); }
.legal-card h1 { margin-top: 0; }
.legal-card h2 { margin: 30px 0 10px; }
.legal-card p, .legal-card li { line-height: 1.6; }
.legal-card a { color: var(--pink); }
.legal-note { margin-top: 30px; padding: 14px 16px; border: 2px dashed var(--line); border-radius: 12px; background: #fff; font-size: 14px; }

/* Eck-Banderole proportional an die (kleineren) v24-Karten anpassen –
   früher feste Desktop-Pixel (right:-72px, min-height:58px) → wurde abgeschnitten.
   Schriftgröße fix klein (überschreibt die JS-Autogröße), damit der Text komplett
   in das schmale Eck-Band passt. */
.ribbon-corner {
    width: 74%;
    min-height: 0;
    padding: 4px 6px;
    font-size: 12px !important;
    line-height: 1.1 !important;
    letter-spacing: 0;
}
.ribbon-corner.ribbon-top-left     { top: 12%;    left: -9%;  right: auto; bottom: auto; transform: rotate(-40deg); }
.ribbon-corner.ribbon-top-right    { top: 12%;    right: -9%; left: auto;  bottom: auto; transform: rotate(40deg); }
.ribbon-corner.ribbon-bottom-left  { bottom: 12%; left: -9%;  right: auto; top: auto;    transform: rotate(40deg); }
.ribbon-corner.ribbon-bottom-right { bottom: 12%; right: -9%; left: auto;  top: auto;    transform: rotate(-40deg); }

/* Hero-Textpanel: EIN klares Panel statt zweier versetzter Deko-Ebenen
   (die wirkten wie verrutschte, sich überdeckende Kästen). Jetzt im gleichen
   Hard-Shadow-Stil wie die übrigen Karten der Seite. */
.hero-copy::before,
.hero-copy::after { display: none; }
.copy-panel {
    background: var(--paper);
    border: 3px solid var(--line);
    border-radius: var(--radius);
    box-shadow: 8px 8px 0 var(--line);
    padding: clamp(22px, 4vw, 44px);
}

/* Act-Karten beim Überfahren hervorheben – früher per z-index (Karten überlappten),
   jetzt per leichtem Vergrößern + Schatten, da die Karten nebeneinander liegen. */
.photo-card { transition: transform .18s ease, box-shadow .18s ease; }
@media (hover: hover) {
    .photo-card:hover { transform: scale(1.045); box-shadow: 0 18px 42px rgba(0,0,0,.45); z-index: 5; }
}

/* =========================================================================
   Einheitliche Inhaltsbreite: Hero UND alle Sektionen auf dieselbe
   Maximalbreite + denselben Seitenabstand bringen, damit alle Bereiche auf
   den gleichen Kanten ausgerichtet sind (vorher liefen die Breiten/Ränder
   auseinander – Hero schmal, Sektionen quasi volle Breite). */
.hero { padding-inline: var(--gutter); }
.hero-art  { max-width: var(--content-max); }
.hero-copy { max-width: var(--content-max); }
.copy-panel { max-width: var(--content-max); }

.section-head,
.review-grid,
.date-list { max-width: 100%; margin-inline: auto; }

/* Sektionen als eingefasste Panels im Stil des Hero-Copy-Panels
   (statt vollflächiger Creme-Bänder über die ganze Bildschirmbreite):
   zentriert, begrenzt, mit Rand + Hard-Shadow auf dem dunklen Hintergrund. */
.section {
    width: calc(100% - 2 * var(--gutter));
    max-width: var(--content-max);
    margin: clamp(26px, 4vw, 52px) auto;
    padding: clamp(26px, 4vw, 52px);
    border: 3px solid var(--line);
    border-radius: var(--radius);
    box-shadow: 8px 8px 0 var(--line);
}
/* Presse-Inhalt direkt auf dem Panel statt als eigene Karte (kein Karte-in-Karte) */
.press-box {
    max-width: none;
    background: transparent;
    border: 0;
    box-shadow: none;
    padding: 0;
}

/* === Barrierefreiheit === */
/* "Zum Inhalt springen" – nur sichtbar bei Tastaturfokus */
.skip-link {
    position: absolute;
    left: 10px;
    top: -70px;
    z-index: 200;
    padding: 10px 18px;
    background: var(--yellow);
    color: var(--ink);
    border: 3px solid var(--line);
    border-radius: 10px;
    font-weight: 900;
    text-decoration: none;
    transition: top .15s ease;
}
.skip-link:focus { top: 10px; }

/* Klar sichtbarer Tastatur-Fokus auf allen interaktiven Elementen */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
summary:focus-visible,
[tabindex]:focus-visible {
    outline: 3px solid #02e7ff;
    outline-offset: 2px;
    border-radius: 4px;
}

/* Termin-Filter (Zeitraum Von–Bis) */
.date-filter {
    display: flex;
    align-items: flex-end;
    flex-wrap: wrap;
    gap: 14px;
    margin-bottom: 22px;
}
.date-filter-field {
    display: flex;
    flex-direction: column;
    gap: 5px;
    font-weight: 800;
    color: var(--ink);
    font-size: 14px;
}
.date-filter-field input[type="date"],
.date-filter-field select {
    padding: 9px 12px;
    border: 3px solid var(--line);
    border-radius: 12px;
    background: #fff;
    color: var(--ink);
    font: inherit;
    font-weight: 700;
}
.date-filter-field select { min-width: 170px; cursor: pointer; }
.date-filter .date-filter-reset { padding: 9px 16px; }
.date-empty {
    margin-top: 18px;
    font-weight: 800;
    color: var(--ink);
}
.linklike {
    background: none;
    border: none;
    padding: 0;
    font: inherit;
    font-weight: 900;
    color: var(--ink);
    text-decoration: underline;
    cursor: pointer;
}

/* Termin-Blätterung */
/* Wichtig: .date-row hat display:grid -> das hidden-Attribut (display:none aus
   dem Browser-Standard) würde sonst überschrieben. Diese Regel erzwingt es. */
.date-row[hidden] { display: none !important; }

/* Besetzung pro Termin – quadratisches Act-Raster (max. 2 nebeneinander), evtl. unter einem Gruppenbild */
.date-media {
    position: relative;
    width: 100%;
    max-width: 620px;
    margin: 0 auto;
}
.date-acts {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 18px;
    max-width: 600px;   /* 2 × 280px Karten + Gap -> 2 pro Reihe (große Bilder) */
    margin: 0 auto;
}
/* Gruppenbild = Querformat-Banner (16:9), definiert die Boxhöhe -> nie gestaucht.
   Die Acts liegen als unsichtbares Overlay darüber, bis man tippt/hovert. */
.date-media-group {
    border: 3px solid var(--line);
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 4px 0 var(--line);
    cursor: pointer;
    transition: opacity .28s ease;
}
.date-media.has-group .date-media-group { position: relative; aspect-ratio: 16 / 9; width: 100%; }
.date-media.has-group .date-acts {
    position: absolute;
    inset: 0;
    align-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity .2s ease;
}
.date-media-group img { width: 100%; height: 100%; object-fit: cover; display: block; }
.date-media-group::after {
    content: "Besetzung ansehen";
    position: absolute;
    left: 0; right: 0; bottom: 0;
    padding: 6px 8px;
    background: rgba(0, 0, 0, .62);
    color: #fff;
    font-size: 12px;
    font-weight: 900;
    text-align: center;
    text-transform: uppercase;
    letter-spacing: .04em;
}
/* Aufdecken (Tap = .is-open per JS / Hover auf Desktop): Acts kommen in den Fluss (Box wächst
   auf die Rasterhöhe), das Banner wird zum ausgeblendeten Overlay. */
.date-media.has-group.is-open .date-media-group { position: absolute; inset: 0; opacity: 0; pointer-events: none; }
.date-media.has-group.is-open .date-acts { position: relative; inset: auto; opacity: 1; pointer-events: auto; }
@media (hover: hover) {
    .date-media.has-group:hover .date-media-group { position: absolute; inset: 0; opacity: 0; pointer-events: none; }
    .date-media.has-group:hover .date-acts { position: relative; inset: auto; opacity: 1; pointer-events: auto; }
}
.date-act { margin: 0; }
.date-act-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    width: 280px;
    text-decoration: none;
    color: inherit;
    cursor: pointer;
}
/* Karte wird intern in „Hero-Größe" (214px) gerendert und als Ganzes herunter-
   skaliert -> Banderole sitzt proportional exakt wie im Hero. */
.date-act-figure {
    width: 280px;
    height: 350px;
    position: relative;
    transition: transform .15s ease;
}
.date-acts .photo-card {
    position: absolute;
    top: 0;
    left: 0;
    width: 214px;
    transform: scale(1.308);
    transform-origin: top left;
}
.date-act-card:hover .date-act-figure,
.date-act-card:focus-visible .date-act-figure { transform: translateY(-3px); }
.date-act-name {
    font-size: 13px;
    font-weight: 900;
    text-align: center;
    line-height: 1.15;
    overflow-wrap: anywhere;
}

/* Act-Lightbox (großes Bild bei Klick ohne Link) */
.act-lightbox {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: rgba(0, 0, 0, .78);
}
.act-lightbox[hidden] { display: none; }
/* Bei offener Großansicht bleibt der "Tickets sichern"-Button im Vordergrund
   (über dem Overlay 1000, aber unter dem Checkout-Popup 1100). */
body.act-lightbox-open .sticky-cta { z-index: 1050 !important; }
.act-lightbox-figure {
    margin: 0;
    max-width: min(92vw, 460px);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
}
.act-lightbox-figure img {
    max-width: 100%;
    max-height: 78vh;
    border: 4px solid var(--line);
    border-radius: 16px;
    background: #181818;
    box-shadow: 10px 10px 0 rgba(0, 0, 0, .5);
}
.act-lightbox-figure figcaption {
    color: #fff;
    font-weight: 900;
    font-size: 18px;
    text-align: center;
}
.act-lightbox-close {
    position: absolute;
    top: 18px;
    right: 22px;
    width: 48px;
    height: 48px;
    padding: 0;
    border: 3px solid #fff;
    border-radius: 999px;
    background: rgba(0, 0, 0, .4);
    color: #fff;
    font-size: 26px;
    font-weight: 900;
    line-height: 1;
    cursor: pointer;
}
/* Ticket-Popup (Universe-Checkout im Overlay, Termin vorgewählt) */
.ticket-modal {
    position: fixed;
    inset: 0;
    z-index: 1100;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: rgba(0, 0, 0, .82);
}
.ticket-modal[hidden] { display: none; }
.ticket-modal-panel {
    position: relative;
    width: min(96vw, 520px);
    height: min(88vh, 760px);
    display: flex;
    flex-direction: column;
    background: #fff;
    border: 4px solid var(--line);
    border-radius: 18px;
    box-shadow: 12px 12px 0 rgba(0, 0, 0, .5);
    overflow: hidden;
}
.ticket-modal-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 16px;
    background: var(--ink);
    color: #fff;
}
.ticket-modal-bar strong { font-size: 16px; font-weight: 900; letter-spacing: .02em; }
.ticket-modal-close {
    width: 38px;
    height: 38px;
    padding: 0;
    border: 2px solid #fff;
    border-radius: 999px;
    background: transparent;
    color: #fff;
    font-size: 22px;
    font-weight: 900;
    line-height: 1;
    cursor: pointer;
}
.ticket-modal-frame {
    flex: 1;
    width: 100%;
    border: 0;
    background: #fff;
}
.ticket-modal-fallback {
    padding: 10px 16px;
    text-align: center;
    font-weight: 700;
    font-size: 13px;
    color: var(--ink);
    background: var(--yellow);
    text-decoration: none;
}
@media (max-width: 600px) {
    .ticket-modal { padding: 0; }
    .ticket-modal-panel { width: 100vw; height: 100vh; border: 0; border-radius: 0; box-shadow: none; }
}
.date-pager {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 16px;
    margin-top: 26px;
}
.date-pager .pager-btn {
    padding: 10px 20px;
    border: 3px solid var(--line);
    border-radius: 999px;
    background: var(--yellow);
    color: var(--ink);
    font: inherit;
    font-weight: 1000;
    cursor: pointer;
    box-shadow: 0 3px 0 var(--line);
}
.date-pager .pager-btn:disabled { opacity: .4; cursor: default; box-shadow: none; }
.date-pager .pager-info { font-weight: 800; color: var(--ink); }

/* „Coming up next“: Termindaten + Ticket direkt unter den Act-Karten */
.coming-meta {
    position: relative;
    z-index: 3;
    width: min(980px, 100%);
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 12px clamp(16px, 2.5vw, 32px);
    margin-top: 6px;
    text-align: center;
}
.coming-meta-line {
    margin: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 3px;
    color: #fff;
    text-shadow: 0 2px 10px rgba(0, 0, 0, .65), 0 0 2px rgba(0, 0, 0, .9);
}
.coming-meta-line strong { font-size: clamp(20px, 2.3vw, 30px); font-weight: 1000; }
.coming-meta-line span { font-size: 15px; font-weight: 800; opacity: .92; }
.coming-meta .mini-button { font-size: 18px; }

/* Info-/About-Sektion + FAQ (Inhalt für Besucher & SEO) */
.about-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; counter-reset: aboutnum; }
@media (max-width: 880px) { .about-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 560px) { .about-grid { grid-template-columns: 1fr; } }
.about-card { border: 3px solid var(--line); border-radius: 16px; background: var(--paper); box-shadow: 7px 7px 0 var(--line); overflow: hidden; display: flex; flex-direction: column; counter-increment: aboutnum; transition: transform .15s ease, box-shadow .15s ease; }
@media (hover: hover) { .about-card:hover { transform: translate(-2px, -2px); box-shadow: 11px 11px 0 var(--line); } }
.about-card h3 {
    margin: 0;
    display: flex; align-items: center; gap: 10px;
    background: var(--yellow); color: var(--ink);
    padding: 13px 16px; border-bottom: 3px solid var(--line);
    font-size: clamp(18px, 1.9vw, 23px); line-height: 1.08;
}
.about-card h3::before {
    content: counter(aboutnum, decimal-leading-zero);
    flex: 0 0 auto;
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 30px; height: 30px; padding: 0 6px;
    background: var(--ink); color: var(--yellow);
    border-radius: 8px; font-size: 15px; font-weight: 900;
}
.about-card p { margin: 0; padding: 16px 18px; font-size: 16px; line-height: 1.55; }

.faq-list { display: grid; gap: 12px; max-width: 880px; }
.faq-item { border: 3px solid var(--line); border-radius: 14px; background: var(--paper); box-shadow: 4px 4px 0 var(--line); overflow: hidden; }
.faq-item summary { cursor: pointer; list-style: none; padding: 15px 20px; font-weight: 900; font-size: 17px; display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; font-size: 26px; line-height: 1; flex: 0 0 auto; }
.faq-item[open] summary::after { content: "\2013"; }
.faq-answer { padding: 0 20px 18px; font-size: 16px; line-height: 1.55; }

/* Klickflaeche ueber den Hero-Act-Karten (Coming up next): Link oder Lightbox wie bei den Terminen */
.photo-card .act-hit { position: absolute; inset: 0; z-index: 6; display: block; cursor: pointer; }

/* Handy: Lineup zeigt 2 Act-Karten pro Reihe. Bewusst am Dateiende, damit es die
   Basis-Regeln (.date-act-figure / .date-acts .photo-card) sicher überschreibt.
   Ganze Karte wird kleiner skaliert -> Banderole bleibt proportional. */
@media (max-width: 560px) {
    .date-acts { max-width: 100%; gap: 14px; justify-content: center; }
    .date-act-card { width: 230px; }
    .date-act-figure { width: 230px; height: 288px; }
    .date-acts .photo-card { width: 214px; transform: scale(1.075); transform-origin: top left; }
}

/* Hero „Coming up next": Kopfzeile mit Ticket-Button oben rechts (Position bleibt stabil). */
.coming-head { display: flex; justify-content: space-between; align-items: center; gap: 10px clamp(12px, 2vw, 28px); flex-wrap: wrap; margin-bottom: clamp(6px, 1.4vw, 16px); }
.coming-head .coming { margin: 0; }
.coming-cta { flex: 0 0 auto; align-self: center; }
@media (max-width: 560px) { .coming-head { justify-content: center; } }

