/*----------------*/
/* SECTION TEASER */
/*----------------*/
section.teaser.micropayment{
	padding: 64px 0 0 0;
}
section.teaser.micropayment picture.bg_image img {
	object-position: center;
}
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(--micropayment_secondary), 0.4);
}
section.teaser::after {
	width: 64%;
	left: 0;
	opacity: 0.3;
}
section.teaser div.flex {
	height: 100%;
	gap: 0;
	position: relative;
	z-index: 9;
	align-items: stretch;
}
section.teaser.text-align-center div.flex {
	justify-content: center;
	position: relative;
}
.micropayment section.teaser .flex div.text {
	position: relative;
	z-index: 9;
}
.micropayment section.teaser .flex div.assets {
	flex-direction: initial;
	position: relative;
	display: flex;
	top: auto;
	max-height: 700px;
	position: absolute;
	right: 0;
	bottom: 0;
	height: 100%;
	width: 50%;
	z-index: 1;
}
.micropayment section.teaser .flex div.assets div.image {
	height: 100%;
	width: 100%;
}
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;
}
.micropayment section.teaser div.image picture img {
	width: auto;
	max-height: 100%;
	height: initial;
	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: 64px 0 96px 0;
	position: relative;
	z-index: 9;
	align-self: center;
}
section.teaser.teaser-height-small div.text {
	padding: 80px 0 40px;
}

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(--micropayment_maxWidth) / 1.8 );
}
section.teaser div.text h1,
section.teaser div.text h2 {
	position: relative;
	z-index: 1;
	width: 125%;
	letter-spacing: -2px
}
section.teaser div.text.asset-type-empty h1,
section.teaser div.text.asset-type-empty h2 {
	width: 100%;
}
section.teaser div.text p:not(.subheadline) {
	font-size: var(--micropayment_text_medium_fontSize);
	line-height: var(--micropayment_text_medium_lineHeight);
	font-weight: var(--micropayment_text_medium_fontWeight);
}
section.teaser div.text p.lead {
	font-size: var(--micropayment_text_large_fontSize);
	line-height: var(--micropayment_text_large_lineHeight);
	font-weight: var(--micropayment_text_medium_fontWeight);
}
section.teaser div.text div.buttons {
	padding: 24px 0;
}
/*-----------------------------*/
/* !SECTION TEASER HEIGHT FULL */
/*-----------------------------*/
section.teaser.teaser-height-full {
	height: calc( 100vh - 88px);
	padding-bottom: 0;
}
section.teaser.teaser-height-full .content {
	height: 100%;
}
@media ( max-width: 768px ) {
	section.teaser.teaser-height-full {
		height: auto;
	}	
}
/*--------------------------*/
/* 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(--micropayment_borderRadiusBigs);
}
@media ( max-width: 1200px ) {
	section.teaser div.flex {
		align-items: initial;
		flex-direction: column;
	}
	section.teaser div.text h1,
	section.teaser div.text h2 {
		font-size: 72px;
		line-height: 80px;
		width: 100%;
	}
	.micropayment section.teaser div.flex {
		flex-direction: column;
	}
	.micropayment section.teaser div.flex div.text {
		flex: 1 1 100%;
		padding-bottom: 0;
		max-width: 100%;
	}
	.micropayment section.teaser .flex div.assets {
		flex-direction: initial;
		display: flex;
		top: auto;
		max-height: inherit;
		position: relative;
		right: auto;
		bottom: auto;
		height: initial;
		width: 100%;
		z-index: 1;
		display: block;
	}
	.micropayment section.teaser .flex div.assets div.image {
		max-height: 100%;
		display: block;
	}
	.micropayment section.teaser .flex div.assets div.image picture {
		width: 100%;
		height: 100%;
		display: block;
	}
	.micropayment section.teaser .flex div.assets div.image picture img {
		width: 100%;
		height: 100%;
		object-fit: contain;
		object-position: center;
		display: block;
	}
}
@media ( max-width: 768px ) {
	section.teaser div.flex {
		flex-direction: column;
	}
	section.teaser div.text {
		padding: 48px 0 0 0;
	}
	section.teaser div.text h1,
	section.teaser div.text h2,
	section.teaser div.text .headline {
		font-size: var(--micropayment_headline_h1_fontSize);
		line-height: var(--micropayment_headline_h1_lineHeight);
		width: 100%;
	}
	
	section.teaser div.content {
		padding: 0;
	}
	section.teaser div.image {
		order: -1;
		justify-content: center;
	}
	section.teaser div.image div.image-content {
		position: relative;
		left: initial;
		bottom: initial;
		height: 32vh;
		width: initial;
	}
	section.teaser div.image div.image-content picture {
		width: initial;
	}
	.micropayment section.teaser div.flex div.text {
		padding: 48px 24px 24px 24px;
		border-radius: 32px 32px 0 0;
		background: rgba( var(--micropayment_white), 1);
	}
	.micropayment section.teaser div.flex div.text article {
		max-width: 100%;
	}
	section.teaser p.subheadline {
		color: rgba(var(--micropayment_black), .72);
	}
	section.teaser div.text .headline {
		color: rgba(var(--micropayment_dark), 1);
	}
	section.teaser div.text p:not(.subheadline) {
		color: var(--micropayment_textColor);
	}
	.micropayment section.teaser .flex div.assets {
		position: relative;
		right: auto;
		bottom: auto;
		width: 100%;
		height: auto;
		max-height: 400px;
		padding: 0 24px;
	}
	.micropayment section.teaser .flex div.assets div.image {
		max-height: 40vh;
		display: block;
	}
	.micropayment section.teaser .flex div.assets div.image  picture img {
		max-height: 40vh !important;
	}
}
@media ( max-width: 589px ) {
	section.teaser div.text h1,
	section.teaser div.text h2 {
		font-size: 40px;
		line-height: 48px;
	}
	
	section.teaser.teaser-height-small div.flex {
		min-height: initial;
	}
	section.teaser div.image div.image-content {
		height: 72vh;
	}
}