/*
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;
}

body{
    overflow-x: hidden;
}

body.single-post{
    word-wrap: break-word;
}

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

h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5{
    color: var(--color-black);
}

    /* 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;
        }

/* 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;
    }


    /* Mega-Menu (mobile) */

    header .gm-navigation-drawer--mobile .gm-dropdown-menu-wrapper{padding-left: 0}
    header .gm-navigation-drawer--mobile .gm-dropdown-menu .gm-anchor{display: none}
    header .gm-navigation-drawer--mobile .list-style-4 li a{padding: 10px 0}
    header .gm-navigation-drawer--mobile .svg-icon-lg{display: none; max-width: calc(var(--base-clearance-lg)* 0.75);}


    /* 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 .gm-toolbar-nav-container a .gm-menu-item__txt{
        text-transform: uppercase;
        font-size: var(--base-font-md);
    }

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

    /* 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;
        }

    }

/* 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: 160%;
        margin-bottom: 20px;
        margin-top: 30px;
        display: inline-block;
    }

    #impressum h3,
    #datenschutz h3{
        font-size: 130%;
    }

    #impressum h4,
    #datenschutz h4{
        font-size: 105%;
    }

    #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;
}

/* Kategorien (Posts) */

.post-categories-nav{
    background-color: var(--color-surface-1);
    padding: var(--base-clearance-md);
    border-radius: var(--base-radius);
    display: flex;
    justify-content: center;
}

.post-categories-nav .post-categories-title{
    color: var(--body-muted);
}

.post-categories-nav ul{
    list-style: none;
    display: flex;
    justify-content: center;
    margin: 0;
    padding: 0;
}

.post-categories-nav ul li {
    display: inline-block;
    margin-right: 10px;
}

.post-categories-nav ul li.aktiv a {
    font-weight: bold;
}

/* 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_1);
    font-weight: var(--base_font_weight_1);
    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;
}


.section-white{
    background-color: var(--color-surface-1);
    border-radius: var(--base-radius);
}

.section-white .svg-icon-lg:before{
    content:"";
    width: 100px;
    height: 100px;
    display: flex;
    background-color: #f5f5f5;
}

.vc_column-inner-border-right > .wpb_column > .vc_column-inner > .wpb_wrapper{
    padding: var(--base-clearance-lg) var(--base-clearance-md) var(--base-clearance-sm) var(--base-clearance-md);
    height: 100%;
}

.vc_column-inner-border-right > .wpb_column:not(:last-of-type) > .vc_column-inner > .wpb_wrapper{
    border-right: 2px solid #e9e9e9;
}


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

.list-style-3 li {
    text-align: center;
    font-size: var(--base-font-md);
}

.list-style-3 li a{
    border: 1px solid #fff;
    border-radius: var(--border-radius);
    width: 100%;
    display: block;
    padding: 2px 5px;
    margin-bottom: 5px;
    background-color: #fff;
    transition: transform .5s;
    color: var(--color-primary-hover);
}

.list-style-3 li a:hover{
    border: 1px solid var(--color-primary-hover);
    background-color: var(--color-primary-hover);
    color: var(--color-primary-contrast);
    transition: transform .5s;
}


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

.list-style-4 li {
    text-align: left;
    font-size: var(--base-font-sm);
}

@media (min-width: 1200px) {
    .list-style-4 li {
        text-align: center;
        font-size: var(--base-font-md);
    }
}


.list-style-4 li a{
    border: 1px solid #fff;
    border-bottom: 1px solid #ddd;
    width: 100%;
    display: block;
    padding: 10px;
    background-color: transparent;
    transition: transform .5s;
    color: var(--body-color);
    width: 100%;
    display: block;
}

.list-style-4 li a:hover{
    border: 1px solid var(--color-primary-hover);
    background-color: var(--color-primary-hover);
    color: var(--color-primary-contrast);
    transition: transform .5s;
}


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

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

/* Gruppen */

.gruppe-header h1,
.gruppe-header .h1 {
    font-size: clamp(16px, calc(2vw + 3rem), 70px) !important;
    line-height: 1;
}

.section-anfrage{
    padding: var(--base-clearance-md) var(--base-clearance-sm) !important;
    background-color: var(--color-surface-1);
    border-radius: var(--base-radius);
    box-shadow: var(--shadow-md);
}

@media (min-width: 768px) {
    .section-anfrage{
        padding: var(--base-clearance-lg) !important;
    }
}

.section-team{
    padding: var(--base-clearance-md) !important;
    background-color: var(--color-surface-1);
    border-radius: var(--base-radius);
    box-shadow: var(--shadow-sm);
}

.section-jobs{
    padding: var(--base-clearance-sm) var(--base-clearance-sm) 0 var(--base-clearance-sm) !important;
    background-color: var(--color-surface-1);
    border-radius: var(--base-radius);
    box-shadow: var(--shadow-md);
}

@media (min-width: 768px) {
    .section-jobs{
        padding: var(--base-clearance-lg) var(--base-clearance-lg) var(--base-clearance-sm) var(--base-clearance-lg) !important;
    }
}

.section-wunschliste{
    padding: var(--base-clearance-lg) !important;
    background-color: var(--color-surface-1);
    border-radius: var(--base-radius);
    box-shadow: var(--shadow-md);
}

.zitat p{
    font-family: var(--base_font_family_3);
    font-style: var(--base_font_style_3);
    font-weight: var(--base_font_weight_3);
}

.eckdaten > .wpb_column > .vc_column-inner > .wpb_wrapper{
    padding: var(--base-clearance-sm) var(--base-clearance-sm) 0 var(--base-clearance-sm);
    background-color: var(--color-primary-hover);
    color: var(--color-primary-contrast);
    border-radius: var(--base-radius);
    text-align: center;
    height: 100%;
    margin-bottom: var(--base-clearance-sm);
    
    display: flex;
    align-items: center;
    justify-content: center;
}

.eckdaten > .wpb_column > .vc_column-inner > .wpb_wrapper .wpb_text_column{
    margin-bottom: var(--base-clearance-sm);
}

.eckdaten > .wpb_column > .vc_column-inner > .wpb_wrapper .svg-wrapper{
    margin: 0 auto;
    margin-bottom: var(--base-clearance-md);
    display: none;
}

/* 404 */

#page_404{
    padding: 20vh 0;
}