/*======================================
Theme Name: Divi Child Theme
Theme URI: http://www.elegantthemes.com
Description: Divi Child Theme
Author: ineu
Template: Divi
Version: 1.0.0
======================================*/

/*add your custom CSS below this line*/


/*fixing horizontal scroll bug*/
#page-container { 
	overflow:hidden; 
}

/*Backend Modification: make Divi Builder text style settings sticky on scroll*/
.mce-panel .mce-stack-layout-item.mce-first {
	position: sticky!important;
	top: -60px;
}


/*hyphens*/
h3.et_pb_module_header,
h3.et_pb_toggle_title {
	-webkit-hyphens: auto;
	-ms-hyphens: auto;
	hyphens: auto;
}
@media only screen and (max-width:800px) {
	.introtext-job {
		-webkit-hyphens: auto;
		-ms-hyphens: auto;
		hyphens: auto;
	}
}

/*text styles*/
ul li::marker {
	color: #ff6d00;
}
ul li {
	padding-bottom: 12px;
}

blockquote {
	padding-left: 0px;
}
p strong {
	font-weight: 700;
}
.introtext-job {
	font-weight: 700!important;
}
#page-container .et_pb_section .et_pb_button.textbutton {
	text-decoration-color: #000000!important;
}
.et_pb_text h2 a,
.job-badge p a,
.menu-item-s a,
.et_pb_row_0_tb_footer a,
.et_pb_row_1_tb_footer a {
	text-decoration: none!important;
}

/* menu */
.menu-item p {
	font-size: clamp(28px, 5.5vh, 80px)!important;
	line-height: 90%;
	margin: 2vh 0;
}

/*image aspect ratio square 1:1*/
.pa-image-1-1 .et_pb_image_wrap {
	display: inline-block;
}
.pa-image-1-1 .et_pb_image_wrap img {
	aspect-ratio: 1/1;
	object-position: center center;
	object-fit: cover;
}
/*header image boxes*/
.image-header-2 .et_pb_image_wrap,
.image-header-r .et_pb_image_wrap, 
.image-header-l .et_pb_image_wrap,
.image-cta .et_pb_image_wrap {
	display: inline-block;
}
#home.image-header-r .et_pb_image_wrap img {
	object-position: left bottom !important;
}
#wp.image-header-r .et_pb_image_wrap img {
	object-position: center center !important;
}
#about.image-header-2 .et_pb_image_wrap img {
	object-position: center center !important;
}
@media (min-width: 981px) {
	.image-header-r .et_pb_image_wrap img,
	.image-header-2 .et_pb_image_wrap img {
		height: 640px !important;
	}
	.image-header-l .et_pb_image_wrap img {
		aspect-ratio: 1/1;
	}
	.image-cta .et_pb_image_wrap img {
		aspect-ratio: 7/8;
	}
}
@media (min-width: 768px) and (max-width: 980px) {
	.image-header-r .et_pb_image_wrap img,
	.image-header-l .et_pb_image_wrap img {
		aspect-ratio: 4/3;
	}
	.image-header-2 .et_pb_image_wrap img,
	.image-cta .et_pb_image_wrap img  {
		aspect-ratio: 1/1;
	}
}
@media (max-width: 767px) {
	.image-header-r .et_pb_image_wrap img,
	.image-header-l .et_pb_image_wrap img,
	.image-header-2 .et_pb_image_wrap img {
		aspect-ratio: 8/7;
	}
	.image-cta .et_pb_image_wrap img  {
		aspect-ratio: 1/1;
	}
}
.image-header-2 .et_pb_image_wrap img,
.image-header-r .et_pb_image_wrap img,
.image-header-l .et_pb_image_wrap img {
	object-position: center center;
	object-fit: cover;
}
.image-cta .et_pb_image_wrap img {
	object-position: center top;
	object-fit: cover;
}


/*show desktop menu on phone*/
@media (max-width: 980px) {
	.pa-open-mobile-menu .et_pb_menu__menu {
		display: flex!important;
	}
	.pa-open-mobile-menu .et_mobile_nav_menu {
		display: none!important;
	}
}

/*style the Divi Blurb link as a button*/
a.pa-blurb-button {
	color: #ffffff;
	background: #ff6d00;
	border: 2px solid #ff6d00;
	padding: .7em 1.3em;
	margin-top: 20px;
	font-size: 16px;
	font-family: 'Outfit';
	font-style: normal;
	font-weight: 800;
	letter-spacing: 0.8px;
	text-transform: uppercase;
	display: inline-block;
	transition: all 0.3s ease-in-out;
}

/*style the Divi Blurb link text as a button on hover*/
a.pa-blurb-button:hover {
	background: transparent;
	color: #ff6d00;
	border: 2px solid #ff6d00;
	cursor: pointer;
	transition: all 0.3s ease-in-out;
}

/*add a transition effect*/
.pa-blurb-icon-button {
	transition: box-shadow .2s ease-in-out;
}

/*add an arrow icon in the bottom right corner*/
.pa-blurb-icon-button:after {
	font-family: ETModules;
	content: "\24";
	font-size: 36px;
	color: #ff6d00;
	position: absolute;
	bottom: 16px;
	right: 24px;
	transition: all .2s ease;
}

/*add the box shadow on hover*/
.pa-blurb-icon-button:hover {
	box-shadow: 0 10px 20px rgba(0, 0, 0, .15);
	transition: box-shadow .2s ease-in-out;
}

/*adjust the icon on hover*/
.pa-blurb-icon-button:hover:after {
	color: #f05000;
	bottom: 20px;
	transition: all .2s ease;
}

/*padding-left*/
@media (min-width: 768px) and (max-width: 980px) {
	.et_pb_blurb_position_left_tablet .et_pb_blurb_container {
		padding-left: 40px!important;
	}
}

/*move the arrows in from the right to align with modules
	.pa-dcm-textmodule .slick-arrow {
	margin-left: -48px!important;
}

/* Carousel dots */
@media (max-width: 767px) {
	.pac_dcm_column_1 .slick-dots {
		padding-right: 24px!important;
	}
}


/*blurb module modifications*/

/*change the cursor when hovering over the module*/
.pa-hover-blurb .et_pb_blurb_content {
	cursor: pointer;
}

/*restrict the display of the description text before hovering*/
.pa-hover-blurb .et_pb_blurb_description {
	display: none
}

/*add a smooth transition effect*/
.pa-hover-blurb .et_pb_blurb_container,
.pa-hover-blurb .et_pb_image_wrap {
	transition: all 0.4s ease-in-out !important;
}

/*restrict the triggering of hover effect when we hover on the title and align title to center*/
.pa-hover-blurb .et_pb_module_header {
	position: absolute;
	left: 60%;
	transform: translateX(-60%);
	pointer-events: none;
	width: 100%;
}

/*provide padding to description text so is doesn’t take the full width*/
.pa-hover-blurb .et_pb_blurb_description {
	padding: 0 5%;
}

/*place the whole content on image on hover and place it in center with different text color*/
.pa-hover-blurb .et_pb_blurb_content:hover .et_pb_blurb_container {
	position: absolute;
	top: 85%;
	transform: translateY(-85%);
	color: #ffffff !important;
	cursor: pointer;
	right: 0;
	left: 0;
}
@media only screen and (min-width: 1200px) {
	.pa-hover-blurb .et_pb_blurb_content:hover .et_pb_blurb_container {
		top: 85%;
		transform: translateY(-85%);
	}
}
@media only screen and (min-width: 501px) and (max-width: 1199px) {
	.pa-hover-blurb .et_pb_blurb_content:hover .et_pb_blurb_container {
		top: 75%;
		transform: translateY(-75%);
	}
}
@media only screen and (max-width: 500px) {
	.pa-hover-blurb .et_pb_blurb_content:hover .et_pb_blurb_container {
		top: 85%;
		transform: translateY(-85%);
	}
}

/*place the overlay effect on the image on hover*/
.pa-hover-blurb .et_pb_blurb_content:hover .et_pb_image_wrap:before {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	background-color: #000;
	left: 0;
	top: 0;
	opacity: 0.5;
}

/*make the position of the title relative on hover*/
.pa-hover-blurb .et_pb_blurb_content:hover .et_pb_module_header {
	position: relative;
	text-align: center;
}

/*change the title text color and font size on hover*/
.pa-hover-blurb .et_pb_blurb_content:hover .et_pb_blurb_container .et_pb_module_header {
	color: #ffffff!important;
}

/*show the description text on hover*/
.pa-hover-blurb .et_pb_blurb_content:hover .et_pb_blurb_description {
	display: block;
}

/*zoom the image on hover*/
.pa-hover-blurb .et_pb_blurb_content:hover .et_pb_image_wrap {
	transform: scale(1.05);
}

/*blurb image aspect ratios*/
@media only screen and (min-width: 501px) {
	.pa-hover-blurb .et_pb_image_wrap {
		aspect-ratio: 4 / 5;
	}
}
@media only screen and (max-width: 500px) {
	.pa-hover-blurb .et_pb_image_wrap {
		aspect-ratio: 9 / 10;
	}
}
.pa-hover-blurb .et_pb_image_wrap img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}


/*team columns*/
@media only screen and (min-width: 1440px) {
	.teamcolumns.et_pb_column {
		display:grid;
		grid-template-columns: 25% 25% 25% 25%;
		grid-auto-rows: auto;
		grid-column-gap: 32px;
		grid-row-gap: 48px;
		padding-right: 96px;
	}
}
@media only screen and (min-width: 800px) and (max-width: 1439px) {
	.teamcolumns.et_pb_column {
		display:grid;
		grid-template-columns: 33.3% 33.3% 33.3%;
		grid-auto-rows: auto;
		grid-column-gap: 32px;
		grid-row-gap: 48px;
		padding-right: 64px;
	}
}
@media only screen and (min-width: 501px) and (max-width: 799px) {
	.teamcolumns.et_pb_column {
		display:grid;
		grid-template-columns: 50% 50%;
		grid-auto-rows: auto;
		grid-column-gap: 24px;
		padding-right: 24px;
	}
}
@media only screen and (min-width: 768px) and (max-width: 799px) {
	.teamcolumns.et_pb_column {
		grid-row-gap: 40px;
	}
}
@media only screen and (max-width: 500px) {
	.teamcolumns.et_pb_column {
		grid-template-columns: 100%;
		grid-auto-rows: auto;
		padding-right: 0;
	}
}

/*person module modification*/
.pa-person:hover img {
-ms-transform: scale(1.00) !important;
-webkit-transform: scale(1.00) !important;
transform: scale(1.00) !important;
transition: all .5s cubic-bezier(0.170, 0.690, 0.470, 0.995);
}
.pa-person {
overflow: hidden;
}
.pa-person img {
transition: all .5s ease;
-ms-transform: scale(1.05);
-webkit-transform: scale(1.05);
transform: scale(1.05);
-webkit-transform-origin: bottom;
-moz-transform-origin: bottom;
-ms-transform-origin: bottom;
-o-transform-origin: bottom;
transform-origin: bottom;
}

/*text-image-teaser*/
@media (min-width: 1344px) {
	.in-textright .et_pb_text_inner {
		padding-right: calc(60% - 288px) !important;
	}
	.in-textleft .et_pb_text_inner {
		padding-left: calc(60% - 288px) !important;
	}
}

/*add icon to the opened accordion*/
.pa-accordion .et_pb_accordion_item.et_pb_toggle_open .et_pb_toggle_title:before {
	display: block;
	content: "\e04f";
	font-size: 24px;
	right: -4px;
	color: #FF6D00;
}
.pa-accordion .et_pb_accordion_item.et_pb_toggle_open .et_pb_toggle_title:hover:before {
	color: #F05000!important;
}

/*joblist button*/
.jobbutton {
  line-height: 120%!important;
	width: 100%;
}
.jobbutton.et_pb_button_wrapper {
  padding-right: 40px;
}
.jobbutton,
.jobbutton:hover {
  border-left: none!important;;
  border-right: none!important;;
}
.jobbutton.et_pb_button.et_pb_bg_layout_light,
.jobbutton.et_pb_button.et_pb_bg_layout_light:hover {
  padding-right: 80px!important;
}
.jobbutton::after {
    position: absolute;
    top: 50%;
    transform: translateY(-55%);
    right: 0;
}

/*benefits grid*/
.benefits {
	display: flex;
	flex-wrap: wrap;
}
@media only screen and (min-width: 1025px) {
	.benefit-item {
		flex: 0 0 33.33%;
		padding: 20px 40px 20px 0!important;
	}
	.benefits {
		justify-content: center;
	}
}
@media only screen and (min-width: 501px) and (max-width: 1024px) {
	.benefit-item {
		flex: 0 0 50%;
		padding: 20px 40px 20px 0!important;
	}
	.benefits {
		justify-content: flex-start;
	}
	.benefit-section {
		padding-right: 0!important;
	}
}
@media only screen and (max-width: 500px) {
	.benefit-item {
		flex: 0 0 100%;
		padding: 20px 0px 20px 0!important;
	}
}


/* --- input form styles --- */

/* disable title text */
.et_pb_contact_field_options_title {
	display: none;
}
/* text area height */
.et_pb_contact_field textarea.et_pb_contact_message {
	min-height: 240px;
}
/* select field arrow */
.et_pb_contact_field[data-type="select"]::after {
	right: 20px;
}
/* link styles */
.et_pb_contact_field a {
  color: #ff6d00;
  font-weight: 700;
  text-decoration: underline;
  text-decoration-style: dotted;
  text-decoration-color: #333333;
}
.et_pb_contact_field a:hover {
  color: #f05000;
}
/* radio button position */
.et_pb_contact p input[type="radio"] + label i {
  margin-top: -4px;
}
/* add '*' to radio button 'datenschutz' */
.et_pb_contact_field_radio label a:after {
  content:"*";
  margin-left: 3px;
  color: #333;
  font-weight: 200;
}
/* horizontal spacing for 2 column fields */
@media only screen and (min-width: 768px) {
	.et_pb_contact_field_half.et_pb_contact_field_last {
  		padding-left: 24px!important;
	}
}
/* adjust vertical space for 2 column fields */
.et_pb_contact_field_half {
	margin-top: 0!important;
}
/* contact-field message */
.et-pb-contact-message {
	background-color: #ff6d00;
	width: fit-content;
}
@media only screen and (min-width: 981px) {
	.et-pb-contact-message p {
		font-size: 28px;
	}
}
@media only screen and (min-width: 768px) and (max-width: 980px) {
	.et-pb-contact-message p {
		font-size: 24px;
	}
}
@media only screen and (max-width: 767px) {
	.et-pb-contact-message p {
		font-size: 22px;
	}
}
.et-pb-contact-message p {
	font-weight: 800;
    line-height: 110%;
	color: #fff;
	text-align: left;
	padding: 24px!important;
}
/* error message details */
.et-pb-contact-message ul {
	margin-top: 0px;
	margin-bottom: 24px;
	margin-left: 26px;
	margin-right: 26px;
	padding-bottom: 2px;
}
.et-pb-contact-message ul li {
  padding-bottom: 0px;
  color: #fff;
  font-weight: 200;
}
.et-pb-contact-message ul li::marker {
	color: #fff;
}
@media only screen and (min-width: 981px) {
	.et-pb-contact-message ul li {
		font-size: 20px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 980px) {
	.et-pb-contact-message ul li {
		font-size: 18px;
  }
}
@media only screen and (max-width: 767px) {
  .et-pb-contact-message ul li {
		font-size: 16px;
  }
}
.et_pb_contact p .et_contact_error {
  border: 1px solid #ff6d00 !important;
}
.et_pb_contact .et_pb_contact_form p.et_contact_error .et_pb_contact_field_radio label,
.et_pb_contact .et_pb_contact_form p.et_contact_error .et_pb_contact_field_radio label a:after {
  color: #ff6d00!important;
}

.et_pb_contact .et_pb_contact_form p.et_contact_error .et_pb_contact_field_radio label i {
  border-width: 1px;
	border-color: #ff6d00!important;
}


/* --- job-badge --- */
.job-badge {
	display: flex;
	align-items: center;
}
@media only screen and (min-width: 981px) {
	.job-badge .et_pb_text_inner {
		padding-bottom: 20px;
	}
}
@media only screen and (max-width: 980px) and (min-width: 768px) {
	.job-badge .et_pb_text_inner {
		padding-bottom: 16px;
	}
}
@media only screen and (max-width: 767px) {
	.job-badge .et_pb_text_inner {
		padding-bottom: 0px;
	}
}
.job-badge p {
	padding-bottom: 8px;
}

.et_pb_row.et_pb_row_0.jobbadge-row {
    position: absolute !important;
    top: 20px;
    bottom: auto;
    left: auto;
    right: 8px;
}
@media only screen and (min-width: 1920px) {
  .et_pb_row.et_pb_row_0.jobbadge-row {
    top: 20px;
    bottom: auto;
    left: calc(50% + 912px - 220px + 48px) !important;
    right: auto !important;
  }
}
@media only screen and (min-width: 768px) and (max-width: 980px) {
  .et_pb_row.et_pb_row_0.jobbadge-row {
    top: 20px;
    bottom: auto;
    left: auto !important;
    right: -32px !important;
  }
}
@media only screen and (max-width: 767px) {
  .et_pb_row.et_pb_row_0.jobbadge-row {
    top: 20px;
    bottom: auto;
    left: auto !important;
    right: -92px !important;
  }
}

@media only screen and (min-width: 981px) {
  .job-badge.et_pb_text:hover {
    width: 220px!important;
  }
}
@media only screen  and (min-width: 768px) and (max-width: 980px) {
  .job-badge.et_pb_text:hover {
    width: 180px!important;
  }
}
@media only screen  and (max-width: 767px) {
  .job-badge.et_pb_text:hover {
    width: 140px!important;
  }
}

.job-badge {
	animation-name: pulse-job-button;
	animation-duration: 3.0s;
	animation-iteration-count: infinite;

}
@keyframes pulse-job-button {
	0% {
		transform: scale(0.95) rotate(5deg);
		box-shadow: 0 0 0 0 rgba(240, 124, 0, 0.7);
	}
	70% {
		transform: scale(1) rotate(5deg);
		box-shadow: 0 0 0 18px rgba(240, 124, 0, 0);
	}
	100% {
		transform: scale(0.95) rotate(5deg);
		box-shadow: 0 0 0 0 rgba(240, 124, 0, 0);
	}
}



/* --- complianz: additional cookie banner styles --- */

.cmplz-btn.cmplz-accept:hover {
  background-color: #f05000!important;
  border: 1px solid #f05000!important;
}
.cmplz-btn.cmplz-deny:hover,
.cmplz-btn.cmplz-view-preferences:hover,
.cmplz-btn.cmplz-save-preferences:hover {
  background-color: #ddd!important;
  border: 1px solid #ddd!important;
}
.cmplz-documents a {
  text-decoration: none!important;
}
.cmplz-documents a:hover {
  color: #000!important;
}
.cmplz-cookiebanner .cmplz-close:hover {
  color: #b2b2b2!important;
}
@media (max-width: 768px) {
  .cmplz-cookiebanner {
    width: calc(100% - 40px)!important;
    max-width: 500px!important;
  }
}
@media (max-width: 360px) {
  .cmplz-cookiebanner {
    width: calc(100% - 20px)!important;
  }
}

/* --- complianz: additional cookie pages text styles --- */
#cmplz-document {
	max-width: 100%;
}
@media only screen and (min-width: 981px) {
	#cmplz-document p, #cmplz-document li  {
		font-size: 20px;
	}
}
@media only screen and (max-width: 980px) and (min-width: 768px) {
	#cmplz-document p, #cmplz-document li  {
		font-size: 18px;
	}
}
@media only screen and (max-width: 767px) {
	#cmplz-document p, #cmplz-document li  {
		font-size: 16px;
	}
}
#cmplz-document p, #cmplz-document li  {
	line-height: 140%;
}
@media only screen and (min-width: 981px) {
	#cmplz-document h2 {
		font-size: 32px;
	}
}
@media only screen and (max-width: 980px) and (min-width: 768px) {
	#cmplz-document h2 {
		font-size: 28px;
	}
}
@media only screen and (max-width: 767px) {
	#cmplz-document h2 {
		font-size: 24px;
	}
}
#cmplz-document h2 {
	line-height: 120%;
}
#cmplz-document a {
	text-decoration: underline;
	text-decoration-style: dotted;
	text-decoration-color: #333;
}

