/* ==========================================================================
   1. HEADER BASIS & LOGO
   ========================================================================== */
#sp-header {
    background-color: #004274 !important;
    height: 120px !important;
    min-height: 120px !important;
    display: flex !important;
    align-items: center !important;
    box-shadow: 0 4px 15px rgba(0,0,0,0.3) !important;
    border: none !important;
}

#sp-header .container { 
    max-width: 98% !important; 
    padding: 0 20px !important; 
}

#sp-header .row { 
    display: flex !important; 
    align-items: center !important; 
    width: 100% !important; 
}

#sp-logo { 
    flex: 0 0 auto !important; 
    display: flex !important; 
    align-items: center !important; 
}

#sp-logo img { 
    max-height: 100px !important; 
    width: auto !important;
}

/* ==========================================================================
   2. HAUPTMENÜ (DESKTOP)
   ========================================================================== */
#sp-menu { 
    flex: 1 !important; 
    display: flex !important; 
    justify-content: center !important; 
}

/* Zwingt alle Punkte auf Weiß & 100% Sichtbarkeit */
html body #sp-header #sp-menu .sp-megamenu-parent > li > a,
html body #sp-header #sp-menu .sp-megamenu-parent > li > span {
    color: #ffffff !important;
    opacity: 1 !important;
    visibility: visible !important;
    font-size: 21px !important;
    font-weight: 500 !important;
    padding: 10px 22px !important;
    display: block !important;
    background: transparent !important;
}

/* Hover-Farbe Hauptmenü */
html body #sp-header #sp-menu .sp-megamenu-parent > li:hover > a {
    color: #ffcc00 !important;
}

/* ==========================================================================
   3. UNTERMENÜ (DROPDOWN DESKTOP)
   ========================================================================== */
/* Container: Grau & Schatten */
#sp-header .sp-megamenu-parent .sp-dropdown,
#sp-header .sp-megamenu-parent .sp-dropdown .sp-dropdown-inner,
#sp-header .sp-megamenu-parent .sp-dropdown ul {
    background-color: #d1d1d1 !important; 
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
    box-shadow: 0 20px 50px rgba(0,0,0,0.5) !important;
}

#sp-header .sp-megamenu-parent .sp-dropdown {
    border-top: 4px solid #ffcc00 !important;
    width: 280px !important;
}

#sp-header .sp-megamenu-parent .sp-dropdown li.sp-menu-item {
    width: 100% !important;
    list-style: none !important;
}

/* Untermenü Links */
#sp-header .sp-megamenu-parent .sp-dropdown li.sp-menu-item > a {
    color: #333333 !important;
    background-color: #d1d1d1 !important;
    font-size: 17px !important;
    padding: 15px 25px !important;
    display: block !important;
    width: 100% !important;
    box-sizing: border-box !important;
    border-bottom: 1px solid rgba(0,0,0,0.08) !important;
    transition: all 0.2s ease;
}

/* Untermenü Hover: Blau/Gelb volle Breite */
#sp-header .sp-megamenu-parent .sp-dropdown li.sp-menu-item > a:hover {
    color: #ffcc00 !important;
    background-color: #004274 !important;
    padding-left: 30px !important;
}

#sp-header .sp-megamenu-parent .sp-dropdown li:last-child > a {
    border-bottom: none !important;
}

/* ==========================================================================
   4. MOBILE NAVIGATION (HAMBURGER & OFF-CANVAS)
   ========================================================================== */

/* Hamburger auf Desktop verstecken */
@media (min-width: 992px) {
    #offcanvas-toggler { display: none !important; }
}

/* Mobile Anpassungen */
@media (max-width: 991px) {
    #sp-header { height: 100px !important; min-height: 100px !important; }
    #sp-logo img { max-height: 70px !important; }

    /* Hamburger nach rechts zwingen */
    #sp-menu {
        display: flex !important;
        flex: 1 !important;
        justify-content: flex-end !important;
    }

    #offcanvas-toggler {
        display: flex !important;
        justify-content: flex-end !important;
        margin-left: auto !important;
        padding-right: 10px !important;
    }
}

/* Hamburger Icon Farbe */
.burger-icon span { background-color: #ffffff !important; }

/* Off-Canvas Menü Design */
.offcanvas-menu { background-color: #004274 !important; }

.offcanvas-menu .offcanvas-inner ul.menu li a, 
.offcanvas-menu .offcanvas-inner ul.menu li span {
    color: #ffffff !important;
    opacity: 1 !important;
    font-size: 17px !important;
    font-weight: 400 !important; 
    padding: 14px 20px !important; 
    display: block !important;
    border-bottom: 1px solid rgba(255,255,255,0.08) !important;
}

/* Aktiv & Klick Mobil */
.offcanvas-menu .offcanvas-inner ul.menu li.active > a,
.offcanvas-menu .offcanvas-inner ul.menu li a:hover {
    color: #ffcc00 !important;
    background-color: rgba(0, 0, 0, 0.2) !important;
}

.close-offcanvas { color: #ffffff !important; font-size: 28px !important; }

/* --- 5. BEGRÜSSUNG (PHP/Sourcerer Modul) --- */
.greeting-wrap {
    padding-top: 40px;
    padding-bottom: 20px;
    clear: both;
    width: 100%;
}

.greeting-title {
    font-size: 20px !important;
    font-weight: 400 !important; /* Kräftige Schrift */
    color: #222 !important;
    border-left: 6px solid #f6c000; /* Gelber eMAGazin-Balken */
    padding-left: 20px;
    margin: 0 !important;
    text-align: left;
}

/* Desktop-Feinjustierung der Begrüßung (100px Einzug) */
@media (min-width: 992px) {
    .greeting-title {
        margin-left: 100px !important;
    }
}

/* --- 6. MOBILE / HAMBURGER MENÜ & MOBILE BEGRÜSSUNG --- */
@media (max-width: 991px) {
    
    /* Header auf Mobile */
    #sp-header {
        height: 90px !important;
    }

    /* Mobile Hauptmenü-Punkte */
    body .offcanvas-menu .offcanvas-inner ul.menu > li > a,
    body .offcanvas-menu .offcanvas-inner ul.menu > li > span {
        font-size: 21px !important;
        font-weight: 500 !important;
        padding: 12px 20px !important;
    }

    /* Mobile Untermenü-Punkte (Kompakt & eingerückt) */
    body .offcanvas-menu .offcanvas-inner ul.menu li ul li a {
        font-size: 18px !important;
        padding-top: 11px !important;
        padding-bottom: 11px !important;
        padding-left: 35px !important;
        color: #555 !important;
        display: block !important;
        border-bottom: 1px solid rgba(0,0,0,0.05) !important;
        background-color: #fafafa !important;
    }

    /* Mobile Begrüßung (Ohne 100px Einzug) */
    .greeting-title {
        font-size: 16px !important;
        margin-left: 15px !important;
        border-left-width: 5px;
    }
    
    .greeting-wrap {
        padding-top: 20px;
    }
}