/**
Theme Name: Hello Elementor Child
Author: Webadmin
Author URI: #
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: hello-elementor-child
Template: hello-elementor
*/


/* DL 20.10.2022
** Main css in /inc/assets/css/main.css
*/

.elementor-location-single {
    overflow: hidden;
}

.hidden {
	display: none !important;
}

.footer-link {
	font-size: 17px;
    line-height: 30px;
    font-weight: 300;
}

.elementor-element.rechtliches-titel {
	margin-bottom: 15px;	
}

/* SEARCH FIELD FAQ Start */

.search-in-place-mark-active, .search-in-place a:focus, .search-in-place-mark {
    text-decoration: none;
    text-decoration-color: transparent;
    text-decoration-style: unset;
    background-color: #bad09f !important;
    outline: none;
    box-shadow: none;
}

input.search-field {
	text-transform: none;
	background-color: #fff !important;
}

input.search-field:focus-visible {
	outline-offset: 0;
    outline-color: #005fcc;
	transition: none;
}

div.search-in-place .label.more, div.search-in-place .label {
	display:none;
}

div.search-in-place .item.last, div.search-in-place .item  {
	border-bottom: none;
}

div.search-in-place .item:hover {
	background-color: rgb(245,245,245);
}

/* SEARCH FIELD FAQ End */

main {
    max-width: 2800px;
    display: block;
    margin-left: auto;
    margin-right: auto;
    overflow: hidden;
}

a {
    text-underline-offset: 5px;
}

sub {
    font-size: 60%;
    bottom: -0.2em;
}

p:last-child {
    margin-bottom: 0;
}

h1 b,
h1 strong {
    font-weight: 700;
}

b,
strong {
    font-weight: 700;
}

.dots-rectangle {
    position: relative;
}

.dots-rectangle:after {
    content: " ";
    position: absolute;
    left: 175px;
    top: calc(100% + 50px);
    width: 3000px;
    height: 315px;
    background: url('img/punktmuster.svg') repeat top left;
    background-size: auto 135px;
}

.dots-rectangle-left {
    position: relative;
}

.dots-rectangle-left:after {
    content: " ";
    position: absolute;
    right: 0;
    top: 0;
    width: 3000px;
    height: 315px;
    background: url('img/punktmuster.svg') repeat top right;
    background-size: auto 135px;
    z-index: -1;
}

.dots-rectangle.dots-recangle-referenzen:after {
    /*left: 65%;
  top: -50px;
  height: calc(100% - 165px);
  */
    left: 10px;
    bottom: -70px;
    height: 520px;
}

.custom-card {
    position: relative;
    overflow: hidden;
}

.custom-card .ha-card-body {
    position: absolute;
    bottom: 0;
    left: 0;
    background-color: rgba(255, 255, 255, 0.9);
    width: auto !important;
    border-radius: 0 0 0 60px;
    overflow: hidden;
}

.custom-card figure {
    height: auto !important;
}

.elementor-button-info a,
.custom-card a {
    background: transparent !important;
    padding: 0 !important;
    color: var(--e-global-color-text) !important;
    box-shadow: none !important;
}

.elementor-button-info.white-button a {
    color: white !important;
}

.elementor-button-info .elementor-button-text:after,
.custom-card a>span:after {
    background: url(img/arrow-green.svg) no-repeat center;
    height: 20px;
    background-size: contain;
    width: 30px;
    content: " ";
    display: inline-block;
    vertical-align: middle;
    margin-bottom: 4px;
    margin-left: 12px;
    transition: transform ease 0.5s;
}

.elementor-button-info.white-button .elementor-button-text:after {
    background-image: url(img/arrow-right.svg);
}

.elementor-button-info a:hover,
.custom-card a:hover {
    color: var(--e-global-color-83f8500) !important;
}

.elementor-button-info a:hover .elementor-button-text:after,
.custom-card a:hover>span:after {
    transform: translateX(10px);
}

a {
    transition: all ease 0.5s;
}

.image-card {
    background-color: white;
    border-radius: 0 0 0 60px;
    -webkit-box-shadow: 5px 5px 15px 0 rgba(0, 0, 0, 0.1);
    box-shadow: 5px 5px 15px 0 rgba(0, 0, 0, 0.1);
    padding: 30px;
}

.image-card figure {
    display: flex;
    flex-direction: column;
}

.image-card figure img {
    order: 2;
}

.image-card .figcaption {
    margin-bottom: 50px;
}

.sticky-header {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    transition: padding, background ease 0.5s;
}

.logo-gray {
    display: none;
}

.sticky-header.elementor-sticky--effects .logo-gray {
    display: block;
}

.sticky-header.elementor-sticky--effects .logo-white {
    display: none;
}

.sticky-header.elementor-sticky--effects {
    /* background: rgba(255, 255, 255, 0.8); */
    background: #fff;
    padding-top: 15px !important;
}

.sticky-header.elementor-sticky--effects a {
    color: var(--e-global-color-text) !important;
}

.sticky-header.elementor-sticky--effects a:hover {
    /*color: var(--e-global-color-83f8500) !important;*/
}


/* Masonry */

.masonry-cards {
    margin-left: -12.5px;
    margin-right: -12.5px;
}

.dots-rectangle.after-masonry:after {
    top: auto;
    z-index: -1;
    bottom: 0;
    left: 100px;
    height: calc(100% + 250px);
}

.dots-rectangle.masonry-cards:after {
    top: calc(100% - 250px);
    z-index: -1;
    left: calc(100% - 320px);
    height: 625px;
}

.masonry-card {
    width: 50%;
    margin-top: 100px;
    padding: 12.5px;
    opacity: 0;
}

.masonry-card img {
    transition: all ease 0.5s;
    display: block;
}

.masonry-card {
    margin-top: 0;
}
.masonry-cards-image {
	transform: translateZ(0);
	border-radius:0 0 0 60px;
	overflow:hidden;
}
.grid-sizer {
    width: 50%;
}

.masonry-cards-inner {
    position: relative;
    border-radius: 0 0 0 60px;
    overflow: hidden;
}

.masonry-card:hover img {
    transform: scale(1.1);
    opacity: 0.5;
}

.masonry-cards-text {
    position: absolute;
    bottom: 0;
    left: 0;
    padding: 25px;
    background-color: rgba(255, 255, 255, 0.9);
    border-radius: 0 0 0 60px;
    
}

.masonry-cards-label {
    color: var(--e-global-color-83f8500);
    text-transform: uppercase;
    font-size: 17px;
    letter-spacing: 0.5px;
    line-height: 1.64;
    font-weight: 600;
}

.masonry-cards-title {
    color: var(--e-global-color-text);
    font-size: 20px;
    line-height: 1.4;
    font-weight: 600;
    max-width: 320px;
    width: 90%;
    font-size: 24px;
}

.masonry-cards-title i {
    color: var(--e-global-color-83f8500);
	    display: inline;
    margin-left: 7px;
}


/* Masonry End */


/* Product USPS */

.product-usps {
    margin-left: -15px;
    margin-right: -15px;
    display: flex;
    flex-wrap: wrap;
    position: relative;
    padding: 130px 0;
    width: 100%;
    margin-top: 70px;
}

.product-usps:after {
    content: " ";
    position: absolute;
    right: 50%;
    top: 0;
    width: 3000px;
    height: 100%;
    background: url(img/punktmuster.svg) repeat top left;
    background-size: auto 135px;
    z-index: -1;
}

.product-usp {
    background-color: #EDEAE9;
    padding: 25px 30px;
    margin: 15px;
    width: calc(33.3333% - 30px);
    text-align: center;
    border-radius: 0 0 0 60px;
    -webkit-box-shadow: 5px 5px 10px 5px rgba(0, 0, 0, 0.1);
    box-shadow: 5px 5px 10px 5px rgba(0, 0, 0, 0.1);
}

.product-usps {}


/* Product USPS ENd */


/* Elementor Carousel */

.swiper-pagination-bullet {
    border: 1px solid var(--e-global-color-83f8500);
}

.swiper-container-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 3px;
}

.swiper-slide-inner {
    position: relative;
}

.swiper-slide-inner figcaption {
    position: absolute;
    left: 0;
    bottom: 0;
    right: 0;
    text-align: center;
    background: rgba(255, 255, 255, 0.8);
    font-family: "Work Sans";
    font-weight: 500;
    font-style: normal;
    color: var(--e-global-color-text);
    padding: 12px 10px;
}

.elementor-image-carousel img {
    display: block;
}

.swiper-container-horizontal>.swiper-pagination-bullets {
    bottom: -10px;
}


/* Elementor Carousel End */


/* Green Box */

.green-box-wrapper {}

.green-box {
    max-width: 360px;
    position: relative;
    display: block;
    margin: 0 0 0 auto;
}

.green-box-sections {
    position: absolute;
    top: 10px;
    left: calc(13% + 20px);
    right: 20px;
    bottom: calc(13% + 30px);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.green-box-sections h2 {
    margin-bottom: 0;
    color: var(--e-global-color-83f8500);
}

.green-box-sections p {
    text-transform: uppercase;
    font-weight: 400;
    font-size: 89%;
    line-height: 1.4;
}


/* Green Box End */


/* Mainmenu */

.elementor-nav-menu .sub-menu a {
    position: relative;
}

.elementor-nav-menu .sub-menu a:after {
    font-family: 'cpcfont' !important;
    content: "\e905";
    font-size: 8px;
    position: absolute;
    left: 0;
    top: 7px;
}

.elementor-nav-menu .sub-menu {
    border-radius: 0 0 0 15px;
    overflow: hidden;
}

.elementor-nav-menu .sub-menu li:last-child {
    border-radius: 0 0 0 15px;
    overflow: hidden;
}

.elementor-nav-menu .sub-arrow i {
    font-size: 9px;
}


/* Mainmenu End */


/* Search filter */

.custom-cards {
    margin-left: -12.5px;
    margin-right: -12.5px;
    display: flex;
    flex-wrap: wrap;
}

.custom-cards .masonry-card {
    opacity: 1;
    width: 33.333%;
}

.video-cards .masonry-card {
    opacity: 1;
    width: 50%;
}

.video-cards .masonry-card .masonry-cards-image img {
    width: 100%;
}

.video-cards .masonry-cards-text {
    padding: 10px 25px;
}


/* FRAGEN UND ANTWORTEN start */

.fragen-accordion .elementor-accordion .elementor-accordion-item:nth-child(even) {
    background-color: rgb(245,245,245);
}

.fragen-accordion .elementor-accordion .elementor-accordion-item {
	/* border-bottom: 1px solid #d4d4d4; */
	border-top: none;
	border-right: none;
	border-left: none;
}

.fragen-accordion .elementor-accordion .elementor-tab-title {
    padding: 15px;
	line-height: 1.8rem;
}

.fragen-accordion .elementor-accordion .elementor-tab-content {
    border-top: none;
	padding: 5px 26px 30px 45px;
}

.fragen-accordion .elementor-accordion .elementor-tab-title .elementor-accordion-icon {
	height: 30px;
	line-height: 27px;
}

.fragen-accordion .elementor-accordion .elementor-tab-title .elementor-accordion-icon svg {
    width: 1.2rem;
    height: 1.2rem;
    margin-top: 3px;
}

.fragen-accordion .elementor-accordion-title {
    font-family: "Work Sans";
    font-weight: 600;
    font-style: normal;
}

.f-n-a-icon i.cpccustomicon-file-text {
	margin-right: 10px;
    color: #BAD09F;
    font-size: 1.1em;
}

.f-n-a-icon a {
	text-decoration: underline;
}

/* FRAGEN UND ANTWORTEN end */

/* Downloads */

#search-filter-form-1521 ul {
    justify-content: space-between;
    display: flex;
	margin-left:-7px;
	margin-right:-7px;
	padding-left:0;
	align-items:center;
	flex-wrap:wrap;
}
#search-filter-form-1521 ul li label {
	width:100%;
}
#search-filter-form-1521 .search-filter-reset {
	text-transform:uppercase;
	background-color:#f6f6f6;
	font-weight:600;
	    padding: 10px 15px;
    border-radius: 4px;
	white-space:nowrap;
}
#search-filter-form-1521 ul li {
	width:33.3333%;
	padding-left:7px;
	padding-right:7px;
}
#search-filter-form-1521 ul li input {
	border-radius:4px;
}
#search-filter-form-1521 .sf-field-search input {
	padding-right:40px;
}
#search-filter-form-1521 .sf-field-search label:after {
	content:" ";
	position:absolute;
	right:15px;
top:calc(50% - 9px);
	    content: "\e901";
	    font-family: 'cpcfont' !important;
}
#search-filter-form-1521 .sf-field-search label {
	position:relative;
}
.search-filter-results .masonry-cards-title{
	width:100%;
	max-width:none;
	font-size:20px;
}
.search-filter-results .masonry-cards-text {
	width:100%;
}
.cpc-downloads th,
.cpc-downloads td {
    border: none !important;
}

.cpc-downloads th {
    background-color: unset !important;
    border-bottom: 2px solid !important;
    border-color: var(--e-global-color-83f8500) !important;
    text-align: left;
}

.cpc-downloads .w3eden {
    text-align: center;
}

.w3eden a {
    text-decoration: none;
}

.w3eden a:hover {
    text-decoration: none;
}

.cpc-downloads .w3eden a {
    color: var(--e-global-color-83f8500);
    font-size: 20px;
}

.downloads-pagination {
    float: right;
}

.wp-pagenavi a,
.wp-pagenavi span {
    padding: 4px 10px;
}

.wp-pagenavi a i {
    font-size: 12px;
}


/* Contact Form */

.cf-info {
    float: right;
}

.submit-row {
    text-align: center;
    margin-bottom: 20px;
}


/* Post Navigation */

.post-nav-left-outer .elementor-post-navigation__next a,
.post-nav-right-outer .elementor-post-navigation__prev a {
    display: none !important;
}


/* Fancybox Search */

#cpcsearchbox {
    width: 100%;
    min-height: 100%;
    max-width: 1140px;
}

.custom-fb-search .fancybox__backdrop {
    background-color: #fff;
}

.custom-fb-search .fancybox__content>.carousel__button.is-close {
    position: absolute;
    top: 0px !important;
}

.row.search-input-row,
.loadmore-serach {
    text-align: center;
}

.row.search-input-row ul {
    padding: 0px !important;
}

.row.search-input-row .sf-field-search label {
    max-width: 850px;
    width: 100%;
}

.row.search-input-row .sf-field-search input {
    width: 100%;
}

.custom-search-results .search-result {
    padding: 15px;
}

.loadmore {
    outline: none !important;
    border: none !important;
    padding: 10px 40px;
    box-shadow: 0px 0px 10px 0px rgb(0 0 0 / 30%) !important;
}

.loadmore:hover {
    color: white !important;
    background-color: #9eb582;
}

.loadmore-wrapper {
    text-align: center;
}

.loadmore {
    margin-top: 100px;
}

.custom-search-results {
    max-height: calc(100vh - 277px);
    max-width: 850px;
    overflow: hidden;
    overflow-y: auto;
    margin: 20px auto;
}
.custom-search-results .loadmore {
	margin-top:0;
	display:inline-block;
}
.search-input-row .sf-field-posts_per_page {
    display: none !important;
}

.custom-fb-search .carousel__button.is-close {
    background-color: #fff;
    box-shadow: unset;
}

.custom-fb-search .carousel__button.is-close svg {
    color: #000;
}

.custom-fb-search .carousel__button.is-close:hover svg {
    color: var(--e-global-color-83f8500);
}


/* Contact Form */

.wpcf7-form .row > div {
    margin-bottom: 22px;
}

.wpcf7-form input,
.wpcf7-form select,
.wpcf7-form textarea {
    padding: 12px 1rem;
    border-color: #c1c1c1;
}

.wpcf7-radio .wpcf7-list-item-label::before {
    content: " ";
    border-radius: 50%;
    width: 18px;
    height: 18px;
    display: inline-block;
    border: 1px solid #c1c1c1;
    transition: all ease 0.5s;
    vertical-align: middle;
    margin-bottom: 5px;
    margin-right: 15px;
}

.wpcf7-radio {
    position: relative;
}

.wpcf7-radio .wpcf7-list-item+.wpcf7-list-item {
    margin-left: 40px;
}

.wpcf7-radio input {
    position: absolute;
    opacity: 0;
}

.wpcf7-radio input:checked+.wpcf7-list-item-label::before {
    background-color: var(--e-global-color-83f8500);
}

.wpcf7-list-item {
    margin-left: 0;
}

.wpcf7-submit {
    outline: none !important;
    border: none !important;
    padding: 10px 40px !important;
    box-shadow: 0px 0px 10px 0px rgb(0 0 0 / 30%) !important;
}

.wpcf7-submit:hover {
    color: white !important;
    background-color: #9eb582 !important;
}

.wpcf7-checkbox .wpcf7-list-item-label, .wpcf7-acceptance .wpcf7-list-item-label {
    position: relative;
    padding-left: 35px;
	display:block;
	line-height:1.2;
}

.wpcf7-checkbox .wpcf7-list-item-label::before, .wpcf7-acceptance .wpcf7-list-item-label::before {
    position: absolute;
    top: 2px;
    left: 0;
    content: " ";
    border-radius: 0;
    width: 18px;
    height: 18px;
    display: inline-block;
    border: 1px solid #c1c1c1;
    transition: all ease 0.5s;
    vertical-align: middle;
    margin-bottom: 5px;
    margin-right: 15px;
}

.wpcf7-checkbox input:checked+.wpcf7-list-item-label::before,  .wpcf7-acceptance input:checked+.wpcf7-list-item-label::before {
    background-color: var(--e-global-color-83f8500);
}

.wpcf7-checkbox input, .wpcf7-acceptance input {
    position: absolute;
    opacity: 0;
}
.wpcf7 .wpcf7-submit:disabled {
	opacity:0.5;
}
.datenschutz-row {
    position: relative;
	margin-left: 12px;
}

.datenschutz-row .wpcf7-form-control-wrap {
    position: absolute;
    left: 0;
    top: 0;
}

.datenschutz-row .cf-datenschutz {
    padding-left: 22px;
    display: block;
}

.row.submit-row {
    margin-top: 80px;
}

.wpcf7-form-control.g-recaptcha.wpcf7-recaptcha > div {
	margin: 0 auto 2rem auto;
}

span.wpcf7-spinner {
    display: none;
}


/* Footer */

.footer-scrollicon a {
    background: white;
    z-index: 100;
    padding: 20px;
    margin-bottom: -20px;
    position: relative;
    box-shadow: 0px 0px 10px 0px rgb(0 0 0 / 10%);
    border-radius: 50%;
}


/*---- Salim add CSS here ----*/

.pagination-sec {
    display: flex;
    width: 100%;
    justify-content: space-between;
    align-items: center;
    text-transform: uppercase;
    margin-top: 80px;
    margin-bottom: 80px;
}

.pagination-sec>div {
    flex: 1;
}

.back-to-overview-button {
    text-align: center;
}

.back-to-overview-button a {
    font-size: 24px;
    line-height: 1.4;
    font-weight: 600;
    padding-left: 7px;
    padding-right: 7px;
}

.pagination-sec .prev-arrow {
    float: left;
}

.pagination-sec .next-arrow {
    text-align: right;
}

.pagination-sec .prev-arrow,
.pagination-sec .next-arrow {
    font-weight: 600;
}

.pagination-sec i.fa {
    font-size: 22px;
    vertical-align: middle;
}

.pagination-sec .next-arrow i,
.pagination-sec .prev-arrow i {
    margin-left: 5px;
    font-size: 22px;
    display: inline-block;
    vertical-align: middle;
    margin-bottom: 3px;
}

.pagination-sec .prev-arrow i {
    margin-right: 5px;
}
@media screen and (max-width:991px) {
	.product-usp {
		width:100%;
	}
	body .fancybox__content {
		padding:15px;
	}
	.custom-search-results {
    max-height: calc(100vh - 220px);
	}
	.dots-rectangle.after-masonry:after {
    left: 20px;
    height: 150px;
    bottom: auto;
    top: calc(100% + 40px);
	}
	.dots-rectangle.dots-recangle-referenzen:after {
    
    bottom: -20px;
    height: 120px;
}
}
@media screen and (max-width:767px) {
	.masonry-card, .custom-cards .masonry-card {
		width:100%;
	}
	.back-to-overview-button {
		width:100%;
		order:1;
		margin-bottom:15px;
	}
	.prev-arrow {
		order:2;
	}
	.next-arrow {
		order:3;
	}
	.pagination-sec {
		flex-wrap:wrap;	
		margin:30px 0;
	}
	.pagination-sec>div {
		flex:initial;	
	}
	#search-filter-form-1521 ul li {
		width:100%;
	}
	.wpcf7-radio .wpcf7-list-item+.wpcf7-list-item {
		margin-left:0;
	}
	.wpcf7-radio .wpcf7-list-item {
		width:100%;
		margin:5px 0;
	}
	
	
	/* FRAGEN UND ANTWORTEN start */
	
	.fragen-accordion .elementor-accordion .elementor-tab-title {
		line-height: 26px;
		padding: 10px;
		font-size: 1em;
	}
	
	.fragen-accordion .elementor-accordion .elementor-tab-title .elementor-accordion-icon {
		height: 60px;
		line-height: 27px;
		margin-right: 5px;
	}
	
	.fragen-accordion .elementor-accordion .elementor-tab-content {
		border-top: none;
		padding: 5px 10px 30px 35px;
	}
	
	.fragen-accordion .elementor-accordion .elementor-tab-title .elementor-accordion-icon svg {
		width: 1rem;
		height: 1rem;
		margin-top: 5px;
	}
	
	/* FRAGEN UND ANTWORTEN ende */
	
	
	/* NEWSLETTER ANMELDUNG */
	
	#sib-container {
		padding-top: 0px !important;
	}
	
	.footer-nav ul li a {
		line-height: 26px;
	}
}
