/*
 Theme Name: GeneratePress Child
 Theme URI: https://generatepress.com
 Description: Child Theme für GeneratePress
 Author: Michael
 Template: generatepress
 Version: 1.0.1
*/

/************************************************************
 * MODUL 1 – HEADER / BANNER
 ************************************************************/

/* Header-Container neutralisieren */
.site-header,
.inside-header,
.header-widget,
.header-widget .widget,
.header-widget .widget_custom_html,
.header-widget .textwidget,
.header-block {
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
}

/* Banner-Container */
.header-banner {
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    width: 100% !important;
    max-width: 100% !important;
}

/* Banner-Bild */
.header-banner img {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    box-shadow: none !important;
}

/* Desktop: Bild nicht größer als Original */
@media (min-width: 1025px) {
    .header-banner {
        max-width: 1121px !important;
    }
    .header-banner img {
        max-width: 1121px !important;
        width: auto !important;
    }
}

/********************************************
 * KOMBINIERTER FIX – LOGO-WIDGET & MOBILE-MENÜ
 ********************************************/

/* 1) Desktop: Abstand zwischen Header-Bild und Logo-Widget */
@media (min-width: 1025px) {
    .header-logos {
        margin-top: 22px !important;
    }
}

/* 2) Tablet & Mobile: Logo-Widget komplett ausblenden */
@media (max-width: 1024px) {
    .header-logos {
        display: none !important;
        visibility: hidden !important;
        height: 0 !important;
        overflow: hidden !important;
        margin: 0 !important;
        padding: 0 !important;
    }
}

/* 3) Mobile: Menü vollständig entfernen */
@media (max-width: 1024px) {
    .main-navigation,
    .menu-toggle,
    .site-header .site-branding,
    .site-header .main-title,
    .site-header .site-logo {
        display: none !important;
        visibility: hidden !important;
        height: 0 !important;
        overflow: hidden !important;
        margin: 0 !important;
        padding: 0 !important;
    }
}

/************************************************************
 * MODUL 2 – CONTENT-START & TYPOGRAFIE
 ************************************************************/

.site-content {
    margin-top: 28px !important;
}

.site-content .inside-site {
    max-width: 1121px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

h1.entry-title {
    font-size: 32px !important;
    line-height: 1.25 !important;
    font-weight: 700 !important;
    margin: 0 0 22px 0 !important;
    padding: 0 !important;
    text-align: left !important;
}

h2 { font-size: 26px !important; line-height: 1.3 !important; font-weight: 700 !important; margin: 32px 0 16px 0 !important; }
h3 { font-size: 22px !important; line-height: 1.35 !important; font-weight: 700 !important; margin: 28px 0 14px 0 !important; }
h4 { font-size: 18px !important; line-height: 1.4 !important; font-weight: 700 !important; margin: 24px 0 12px 0 !important; }

.entry-content p {
    font-size: 17px !important;
    line-height: 1.6 !important;
    margin: 0 0 18px 0 !important;
    padding: 0 !important;
}

.entry-content ul,
.entry-content ol {
    margin: 0 0 20px 20px !important;
    padding: 0 !important;
    line-height: 1.6 !important;
}

.entry-content li {
    margin-bottom: 10px !important;
}

/* Tablet-Anpassungen (600–1024px) */
@media (min-width: 600px) and (max-width: 1024px) {
    .site-content { margin-top: 24px !important; }
    h1.entry-title { font-size: 28px !important; margin-bottom: 20px !important; }
    h2 { font-size: 24px !important; margin: 28px 0 16px 0 !important; }
    h3 { font-size: 20px !important; margin: 24px 0 14px 0 !important; }
    h4 { font-size: 17px !important; margin: 20px 0 12px 0 !important; }
    .entry-content p { font-size: 16px !important; margin-bottom: 16px !important; }
}

/* Smartphone-Anpassungen (bis 599px) */
@media (max-width: 599px) {
    .site-content { margin-top: 18px !important; }
    h1.entry-title { font-size: 24px !important; margin-bottom: 18px !important; }
    h2 { font-size: 22px !important; margin: 24px 0 14px 0 !important; }
    h3 { font-size: 18px !important; margin: 20px 0 12px 0 !important; }
    h4 { font-size: 16px !important; margin: 18px 0 10px 0 !important; }
    .entry-content p { font-size: 15px !important; margin-bottom: 14px !important; }
}

/************************************************************
 * MODUL 3 – DESKTOP & TABLET: PURE FULL-WIDTH LAYOUT (OHNE SIDEBAR)
 ************************************************************/
@media (min-width: 1025px) {
    .site-content .inside-site {
        display: block !important;
        max-width: 1121px !important;
        margin-left: auto !important;
        margin-right: auto !important;
        padding: 0 !important;
    }

    .content-area {
        width: 100% !important;
        max-width: 1121px !important;
        margin: 0 !important;
        padding: 0 !important;
        float: none !important;
        display: block !important;
    }

    /* Keine Sidebar-Störungen im Desktop */
    .sidebar {
        display: none !important;
    }
}

@media (min-width: 600px) and (max-width: 1024px) {
    .site-content,
    .site-content .inside-site {
        display: block !important;
        width: 100% !important;
        max-width: 1121px !important;
        margin-left: auto !important;
        margin-right: auto !important;
        padding: 0 !important;
        float: none !important;
    }

    .content-area {
        width: 100% !important;
        float: none !important;
        margin: 0 auto !important;
        display: block !important;
    }

    /* Keine Sidebar-Störungen im Tablet */
    .sidebar {
        display: none !important;
    }
}

/************************************************************
 * MODUL 4 – NEUER VERFÜGBARKEITS-CHECK (.neu-suchkasten)
 ************************************************************/

/* Der äußere Kasten - IMMER SICHTBAR */
.neu-suchkasten {
    display: block !important;
    visibility: visible !important;
    background: #f4f7fa !important;
    border: 1px solid #e1e6eb !important;
    border-radius: 12px !important;
    padding: 30px !important;
    max-width: 600px !important;
    margin: 25px auto !important;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05) !important;
    text-align: center !important;
}

/* Überschrift im Kasten */
.neu-suchkasten h3 {
    font-size: 22px !important;
    font-weight: 700 !important;
    color: #1a202c !important;
    margin: 0 0 15px 0 !important;
}

/* Das Formular-Layout */
.neu-suchkasten form,
.neu-suchkasten .plz-check {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    align-items: center !important;
}

/* Text-Label über dem Eingabefeld */
.neu-suchkasten label {
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #4a5568 !important;
    margin-bottom: 4px !important;
}

/* Das PLZ-Eingabefeld */
.neu-suchkasten input[type="text"] {
    width: 100% !important;
    max-width: 250px !important;
    padding: 12px 15px !important;
    font-size: 18px !important;
    font-weight: bold !important;
    letter-spacing: 2px !important;
    text-align: center !important;
    border: 2px solid #cbd5e0 !important;
    border-radius: 6px !important;
    background-color: #ffffff !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
}

.neu-suchkasten input[type="text"]:focus {
    border-color: #0056b3 !important;
    box-shadow: 0 0 0 3px rgba(0, 86, 179, 0.15) !important;
    outline: none !important;
}

/* Der Absende-Button */
.neu-suchkasten button {
    width: 100% !important;
    max-width: 250px !important;
    background: #0056b3 !important;
    color: #ffffff !important;
    padding: 14px 20px !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    border: none !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    transition: background 0.2s ease, transform 0.1s ease !important;
    box-shadow: 0 2px 5px rgba(0, 86, 179, 0.2) !important;
}

.neu-suchkasten button:hover {
    background: #003d82 !important;
}

.neu-suchkasten button:active {
    transform: scale(0.98) !important;
}

/* Fehlermeldung */
.neu-suchkasten .plz-error {
    color: #e53e3e !important;
    font-size: 14px !important;
    margin-top: 10px !important;
    font-weight: 600 !important;
}

/************************************************************
 * MODUL 5 – NEUES MULTI-TECHNOLOGIE TABELLEN LAYOUT
 ************************************************************/
#anbieter-tabelle-wrapper {
    display: none;
    margin-top: 25px;
    width: 100%;
}

.anbieter-tabelle {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.anbieter-zeile.multi-tech {
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr 1fr 1fr;
    background: #ffffff;
    border: 1px solid #eaeaea;
    border-radius: 8px;
    padding: 12px;
    align-items: center;
    box-shadow: 0 2px 6px rgba(0,0,0,0.03);
    gap: 10px;
}

.tech-col {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 8px;
    border-right: 1px dashed #f0f0f0;
}

.tech-col:last-child {
    border-right: none;
}

.col-logo {
    font-weight: bold;
}

.tech-label-mobile {
    display: none;
}

.tech-speed {
    font-size: 0.8rem;
    color: #666;
}

.tech-price {
    font-size: 1.1rem;
    font-weight: bold;
    color: #16a34a;
    margin: 3px 0;
}

.tech-link {
    font-size: 0.75rem;
    background: #0056b3;
    color: #fff !important;
    padding: 4px 10px;
    border-radius: 4px;
    text-decoration: none;
    font-weight: bold;
}

.tech-link:hover {
    background: #003d82;
}

.not-available {
    color: #ccc;
    font-size: 1.2rem;
}

.no-offer {
    background: #fafafa;
}

.anbieter-legende {
    display: none;
    justify-content: center;
    gap: 20px;
    margin-top: 15px;
}

/************************************************************
 * MODUL 5.1 – BRANDING & SICHERE LOKALE LOGO-AUSGABE
 ************************************************************/
.tech-col.col-logo {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 120px !important;
    min-height: 50px !important;
    padding: 5px !important;
}

.provider-logo {
    display: block !important;
    width: 110px !important;
    height: 45px !important;
    background-size: contain !important;
}