/* ------------------------------ */
/* ------- Contact + Map -------- */
/* ------------------------------ */

.section > .section__contact {
    position: relative;
    margin-top: calc(var(--spacing-11) / 2);
    padding-top: 0;
    padding-bottom: calc(var(--spacing-10) + var(--spacing-2));
    background-color: var(--brand-color);
}

.section--color > .section__contact:last-child {
    padding-bottom: 0;
}

.section--color .section__contact:first-child {
    margin-top: calc(-1 * var(--spacing-10));
}

.section.section--color > .section__contact {
    padding-top: calc(var(--spacing-11) / 2);
}

.section.section--color > .section__teaser_below--white + .section__contact, .section.section--color > .section__opening_hours + .section__contact {
    margin-top: 0;
}

.section > .section__contact::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    height: var(--spacing-9);
    width: 100%;
    background-color: var(--brand-white);
}

.section.section--color > .section__contact::before {
    height: calc(var(--spacing-9) + var(--spacing-11) / 2);
}

.section__contact, .section__contact a {
    color: var(--brand-white);
}

.contact__address b, .contact__address  strong {
    font-style: normal;
}

.contact_address_cta {
    margin-top: calc(var(--spacing-5) - var(--spacing-1));
}

.contact_address_cta .button--normal {
    margin-top: 0;
}



/* Öffnungszeiten */
.section > .section__opening_hours {
    margin-top: calc(var(--spacing-11) / 2);
    padding-top: calc(var(--spacing-11) / 2) !important;
    padding-bottom: var(--spacing-4);
    border-top: 1px solid;
}

main .section__opening_hours p, main .section__opening_hours ul, main .section__opening_hours ol, main .section__opening_hours a, main .section__opening_hours span {
    max-width: var(--width-content-big);
}  

.section--color > .section__teaser_below--white + .section__opening_hours {
    margin-top: 0;
    background-color: var(--brand-white);
}

.section--color .section__opening_hours, .section--color .section__opening_hours a {
    color: var(--brand-black);
}

.section:first-child .section__opening_hours:first-child {
    padding-top: 0 !important;
    border-top: 0;
}

.opening_hours__overview {
    margin-right: calc(-1 * var(--spacing-3));
    margin-left: calc(-1 * var(--spacing-3));
    margin-bottom: var(--spacing-5);
}

.opening_hours__overview > div {
    padding-right: var(--spacing-3);
    padding-left: var(--spacing-3);
}

.opening_hours__overview b, .opening_hours__overview strong {
    font-style: normal;
}



/* ------------------------------ */
/* -------- Media Queries ------- */
/* ------------------------------ */

@media all and (min-width: 1240px) {
    
    .contact__map {
        padding-left: calc(var(--spacing-8) - var(--spacing-4) * 2);
    }

    .contact__map .googlemaps {
        height: 100%;
        min-height: 400px;
    }

}


@media all and (min-width: 1400px) {

    .contact__address {
        padding-top: calc(var(--spacing-10) + var(--spacing-9));
        padding-right: calc(var(--spacing-4) * 2);
    }

}


@media all and (min-width: 1600px) {

    .contact__address {
        -ms-flex-preferred-size: 35%;
        flex-basis: 35%;
        max-width: 35%;
    }
    
    .contact__map {
        -ms-flex-preferred-size: 65%;
        flex-basis: 65%;
        max-width: 65%;
    }

}


@media all and (min-width: 1900px) {

    .section__contact .contact {
        padding-left: calc(var(--spacing-6) + var(--spacing-11));
    }

}


@media all and (max-width: 1899.98px) and (min-width: 1600px) {

    .section__contact .contact {
        padding-left: calc(var(--spacing-6) + var(--spacing-10));
    }

}


@media all and (max-width: 1599.98px) and (min-width: 1400px) {

    .section__contact .contact {
        padding-left: calc(var(--spacing-6) + var(--spacing-8));
    }

}


@media all and (max-width: 1599.98px) and (min-width: 1240px) {

    .contact__address {
        -ms-flex-preferred-size: 40%;
        flex-basis: 40%;
        max-width: 40%;
    }
    
    .contact__map {
        -ms-flex-preferred-size: 60%;
        flex-basis: 60%;
        max-width: 60%;
    }

}


@media all and (max-width: 1399.98px) and (min-width: 1240px) {

    .contact__address {
        padding-top: calc(var(--spacing-10) + var(--spacing-8));
        padding-right: var(--spacing-6)
    }

}


@media all and (max-width: 1239.98px) {

    .contact__address, .contact__map {
        -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
        max-width: 100%;
    }

    .contact__map .googlemaps {
        aspect-ratio: 1170 / 730;
        margin-bottom: var(--spacing-7);
    }

}


@media all and (max-width: 991.98px) {

    .section > .section__contact {
        padding-bottom: var(--spacing-9);
    }

    .contact__map .googlemaps {
        margin-bottom: var(--spacing-6);
    }

}


@media all and (max-width: 991.98px) and (min-width: 768px) {

    .opening_hours__overview > div:nth-child(n+3) {
        margin-top: var(--spacing-3);
    }

}


@media all and (max-width: 767.98px) {

    .opening_hours__overview > div + div {
        margin-top: var(--spacing-3);
    }

    .contact_address_cta .button--normal:last-child {
        margin-bottom: calc(-1 * var(--spacing-1));
    }

}
