.homepage {
	text-underline-offset: 3px;
}

.north-east-list {
	list-style: '';
	display: inline-block;
}

.north-east-list li {	
	position: relative;
	text-align: left;
}

.north-east-list li::before {
	content: '➚';
	color: var(--orange);
	font-size: 1.6rem;
	position: absolute;
	left: -24px;
  	top: -7px;
}

.show-content a {	
	display: inline-block;
}

.show-content a p {	
	padding: 0;
	width: clamp(60px, 10vw, 140px);
	height: auto;
	aspect-ratio: 5 / 3;
	font-size: 0px;
	background-image: url(img/DoubleDownArrow.png);
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center calc(50% + 2px);
}

.slider-item-text.show-content {
	top: initial;
	bottom: -1px;
	left: 50%;
	transform: translateX(-50%);
}

.pageWidth {
	margin-left: auto;
	margin-right: auto;
	max-width: var(--page-width);
}

.cmsFlexible h1, .cmsFlexible h2, .cmsFlexible h3 {
	color: var(--orange);
	text-transform: uppercase;
	text-align: center;
}

.cmsFlexible h2, .cmsFlexible h3 {
	font-weight: normal;
}

.cmsFlexible h4 {
	text-decoration: none;
	color: var(--white);
	background-color: var(--orange);
	padding: 10px 20px;
	text-decoration: none;
	text-transform: uppercase;
	display: inline;
}

.cmsFlexible h4.cmsHeadline.standardMargin,
.cmsAnchorFormatted.standardMargin {
	display: block;
	margin: auto;
	width: fit-content;
}

.cmsFlexible h5 {
	color: var(--orange);
	margin-top: 20px;
	margin-bottom: 10px;
}

h1.cmsHeadline ~ h2.cmsHeadline {
	color: var(--green);
	text-transform: none;
	font-weight: bold;
}

.cmsFlexible > h3 {
	margin-top: 0;
}

/* Container ganze Breite */
.cmsAlignCenter.width100,
.cmsBoxBack.width100 {
	overflow: hidden;
	background-color: var(--back100);
	padding: 0px max(var(--padding-left, 0px), calc(50vw - calc(var(--narrow-text-width, 600px) / 2))) 50px;
	max-width: 100vw;
}

.width100 > h1:first-child,
.width100 h2:first-child,
.width100 > div > h1:first-child {	
	padding-top: 0px;
	padding-bottom: 30px;
}

.shop-service {
	--narrow-text-width: 900px;
}

.narrow-text,
.shop-service {
	display: block;
	margin-left: auto;
	margin-right: auto;
	max-width: var(--narrow-text-width, 600px);
}

.narrow-text {
	text-align: center;
}

.cmsAlignCenter.boxPadding,
.cmsAlignLeft.boxPadding,
.cmsBoxBack.boxPadding {
	padding-top: 30px;
	padding-bottom: 30px;
	overflow: auto;
}

.last-element {
	margin-top: auto;
}

.round-corners {
	border-radius: 20px;
}

.grid-image {
	object-fit: cover;
	height: 100%;
	width: auto;
}

.align-left,
.align-right,
.align-center {
	text-align: left;
	padding-left: var(--padding-left);
	padding-right: var(--padding-right);
	padding-bottom: 30px;
}


.lieferanten .swiper-slide-container {
	background-color: var(--white);
	border: 1px solid #eee;
	box-shadow: var(--box-shadow-kachel);
	--swiper-pagination-top: 95%;
}

.lieferanten,
.lieferanten h5 {
	text-align: center;
}

.lieferanten a {
	text-decoration: none;
}

.lieferanten span {
	color: var(--text-color);
}

.lieferanten img {
	/* border-radius: 10px; */
	height: 243px;
	object-fit: cover;
}

.rezessionen img.cut-image {
	clip-path: inset(0% 0% 50px 0%);
}

.big-content-kacheln {
	margin-top: 80px;
	margin-bottom: 50px;
	column-gap: 30px;
	/* margin-left: calc(0px - var(--padding-left));
  	margin-right: calc(0px - var(--padding-right)); */
}

.big-kachel {
	background-color: var(--white);
	border: 1px solid #eee;
	box-shadow: var(--box-shadow-kachel);
	/* border-radius: 30px; */
	overflow: clip;
	display: flex;
  	flex-direction: column;
	max-width: 700px;
	margin: 0 auto;
}

.big-kachel > *:first-child {
	/* border-radius: 20px;
	margin: 30px 30px 0 30px; */
	overflow: clip;
	height: 340px;
	width: auto;
}

.big-kachel > img {
	width: 100%;
	height: auto;
	object-fit: cover;
}

.big-kachel-content {
	padding: 30px;
	display: flex;
	flex-direction: column;
	flex: 1;
}

.big-kachel-content a {
	padding: 10px 10px 4px 10px;
	display: inline-block;
	color: var(--white);
	background-color: var(--orange);
	text-decoration: none;
	align-self: center;
}

.big-kachel-content h3 {
	--cms-text-align: center;
}

#home-start > h1,
#home-start > h2 {
	--cms-text-align: center;
}

#home-start > div.introtext {
	padding: 30px;
	text-align: center;
	background-color: #f8f8f8;
}


h1.cmsHeadline,
h2.cmsHeadline,
h3.cmsHeadline {
	margin: 50px auto 50px;
	max-width: 600px;
	width: auto;
	white-space: wrap;
	text-align: center;
	text-wrap: balance;
	position: relative;
}

h3.cmsHeadline {
	margin: 30px auto 30px;
}

h1.cmsHeadline::before,
h2.cmsHeadline::before,
h3.cmsHeadline::before {
	content: '';
	display: block;
	background-color: var(--overline-color, var(--green));
	position: absolute;
	width: 0;
	height: 4px;
	top: -6px;
	left: 50%;
	transform: scaleX(0) translateX(-50%);
	transform-origin: 50% 0;
	--transition-speed: 500ms;
	transition: transform var(--transition-speed), left var(--transition-speed), width var(--transition-speed);
}

h1.cmsHeadline.overline-animation::before,
h2.cmsHeadline.overline-animation::before,
h3.cmsHeadline.overline-animation::before {
	transform: scaleX(1) translateX(0%);
	left: calc((var(--container-width, 100%) - var(--real-text-width, 0px)) / 2);
	width: var(--real-text-width, 100%);
}



/* grid box */

.grid-box {
	padding-left: 0px;
	padding-right: 0px;
	--line-height: 1.5;	
	text-align: center;	
}

.grid-box-margin {
	margin-top: 30px;
	margin-bottom: 30px;		
}

.grid-box .cmsFlexColumn {
	align-items: center;
}

.grid-box .cmsGridContainer > * {
	max-width: 450px;
}

.grid-box h1.cmsHeadline,
.grid-box h2.cmsHeadline,
.grid-box h3.cmsHeadline {
	display: inline-block;
	margin: 50px auto 20px;
	max-width: 600px;
	width: min-content;
	white-space: nowrap;	
}

.grid-box .align-left,
.grid-box .align-right,
.grid-box .align-left *,
.grid-box .align-right *,
.grid-box .align-center *,
.grid-box .align-center * {
	text-align: center;
}

.grid-box .align-left h1.cmsHeadline,
.grid-box .align-right h1.cmsHeadline,
.grid-box .align-center h1.cmsHeadline,
.grid-box .align-left h2.cmsHeadline,
.grid-box .align-right h2.cmsHeadline,
.grid-box .align-center h2.cmsHeadline,
.grid-box .align-left h3.cmsHeadline,
.grid-box .align-right h3.cmsHeadline,
.grid-box .align-center h3.cmsHeadline {
	text-align: center;
	margin-left: initial;
	margin-right: initial;
}

.grid-box img {
	object-fit: cover;
	width: auto;
	height: 100%;
}

.grid-box .cmsAnchorFormatted {
	display: inline;
}

.green-box {
	--back100: var(--green);
	background-color: var(--green);
	background-image: linear-gradient(to bottom right, var(--green-gradient-start), var(--green-gradient-end));
	color: var(--white);
}

.green-box.width100 {
	--narrow-text-width: 1000px;
	font-size: 24px;
}

.green-box h1.cmsHeadline,
.green-box h2.cmsHeadline,
.green-box h3.cmsHeadline {
	color: var(--white);
	--overline-color: var(--orange);
}

.green-box a, 
.green-box a:visited {
	color: var(--white);
}

.white-box {
	--back100: var(--white);
	border: 1px solid #eee;
	box-shadow: var(--box-shadow-kachel);
}

.white-box h3 {
	color: var(--text-color);
	text-transform: none;
}

.green-box:has(+ .moved-up-container) {
	padding-bottom: calc(var(--moved-up) + 20px);
}

.green-box + .moved-up-container {
	position: relative;
	top: calc(0px - var(--moved-up));
	background-color: var(--back100);
}

#willkommen {
	padding: var(--standard-padding);
}

#willkommen .cmsAnchorFormatted {
	margin: auto;
	width: fit-content;
	display: block;
}



@media screen and (min-width: 800px) {
	.grid-box .cmsFlexColumn.align-left {
		align-items: flex-start;
	}

	.grid-box .cmsFlexColumn.align-right {
		align-items: flex-end;
	}

	.grid-box .cmsFlexColumn.align-center {
		align-items: center;
	}

	* + .align-left,
	* + .align-right,
	* + .align-center {
		--padding-left: 40px;
		--padding-right: 40px;
		padding-bottom: 30px;
	}

	.align-left,
	.align-left *  {
		text-align: left!important;		
	}

	.align-right,
	.align-right * {
		text-align: right!important;
	}

	.align-center,
	.align-center * {
		text-align: center!important;
	}
}