
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; font-size: 18px; }
body { background: var(--black); color: var(--cream); font-family: 'Lora', serif; overflow-x: hidden; line-height: 1.7; }

/* NAV */
nav { position: fixed; inset: 0 0 auto; z-index: 200; padding: 1.4rem 3rem; display: flex; justify-content: space-between; align-items: center; background: linear-gradient(to bottom, rgba(10,8,6,0.98) 0%, transparent 100%); }
.logo { text-decoration: none; }
.logo-top { font-family: 'Playfair Display', serif; font-size: 1.2rem; font-weight: 700; color: var(--accent); display: block; }
.logo-bot { font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.3em; color: var(--cream); opacity: 0.35; display: block; margin-top: 3px; }
.nav-links { display: flex; gap: 2.2rem; list-style: none; }
.nav-links a { font-family: var(--mono); font-size: 0.82rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--cream); opacity: 0.7; text-decoration: none; transition: opacity .25s, color .25s; padding: 0.3rem 0; }
.nav-links a:hover { opacity: 1; color: var(--accent); }
.nav-cta { font-family: var(--mono); font-size: 0.82rem; letter-spacing: 0.15em; text-transform: uppercase; background: var(--accent); color: var(--black); padding: 0.85rem 1.8rem; text-decoration: none; transition: background .25s; white-space: nowrap; font-weight: 400; }
.nav-cta:hover { background: var(--accent-l); }

/* HERO */
.hero { min-height: 100vh; display: flex; flex-direction: column; justify-content: flex-end; padding: 0 3rem 5rem; position: relative; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; background: radial-gradient(ellipse 70% 55% at 60% 35%, rgba(232,101,10,0.08) 0%, transparent 60%), radial-gradient(ellipse 50% 60% at 10% 70%, rgba(232,101,10,0.04) 0%, transparent 55%), linear-gradient(165deg, var(--black) 0%, #0f0b07 60%, var(--black) 100%); }
.hero-wm { position: absolute; right: -2rem; top: 50%; transform: translateY(-50%) rotate(90deg); font-family: 'Playfair Display', serif; font-size: 8rem; font-weight: 900; color: var(--cream); opacity: 0.02; letter-spacing: 0.3em; white-space: nowrap; pointer-events: none; user-select: none; }
.hero-frame { position: absolute; inset: 5% 4%; border: 1px solid rgba(232,101,10,0.07); pointer-events: none; }
.hero-content { position: relative; z-index: 2; max-width: 950px; }
.hero-eyebrow { font-family: var(--mono); font-size: 0.85rem; letter-spacing: 0.35em; text-transform: uppercase; color: var(--accent); display: flex; align-items: center; gap: 1.2rem; margin-bottom: 2rem; }
.hero-eyebrow::after { content: ''; flex: 0 0 50px; height: 1px; background: var(--accent); opacity: 0.4; }
.hero-title { font-family: 'Playfair Display', serif; font-size: clamp(3.2rem, 8vw, 7.5rem); font-weight: 900; line-height: 0.92; letter-spacing: -0.02em; color: var(--cream); }
.hero-title span { display: block; }
.hero-title em { color: var(--accent); font-style: italic; }
.hero-sub { margin-top: 2rem; max-width: 580px; font-size: 1.3rem; line-height: 1.75; font-style: italic; color: var(--cream); opacity: 0.65; }
.hero-actions { display: flex; gap: 1.5rem; margin-top: 3rem; flex-wrap: wrap; align-items: center; }
.btn { font-family: var(--mono); font-size: 0.88rem; letter-spacing: 0.18em; text-transform: uppercase; padding: 1.1rem 2.8rem; text-decoration: none; display: inline-block; transition: all .25s; min-height: 52px; display: inline-flex; align-items: center; }
.btn-accent { background: var(--accent); color: var(--black); font-weight: 400; }
.btn-accent:hover { background: var(--accent-l); }
.btn-outline { border: 2px solid rgba(245,237,224,0.3); color: var(--cream); }
.btn-outline:hover { border-color: var(--accent); color: var(--accent); }
.hero-scroll { position: absolute; bottom: 2rem; right: 3rem; font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--cream); opacity: 0.2; display: flex; align-items: center; gap: 0.8rem; writing-mode: vertical-rl; }
.hero-scroll::after { content: ''; width: 1px; height: 60px; background: currentColor; animation: line-drop 2s ease infinite; }

/* BANNER */
.aktuell-banner { background: var(--accent); color: var(--black); padding: 1.4rem 3rem; display: flex; justify-content: center; align-items: center; gap: 2rem; flex-wrap: wrap; }
.aktuell-banner strong { font-family: 'Playfair Display', serif; font-size: 1.3rem; }
.aktuell-banner span { font-family: var(--mono); font-size: 0.85rem; letter-spacing: 0.12em; }
.aktuell-banner a { font-family: var(--mono); font-size: 0.85rem; letter-spacing: 0.15em; text-decoration: underline; color: var(--black); opacity: 0.75; font-weight: 400; }
.aktuell-banner a:hover { opacity: 1; }
.banner-termine { display: flex; gap: 0.6rem; flex-wrap: wrap; }
.banner-termin { font-family: var(--mono); font-size: 0.78rem; background: rgba(0,0,0,0.15); padding: 0.4rem 0.8rem; display: flex; gap: 0.5rem; align-items: center; }
.banner-termin.clickable { cursor: pointer; text-decoration: none; color: var(--black); }
.banner-termin.premiere { background: rgba(0,0,0,0.3); }

/* SECTIONS */
.sec { padding: 6.5rem 3rem; }
.sec-label { font-family: var(--mono); font-size: 0.78rem; letter-spacing: 0.35em; text-transform: uppercase; color: var(--accent); opacity: 0.9; display: flex; align-items: center; gap: 1rem; margin-bottom: 1rem; }
.sec-label::before { content: ''; width: 28px; height: 1px; background: var(--accent); }
.sec-title { font-family: 'Playfair Display', serif; font-size: clamp(2.2rem, 3.5vw, 3.2rem); font-weight: 700; line-height: 1.15; color: var(--cream); }
.sec-title em { color: var(--accent); font-style: italic; }

/* SPIELPLAN */
.spielplan { background: var(--dark); }
.spielplan-head { max-width: 1120px; margin: 0 auto 3.5rem; display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; gap: 1.5rem; }
.inszenierung { max-width: 1120px; margin: 0 auto 3rem; }
.ins-label { font-family: var(--mono); font-size: 0.78rem; letter-spacing: 0.25em; text-transform: uppercase; color: var(--accent); opacity: 0.7; margin-bottom: 1.4rem; display: flex; align-items: center; gap: 0.8rem; }
.ins-label::before { content: ''; width: 20px; height: 1px; background: var(--accent); opacity: 0.5; }
.ins-header { display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; gap: 1rem; margin-bottom: 1.8rem; padding-bottom: 1.8rem; border-bottom: 1px solid var(--border); }
.ins-title { font-family: 'Playfair Display', serif; font-size: 2.1rem; font-weight: 700; color: var(--cream); line-height: 1.2; }
.ins-author { font-size: 1.1rem; font-style: italic; color: var(--cream); opacity: 0.6; margin-top: 0.5rem; }
.ins-badge { font-family: var(--mono); font-size: 0.78rem; letter-spacing: 0.18em; text-transform: uppercase; background: var(--accent); color: var(--black); padding: 0.5rem 1.2rem; white-space: nowrap; }
.ins-beschreibung { font-size: 1.12rem; line-height: 1.85; color: var(--cream); opacity: 0.72; margin: 1.4rem 0 2rem; max-width: 780px; font-style: italic; border-left: 3px solid rgba(232,101,10,0.3); padding-left: 1.4rem; }
.shows-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); gap: 2px; }
.show-slot { background: var(--card); padding: 1.8rem; border-top: 3px solid transparent; transition: border-color .25s, background .25s, transform .15s; position: relative; }
.show-slot.clickable { cursor: pointer; }
.show-slot.clickable:hover { border-top-color: var(--accent); background: #201a12; transform: translateY(-2px); }
.show-slot.clickable:hover .slot-buchung { opacity: 1; }
.show-slot.vergangen { opacity: 0.28; pointer-events: none; cursor: default; }
.show-slot.vergangen .slot-date { text-decoration: line-through; text-decoration-color: rgba(245,237,224,0.4); }
.slot-date { font-family: var(--mono); font-size: 0.95rem; letter-spacing: 0.08em; color: var(--accent); margin-bottom: 0.6rem; font-weight: 400; }
.slot-day { font-family: var(--mono); font-size: 0.78rem; letter-spacing: 0.12em; color: var(--cream); opacity: 0.45; text-transform: uppercase; margin-bottom: 0.6rem; }
.slot-time { font-family: var(--mono); font-size: 1rem; color: var(--cream); opacity: 0.85; font-weight: 400; }
.slot-extra { font-family: var(--mono); font-size: 0.75rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); margin-top: 0.6rem; }
.slot-extra { 
    /* -------- Worttrennung ---------- */
    hyphens: auto;                 /* echte Silbentrennung (mit Bindestrich) */
    overflow-wrap: anywhere;      /* fallback für Browser ohne hyphens   */
    word-break: normal;           /* kein brutales break‑all */

    /* optional: Mindestlängen vor/nach Trennstrich */
    hyphenate-limit-chars: 6 3;    /* mindestens 6/3 Zeichen, falls unterstützt */  
}
.slot-extra.ausverkauft { color: #e05050; }
.slot-buchung { display: block; margin-top: 0.9rem; font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--black); background: var(--accent); padding: 0.45rem 0.9rem; text-decoration: none; opacity: 0; transition: opacity .2s; text-align: center; }
.slot-avail { display: inline-block; margin-top: 0.7rem; font-family: var(--mono); font-size: 0.65rem; letter-spacing: 0.12em; text-transform: uppercase; padding: 0.25rem 0.65rem; border-radius: 2px; }
.slot-avail.frei   { background: rgba(60,180,80,0.15);  color: #5ecf72; border: 1px solid rgba(60,180,80,0.3); }
.slot-avail.wenige { background: rgba(232,140,10,0.15); color: #f0a030; border: 1px solid rgba(232,140,10,0.3); }
.slot-avail.voll   { background: rgba(200,50,50,0.15);  color: #e05050; border: 1px solid rgba(200,50,50,0.3); }
.karten-bar { max-width: 1120px; margin: 2.5rem auto 0; padding: 2rem 2.5rem; background: var(--card); border-left: 4px solid var(--accent); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1.5rem; }
.karten-bar-label { font-family: var(--mono); font-size: 0.78rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--accent); margin-bottom: 0.5rem; }
.karten-bar-text { font-size: 1.1rem; color: var(--cream); opacity: 0.8; }

/* PLAKAT */
.ins-plakat-wrap { display: flex; gap: 2.5rem; align-items: flex-start; margin-bottom: 2rem; }
.ins-plakat-img { width: 180px; aspect-ratio: 2/3; object-fit: cover; display: block; border: 1px solid var(--border); flex-shrink: 0; cursor: zoom-in; box-shadow: 0 8px 32px rgba(0,0,0,0.5); transition: transform .25s, box-shadow .25s; }
.ins-plakat-img:hover { transform: scale(1.03); box-shadow: 0 12px 40px rgba(232,101,10,0.25); }

/* ENSEMBLE */
.ensemble-wrap { max-width: 1120px; margin: 0 auto 0; }
.ensemble-toggle { width: 100%; background: none; border: none; border-top: 1px solid var(--border); cursor: pointer; padding: 1.5rem 0; display: flex; justify-content: space-between; align-items: center; text-align: left; transition: border-color .25s; }
.ensemble-toggle:hover { border-color: rgba(232,101,10,0.4); }
.ensemble-toggle-label { font-family: var(--mono); font-size: 0.78rem; letter-spacing: 0.28em; text-transform: uppercase; color: var(--accent); opacity: 0.8; }
.ensemble-toggle-hint { font-family: var(--mono); font-size: 0.75rem; color: var(--cream); opacity: 0.35; display: flex; align-items: center; gap: 0.7rem; }
.toggle-arrow { transition: transform .3s; display: inline-block; }
.ensemble-toggle.open .toggle-arrow { transform: rotate(180deg); }
.ensemble-panel { display: none; padding: 2.5rem 0 1rem; }
.ensemble-panel.open { display: block; }
.ensemble-gruppe-label { font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.35em; text-transform: uppercase; color: var(--accent); opacity: 0.55; margin: 2rem 0 1.2rem; padding-bottom: 0.6rem; border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 0.8rem; }
.ensemble-gruppe-label::before { content: ''; width: 16px; height: 1px; background: var(--accent); opacity: 0.5; }
.ensemble-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 2px; }
.ensemble-person { background: var(--card); padding: 1.6rem; display: flex; gap: 1.2rem; align-items: center; border-left: 2px solid transparent; transition: border-color .22s, background .22s; }
.ensemble-person:hover { border-left-color: var(--accent); background: #1e1a14; }
.ensemble-foto { width: 54px; height: 54px; border-radius: 50%; object-fit: cover; flex-shrink: 0; border: 2px solid rgba(232,101,10,0.25); cursor: zoom-in; transition: border-color .22s; }
.ensemble-foto:hover { border-color: var(--accent); }
.ensemble-initials { width: 54px; height: 54px; border-radius: 50%; background: rgba(232,101,10,0.1); border: 2px solid rgba(232,101,10,0.2); display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-family: 'Playfair Display', serif; font-size: 1.1rem; color: var(--accent); opacity: 0.7; font-style: italic; }
.ensemble-info { min-width: 0; }
.ensemble-rolle { font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--accent); opacity: 0.65; display: block; margin-bottom: 0.3rem;    
	 /* -------- Worttrennung ---------- */
    hyphens: auto;                 /* echte Silbentrennung (mit Bindestrich) */
    overflow-wrap: anywhere;      /* fallback für Browser ohne hyphens   */
    word-break: normal;           /* kein brutales break‑all */

    /* optional: Mindestlängen vor/nach Trennstrich */
    hyphenate-limit-chars: 6 3;    /* mindestens 6/3 Zeichen, falls unterstützt */  
    }
.ensemble-name { font-family: 'Playfair Display', serif; font-size: 1.05rem; font-weight: 600; color: var(--cream); line-height: 1.2; }

/* WEITERE INSZENIERUNGEN */
.weitere-ins-wrap { max-width: 1120px; margin: 3.5rem auto 0; }
.weitere-ins-toggle { width: 100%; background: none; border: none; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); cursor: pointer; padding: 1.5rem 0; display: flex; justify-content: space-between; align-items: center; text-align: left; transition: border-color .25s; }
.weitere-ins-toggle:hover { border-color: rgba(232,101,10,0.4); }
.weitere-ins-toggle-label { font-family: var(--mono); font-size: 0.78rem; letter-spacing: 0.28em; text-transform: uppercase; color: var(--accent); opacity: 0.75; }
.weitere-ins-toggle-hint { font-family: var(--mono); font-size: 0.75rem; color: var(--cream); opacity: 0.35; display: flex; align-items: center; gap: 0.7rem; }
.weitere-ins-toggle.open .toggle-arrow { transform: rotate(180deg); }
.weitere-ins-list { display: none; flex-direction: column; gap: 2px; padding-top: 2px; }
.weitere-ins-list.open { display: flex; }
.wi-item { background: var(--card); padding: 1.8rem 2rem; display: grid; grid-template-columns: 68px 1fr auto; gap: 1.8rem; align-items: center; border-left: 3px solid transparent; opacity: 0.6; transition: opacity .25s, border-color .25s; }
.wi-item:hover { opacity: 1; border-left-color: rgba(232,101,10,0.35); }
.wi-plakat { width: 68px; aspect-ratio: 2/3; object-fit: cover; border: 1px solid var(--border); display: block; cursor: zoom-in; transition: opacity .2s; }
.wi-plakat:hover { opacity: 0.85; }
.wi-plakat-ph { width: 68px; aspect-ratio: 2/3; background: var(--black); border: 1px dashed rgba(232,101,10,0.15); display: flex; align-items: center; justify-content: center; font-size: 1.5rem; opacity: 0.25; }
.wi-genre { font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.2em; color: var(--accent); opacity: 0.7; margin-bottom: 0.4rem; }
.wi-titel { font-family: 'Playfair Display', serif; font-size: 1.25rem; font-weight: 600; color: var(--cream); margin-bottom: 0.5rem; line-height: 1.2; }
.wi-desc { font-size: 0.92rem; line-height: 1.65; color: var(--cream); opacity: 0.5; font-style: italic; }
.wi-badge { font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.18em; text-transform: uppercase; padding: 0.35rem 0.9rem; white-space: nowrap; align-self: flex-start; }
.wi-badge.beendet   { border: 1px solid rgba(245,237,224,0.12); color: var(--cream); opacity: 0.35; }
.wi-badge.demnächst { background: var(--accent); color: var(--black); }
.wi-termine { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-top: 0.8rem; }
.wi-termin { font-family: var(--mono); font-size: 0.72rem; padding: 0.3rem 0.7rem; background: rgba(245,237,224,0.05); display: flex; gap: 0.4rem; align-items: center; }
.wi-termin.vergangen { opacity: 0.3; text-decoration: line-through; }
.wi-termin.ausverkauft { color: #e05050; }
.wi-termin.buchbar { cursor: pointer; text-decoration: none; color: var(--cream); border: 1px solid rgba(232,101,10,0.3); }
.wi-termin.buchbar:hover { background: rgba(232,101,10,0.15); }

/* ÜBER UNS */
/* -------------------------------------------------
   Grundvariablen (Farben & Fonts – unverändert)
--------------------------------------------------- */
:root {
    /* Grid‑Mindestbreite für Desktop (falls du ein Grid in .ueber nutzt) */
    --grid-min-col: 500px;
}

/* -------------------------------------------------
   Sektion „Über Uns“
--------------------------------------------------- */
.ueber { background: var(--dark); }

.ueber-inner {
    max-width: 1120px;
    margin: 0 auto;
    padding-left: 1rem;      /* wichtig für kleine Bildschirme */
    padding-right: 1rem;
}

/* -------------------------------------------------
   Stage (Bild‑Container)
--------------------------------------------------- */
.stage {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;          /* fallback, wenn kein Bild vorhanden ist */
    overflow: hidden;
    background: var(--card);      /* Hintergrundfarbe für den Platzhalter */
}

/* Bild – immer komplett skalieren */
.stage img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* -------------------------------------------------
   Platzhalter‑Elemente (falls kein Bild)
--------------------------------------------------- */
.stage-curtain-l,
.stage-curtain-r,
.stage-light,
.stage-boards,
.stage-text {
    position: absolute;
    /* Hier kommen deine bestehenden Styles rein – wir lassen sie unverändert. */
}

/* -------------------------------------------------
   Responsives Verhalten
--------------------------------------------------- */

/* Tablet */
@media (max-width: 768px) {
    :root { --grid-min-col: 300px; }
}

/* Kleine Smartphones */
@media (max-width: 480px) {
    :root { --grid-min-col: 260px; }

    .ueber-inner {
        padding-left: 0.75rem;
        padding-right: 0.75rem;
    }
}

/* Sehr kleine Geräte – 360 px und darunter */
@media (max-width: 360px) {
    .ueber-inner {
        padding-left: 0.5rem;
        padding-right: 0.5rem;
    }

    .stage {
        aspect-ratio: auto;          /* Höhe folgt dem Bildinhalt */
    }

    .stage-text p {
        font-size: 0.9rem;           /* etwas kleinerer Text, damit er reinpasst */
    }
}

/*
.stat-strip { display: grid; grid-template-columns: repeat(3,1fr); border-top: 1px solid var(--border); margin-top: 0; }
.stat-item { padding: 1.4rem 1rem; text-align: center; border-right: 1px solid var(--border); }
.stat-item:last-child { border-right: none; }
.stat-num { font-family: 'Playfair Display', serif; font-size: 2rem; font-weight: 700; color: var(--accent); display: block; }
.stat-lbl { font-family: var(--mono); font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--cream); opacity: 0.4; }
*/
/* -------------------------------------------------
   1️⃣ Basis‑Layout – 3 Spalten bei genügend Platz
   ------------------------------------------------- */
.stat-strip{
    /* Grid‐Grundstruktur */
    display: grid;
    gap: 0;                               /* wir nutzen den Border als “Trenner” */

    /* 3 Spalten, solange mindestens 3 × min‑Breite (≈250 px) passen.
       Fällt die Breite darunter, legt das Grid automatisch nur so
       viele Spalten an, wie noch reinpassen → automatischer Umbruch. */
    grid-template-columns:
        repeat(auto-fit, minmax(250px, 1fr));

    border-top: 1px solid var(--border);
    margin-top: 0;
}

/* -------------------------------------------------
   2️⃣ Einzelne Kachel
   ------------------------------------------------- */
.stat-item{
    padding: 1.4rem 1rem;
    text-align:center;

    /* Trenn‑Border rechts – nur, wenn das Element nicht das letzte in seiner Zeile ist */
    border-right:1px solid var(--border);
}

/* Das rechte Ende jeder **Zeile** soll keinen Border mehr haben.
   Wir nutzen den „grid‑row“ – „grid‑column“-Trick:  */
.stat-item:nth-child(3n){               /* jedes dritte Element (erste Zeile) */
    border-right:none;                  /* rechter Rand der Zeile entfernen */
}

/* Für kleinere Bildschirme gibt es keine feste “jede 3. Zeile” mehr,
   deshalb überschreiben wir den Border‑Reset per Media Query: */
@media (max-width: 768px){
    .stat-item{
        border-right:1px solid var(--border);
    }
    /* Jetzt entfernen wir den rechten Rand nur am *letzten* Element
       jeder Zeile – das lässt sich mit dem Grid‑„auto‑fit“‑Verhalten
       über die Pseudo‑Klasse :last-child lösen: */
    .stat-item:last-child{
        border-right:none;
    }
}

/* -------------------------------------------------
   3️⃣ Inhalt (Zahl & Beschriftung)
   ------------------------------------------------- */
.stat-num{
    font-family:'Playfair Display',serif;
    font-size:2rem;
    font-weight:700;
    color:var(--accent);
    display:block;
}
.stat-lbl{
    font-family:var(--mono);
    font-size:.65rem;
    letter-spacing:.2em;
    text-transform:uppercase;
    color:var(--cream);
    opacity:.4;
}

/* -------------------------------------------------
   4️⃣ Noch ein kleiner Feinschliff für sehr kleine Geräte
      (≤ 360 px) – alles in einer Spalte, kein rechter Border mehr.
   ------------------------------------------------- */
@media (max-width: 360px){
    .stat-strip{
        grid-template-columns:1fr;          /* immer nur eine Spalte */
    }
    .stat-item{
        border-right:none;                  /* kein “Trenner” mehr nötig */
    }
}


.platt-quote { border-left: 3px solid var(--accent); padding: 1rem 1.5rem; margin: 2rem 0; }
.platt-quote q { font-family: 'Playfair Display', serif; font-size: 1.3rem; font-style: italic; color: var(--accent); opacity: 0.9; }
.platt-quote cite { display: block; margin-top: 0.5rem; font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.2em; color: var(--cream); opacity: 0.4; }


/* FÖRDERUNG */
/* ---------- Layout ----------
   Container zentrieren + Seitenpadding */
.foerderung { background: var(--dark); }
.fg-inner {
    max-width: 1120px;
    margin: 0 auto;
    padding-left: 1rem;      /* <-- wichtig für kleine Bildschirme */
    padding-right: 1rem;
}

/* ---------- Grid ----------
   Auto‑Fill + Minmax (variabel) */
.fg-grid {
    display: grid;
    gap: 2rem;                     /* Abstand zwischen Karten */
    margin-top: 3rem;
    grid-template-columns:
        repeat(auto-fill, minmax(var(--grid-min-col), 1fr));
}

/* ---------- Karten ----------
   (keine Änderungen nötig) */
.fg-item {
    background: var(--card);
    padding: 2rem;
    border-top: 3px solid transparent;
    transition: border-color .25s;
}
.fg-item:hover { border-top-color: var(--accent); }
.fg-date {
    font-family: var(--mono);
    font-size: .72rem;
    letter-spacing: .2em;
    color: var(--accent);
    opacity: .7;
    margin-bottom: .6rem;
}
.fg-title {
    font-family: 'Playfair Display', serif;
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--cream);
    margin-bottom: .8rem;
    line-height: 1.3;
}
.fg-text {
    font-size: 1rem;
    color: var(--cream);
    opacity: .65;
    line-height: 1.7;
}

/* ---------- Responsives Verhalten ----------
   Tablet */
@media (max-width: 768px) {
    :root { --grid-min-col: 300px; }
}

/* Kleine Smartphones */
@media (max-width: 480px) {
    :root { --grid-min-col: 260px; }
}

/* Sehr kleine Geräte – 360 px und darunter */
@media (max-width: 360px) {
    .fg-grid {
        grid-template-columns: 1fr;   /* immer nur eine Spalte */
    }
    .fg-item {
        padding: 1.5rem;               /* etwas kompakter */
    }
}


/* AKTUELLES */
.aktuelles { background: var(--dark); }
.ak-inner { max-width: 1120px; margin: 0 auto; }
.ak-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px,1fr)); gap: 2px; margin-top: 3rem; }
.ak-item { background: var(--card); padding: 2rem; border-top: 3px solid transparent; transition: border-color .25s; }
.ak-item:hover { border-top-color: var(--accent); }
.ak-date { font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.2em; color: var(--accent); opacity: 0.7; margin-bottom: 0.6rem; }
.ak-title { font-family: 'Playfair Display', serif; font-size: 1.3rem; font-weight: 700; color: var(--cream); margin-bottom: 0.8rem; line-height: 1.3; }
.ak-text { font-size: 1rem; color: var(--cream); opacity: 0.65; line-height: 1.7; }

/* GALERIE */
.galerie-section { max-width: 1120px; margin: 0 auto; margin-top: 5rem; }
.galerie-label { font-family: var(--mono); font-size: 0.78rem; letter-spacing: 0.35em; text-transform: uppercase; color: var(--accent); opacity: 0.8; display: flex; align-items: center; gap: 1rem; margin-bottom: 1.5rem; }
.galerie-label::before { content: ''; width: 28px; height: 1px; background: var(--accent); }
.galerie-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 3px; }
.galerie-item { position: relative; aspect-ratio: 4/3; overflow: hidden; cursor: pointer; }
.galerie-item img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s ease; filter: brightness(0.85); }
.galerie-item:hover img { transform: scale(1.04); filter: brightness(1); }
.galerie-caption { position: absolute; bottom: 0; left: 0; right: 0; padding: 1rem 1.2rem; background: linear-gradient(to top, rgba(10,8,6,0.85), transparent); font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.12em; color: var(--cream); opacity: 0; transition: opacity .3s; }
.galerie-item:hover .galerie-caption { opacity: 1; }

/* STÜCK-GALERIE */
.stueck-galerie { max-width: 1120px; margin: 3.5rem auto 0; }
.stueck-galerie-label { font-family: var(--mono); font-size: 0.78rem; letter-spacing: 0.32em; text-transform: uppercase; color: var(--accent); opacity: 0.8; display: flex; align-items: center; gap: 1rem; margin-bottom: 1.5rem; }
.stueck-galerie-label::before { content: ''; width: 24px; height: 1px; background: var(--accent); }
.stueck-galerie-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 3px; }
.sg-item { position: relative; aspect-ratio: 4/3; overflow: hidden; cursor: pointer; background: var(--card); }
.sg-item img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s ease, filter .4s; filter: brightness(0.82); }
.sg-item:hover img { transform: scale(1.06); filter: brightness(1); }
.sg-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(10,8,6,0.75) 0%, transparent 55%); opacity: 0; transition: opacity .3s; display: flex; align-items: flex-end; padding: 1.2rem; }
.sg-item:hover .sg-overlay { opacity: 1; }
.sg-overlay span { font-family: var(--mono); font-size: 0.78rem; letter-spacing: 0.1em; color: var(--cream); line-height: 1.4; }
.sg-zoom-hint { position: absolute; top: 0.8rem; right: 0.8rem; background: rgba(10,8,6,0.7); color: var(--accent); font-size: 1rem; width: 2rem; height: 2rem; display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity .3s; }
.sg-item:hover .sg-zoom-hint { opacity: 1; }

/* MITMACHEN */
.mitmachen { background: var(--black); }
.mit-inner { max-width: 1120px; margin: 0 auto; }
.mit-intro { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; margin-bottom: 3rem; }
.mit-cards { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; }
.mit-card { background: var(--card); padding: 2.5rem; border-top: 3px solid transparent; transition: border-color .25s; }
.mit-card:hover { border-top-color: var(--accent); }
.mit-card .ic { font-size: 2rem; margin-bottom: 1rem; }
.mit-card h3 { font-family: 'Playfair Display', serif; font-size: 1.3rem; font-weight: 700; color: var(--cream); margin-bottom: 0.8rem; }
.mit-card p { font-size: 1rem; color: var(--cream); opacity: 0.6; line-height: 1.7; }

/* THEATERSCHULE */
.theaterschule { background: var(--dark); }
.ts-inner { max-width: 1120px; margin: 0 auto; }
.ts-intro { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: start; margin-bottom: 3rem; }
.ts-cards { display: grid; grid-template-columns: repeat(auto-fill,minmax(220px,1fr)); gap: 2px; margin-bottom: 2.5rem; }
.ts-card { background: var(--card); padding: 2rem; border-top: 3px solid transparent; transition: border-color .25s; }
.ts-card:hover { border-top-color: var(--accent); }
.ts-icon { font-size: 1.8rem; display: block; margin-bottom: 0.8rem; }
.ts-name { font-family: 'Playfair Display', serif; font-size: 1.15rem; font-weight: 700; color: var(--cream); margin-bottom: 0.3rem; }
.ts-alter { font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.18em; color: var(--accent); opacity: 0.7; }
.ts-info { font-size: 0.95rem; color: var(--cream); opacity: 0.6; line-height: 1.65; margin-top: 0.6rem; }
.ts-kontakt { background: var(--card); padding: 2rem 2.5rem; border-left: 4px solid var(--accent); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1.5rem; }
.ts-kontakt-label { font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.25em; text-transform: uppercase; color: var(--accent); opacity: 0.7; margin-bottom: 0.4rem; }
.ts-kontakt-name { font-family: 'Playfair Display', serif; font-size: 1.1rem; color: var(--cream); }

/* SPIELSTÄTTE */
.spielstaette { background: var(--black); }
.ss-inner { max-width: 1120px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: start; }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; margin-top: 2.5rem; background: var(--border); border: 1px solid var(--border); }
.contact-item { background: var(--card); padding: 1.2rem 1.5rem; }
.contact-label { font-family: var(--mono); font-size: 0.65rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--accent); opacity: 0.6; display: block; margin-bottom: 0.3rem; }
.contact-val { font-size: 1rem; color: var(--cream); opacity: 0.8; text-decoration: none; }
.contact-val:hover { color: var(--accent); }
.map-box { position: relative; }
.map-box iframe { width: 100%; height: 380px; border: none; display: block; filter: sepia(30%) hue-rotate(15deg) brightness(0.75); }
.map-caption { display: flex; justify-content: space-between; align-items: center; padding: 0.8rem 0; font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.1em; color: var(--cream); opacity: 0.45; }
.map-caption a { color: var(--accent); opacity: 0.7; text-decoration: none; }
.map-caption a:hover { opacity: 1; }

/* LIGHTBOX */
.lightbox { display: none; position: fixed; inset: 0; z-index: 1000; background: rgba(5,4,2,0.96); flex-direction: column; align-items: center; justify-content: center; }
.lightbox.open { display: flex; }
.lightbox-main { position: relative; display: flex; align-items: center; justify-content: center; width: 100%; flex: 1; padding: 4rem 5rem; }
.lightbox img { max-width: 88vw; max-height: 82vh; object-fit: contain; border: 1px solid rgba(232,101,10,0.2); box-shadow: 0 0 60px rgba(0,0,0,0.8); user-select: none; }
.lightbox-close { position: absolute; top: 1.2rem; right: 1.8rem; font-size: 2.2rem; color: var(--cream); opacity: 0.5; cursor: pointer; background: none; border: none; line-height: 1; transition: opacity .2s, color .2s; z-index: 10; font-family: var(--mono); padding: 0.3rem 0.6rem; }
.lightbox-close:hover { opacity: 1; color: var(--accent); }
.lightbox-arrow { position: absolute; top: 50%; transform: translateY(-50%); background: rgba(10,8,6,0.7); border: 1px solid rgba(232,101,10,0.2); color: var(--cream); font-size: 1.6rem; cursor: pointer; width: 3.2rem; height: 3.2rem; display: flex; align-items: center; justify-content: center; transition: background .2s, color .2s; user-select: none; font-family: var(--mono); }
.lightbox-arrow:hover { background: var(--accent); color: var(--black); border-color: var(--accent); }
.lightbox-arrow.prev { left: 1rem; }
.lightbox-arrow.next { right: 1rem; }
.lightbox-arrow.hidden { opacity: 0; pointer-events: none; }
.lightbox-footer { padding: 0.8rem 2rem 1.4rem; display: flex; flex-direction: column; align-items: center; gap: 0.5rem; width: 100%; }
.lightbox-caption { font-family: var(--mono); font-size: 0.85rem; letter-spacing: 0.15em; color: var(--cream); opacity: 0.65; text-align: center; }
.lightbox-counter { font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.2em; color: var(--accent); opacity: 0.6; }
.lightbox-dots { display: flex; gap: 0.5rem; margin-top: 0.3rem; }
.lb-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--cream); opacity: 0.2; cursor: pointer; transition: opacity .2s, background .2s; }
.lb-dot.active { background: var(--accent); opacity: 1; }

/* SOCIAL */
.social-bar { display: flex; gap: 0.8rem; margin-top: 1.4rem; flex-wrap: wrap; }
.social-link { width: 44px; height: 44px; border-radius: 50%; background: rgba(245,237,224,0.06); border: 1px solid rgba(245,237,224,0.12); display: flex; align-items: center; justify-content: center; text-decoration: none; font-size: 1.1rem; transition: background .2s, border-color .2s, transform .2s; color: var(--cream); opacity: 0.6; }
.social-link:hover { background: var(--accent); border-color: var(--accent); opacity: 1; transform: translateY(-2px); color: var(--black); }
.hero-social { position: absolute; bottom: 2.5rem; left: 3rem; display: flex; gap: 0.7rem; z-index: 2; }
.hero-social .social-link { width: 38px; height: 38px; font-size: 1rem; background: rgba(10,8,6,0.5); border-color: rgba(232,101,10,0.25); opacity: 0.55; }
.hero-social .social-link:hover { opacity: 1; }

.social-link.fb{
    color: #ffb400;          /* Facebook‑Farbe, z. B. #ffb400 */
    display: inline-block;
}
.social-link.fb:hover{
    color: var(--cream);
}

.social-link.ig{
    color: #e1306c;               /* Instagram‑Typfarbe */
    width: 2.5rem;
    height: 2.5rem;
}
.social-link.ig:hover{color:#ffb400;}


/* VORSTAND */
.vorstand-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px,1fr)); gap: 1.2rem; margin-top: 1rem; }
.vorstand-item { display: flex; flex-direction: column; align-items: center; gap: 0.6rem; text-align: center; }
.vorstand-foto { width: 72px; height: 72px; border-radius: 50%; object-fit: cover; border: 2px solid rgba(232,101,10,0.3); cursor: zoom-in; transition: border-color .2s; }
.vorstand-foto:hover { border-color: var(--accent); }
.vorstand-initials { width: 72px; height: 72px; border-radius: 50%; background: rgba(232,101,10,0.1); border: 2px solid rgba(232,101,10,0.2); display: flex; align-items: center; justify-content: center; font-family: 'Playfair Display', serif; font-size: 1.3rem; color: var(--accent); font-style: italic; }
.vorstand-funktion { font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--accent); opacity: 0.65; }
.vorstand-name { font-family: 'Playfair Display', serif; font-size: 0.95rem; color: var(--cream); opacity: 0.82; line-height: 1.3; }

/* PARTNER */
.partner-section { background: var(--dark); padding: 3rem 3rem; border-top: 1px solid var(--border); }
.partner-inner { max-width: 1120px; margin: 0 auto; }


/* -------------------------------------------------
   SECTION‑LABEL
------------------------------------------------- */
.partner-label {
  font-family: var(--mono);
  font-size: 0.85rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;

  /* Dezent, aber gut lesbar */
  color: rgba(255, 255, 255, 0.70);   /* statt opacity 0.28 auf Farbe verteilt */
  text-align: center;
  margin-bottom: 1.5rem;
}

/* -------------------------------------------------
   LIST / ITEM
------------------------------------------------- */
.partner-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem;
}

.partner-item {
  font-family: var(--mono);
  font-size: 0.92rem;
  letter-spacing: 0.08em;

  /* Text fast voll deckend → besserer Kontrast */
  color: var(--cream-bright);
  opacity: 0.90;                     /* vorher 0.38 */

  text-decoration: none;
  padding: 0.5rem 1rem;

  /* Rahmen leicht sichtbar, aber nicht zu dominant */
  border: 1px solid rgba(255, 255, 255, 0.20);
  transition: all .15s ease-out;    /* flüssigeres Hover‑Feedback */

  white-space: nowrap;
}

/* HOVER – kräftige Hervorhebung */
.partner-item:hover {
  opacity: 1;                                 /* volle Deckkraft */
  border-color: var(--accent-strong);         /* Akzentfarbe */
  color: var(--accent-strong);
}

/* Nicht klickbare Items bleiben unverändert, nur optisch deaktiviert */
.partner-item.no-link {
  pointer-events: none;
  cursor: default;
  opacity: 0.55;               /* leicht ausgegraut, damit klar ist, dass es nicht aktiv ist */
}

/* MODALS */
.modal-overlay { display: none; position: fixed; inset: 0; z-index: 500; background: rgba(5,4,2,0.92); overflow-y: auto; padding: 3rem 1.5rem; }
.modal-overlay.open { display: flex; align-items: flex-start; justify-content: center; }
.modal-box { background: var(--dark); border: 1px solid var(--border); max-width: 760px; width: 100%; padding: 3rem 3.5rem; position: relative; margin: auto; }
.modal-close { position: absolute; top: 1.2rem; right: 1.5rem; background: none; border: none; cursor: pointer; font-size: 1.8rem; color: var(--cream); opacity: 0.4; font-family: var(--mono); line-height: 1; transition: opacity .2s, color .2s; }
.modal-close:hover { opacity: 1; color: var(--accent); }
.modal-label { font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.35em; text-transform: uppercase; color: var(--accent); opacity: 0.8; margin-bottom: 0.8rem; }
.modal-title { font-family: 'Playfair Display', serif; font-size: 2rem; font-weight: 700; color: var(--cream); margin-bottom: 2.5rem; }
.modal-section { margin-bottom: 2rem; }
.modal-section h3 { font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.25em; text-transform: uppercase; color: var(--accent); opacity: 0.7; margin-bottom: 0.8rem; padding-bottom: 0.5rem; border-bottom: 1px solid var(--border); }
.modal-section p, .modal-section address { font-size: 1rem; line-height: 1.8; color: var(--cream); opacity: 0.72; font-style: normal; }
.modal-section a { color: var(--accent); opacity: 0.85; text-decoration: none; }
.modal-section a:hover { opacity: 1; }
.modal-section table { border-collapse: collapse; width: 100%; }
.modal-section table td { padding: 0.3rem 1rem 0.3rem 0; font-size: 1rem; color: var(--cream); opacity: 0.72; vertical-align: top; line-height: 1.6; }
.modal-section table td:first-child { font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.1em; color: var(--accent); opacity: 0.6; white-space: nowrap; padding-right: 1.5rem; }

/* HERO MIT BILD */
.hero-img { position: absolute; inset: 0; z-index: 1; background-size: cover; background-position: center; background-repeat: no-repeat; }
.hero-img::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(10,8,6,0.92) 0%, rgba(10,8,6,0.55) 50%, rgba(10,8,6,0.4) 100%); }

/* ANIMATIONEN */
@keyframes line-drop { 0%,100% { opacity:1; } 50% { opacity:0.3; } }
.reveal { opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in { opacity:1; transform:none; }

/* FOOTER */
footer { background: var(--dark); border-top: 1px solid var(--border); }
.foot-inner { max-width: 1120px; margin: 0 auto; padding: 4rem 3rem 3rem; display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 3rem; }
.fn { font-family: 'Playfair Display', serif; font-size: 1.3rem; font-weight: 700; color: var(--cream); margin-bottom: 0.4rem; }
.fs { font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.25em; color: var(--accent); opacity: 0.7; }
.foot-brand p { font-size: 1rem; color: var(--cream); opacity: 0.5; margin-top: 0.8rem; line-height: 1.65; }
.foot-col h4 { font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.28em; text-transform: uppercase; color: var(--accent); opacity: 0.6; margin-bottom: 1.2rem; }
.foot-col ul { list-style: none; }
.foot-col li { margin-bottom: 0.6rem; }
.foot-col a { font-size: 1rem; color: var(--cream); opacity: 0.55; text-decoration: none; transition: opacity .2s, color .2s; }
.foot-col a:hover { opacity: 1; color: var(--accent); }
.foot-bottom { max-width: 1120px; margin: 0 auto; padding: 1.5rem 3rem 2rem; border-top: 1px solid var(--border); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; }
.foot-bottom p { font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.08em; color: var(--cream); opacity: 0.3; }
.foot-platt { font-family: 'Playfair Display', serif; font-style: italic; color: var(--accent); opacity: 0.35; font-size: 0.95rem; }

@media (max-width: 1330px) {
    nav { padding: 1.1rem 1.4rem; }
    .nav-links, .nav-cta { display: none; }
    .hero, .sec { padding-left: 1.4rem; padding-right: 1.4rem; }
    .hero { padding-bottom: 4rem; }
    .ueber-inner, .ss-inner, .mit-intro { grid-template-columns: 1fr; gap: 2.5rem; }
    .mit-cards { grid-template-columns: 1fr; }
    .foot-inner { grid-template-columns: 1fr 1fr; }
    .shows-grid { grid-template-columns: repeat(auto-fill, minmax(140px,1fr)); }
    .contact-grid { grid-template-columns: 1fr; }
    .karten-bar { flex-direction: column; align-items: flex-start; }
    .ts-intro { grid-template-columns: 1fr; }
}



/* -------------------------------------------------
   Schriftfarben kräftiger machen
--------------------------------------------------- */

/* Grundvariablen – ggf. hier ergänzen */
:root{
    /* Beispiel für extra starke Textfarbe
       --text-strong:#ffea00;   // uncomment if you like it */
}

/* .partner-item – Navigation / Partner‑Liste */
.partner-item{
    font-family: var(--mono);
    font-size:0.92rem;
    letter-spacing:0.08em;

    color:var(--accent-strong);  /* kräftiger Akzent */
    opacity:1;                    /* keine Transparenz */

    text-decoration:none;
    padding:.5rem 1rem;
    border:1px solid rgba(255,255,255,.20);
    transition:all .15s ease-out;
    white-space:nowrap;
}
.partner-item:hover{
    opacity:1;
    border-color:var(--accent-strong);
    color:var(--accent-strong);
}

/* Nicht‑klickbare Items – leicht ausgegraut, aber lesbar */
.partner-item.no-link{
    pointer-events:none;
    cursor:default;
    opacity:.55;   /* bleibt bewusst reduziert */
}

/* Ensemble‑Titel */
.ensemble-name{
    font-family:'Playfair Display',serif;
    font-size:1.05rem;
    font-weight:600;
    color:var(--cream-bright);  /* helleres Creme */
    line-height:1.2;
    opacity:1;
}

 
/* -------------------------------------------------
   Hamburger‑Button (versteckt im Desktop‑Modus)
   ------------------------------------------------- */
.hamburger {
    display: none;                     /* erst per Media‑Query sichtbar */
    background: transparent;
    border: 0;
    font-size: 1.8rem;
    line-height: 1;
    color: var(--cream-bright);        /* gleiche Farbe wie deine anderen Texte */
    cursor: pointer;
    padding: 0.4rem 0.6rem;
}

 /* -------------------------------------------------
    Bestehende Styles (z. B. .stage, .stat-strip) …
    ------------------------------------------------- */
 
/* -----------------------------------------------------------------
   Grundlayout für die neue Navigationsleiste
   ----------------------------------------------------------------- */
nav {
    position: fixed;
    inset: 0 0 auto;
    z-index: 200;
    padding: 1.4rem 3rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: linear-gradient(to bottom, rgba(10,8,6,0.98) 35%, transparent 100%); 
}

/* Logo – bleibt unverändert (aus deinem Original) */
.nav .logo {
    display: flex;
    flex-direction: column;
    color: var(--cream-bright);
    text-decoration: none;
}

/* Hamburger‑Button – erst ab kleiner Breite sichtbar */
.hamburger {
    display: none;               /* Desktop: unsichtbar */
    background: transparent;
    border: 0;
    font-size: 1.8rem;
    color: var(--cream-bright);
    cursor: pointer;
}

/* Menü‑Liste – Desktop‑Version (horizontal) */
.nav-links {
    display: flex;
    gap: 1.2rem;
    list-style: none;
    margin: 0;
    padding: 0;
}
.nav-links a {
    color: var(--cream);
    text-decoration: none;
    font-family: var(--mono);
    transition: color .15s ease;
    opacity:0.85; 
}
.nav-links a:hover { color: var(--accent-strong); }

/* -----------------------------------------------------------------
   Mobile‑Breakpoint (max‑width 1320 px)
   ----------------------------------------------------------------- */
@media (max-width: 1320px) {
    .hamburger { display: block; }           /* jetzt sichtbar */

    /* Menü wird zunächst versteckt */
    .nav-links {
        position: absolute;
        top: 100%;          /* direkt unter dem Header */
        left: 0;
        right: 0;
        flex-direction: column;
        max-height: 0;      /* animiertes Aufklappen */
        overflow: hidden;
        transition: max-height .3s ease-out;
        background: linear-gradient(to bottom, transparent 0%, rgba(10,8,6,0.95) 03%,  rgba(10,8,6,0.95) 97%, transparent 100%); 
    }

    /* Wenn die Klasse .open am <nav> liegt → Menü einblenden */
    #main-nav.open .nav-links { max-height: 550px; }   /* genug für alle Links */

    /* Abstand zwischen den einzelnen Items im Mobile‑Menu */
    .nav-links li { padding: 0.8rem 1rem; }
}

