/* 
Theme Name: 4D Elementor
Description: 4D Elementor is a child theme of Hello Elementor, created by Vierdimensional team
Author: Vierdimensional Team
Author URI: https://vierdimensional.com/
Template: hello-elementor
Version: 2.2.1
Text Domain: 4d-elementor
License: GNU General Public License v3 or later.
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Tags: flexible-header, custom-colors, custom-menu, custom-logo, editor-style, featured-images, rtl-language-support, threaded-comments, translation-ready
*/

/* Add your custom styles here */


/************* Elementor ******************++++*/
.elementor-widget-image.header-logo a {
    font-size: 10px !important;
    line-height: 1em;
    display: inline-block;
}

.elementor-widget-text-editor ul, .elementor-widget-text-editor ol {
    margin: 0;
}

.elementor-widget-text-editor ul li {
    list-style: none;
}

.elementor-widget-text-editor ul:not(.elementor-editor-element-settings) li::before {
    content: "+";
    margin-right: 5px;
}

/* Navigation */
.header-navigation .elementor-nav-menu a,
.header-navigation .elementor-nav-menu a:focus {
    border: 0 !important;
}

.header-navigation .elementor-nav-menu a:focus {
    background-color: transparent !important;
}

.header-navigation .elementor-nav-menu li ul.sub-menu {
    margin-left: 0 !important;
    position: relative !important;
    margin-top: 0 !important;
    width: 100% !important;
}

.elementor-widget.elementor-widget-icon-list .elementor-icon-list-icon {
    align-self: flex-start;
    margin-top: .2em;
}

.elementor-widget-icon-list.nth-child-2.color-primary ul li:nth-child(2) .elementor-icon-list-icon svg {
    fill: var(--e-global-color-primary);
}

.elementor-widget-icon-list.nth-child-2.color-primary ul li:nth-child(2) .elementor-icon-list-text {
    color: var(--e-global-color-primary);
}

.elementor-widget-icon a.elementor-icon, .elementor-widget-icon .elementor-icon
 {
    display: block;
}

.icon-button .elementor-button-content-wrapper {
    align-items: center;
}

.icon-button .elementor-button-icon {
    display: block;
    padding: 15px 0 0 15px;
    background: var(--e-global-color-primary);
}

.icon-button.inverted .elementor-button-icon {
    background: var(--e-global-color-text);
}

.icon-button svg {
    transform: rotate(45deg);
    fill: var(--e-global-color-text);
    transition-duration: .3s;
    transition-property: transform;
    display: block;
}

.elementor-widget-n-carousel.icon-rotate .elementor-swiper-button-prev {
       padding: 15px 15px 0 0;
}

.elementor-widget-n-carousel.icon-rotate .elementor-swiper-button-next {
       padding: 15px 0 0 15px;
}

.elementor-widget-n-carousel.icon-rotate .elementor-swiper-button-prev svg,
.elementor-widget-n-carousel.icon-rotate .elementor-swiper-button-prev i {
        transform: rotate(-45deg);
        transition-duration: .3s;
        transition-property: transform;
}

.elementor-widget-n-carousel.icon-rotate .elementor-swiper-button-next svg,
.elementor-widget-n-carousel.icon-rotate .elementor-swiper-button-next i {
        transform: rotate(45deg);
        transition-duration: .3s;
        transition-property: transform;
}

.elementor-widget-n-carousel.icon-rotate .elementor-swiper-button-prev:hover svg,
.elementor-widget-n-carousel.icon-rotate .elementor-swiper-button-prev:hover i {
        transform: rotate(-45deg) scale(1.1);
}

.elementor-widget-n-carousel.icon-rotate .elementor-swiper-button-next:hover svg,
.elementor-widget-n-carousel.icon-rotate .elementor-swiper-button-next:hover i {
        transform: rotate(45deg) scale(1.1);
}

.icon-button.inverted svg {
    fill: var(--e-global-color-primary);
}

.icon-button .elementor-button-link:hover svg {
    transform: rotate(45deg) scale(1.1);
}

.icon-button .elementor-button-text span {
    color: var(--e-global-color-primary);
}

.elementor-widget-heading.kreis-zahl .elementor-widget-container {
    height: auto !important;
}

.elementor-widget-heading.kreis-zahl.centered {
    transform: translate(-50%, -50%);
}

.elementor-element.translate-y {
    transform: translateY(-50%);
}

.text-stroke .jet-headline__label span {
    -webkit-text-stroke: 4px var(--e-global-color-primary);
    color: transparent !important;
}

.text-stroke-white .jet-headline__label span {
    -webkit-text-stroke: 4px #ffffff;
    color: transparent !important;
}

.elementor-widget-text-editor a.text-klein {
    font-size: var(--e-global-typography-accent-font-size);
}

.elementor-widget-text-editor a.text-klein .icon {
    vertical-align: baseline;
}

/* Header */
.elementor-location-header {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.elementor-location-header.scrolled {
  min-height: 100px;
}

.elementor-location-header.scrolled .seitentitel {
    transform-origin: center left;
}

.elementor-location-header.scrolled .logo {
    transform: scale(0.65);
    transform-origin: center right;
}

/* Footer */
.elementor-location-footer .footer-kontakt a {
	color: var(--e-global-color-text);
	font-size: 16px;
}

.elementor-widget-image:not(.header-logo) a {
	display: flex !important;
	height: 100%;
}

/* Audio Widget */
.elementor-widget-jet-audio::after {
    content: attr(data-title);
    position: absolute;
    top: 50%;
    left: 40px;
    transform: translateY(-50%);
    font-size: 12px;
    padding-right: 40px;
}

/* Akkordion */
.elementor-widget-n-accordion .e-n-accordion {
  counter-reset: faq-counter;
}

.elementor-widget-n-accordion .e-n-accordion .e-n-accordion-item {
  border-bottom: 1px solid var(--e-global-color-text);
}

.elementor-widget-n-accordion .e-n-accordion-item summary::before {
  counter-increment: faq-counter;
  content: counter(faq-counter, decimal-leading-zero);
  font-size: var(--n-accordion-title-font-size);
  font-weight: var(--e-global-typography-73ff3fa-font-weight);
  display: flex;
}

.elementor-widget-n-accordion .e-n-accordion-item .e-n-accordion-item-title {
    gap: 120px;
}

.elementor-widget-n-accordion .e-n-accordion-item .e-n-accordion-item-title .e-closed svg,
.elementor-widget-n-accordion .e-n-accordion-item .e-n-accordion-item-title .e-closed i {
    transform: rotate(45deg);
    transition-duration: .3s;
}

.elementor-widget-n-accordion .e-n-accordion-item .e-n-accordion-item-title .e-opened svg,
.elementor-widget-n-accordion .e-n-accordion-item .e-n-accordion-item-title .e-opened i {
    transform: rotate(-45deg);
    transition-duration: .3s;
}

.elementor-widget-n-accordion .e-n-accordion-item .e-n-accordion-item-title:hover .e-closed svg,
.elementor-widget-n-accordion .e-n-accordion-item .e-n-accordion-item-title:hover .e-closed i {
        transform: rotate(45deg) scale(1.1);
}

.elementor-widget-n-accordion .e-n-accordion-item .e-n-accordion-item-title:hover .e-opened svg,
.elementor-widget-n-accordion .e-n-accordion-item .e-n-accordion-item-title:hover .e-opened i {
    transform: rotate(-45deg) scale(1.1);
}

.elementor-widget-n-accordion .e-n-accordion-item-title-header {
    flex-grow: 1;
    justify-content: flex-end;
}

.elementor-widget-n-accordion .e-n-accordion-item-title-header .e-n-accordion-item-title-text {
    max-width: 600px;
}

/* Karusell */
.elementor-widget-n-carousel.awards .swiper-slide.swiper-slide-active,
.elementor-widget-n-carousel.awards .swiper-slide.swiper-slide-next {
    border-right: 1px solid var(--e-global-color-text);
}

/* Jet Karusell */
.jet-carousel {
    margin-left: 0 !important;
    margin-right: 0 !important;
}

.jet-carousel .jet-slick-dots li span {
    text-indent: 0 !important;
    width: auto !important;
    height: auto !important;
    background-color: transparent !important;
    font-size: 16px;
    font-weight: 800;
}

.jet-carousel .jet-slick-dots li:not(.slick-active) span {
    color: var(--e-global-color-text);
}

.jet-carousel .jet-slick-dots li.slick-active span {
    color: var(--e-global-color-primary);
}

.jet-carousel-wrap.jet-equal-cols .jet-carousel__item img {
    width: 100%;
}

.team-slider .jet-carousel .jet-arrow.next-arrow svg,
.logo-slider .elementor-image-carousel-wrapper .elementor-swiper-button-next svg,
.team-slider .jet-carousel .jet-arrow.prev-arrow svg,
.logo-slider .elementor-image-carousel-wrapper .elementor-swiper-button-prev svg {
    display: block;
    transition-duration: .3s;
    transition-property: transform;
}

.logo-slider .elementor-image-carousel-wrapper .elementor-swiper-button {
    background-color: var(--e-global-color-text);
    padding: 10px;
}

.logo-slider .elementor-image-carousel-wrapper .elementor-swiper-button svg {
    width: 22px;
    height: 22px;
}

.logo-slider .swiper-container {
    width: 90%;
}

/* jet Listings */
.jet-listing .jet-listing-dynamic-field__content p {
    display: inline;
}

.jet-listing .jet-listing-dynamic-field__content .arrow::after {
    content: url('assets/img/arrow.svg');
}

.mitarbeiter .elementor-flip-box__layer__description {
    font-size: 30px;
    font-weight: 800;
}

.jet-listing-grid .jet-listing-grid__slider .slick-arrow svg {
    display: none;
}

.jet-listing-grid .jet-listing-grid__slider .slick-arrow:after {
    content: url('assets/img/arrow-weiss-lang-links.svg');
    line-height: 44px;
    width: 22px;
    height: auto;
}

/* Jobs */
.elementor-widget-jet-headline.job-title .jet-headline {
    display: block;
}

.elementor-widget-jet-headline.job-title .jet-headline .jet-headline__first,
.elementor-widget-jet-headline.job-title .jet-headline .jet-headline__second {
    display: inline;
}

.elementor-widget-jet-headline.job-title .jet-headline .jet-headline__second {
    margin-left: 20px;
}

/* Scroll Effekte */
.premium-hscroll-fixed-content {
    right: 0;
}

.premium-hscroll-slider .premium-hscroll-sections-wrap {
    display: flex;
    align-items: flex-end;
}

.elementor-element.premium-mscroll-yes,
.premium-hscroll-slider .premium-hscroll-scroller-wrap {
    transition-duration: 300ms;
}

.e-con.full-height .elementor-element-edit-mode.elementor-widget-image img {
    height: 100vh;
    width: 100%;
    object-fit: cover;
}

/* CF7 */
::placeholder {
    color: var(--e-global-color-a339ea6);
    opacity: 1;
}

::-ms-input-placeholder {
    color: var(--e-global-color-a339ea6);;
}

.cf-container {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-right: -11px;
    margin-left: -11px;
}

.cf-container[class^="cf-col-"], .cf-container[class*=" cf-col-"] {
    align-self: flex-start;
    padding: 0;
    margin: 0;
}

.cf-col-1,
.cf-col-2,
.cf-col-3,
.cf-col-4,
.cf-col-5,
.cf-col-6,
.cf-col-7,
.cf-col-8,
.cf-col-9,
.cf-col-10,
.cf-col-11,
.cf-col-12 {
    position: relative;
    width: 100%;
    min-height: 1px;
    padding-right: 11px;
    padding-left: 11px;
    margin-bottom: 22px;
}

.wpcf7-form p {
    margin-bottom: 0;
}

.wpcf7-form label {
	color: #fff;
}

.wpcf7-form .wpcf7-select {
    font-family: var(--e-global-typography-accent-font-family), Sans-serif;
    font-size: var(--e-global-typography-accent-font-size);
    font-weight: var(--e-global-typography-accent-font-weight);
    line-height: var(--e-global-typography-accent-line-height);
    color: var(--e-global-color-a339ea6);
    background-color: #4D4D4D;
    padding: 20px 30px;
    border: 0;
    border-radius: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

.wpcf7-not-valid-tip {
    font-size: var(--e-global-typography-c755413-font-size);
}

.elementor-widget:not(.kontaktformular) .wpcf7 form.sent .wpcf7-response-output,
.elementor-widget:not(.kontaktformular) .wpcf7 form.invalid .wpcf7-response-output {
    color: #fff;
}

.wpcf7 form.sent .wpcf7-response-output,
.wpcf7 form.invalid .wpcf7-response-output {
    border: none;
    padding: 0;
    margin-left: 0;
    margin-right: 0;
}

.selectdiv .wpcf7-form-control-wrap:after {
    content: url('img/arrow-weiss.svg');
    right: 15px;
    top: 12px;
    width: 16px;
    height: 16px;
    position: absolute;
    pointer-events: none;
}

.codedropz-upload-inner h6,
.codedropz-upload-inner span,
.codedropz-upload-inner a  {
    color: #fff !important;
    font-size: var(--e-global-typography-c755413-font-size);
}

.dnd-upload-details .name span,
.dnd-upload-details .name em {
    color: #fff;
    font-size: var(--e-global-typography-c755413-font-size);
}

.dnd-upload-status .dnd-upload-details .dnd-progress-bar span {
    background: #fff;
    color: #000;
}

.wpcf7-form input[type="submit"],
.wpcf7-form input[type="submit"]:hover,
.wpcf7-form input[type="submit"]:focus {
    font-size: 20px;
    color: var(--e-global-color-text);
    background-color: var(--e-global-color-primary);
    padding: 20px 40px 20px 40px;
}

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

.elementor-widget:not(.kontaktformular) .wpcf7-form .captcha-image {
    border-color: #fff;
}

.elementor-widget:not(.kontaktformular) .wpcf7-form .cf7ic_instructions, .elementor-widget:not(.kontaktformular) .wpcf7-form .wpcf7-response-output,
.elementor-widget:not(.kontaktformular) .captcha-image .cf7ic_instructions span {
    color: #fff !important;
}

.wpcf7-form .cf7ic_instructions, .wpcf7-form .wpcf7-response-output,
.captcha-image .cf7ic_instructions span {
    font-size: 16px;
    line-height: 1.4em;
}

.elementor-widgetiv:not(.kontaktformular) .captcha-image label>input:checked+svg,
.elementor-widget:not(.kontaktformular) .captcha-image label>input:focus+svg {
    border: 2px solid #fff !important;
}

.kontaktformular .wpcf7-form input[type="email"],
.kontaktformular .wpcf7-form input[type="tel"],
.kontaktformular .wpcf7-form input[type="text"],
.kontaktformular .wpcf7-form textarea {
    background-color: var(--e-global-color-bf5518f) !important;
    color: var(--e-global-color-text) !important;
}

.kontaktformular .wpcf7-form label {
    color: var(--e-global-color-text);
}

.kontaktformular .wpcf7-form .html {
    font-size: var(--e-global-typography-accent-font-size);
    line-height: 1.4em;
    margin-top: 20px;
}

.kontaktformular .wpcf7-checkbox {
    display: flex;
    flex-wrap: wrap;
}

.popup-formular input[type="radio"] {
    width: 18px;
    height: 18px;
	min-width: auto !important;
    appearance: none;
    background-origin: border-box;
    color: var( --e-global-color-primary ) !important;
    background-color: var(--e-global-color-text) !important;
	border-style: solid !important;
	border-width: 1px !important;
    border-color: var( --e-global-color-primary ) !important;
    border-radius: 50% !important;
	padding: 0 !important;
}

.popup-formular input[type="radio"]:checked {
	background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='%23E9FF00' xmlns='http://www.w3.org/2000/svg'%3e%3ccircle cx='8' cy='8' r='3'/%3e%3c/svg%3e");
}

.kontaktformular .wpcf7-checkbox .wpcf7-list-item {
    flex-basis: 280px;
}

.kontaktformular .wpcf7-form input[type="email"]::placeholder,
.kontaktformular .wpcf7-form input[type="tel"]::placeholder,
.kontaktformular .wpcf7-form input[type="text"]::placeholder,
.kontaktformular .wpcf7-form textarea::placeholder {
    color: var(--e-global-color-text);
    opacity: 1;
}

.kontaktformular .wpcf7-form input[type="email"]::-ms-input-placeholder,
.kontaktformular .wpcf7-form input[type="tel"]::-ms-input-placeholder,
.kontaktformular .wpcf7-form input[type="text"]::-ms-input-placeholder,
.kontaktformular .wpcf7-form textarea::-ms-input-placeholder {
    color: var(--e-global-color-text);
}

@media (min-width: 1441px) and (max-width: 2399px) {
    .elementor-hidden-desktop {
        display: none !important;
    }
}

@media (min-width: 1081px) and (max-width: 1440px) {
    .elementor-hidden-laptop {
        display: none !important;
    }
}

@media (min-width: 1081px) {
    .elementor-widget-n-carousel.awards .elementor-swiper-button {
        display: none;
    }

    .elementor-widget-n-carousel.awards:hover .elementor-swiper-button {
        display: inline-flex;
    }
}

@media (max-width: 1080px) {
    body.header-transparent .elementor-location-header .elementor-sticky--active:not(.elementor-sticky--effects) .elementor-widget-image.elementor-hidden-desktop img {
        filter: invert(100%);
    }

    body.header-transparent .elementor-location-header .elementor-sticky--active:not(.elementor-sticky--effects) .elementor-widget-icon svg line {
        stroke: #ffffff !important;
    }

	.e-con {
  		--container-max-width: 100% !important;
	}
	
	.elementor-location-header .elementor-sticky--active.elementor-sticky--effects {
    	min-height: 80px;
    	height: 80px;
	}

	.header-navigation .elementor-nav-menu li ul.sub-menu {
        display: block !important;
    }

    .cf-container[class^="cf-col-"], .cf-container[class*=" cf-col-"] {
        flex: 0 0 100%;
        max-width: 100%;
    }

    .logo-slider .swiper-container {
        width: 86%;
    }

    .kontaktformular .wpcf7-checkbox .wpcf7-list-item {
        flex-basis: 40%;
    }

    .elementor-widget-n-accordion .e-n-accordion-item .e-n-accordion-item-title {
        gap: 60px;
    }

    .elementor-widget-n-accordion .e-n-accordion-item-title-header {
        justify-content: flex-start;
    }

    .elementor-widget-n-carousel.awards .swiper-slide.swiper-slide-next {
        border-right: 0;
    }

    .mobile-position-absolute {
		position: absolute !important;
		bottom: 3%;
		left: 3%;
	}
}

@media (min-width: 768px) {
    .cf-col-1 {
        -ms-flex: 0 0 8.333333%;
        flex: 0 0 8.333333%;
        max-width: 8.333333%;
    }

    .cf-push-1 {
        margin-left: 8.333333%;
    }

    .cf-col-2 {
        -ms-flex: 0 0 16.66667%;
        flex: 0 0 16.66667%;
        max-width: 16.66667%;
    }

    .cf-push-2 {
        margin-left: 16.66667%;
    }

    .cf-col-3 {
        -ms-flex: 0 0 25%;
        flex: 0 0 25%;
        max-width: 25%;
    }

    .cf-push-3 {
        margin-left: 25%;
    }

    .cf-col-4 {
        -ms-flex: 0 0 33.33333%;
        flex: 0 0 33.33333%;
        max-width: 33.33333%;
    }

    .cf-push-4 {
        margin-left: 33.33333%;
    }

    .cf-col-5 {
        -ms-flex: 0 0 41.66667%;
        flex: 0 0 41.66667%;
        max-width: 41.66667%;
    }

    .cf-push-5 {
        margin-left: 41.66667%;
    }

    .cf-col-6 {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }

    .cf-push-6 {
        margin-left: 50%;
    }

    .cf-col-7 {
        -ms-flex: 0 0 58.33333%;
        flex: 0 0 58.33333%;
        max-width: 58.33333%;
    }

    .cf-push-7 {
        margin-left: 58.33333%;
    }

    .cf-col-8 {
        -ms-flex: 0 0 66.66667%;
        flex: 0 0 66.66667%;
        max-width: 66.66667%;
    }

    .cf-push-8 {
        margin-left: 66.66667%;
    }

    .cf-col-9 {
        -ms-flex: 0 0 75%;
        flex: 0 0 75%;
        max-width: 75%;
    }

    .cf-push-9 {
        margin-left: 75%;
    }

    .cf-col-10 {
        -ms-flex: 0 0 83.33333%;
        flex: 0 0 83.33333%;
        max-width: 83.33333%;
    }

    .cf-push-10 {
        margin-left: 83.33333%;
    }

    .cf-col-11 {
        -ms-flex: 0 0 91.66667%;
        flex: 0 0 91.66667%;
        max-width: 91.66667%;
    }

    .cf-push-11 {
        margin-left: 91.66667%;
    }

    .cf-col-12 {
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        max-width: 100%;
    }

}

@media (min-width: 768px) and (max-width: 1080px) {
    .elementor .elementor-hidden-tablet {
        display: none !important;
    }

    .elementor-location-header .elementor-sticky.elementor-sticky--effects .seitentitel {
        transform-origin: center right;
    }
}

@media (max-width: 767px) {
    #ast-scroll-top {
        width: 37px;
        height: 37px;
    }
    
    #ast-scroll-top svg {
        width: 14px;
        height: 17px;
    }
	
	.mobile-position-absolute {
		bottom: 20px;
		left: 20px;
	}
	
	.hg-schwarz-mobile {
		background: #000;
	}
	
	.mobile-color-weiss .elementor-heading-title {
		color: #fff;
	}

    .elementor-hidden-phone, .elementor-hidden-mobile, .elementor-widget-jet-headline.leistung-zahl .jet-headline__second {
        display: none !important;
    }
	
	.text-stroke .jet-headline__label span {
		-webkit-text-stroke-width: 2px;
	}

    .text-stroke-white .jet-headline__label span {
		-webkit-text-stroke: 2px #ffffff;
	}

    .icon-button .elementor-button-icon {
        padding: 10px 0 0 10px;
    }

    .icon-button svg {
        font-size: 17px;
    }
	
	.jet-listing-grid .jet-listing-grid__slider .slick-arrow:after {
		line-height: 37px;
		width: 17px;
	}
	
	.jet-carousel .jet-slick-dots li span {
		font-size: 14px;	
	}

    .elementor-widget-n-accordion .e-n-accordion-item .e-n-accordion-item-title {
        gap: 20px;
    }

    .elementor-widget-n-carousel.awards .swiper-slide.swiper-slide-active {
        border-right: 0;
    }

    .wpcf7-form input[type="submit"],
    .wpcf7-form input[type="submit"]:hover,
    .wpcf7-form input[type="submit"]:focus {
        font-size: 18px;
        padding: 15px 24px 15px 24px;
    }

    .wpcf7-form .wpcf7-select {
        padding: 15px;
    }

    .elementor-location-header .seitentitel .jet-headline__second {
        display: none;
    }

    .jet-listing-grid__item.colspan-2-4 {
        max-width: 100% !important;
        flex: 0 0 100% !important;
    }

    .kontaktformular .wpcf7-checkbox .wpcf7-list-item {
        flex-basis: 100%;
    }
	
	.hintergrund-slider .swiper-slide-contents {
		margin-top: clamp(120px, 20vh, 200px);
	}
}