/*----------------*/
/* SECTION TEASER */
/*----------------*/
section.teaser.revilodesign,
section.teaser.revilodesign.bg-color-green {
	padding: 0;
}
section.teaser div.teaser-wrapper {
	position: relative;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 1;
}
section.teaser::before {
	width: 80%;
	z-index: 2;
	left: 0;
	background: rgba( var(--revilodesign_secondary), 0.4);
}
section.teaser::after {
	width: 64%;
	left: 0;
	opacity: 0.3;
}
section.teaser div.flex {
	height: 100%;
	position: relative;
	z-index: 9;
	padding-top: 0;
}
section.teaser.text-align-center div.flex {
	justify-content: center;
}
section.teaser div.image {
	position: relative;
	display: flex;
}
section.teaser div.image.image-position-top {
	align-items: flex-start;
	padding-bottom: 64px;
}
section.teaser div.image.image-position-center {
	align-items: center;
	padding-bottom: 64px;
	padding-top: 64px;
}
section.teaser div.image.image-position-bottom {
	align-items: flex-end;
	padding-top: 64px;
}
section.teaser div.image div.image-content {
	display: inline-flex;
	width: 100%;
	height: calc(100% - 160px);
}
section.teaser div.image div.image-content div.bg {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	bottom: 0;
	border-radius: var(--revilodesign_borderRadiusBigs) var(--revilodesign_borderRadiusBigs) 0 0;
}
section.teaser div.image div.image-content div.bg.bg-right {
	left: auto;
	right: 0;
}
section.teaser div.image picture,
section.teaser div.image picture img {
	object-fit: contain;
	object-position: bottom;
	position: relative;
	z-index: 9;
}
section.teaser div.image.image-position-center picture,
section.teaser div.image.image-position-center picture img {
	align-items: center;
}
section.teaser div.image.image-position-top picture,
section.teaser div.image.image-position-top picture img {
	align-items: flex-start;
}
section.teaser div.image.image-position-bottom picture,
section.teaser div.image.image-position-bottom picture img {
	align-items: flex-end;
}
section.teaser div.image picture {
	z-index: 6;
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: center;
}
section.teaser div.image picture img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
section+section.teaser div.image picture {
	height: 100%;
	z-index: 6;
}
section+section.teaser div.image.image-position-center picture,
section+section.teaser div.image.image-position-center picture img {
	padding: 80px 0;
}
section.teaser div.text {
	display: flex;
	align-items: flex-start;
	flex-direction: column;
	padding: 160px 0 120px 0;
	position: relative;
	z-index: 9;
}
section.teaser.text-align-center div.text {
	justify-content: center;
	align-items: center;
}
section+section.teaser div.text {
	padding: 80px 0;
}
section.teaser div.text {
	max-width: calc(var(--revilodesign_maxWidth) / 1.8 );
}
section.teaser div.text h1,
section.teaser div.text h2 {
	position: relative;
	z-index: 1;
}
section.teaser div.text div.buttons {
	padding-top: 24px;
}
/*--------------------------*/
/* SECTION TEASER TYPE LOGO */
/*--------------------------*/
section.teaser.image-type-logo *.flex {
	gap: 64px;
}
section.teaser.image-type-logo div.text {
	max-width: 100%;
}
section.teaser.image-type-logo div.text h1,
section.teaser.image-type-logo div.text h2 {
	width: 100%;
}
section.teaser.image-type-logo div.text p {
	width: 80%;
}
section.teaser.image-type-logo div.image {
	display: flex;
	justify-content: flex-end;
	align-items: center;
}
section.teaser.image-type-logo div.image div.image-content {
	height: auto;
	display: inline-flex;
	position: relative;
	left: auto;
	top: auto;
	justify-content: center;
}
section.teaser.image-type-logo div.image picture {
	padding: 48px;
	height: auto;
	max-height: 50%;
	width: 100%;
	position: relative;
	left: auto;
	bottom: auto;
	width: auto;
	transform: none;
}
section.teaser.image-type-logo div.image picture img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	position: relative;
	left: auto;
	bottom: auto;
	border-radius: 0;
}
section.teaser.image-type-logo div.image picture.vector img {
	min-width: 100%;
	max-width: 100%;
}
section.teaser.image-type-logo div.image div.image-content div.bg {
	border-radius: var(--revilodesign_borderRadiusBigs);
}
@media ( max-width: 768px ) {
	section.teaser div.flex {
		flex-direction: column;
		align-items: flex-start;
		justify-content: flex-start;
		height: auto;
	}
	section.teaser div.text {
		padding: 0 0 48px;
	}
	section.teaser div.image,
	section.teaser div.image.image-position-center {
		order: -1;
		padding: 0;
		width: calc( 100% + 48px);
		max-width: calc( 100% + 48px);
		margin-left: -24px;
	}
	section.teaser div.image div.image-content {
		max-height: 56vh;
		height: 480px;
		overflow: hidden;
		display: block;
	}
	section.teaser div.image div.image-content picture,
	section.teaser div.image div.image-content picture img  {
		width: 100%;
		height: 100%;
		max-height: 100%;
		display: block;
		object-fit: cover;
		position: absolute;
		left: 0;
		top: 0;
	}
}