/* ========================================
   HEADER STYLES - FEUERWEHR RAUBLING
   ========================================

   Diese Datei enthält alle Styles für den Header.

   INHALTSVERZEICHNIS:
   1. HEADER BASE (Grundstyles)
   2. SITE BRANDING (Logo & Titel)
   3. MAIN NAVIGATION (Hauptmenü)
   4. MOBILE MENU (Hamburger-Menü)
   5. SHRINK ON SCROLL (Header-Verkleinerung)
   6. LAYOUT: INLINE (Logo links, Menü rechts)
   7. LAYOUT: CENTERED (Logo & Menü zentriert)
   8. LAYOUT: STACKED (Logo oben, Menü darunter)
   9. RESPONSIVE (Tablet & Mobile)

   FARBEN ANPASSEN:
   - Suche nach "HIER ÄNDERN" für alle anpassbaren Stellen
   - Hauptfarben sind in style.css definiert (--red, --dark-gray, etc.)
======================================== */

/* ========================================
   1. SITE HEADER - BASE (Grundstyles)
   ========================================

   Der Header ist "fixed" = bleibt beim Scrollen oben.
   Beim Scrollen wird er kleiner (siehe SHRINK ON SCROLL).
======================================== */

.site-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    /* KEIN width: 100% — Safari berechnet das bei fixed-Elementen
       anders und kann den Header breiter als den Viewport machen.
       left: 0 + right: 0 reicht aus für volle Breite. */

    /* HIER ÄNDERN: Header-Hintergrundfarbe
       Standard: Weiß. Für dunklen Header: var(--dark-gray) */
    background-color: var(--white);

    /* HIER ÄNDERN: Schatten unter dem Header
       0 2px 8px = leichter Schatten
       0 4px 15px = stärkerer Schatten
       none = kein Schatten */
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);

    /* Z-Index: Header immer über anderem Content */
    z-index: 1000;

    /* Sanfter Übergang beim Verkleinern */
    transition: height 0.3s ease, padding 0.3s ease;
}

/* Header Container - begrenzt die Breite */
.site-header .container {
    max-width: var(--container-max-width);
    margin: 0 auto;
    padding: 0 var(--container-padding);
}

/* Header-Inhalt: Flexbox für Logo & Menü
   WICHTIG: Kein justify-content hier setzen!
   Die Ausrichtung wird über die Body-Klassen in den
   Layout-Regeln weiter unten gesteuert. */
.header-inner {
    display: flex;
    align-items: center;
    /* KEIN flex-wrap: wrap — das kann in Safari dazu führen,
       dass Elemente umbrechen und der Header doppelt so hoch wird.
       Stattdessen flex-wrap: nowrap (Standard). */

    /* min-height statt height: Header wächst mit wenn Inhalt
       mehr Platz braucht (z.B. bei schmalerem Browserfenster).
       Verhindert dass Menü-Schrift abgeschnitten wird. */
    min-height: var(--header-height-large);
    transition: min-height 0.3s ease;
}

/* ========================================
   2. SITE BRANDING (Logo & Titel)
   ========================================

   Enthält das Logo ODER den Site-Titel
   (abhängig davon, ob ein Logo im Customizer hochgeladen wurde)
======================================== */

.site-branding {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

/* LOGO-CONTAINER */
.site-logo {
    /* HIER ÄNDERN: Maximale Logo-Höhe im Normalzustand
       Wird beim Scrollen auf 50px reduziert (siehe SHRINK) */
    max-height: 70px;
    transition: max-height 0.3s ease;
}

.site-logo img {
    height: auto;
    /* HIER ÄNDERN: Logo-Höhe anpassen
       Empfohlen: 50-80px für Desktop */
    max-height: 70px;
    width: auto;
    display: block;
    transition: max-height 0.3s ease;
}

/* SITE-TITEL (wird angezeigt wenn kein Logo vorhanden) */
.site-title {
    margin: 0;
    /* HIER ÄNDERN: Schriftgröße des Site-Titels
       Standard: 1.75rem (28px) */
    font-size: 1.75rem;
    font-weight: 700;
    line-height: 1.2;
    transition: font-size 0.3s ease;
}

.site-title a {
    /* HIER ÄNDERN: Farbe des Site-Titels */
    color: var(--dark-gray);
    text-decoration: none;
}

.site-title a:hover {
    /* Hover-Farbe = Hauptfarbe (Rot) */
    color: var(--red);
}

/* SITE-BESCHREIBUNG (Untertitel/Tagline) */
.site-description {
    margin: 0;
    /* HIER ÄNDERN: Schriftgröße der Beschreibung */
    font-size: 0.875rem;
    color: var(--medium-gray);
    transition: font-size 0.3s ease, opacity 0.3s ease;
}

/* ========================================
   3. MAIN NAVIGATION (Hauptmenü)
   ========================================

   Das Hauptmenü wird in WordPress unter
   Design → Menüs → "Hauptmenü" gepflegt.
======================================== */

.main-navigation {
    display: flex;
    align-items: center;
}

.main-menu {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0;

    /* HIER ÄNDERN: Abstand zwischen Menü-Punkten
       Standard: 2rem (32px). Für engere Links: 1.5rem */
    gap: 2rem;
}

.main-menu li {
    margin: 0;
    padding: 0;
}

.main-menu a {
    display: block;

    /* HIER ÄNDERN: Farbe der Menü-Links */
    color: var(--dark-gray);
    text-decoration: none;

    /* HIER ÄNDERN: Schriftstärke der Links
       400 = normal, 500 = medium, 600 = semi-bold, 700 = bold */
    font-weight: 500;

    /* HIER ÄNDERN: Schriftgröße der Menü-Links */
    font-size: 1rem;

    padding: 0.5rem 0;
    position: relative;
    transition: color 0.2s ease, font-size 0.3s ease;
}

/* HOVER-EFFEKT: Animierter Unterstrich
   Ein roter Strich erscheint unter dem Link */
.main-menu a::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;

    /* HIER ÄNDERN: Dicke des Unterstrichs */
    height: 2px;

    /* HIER ÄNDERN: Farbe des Unterstrichs */
    background-color: var(--red);

    /* HIER ÄNDERN: Geschwindigkeit der Animation
       0.2s = schnell, 0.3s = mittel */
    transition: width 0.2s ease;
}

/* Unterstrich bei Hover und aktuellem Menü-Punkt */
.main-menu a:hover::after,
.main-menu .current-menu-item a::after {
    width: 100%;
}

.main-menu a:hover {
    /* Textfarbe beim Hover */
    color: var(--red);
}

/* AKTUELLER MENÜ-PUNKT
   Hervorhebung der aktuellen Seite im Menü */
.main-menu .current-menu-item a {
    color: var(--red);
}

/* ========================================
   4. DROPDOWN / SUBMENU
   ========================================

   Untermenüs werden automatisch von WordPress generiert,
   wenn du im Menü-Editor Seiten einrückst (nach rechts ziehen).

   WordPress fügt automatisch diese Klassen hinzu:
   - .menu-item-has-children: Eltern-Element mit Kindern
   - .sub-menu: Die verschachtelte Liste mit Untermenü-Punkten

   ANPASSEN:
   - Breite: min-width bei .sub-menu
   - Hintergrund: background bei .sub-menu
   - Schatten: box-shadow bei .sub-menu
   - Animation: transition bei .sub-menu
======================================== */

/* Parent-Element: Relativ positioniert für absolute Submenüs */
.main-menu .menu-item-has-children {
    position: relative;
}

/* Pfeil-Indikator für Menüpunkte mit Untermenü */
.main-menu .menu-item-has-children > a::after {
    /* HIER ÄNDERN: Pfeil-Symbol (▾ ▼ ↓ ⌄) */
    content: '▾';
    margin-left: 0.4rem;
    font-size: 0.75em;
    opacity: 0.7;
    transition: transform 0.2s ease;

    /* Reset: Kein Unterstrich für den Pfeil */
    position: static;
    width: auto;
    height: auto;
    background: none;
}

/* Pfeil dreht sich beim Hover */
.main-menu .menu-item-has-children:hover > a::after {
    transform: rotate(180deg);
}

/* ----------------------------------------
   SUBMENU STYLING
   ---------------------------------------- */

.main-menu .sub-menu {
    /* Positionierung: Unter dem Elternelement */
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 1000;

    /* HIER ÄNDERN: Breite des Dropdown-Menüs */
    min-width: 220px;

    /* Layout */
    display: flex;
    flex-direction: column;
    gap: 0;
    list-style: none;
    margin: 0;
    padding: 0.5rem 0;

    /* HIER ÄNDERN: Hintergrundfarbe */
    background: var(--white);

    /* HIER ÄNDERN: Schatten (größer = mehr Tiefe) */
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);

    /* Abgerundete Ecken */
    border-radius: 0 0 8px 8px;

    /* Versteckt bis Hover */
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);

    /* HIER ÄNDERN: Animations-Geschwindigkeit */
    transition: all 0.25s ease;
}

/* Submenu erscheint beim Hover */
.main-menu .menu-item-has-children:hover > .sub-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* ----------------------------------------
   SUBMENU ITEMS
   ---------------------------------------- */

.main-menu .sub-menu li {
    margin: 0;
    padding: 0;
}

.main-menu .sub-menu a {
    display: block;
    padding: 0.75rem 1.25rem;

    /* HIER ÄNDERN: Textfarbe im Submenu */
    color: var(--dark-gray);
    font-size: 0.9375rem;
    font-weight: 400;

    /* Kein Unterstrich-Effekt im Submenu */
    border-left: 3px solid transparent;
    transition: all 0.2s ease;
}

/* Hover-Effekt für Submenu-Links */
.main-menu .sub-menu a:hover {
    /* HIER ÄNDERN: Hover-Hintergrund */
    background-color: var(--light-gray);

    /* HIER ÄNDERN: Akzent-Linie links */
    border-left-color: var(--red);
    color: var(--red);
}

/* Kein animierter Unterstrich im Submenu */
.main-menu .sub-menu a::after {
    display: none;
}

/* Aktiver Submenu-Punkt */
.main-menu .sub-menu .current-menu-item a {
    background-color: var(--light-gray);
    border-left-color: var(--red);
    color: var(--red);
}

/* ----------------------------------------
   VERSCHACHTELTE SUBMENÜS (2. Ebene)
   ----------------------------------------
   Falls du noch tiefere Verschachtelung brauchst
   (Untermenü im Untermenü)
---------------------------------------- */

.main-menu .sub-menu .menu-item-has-children > .sub-menu {
    /* Öffnet nach rechts statt nach unten */
    top: 0;
    left: 100%;
    border-radius: 8px;
}

/* Pfeil zeigt nach rechts für 2. Ebene */
.main-menu .sub-menu .menu-item-has-children > a::after {
    content: '›';
    position: absolute;
    right: 1rem;
    transform: none;
}

.main-menu .sub-menu .menu-item-has-children:hover > a::after {
    transform: translateX(3px);
}

/* ========================================
   MOBILE MENU TOGGLE
======================================== */

.mobile-menu-toggle {
    display: none;
    background: none;
    border: none;
    padding: 0.5rem;
    cursor: pointer;
    z-index: 1001;
}

.menu-toggle-icon {
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
    width: 30px;
}

.menu-toggle-icon span {
    display: block;
    height: 3px;
    width: 100%;
    background-color: var(--dark-gray);
    border-radius: 2px;
    transition: all 0.3s ease;
}

.mobile-menu-toggle:hover .menu-toggle-icon span {
    background-color: var(--red);
}

/* Toggle Icon Animation (Optional für geöffneten Zustand) */
.mobile-menu-toggle[aria-expanded="true"] .menu-toggle-icon span:nth-child(1) {
    transform: rotate(45deg) translate(8px, 8px);
}

.mobile-menu-toggle[aria-expanded="true"] .menu-toggle-icon span:nth-child(2) {
    opacity: 0;
}

.mobile-menu-toggle[aria-expanded="true"] .menu-toggle-icon span:nth-child(3) {
    transform: rotate(-45deg) translate(7px, -7px);
}

/* ========================================
   SCROLLED STATE (.is-scrolled)
======================================== */

/* Kleinere Header-Höhe beim Scrollen */
body.is-scrolled .header-inner {
    min-height: var(--header-height-small);
}

/* Kleineres Logo beim Scrollen */
body.is-scrolled .site-logo {
    max-height: 50px;
}

body.is-scrolled .site-logo img {
    max-height: 50px;
}

/* Kleinerer Site-Title beim Scrollen */
body.is-scrolled .site-title {
    font-size: 1.5rem;
}

/* Site-Description ausblenden beim Scrollen */
body.is-scrolled .site-description {
    font-size: 0;
    opacity: 0;
    height: 0;
    overflow: hidden;
}

/* Kleinere Navigation-Schrift beim Scrollen */
body.is-scrolled .main-menu a {
    font-size: 0.9375rem;
}

/* ========================================
   RESPONSIVE - TABLET
======================================== */

@media (max-width: 992px) {
    .header-inner {
        min-height: 80px;
    }

    body.is-scrolled .header-inner {
        min-height: 60px;
    }
    
    .site-logo {
        max-height: 60px;
    }
    
    .site-logo img {
        max-height: 60px;
    }
    
    body.is-scrolled .site-logo {
        max-height: 45px;
    }
    
    body.is-scrolled .site-logo img {
        max-height: 45px;
    }
    
    .main-menu {
        gap: 1.5rem;
    }
    
    .main-menu a {
        font-size: 0.9375rem;
    }
}

/* ========================================
   RESPONSIVE - MOBILE
======================================== */

@media (max-width: 768px) {
    /* Mobile Menu Toggle anzeigen */
    .mobile-menu-toggle {
        display: block;
    }
    
    /* Navigation standardmäßig versteckt
       !important nötig, da Layout-Regeln (.header-type-einzeilig.logo-*.menu-* .main-navigation)
       außerhalb der Media Query display:flex/flex:1 setzen und höhere Spezifität haben */
    .main-navigation {
        position: fixed !important;
        top: var(--header-height-large) !important;
        left: 0 !important;
        right: 0 !important;
        bottom: auto !important;
        width: 100% !important;
        background-color: var(--white) !important;
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1) !important;
        max-height: 0 !important;
        overflow: hidden !important;
        transition: max-height 0.3s ease, top 0.3s ease !important;
        z-index: 999 !important;

        /* Layout-Regeln überschreiben */
        display: block !important;
        flex: initial !important;
        justify-content: initial !important;
        order: initial !important;
    }

    /* Navigation geöffnet - Menü wird sichtbar */
    .main-navigation.is-open {
        max-height: calc(100vh - var(--header-height-large)) !important;
        overflow-y: auto !important;
    }

    /* Bei gescrolltem Header andere Top-Position */
    body.is-scrolled .main-navigation {
        top: var(--header-height-small) !important;
    }

    body.is-scrolled .main-navigation.is-open {
        max-height: calc(100vh - var(--header-height-small)) !important;
    }
    
    /* Menü-Items vertikal */
    .main-menu {
        flex-direction: column;
        gap: 0;
        padding: 1rem 0;
    }
    
    .main-menu li {
        border-bottom: 1px solid var(--light-gray);
    }
    
    .main-menu li:last-child {
        border-bottom: none;
    }
    
    .main-menu a {
        padding: 1rem var(--container-padding);
        font-size: 1rem;
    }
    
    /* Unterstrich-Effekt entfernen auf Mobile */
    .main-menu a::after {
        display: none;
    }

    /* ----------------------------------------
       DROPDOWN / SUBMENU AUF MOBILE
       ----------------------------------------
       Auf Mobile öffnen Submenüs per Click statt Hover.
       Die Klasse .submenu-open wird per JavaScript gesetzt.
    ---------------------------------------- */

    /* Pfeil für Menüpunkte mit Untermenü (Mobile) */
    .main-menu .menu-item-has-children > a {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }

    .main-menu .menu-item-has-children > a::after {
        content: '+';
        font-size: 1.25rem;
        font-weight: 300;
        opacity: 0.6;
        margin-left: auto;
        transition: transform 0.2s ease;
    }

    /* Plus wird zu Minus wenn geöffnet */
    .main-menu .menu-item-has-children.submenu-open > a::after {
        content: '−';
    }

    /* Submenu: Standardmäßig versteckt */
    .main-menu .sub-menu {
        position: static;
        min-width: 100%;
        max-height: 0;
        overflow: hidden;
        opacity: 1;
        visibility: visible;
        transform: none;
        box-shadow: none;
        border-radius: 0;
        padding: 0;
        background: var(--light-gray);
        transition: max-height 0.3s ease;
    }

    /* Submenu: Geöffnet */
    .main-menu .menu-item-has-children.submenu-open > .sub-menu {
        max-height: 500px; /* Genug Platz für Unterpunkte */
        padding: 0.5rem 0;
    }

    /* Submenu-Links eingerückt */
    .main-menu .sub-menu a {
        padding-left: calc(var(--container-padding) + 1rem);
        font-size: 0.9375rem;
        border-left: none;
    }

    .main-menu .sub-menu a:hover {
        background-color: rgba(0, 0, 0, 0.05);
    }

    /* 2. Ebene noch weiter eingerückt */
    .main-menu .sub-menu .sub-menu a {
        padding-left: calc(var(--container-padding) + 2rem);
    }
    
    /* Active State auf Mobile */
    .main-menu .current-menu-item {
        background-color: var(--light-gray);
    }
}

/* ========================================
   HEADER LAYOUT - POSITIONSSTEUERUNG

   Logo und Menü werden unabhängig über
   Body-Klassen positioniert:

   Header-Typ:
   - .header-type-einzeilig  (Logo + Menü in einer Zeile)
   - .header-type-zweizeilig (Logo oben, Menü darunter)

   Logo-Position:
   - .logo-links / .logo-zentriert / .logo-rechts

   Menü-Position:
   - .menu-links / .menu-zentriert / .menu-rechts

   Einstellbar unter: Customizer → FFW Theme-Einstellungen
======================================== */

/* ========================================
   EINZEILIG: Logo + Menü in einer Zeile
   ======================================== */

.header-type-einzeilig .header-inner {
    display: flex;
    align-items: center;
    min-height: var(--header-height-large);
}

/* --- Logo links, Menü rechts (Standard) --- */
.header-type-einzeilig.logo-links.menu-rechts .header-inner {
    justify-content: space-between;
}

/* --- Logo links, Menü links --- */
.header-type-einzeilig.logo-links.menu-links .header-inner {
    justify-content: flex-start;
    gap: 3rem;
}

/* --- Logo links, Menü zentriert --- */
.header-type-einzeilig.logo-links.menu-zentriert .header-inner {
    justify-content: flex-start;
}
.header-type-einzeilig.logo-links.menu-zentriert .main-navigation {
    flex: 1;
    display: flex;
    justify-content: center;
}

/* --- Logo zentriert, Menü links --- */
.header-type-einzeilig.logo-zentriert.menu-links .header-inner {
    justify-content: flex-start;
}
.header-type-einzeilig.logo-zentriert.menu-links .site-branding {
    order: 1;
    flex: 1;
    display: flex;
    justify-content: center;
}
.header-type-einzeilig.logo-zentriert.menu-links .main-navigation {
    order: 0;
}
.header-type-einzeilig.logo-zentriert.menu-links .mobile-menu-toggle {
    order: 2;
}

/* --- Logo zentriert, Menü rechts --- */
.header-type-einzeilig.logo-zentriert.menu-rechts .header-inner {
    justify-content: flex-end;
}
.header-type-einzeilig.logo-zentriert.menu-rechts .site-branding {
    flex: 1;
    display: flex;
    justify-content: center;
}

/* --- Logo zentriert, Menü zentriert --- */
.header-type-einzeilig.logo-zentriert.menu-zentriert .header-inner {
    justify-content: center;
    gap: 3rem;
}

/* --- Logo rechts, Menü links --- */
.header-type-einzeilig.logo-rechts.menu-links .header-inner {
    justify-content: space-between;
}
.header-type-einzeilig.logo-rechts.menu-links .site-branding {
    order: 1;
}
.header-type-einzeilig.logo-rechts.menu-links .main-navigation {
    order: 0;
}
.header-type-einzeilig.logo-rechts.menu-links .mobile-menu-toggle {
    order: 2;
}

/* --- Logo rechts, Menü rechts --- */
.header-type-einzeilig.logo-rechts.menu-rechts .header-inner {
    justify-content: flex-end;
    gap: 3rem;
}

/* --- Logo rechts, Menü zentriert --- */
.header-type-einzeilig.logo-rechts.menu-zentriert .header-inner {
    justify-content: flex-end;
}
.header-type-einzeilig.logo-rechts.menu-zentriert .main-navigation {
    flex: 1;
    display: flex;
    justify-content: center;
}
.header-type-einzeilig.logo-rechts.menu-zentriert .site-branding {
    order: 1;
}
.header-type-einzeilig.logo-rechts.menu-zentriert .mobile-menu-toggle {
    order: 2;
}

/* Zentriertes Branding: Text mittig */
.logo-zentriert .site-branding {
    align-items: center;
    text-align: center;
}

/* ========================================
   ZWEIZEILIG: Logo oben, Menü darunter
   Jede Zeile wird unabhängig ausgerichtet.
   ======================================== */

.header-type-zweizeilig .header-inner {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    /* min-height vom einzeiligen Layout entfernen —
       zweizeilig bestimmt seine Höhe durch die zwei Zeilen selbst.
       Safari verdoppelt sonst die Höhe (min-height + Zeilenhöhen). */
    min-height: auto;
}

/* Logo-Zeile: Grundstil */
.header-type-zweizeilig .header-row--logo {
    display: flex;
    align-items: center;
    width: 100%;
    padding: 1rem 0;
    transition: padding 0.3s ease;
}

/* Navigations-Zeile: Grundstil */
.header-type-zweizeilig .header-row--nav {
    display: flex;
    align-items: center;
    width: 100%;
    border-top: 1px solid var(--light-gray);
    padding: 0.5rem 0;
    transition: padding 0.3s ease;
}

/* --- Logo-Position in der Logo-Zeile --- */
.logo-links .header-row--logo {
    justify-content: flex-start;
}

.logo-zentriert .header-row--logo {
    justify-content: center;
}

.logo-rechts .header-row--logo {
    justify-content: flex-end;
}

/* --- Menü-Position in der Navigations-Zeile --- */
.menu-links .header-row--nav {
    justify-content: flex-start;
}
.menu-links .header-row--nav .main-navigation {
    justify-content: flex-start;
}

.menu-zentriert .header-row--nav {
    justify-content: center;
}
.menu-zentriert .header-row--nav .main-navigation {
    justify-content: center;
}

.menu-rechts .header-row--nav {
    justify-content: flex-end;
}
.menu-rechts .header-row--nav .main-navigation {
    justify-content: flex-end;
}

/* Zentriertes Logo: Größer im zweizeiligen Layout */
.header-type-zweizeilig.logo-zentriert .site-logo,
.header-type-zweizeilig.logo-zentriert .site-logo img {
    max-height: 80px;
}

/* ========================================
   ZWEIZEILIG: Shrink-on-Scroll
   ======================================== */

body.is-scrolled .header-type-zweizeilig .header-row--logo {
    padding: 0.5rem 0;
}

body.is-scrolled .header-type-zweizeilig .header-row--nav {
    padding: 0.25rem 0;
}

body.is-scrolled .header-type-zweizeilig .site-logo,
body.is-scrolled .header-type-zweizeilig .site-logo img {
    max-height: 50px;
}

body.is-scrolled .header-type-zweizeilig .site-title {
    font-size: 1.25rem;
}

body.is-scrolled .header-type-zweizeilig .site-description {
    font-size: 0;
    opacity: 0;
    height: 0;
    overflow: hidden;
}

body.is-scrolled .header-type-zweizeilig .main-menu a {
    font-size: 0.875rem;
}

/* ========================================
   RESPONSIVE - TABLET (Zweizeilig)
   ======================================== */

@media (max-width: 992px) {
    .header-type-zweizeilig .header-row--logo {
        padding: 0.75rem 0;
    }

    .header-type-zweizeilig .header-row--nav {
        padding: 0.5rem 0;
    }

    .header-type-zweizeilig .site-logo,
    .header-type-zweizeilig .site-logo img {
        max-height: 60px;
    }

    .header-type-zweizeilig .main-menu {
        gap: 1.5rem;
    }
}

/* ========================================
   RESPONSIVE - MOBILE (Alle Layouts)

   Auf Mobile: Immer Logo links, Hamburger rechts.
   Alle .logo-* und .menu-* Klassen werden überschrieben.
   ======================================== */

@media (max-width: 768px) {
    /* Einzeilig: Mobile-Reset */
    .header-type-einzeilig .header-inner {
        justify-content: space-between !important;
    }
    .header-type-einzeilig .site-branding {
        order: 0 !important;
        flex: initial !important;
        justify-content: flex-start !important;
    }
    .header-type-einzeilig .main-navigation {
        order: 1 !important;
        flex: initial !important;
    }
    .header-type-einzeilig .mobile-menu-toggle {
        order: 2 !important;
    }

    /* Zweizeilig: Mobile-Reset */
    .header-type-zweizeilig .header-inner {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
        min-height: 70px;
    }

    .header-type-zweizeilig .header-row--logo {
        padding: 0.5rem 0;
        width: auto;
        justify-content: flex-start !important;
    }

    .header-type-zweizeilig .header-row--nav {
        /* WICHTIG: NICHT display:none! Das würde auch die
           position:fixed .main-navigation darin verstecken.
           Stattdessen nur visuell unsichtbar machen: */
        border: none;
        padding: 0;
        height: 0;
        overflow: visible; /* fixed-Kinder müssen sichtbar bleiben */
    }

    .header-type-zweizeilig .site-branding {
        align-items: flex-start !important;
        text-align: left !important;
    }

    .header-type-zweizeilig .site-logo,
    .header-type-zweizeilig .site-logo img {
        max-height: 50px;
    }
}

/* ========================================
   ACCESSIBILITY
======================================== */

/* Focus States für Keyboard-Navigation */
.main-menu a:focus,
.mobile-menu-toggle:focus {
    outline: 2px solid var(--red);
    outline-offset: 2px;
}

/* Skip to Content Link (für Screenreader) */
.skip-link {
    position: absolute;
    top: -100px;
    left: 0;
    background-color: var(--dark-gray);
    color: var(--white);
    padding: 1rem;
    text-decoration: none;
    z-index: 10000;
}

.skip-link:focus {
    top: 0;
}

/* ========================================
   FARBSCHEMA: HEADER-VARIANTEN
   ========================================
   Gesteuert über Body-Klasse: color-scheme-*
   Standard = weißer Header, kein Override nötig.
======================================== */

/* ----------------------------------------
   VARIANTE A: Dunkel & Kontrast
---------------------------------------- */
.color-scheme-dunkel .site-header {
    background-color: #0d0d1a;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.5);
}

.color-scheme-dunkel .site-header .site-title a,
.color-scheme-dunkel .site-header .site-description {
    color: #e0e0e0;
}

.color-scheme-dunkel .site-header .main-menu > li > a {
    color: #d0d0d0;
}

.color-scheme-dunkel .site-header .main-menu > li > a:hover,
.color-scheme-dunkel .site-header .main-menu > li.current-menu-item > a {
    color: #ff6b6b;
}

.color-scheme-dunkel .site-header .main-menu .sub-menu {
    background-color: #1e1e2f;
    border-top-color: var(--red);
}

.color-scheme-dunkel .site-header .main-menu .sub-menu a {
    color: #c8c8d0;
}

.color-scheme-dunkel .site-header .main-menu .sub-menu a:hover {
    background-color: rgba(255, 255, 255, 0.05);
    color: #ff6b6b;
}

.color-scheme-dunkel .mobile-menu-toggle {
    color: #e0e0e0;
}

/* ----------------------------------------
   DUNKLES FARBSCHEMA – MOBILES MENÜ
   Fixes für aufgeklappten Drawer auf Smartphones.
   !important nötig weil mobile Regeln ebenfalls !important setzen
   und .site-header-Selektoren im fixed Overlay nicht greifen.
---------------------------------------- */
.color-scheme-dunkel .main-navigation {
    background-color: #1e1e2f !important;
}

/* Trennlinien: border-bottom Shorthand überschreiben */
.color-scheme-dunkel .main-menu > li {
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
}

/* ALLE Links im Menü: breit gefasst für Safari-Kompatibilität */
.color-scheme-dunkel .main-menu a {
    color: #d0d0d0 !important;
}

/* Hauptmenü direkte Kinder (zusätzliche Spezifität) */
.color-scheme-dunkel .main-menu > li > a {
    color: #d0d0d0 !important;
}

.color-scheme-dunkel .main-menu > li > a:hover,
.color-scheme-dunkel .main-menu > li > a:focus {
    color: #ff6b6b !important;
    background-color: rgba(255, 255, 255, 0.05) !important;
}

/* Aktiver Menüpunkt */
.color-scheme-dunkel .main-menu .current-menu-item {
    background-color: rgba(255, 255, 255, 0.05) !important;
}

/* Mobile Submenüs */
.color-scheme-dunkel .main-menu .sub-menu {
    background-color: #13131f !important;
}

.color-scheme-dunkel .main-menu .sub-menu a {
    color: #c8c8d0 !important;
}

.color-scheme-dunkel .main-menu .sub-menu a:hover {
    background-color: rgba(255, 255, 255, 0.08) !important;
    color: #ff6b6b !important;
}

/* Hamburger-Icon Balken hell im Dark Mode */
.color-scheme-dunkel .menu-toggle-icon span {
    background-color: #e0e0e0 !important;
}

.color-scheme-dunkel .mobile-menu-toggle:hover .menu-toggle-icon span {
    background-color: #ff6b6b !important;
}

/* ----------------------------------------
   VARIANTE B: Rot (Feuerwehr-Rot)
---------------------------------------- */
.color-scheme-rot .site-header {
    background-color: var(--red);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.25);
}

.color-scheme-rot .site-header .site-title a,
.color-scheme-rot .site-header .site-description {
    color: #ffffff;
}

.color-scheme-rot .site-header .main-menu > li > a {
    color: rgba(255, 255, 255, 0.9);
}

.color-scheme-rot .site-header .main-menu > li > a:hover,
.color-scheme-rot .site-header .main-menu > li.current-menu-item > a {
    color: var(--yellow);
}

.color-scheme-rot .site-header .main-menu .sub-menu {
    background-color: var(--red-dark);
    border-top-color: var(--yellow);
}

.color-scheme-rot .site-header .main-menu .sub-menu a {
    color: rgba(255, 255, 255, 0.9);
}

.color-scheme-rot .site-header .main-menu .sub-menu a:hover {
    background-color: rgba(0, 0, 0, 0.15);
    color: var(--yellow);
}

.color-scheme-rot .mobile-menu-toggle {
    color: #ffffff;
}

/* ----------------------------------------
   VARIANTE C: Modern Mix
---------------------------------------- */
.color-scheme-modern .site-header {
    background-color: var(--dark-gray);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
    border-bottom: 3px solid var(--red);
}

.color-scheme-modern .site-header .site-title a,
.color-scheme-modern .site-header .site-description {
    color: #e0e0e0;
}

.color-scheme-modern .site-header .main-menu > li > a {
    color: #d0d0d0;
}

.color-scheme-modern .site-header .main-menu > li > a:hover,
.color-scheme-modern .site-header .main-menu > li.current-menu-item > a {
    color: var(--yellow);
}

.color-scheme-modern .site-header .main-menu .sub-menu {
    background-color: #1e1e1e;
    border-top-color: var(--yellow);
}

.color-scheme-modern .site-header .main-menu .sub-menu a {
    color: #c0c0c0;
}

.color-scheme-modern .site-header .main-menu .sub-menu a:hover {
    background-color: rgba(255, 255, 255, 0.05);
    color: var(--yellow);
}

.color-scheme-modern .mobile-menu-toggle {
    color: #e0e0e0;
}