/*
Theme Name: P3 Wordpress Theme - Child
Theme URI: https://p3digital.media
Description: Child Theme
Author: P3 DIGITAL/MEDIA
Author URI: https://p3digital.media
Template: p3-homepage
Version: 0.1
Text Domain: p3-homepage-child
Domain Path: /languages
*/


/* Basics */

html {
    scroll-padding-top: 150px;
}

/*
main{
    padding-top: var(--base-clearance-lg);
}*/

#page-header{
    background-color: var(--color-primary);
    color: var(--color-primary-contrast);
    padding: var(--base-clearance-md) 0;
    margin-bottom: var(--base-clearance-lg);
}

#page-header h1{
    font-family: var(--base_font_family_2) !important;
    font-style: var(--base_font_style_2) !important;
    font-weight: var(--base_font_weight_2) !important;
    font-size: var(--base-heading-h2) !important;
}

.box-white{
    padding: var(--base-clearance-xs);
    background-color: var(--color-surface-1);
    border-radius: var(--base-radius);
    box-shadow: var(--shadow-sm);
}

@media (min-width: 768px) {
    .box-white{
        padding: var(--base-clearance-md);
    }
}

/* Icon für Trainingszeiten der Sportangebote */
.table-slider{
    position: absolute;
    right: 0;
}

    /* List-Stylings */

        .list-style-1 ul {
          list-style: none;
          padding: 0;
        }

        .list-style-1 li {
          padding-left: 40px;
        }

        .list-style-1 li:not(:last-child) {
          padding-bottom: 15px;
          border-bottom: 1px solid var(--body-divider);
          margin-bottom: 15px;
        }

        .list-style-1 li:before {
          content: "\f00c";
          font-family: FontAwesome;
          display: inline-block;
          margin-left: -30px;
          width: 30px;
        }



        .list-style-2 ul {
          list-style: none;
          padding: 0;
        }
        .list-style-2 li {
          padding-left: 40px;
        }
        .list-style-2 li:before {
          content: "\f061";
          font-family: FontAwesome;
          display: inline-block;
          margin-left: -30px;
          width: 30px;
        }



        .list-style-4 ul {
          list-style: none;
          padding: 0;
          
        }

        .list-style-4 li {
          display: flex;
          margin: 10px 0px;
          padding-left: 40px;
        }

        .list-style-4 li:before {
          content: "\f0f5";
          font-family: FontAwesome;
          display: inline-block;
          margin-left: -30px;
          width: 30px;
        }

        .list-style-4 li:after {
          background-image: radial-gradient(circle, black 0%, black 24%, rgba(255, 255, 255, 0) 25%, rgba(255, 255, 255, 0) 100%);
          background-size: 0.5em 0.5rem;
          background-repeat: repeat-x;
          background-position: left bottom;
          content: "";
          display: block;
          flex: 1 1 auto;
          margin: 0px 12px 5px 12px;
          order: 2;
        }

        .list-style-4 li em {
          flex: 0 1 auto;
          margin: 0px 0px 0px 0px;
          order: 1;
        }

        .list-style-4 li strong {
          flex: 0 1 auto;
          margin: 0px 0px 0px 0px;
          order: 3;
          white-space: nowrap;
        }

/* Navigation > Groovy Menu */

    @media (min-width: 576px) {
        .gm-container{
            max-width: 540px !important;
        }
    }

    @media (min-width: 768px) {
        .gm-container{
            max-width: 720px !important;
        }
    }

    @media (min-width: 992px) {
        .gm-container{
            max-width: 960px !important;
        }
    }

    @media (min-width: 1200px) {
        .gm-container{
            max-width: 1440px !important;
        }
    }

    header .gm-navbar:not(.gm-navbar-sticky-toggle) .gm-navbar-nav > li.current-menu-item > .gm-anchor,
    header .gm-navbar:not(.gm-navbar-sticky-toggle) .gm-navbar-nav > li.current-menu-ancestor > .gm-anchor,
    header .gm-navbar:not(.gm-navbar-sticky-toggle) .gm-navbar-nav > li.current-page-ancestor > .gm-anchor,
    header .gm-navbar:not(.gm-navbar-sticky-toggle) .gm-navbar-nav > li.current-menu-parent > .gm-anchor,
    header .gm-navbar:not(.gm-navbar-sticky-toggle) .gm-navbar-nav > .menu-item > .gm-anchor:hover,
    header .gm-navbar:not(.gm-navbar-sticky-toggle) .gm-navbar-nav > .menu-item.gm-open > .gm-anchor {
        color: var(--color-primary) !important;
    }

    header .gm-navbar-sticky-toggle .gm-navbar-nav > li.current-menu-parent > .gm-anchor,
    header .gm-navbar-sticky-toggle .gm-navbar-nav > li.current-menu-item > .gm-anchor,
    header .gm-navbar-sticky-toggle .gm-navbar-nav > li.current-menu-ancestor.gm-open > .gm-anchor,
    header .gm-navbar-sticky-toggle .gm-navbar-nav > li.current-menu-ancestor > .gm-anchor,
    header .gm-navbar-sticky-toggle .gm-navbar-nav > li.current-page-ancestor.gm-open > .gm-anchor,
    header .gm-navbar-sticky-toggle .gm-navbar-nav > li.current-page-ancestor > .gm-anchor,
    header .gm-navbar-sticky-toggle .gm-navbar-nav > .menu-item.gm-open > .gm-anchor,
    header .gm-navbar-sticky-toggle .gm-navbar-nav > li > .gm-anchor:hover{
        color: var(--color-primary) !important;
    }

    header .gm-main-menu-wrapper #gm-main-menu .gm-navbar-nav .gm-dropdown-menu li.current-menu-ancestor > .gm-menu-item__link,
    header .gm-main-menu-wrapper #gm-main-menu .gm-navbar-nav .gm-dropdown-menu li.current-page-ancestor > .gm-menu-item__link,
    header .gm-main-menu-wrapper #gm-main-menu .gm-navbar-nav .gm-dropdown-menu li.current-menu-item > .gm-menu-item__link{
        color: var(--color-primary) !important;
    }

    header .gm-main-menu-wrapper #gm-main-menu .gm-navbar-nav .gm-dropdown-menu .gm-menu-item__link:hover{
        color: var(--color-primary-hover) !important;
    }

    /* Zusätzliches Menü (Topbar) */

    #gm-main-menu{
        display: flex;
        flex-direction: column;
    }

    #gm-main-menu .gm-toolbar-nav-container{
        justify-content: flex-end;
    }

    #gm-main-menu ul.gm-navbar-nav{
        height: 100%;
        justify-content: center;
    }

    /* Navbar Buttons / Social Media Links (Desktop) */

    .nav-button > a,
    .nav-button > a:hover{
        padding: var(--base-clearance-xs) var(--base-clearance-sm) !important;
        line-height: unset !important;
    }

    .nav-button-social-media > a,
    .nav-button-social-media > a:hover{
        padding: var(--base-clearance-xs) !important;
        line-height: unset !important;
        margin-left: 8px !important;
        margin-right: 0 !important;
        width: 40px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
    }

    .nav-button-social-media-sm > a,
    .nav-button-social-media-sm > a:hover{
        padding: var(--base-clearance-xs) !important;
        line-height: unset !important;
        margin-left: 8px !important;
        margin-right: 0 !important;
        width: 30px !important;
        height: 30px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
    }


    header .gm-navbar .gm-navbar-nav > li.current-menu-item.nav-button > a.gm-anchor,
    header .gm-navbar .gm-navbar-nav > li.menu-item.nav-button > .gm-anchor:hover,
    header .gm-navbar .gm-navbar-nav > li.current-menu-item.nav-button-social-media > a.gm-anchor,
    header .gm-navbar .gm-navbar-nav > li.menu-item.nav-button-social-media > .gm-anchor:hover,
    header .gm-navbar .gm-navbar-nav > li.current-menu-item.nav-button-social-media-sm > a.gm-anchor,
    header .gm-navbar .gm-navbar-nav > li.menu-item.nav-button-social-media-sm > .gm-anchor:hover{
        color: var(--color-primary-contrast) !important;
        background-color: var(--color-primary-hover) !important;
        border-color: var(--color-primary-hover) !important;
    }
    

    @media (max-width: 1199px) {

        .gm-navigation-drawer .gm-grid-container{
            box-shadow: none;
            transition: 0.3s;
        }

        .gm-navigation-drawer.gm-navigation-drawer--open .gm-grid-container{
            box-shadow: rgba(0, 0, 0, 0.2) 20px 0px 20px;
            transition: 0.3s;
        }

        /* Navbar Buttons / Social Media Links (Mobile) */

        .nav-button-social-media > a,
        .nav-button-social-media > a:hover,
        .nav-button-social-media-sm > a,
        .nav-button-social-media-sm > a:hover{
            margin: 10px 5px 10px 0 !important;
            float: left;
        }

        .nav-button-social-media > a.gm-anchor > span.gm-menu-item__txt-wrapper,
        .nav-button-social-media > a.gm-anchor:hover > span.gm-menu-item__txt-wrapper{
            margin-right: 0 !important;
        }

    }

    /* Nav > Volltextsuche */

    #ajaxsearchlite1 .probox, div.asl_w .probox {
        border: 2px solid #fff !important;
    }

    #ajaxsearchlite1 .probox .proinput input, div.asl_w .probox .proinput input{
        color: #fff !important;
    }

    .gm-navigation-drawer .gm-search .gm-search__txt{display: none !important;}

/* Header & Claim */

    #header{
        background-color: var(--color-surface-1);
        border-radius: var(--base-radius);
        margin-left: 0;
        margin-right: 0;
        margin-bottom: 90px;
    }

    #header h1, #header h2{
        color: var(--color-body);
    }

    #header .text > .vc_column-inner{
        background-color: var(--color-surface-1);
        padding: 30px;
    }

    #header .text > .vc_column-inner .wpb_text_column{
        max-width: 600px;
    }

    @media (min-width: 768px) {
        #header .text > .vc_column-inner{
            padding: 60px;
        }
    }

    #header .img > .vc_column-inner{
        min-height: 350px;
    }

/* Visual Composer */


    /* Full-Width-Bug (vertikale Scrolleiste verbergen) */

    /* body{overflow-x: hidden;} ~ Achtung damit ist 'sticky' nicht mehr möglich! */

    main .vc_separator.vc_sep_color_grey .vc_sep_line {border-color: var(--body-divider) !important;}
    footer .vc_separator.vc_sep_color_grey .vc_sep_line {border-color: var(--footer-divider) !important;}
    

/* Buttons */

    .vc_btn3-container.vc_btn3-inline {
        margin-right: 10px;
        margin-bottom: 10px;
    }

    /* Button-Sizes & Attributes */

    .button-icon > a,
    .button-icon > a:hover{
        border-radius: 3px !important;
        padding: 10px 25px !important;
    }

    .button-icon > a i{
        font-size: 25px !important;
        height: 25px !important;
        line-height: 25px !important;
    }

    /* VC-Button mit Icons */

    .vc-button-icon-left > a, .vc-button-icon-left > a:hover,
    .vc-button-icon-left > button, .vc-button-icon-left > button:hover{
        padding-left: 45px !important;
    }

    .vc-button-icon-right > a, .vc-button-icon-right > a:hover,
    .vc-button-icon-right > button, .vc-button-icon-right > button:hover{
        padding-right: 45px !important;
    }

    .button-lg.vc-button-icon-right > a, .button-lg.vc-button-icon-right > a:hover,
    .button-lg.vc-button-icon-right > button, .button-lg.vc-button-icon-right > button:hover{
        padding-right: calc(45px * var(--base-font-scale-factor)) !important;
    }

    .button-lg.vc-button-icon-right > a i, .button-lg.vc-button-icon-right > a:hover i,
    .button-lg.vc-button-icon-right > button i, .button-lg.vc-button-icon-right > button:hover i{
        right: calc(20px * var(--base-font-scale-factor)) !important;
    }

    /* Button Spinner */

    .button-filled > a span.spinner-border,
    .button-filled > button span.spinner-border,
    .button-outline > a span.spinner-border,
    .button-outline > button span.spinner-border,
    .button-inverse-outline > a span.spinner-border,
    .button-inverse-outline > button span.spinner-border{
        margin-right: 10px;
    }


/* CF7 */

    .wpcf7 form.spam .wpcf7-response-output,
    .wpcf7 form.invalid .wpcf7-response-output,
    .wpcf7 form.unaccepted .wpcf7-response-output {
        border-color: #394759;
        background-color: #394759;
        color: #fff;
        padding: 30px;
        text-align: center;
        margin: 30px 0;
    }

    .wpcf7 form.sent .wpcf7-response-output {
        border-color: #43b0ee;
        background-color: #43b0ee;
        padding: 30px;
        color: #fff;
        margin: 30px 0;
    }


/* Impressum + Datenschutz */

    #impressum h2,
    #datenschutz h2{
        font-size: var(--base-heading-h3) !important;
        margin-bottom: 20px;
        margin-top: 30px;
        display: inline-block;
        border-bottom: 2px solid var(--color-primary);
    }

    #impressum h3,
    #datenschutz h3{
        font-size: var(--base-heading-h4) !important;
    }

    #impressum h4,
    #datenschutz h4{
        font-size: var(--base-heading-h5) !important;
    }

    #impressum h3 + h4,
    #datenschutz h3 + h4{
        margin-top: 15px;
    }
    

/* Shotcodes */


    /* Carousel */

        #p3_posts .owl-stage-outer{
            padding: 30px 0;
        }

        #p3_posts .owl-stage{
            display: flex;
        }
        
        #p3_posts .item{
            background-color: #fff;
            border: 0;
            border-radius: 0;
            margin: 0;
            height: 100%;
            -webkit-box-shadow: 0px 0px 15px 0px rgba(0,0,0,0.15);
            -moz-box-shadow: 0px 0px 15px 0px rgba(0,0,0,0.15);
            box-shadow: 0px 0px 15px 0px rgba(0,0,0,0.15);
            transition: 0.3s;
        }

        #p3_posts .item:hover{
            -webkit-box-shadow: 0px 0px 15px 0px rgba(0,0,0,0.3);
            -moz-box-shadow: 0px 0px 15px 0px rgba(0,0,0,0.3);
            box-shadow: 0px 0px 15px 0px rgba(0,0,0,0.3);
            transition: 0.3s;
        }
        
        #p3_posts .item .card-image{
            height: 280px;
            background-repeat: no-repeat;
            background-size: cover;
            background-position: center center;
            display: inline-table;
        }

/* Borlabs Cookie */
.embed-responsive-16by9 > ._brlbs-cb-youtube {
    margin-top: -56.25%;
}

/* Maps */

.maps iframe{
    width: 100%;
    height: 350px;
}

/* Single */

    .single-erechtshare-header .shariff li{
        margin: 3px !important;
    }

    .single-content-image img{
        border-radius: var(--base-radius);
        max-height: 600px;
        object-fit: cover;
    }

    .single-content-downloads{
        list-style: none;
        padding-left: 30px;
    }

    .single-content-downloads li:before {
        content: "\f063";
        font-family: "Font Awesome 5 Free";
        font-weight: 900;
        -moz-osx-font-smoothing: grayscale;
        -webkit-font-smoothing: antialiased;
        display: inline-block;
        font-style: normal;
        font-variant: normal;
        text-rendering: auto;
        line-height: 1;
        transform: rotate(-90deg);
        transition: all .6s ease;
        color: var(--color-primary);
        margin-left: -30px;
        margin-right: 10px;
    }

    .single-content-downloads li:hover:before {
        transform: rotate(0deg);
        transition: all .3s ease;
    }

/* FAQ */

#faq{
    padding-bottom: 0;
    margin-bottom: var(--base-clearance-lg);
}

@media (min-width: 1024px) {
    #faq{
        padding: var(--base-clearance-lg);
        margin-bottom: var(--base-clearance-xl);
    }
}

#faq .description{
    width: 100%;
    max-width: 800px;
    margin: 0 auto var(--base-clearance-md) auto;
}

#faq .faq-accordion .card{
    background-color: var(--color-surface-1);
    padding: var(--base-clearance-sm);
    border-radius: var(--base-radius);
    margin-bottom: var(--base-clearance-xs);
    border: 0;
}

#faq .faq-accordion .card .card-header{
    padding: 0;
    border: 0;
    background-color: transparent;
}

#faq .faq-accordion .card .card-header h3{font-size: unset !important;}

#faq .faq-accordion .card .card-header h3 button{
    color: var(--body-color);
    font-family: var(--base_font_family_2);
    font-weight: var(--base_font_weight_2);
    font-size: var(--base-font-md);
}

#faq .faq-accordion .card > .card-header button {
    position: relative;
    margin-left: 1.125rem;
    padding: 0 1.5rem 0 .75rem;
    font-size: inherit;
    text-align: left;
}

#faq .faq-accordion .card > .card-header button::before,
#faq .faq-accordion .card > .card-header button::after {
    content: "";
    position: absolute;
    top: calc(50% - .25rem + .2em);
    left: -1.125rem;
    width: 1rem;
    height: .125rem;
    background-color: #212529;
    transition: transform .5s;
    top: 12px;
}

#faq .faq-accordion .card > .card-header button.collapsed::before {
    transform: rotate(180deg);
}

#faq .faq-accordion .card > .card-header button.collapsed::after {
    transform: rotateZ(90deg);
}

#faq .faq-accordion .card .card-body .wpb_text_column{
    margin-bottom: 0;
}

@media (min-width: 1200px) {
    #aktuelles .content{
        min-height: 100vh;
    }
}