ba {
	box-sizing: border-box;
}

body {
	color: #fff;
	font-family: 'Helvetica','Arial','Open Sans', sans-serif;
	font-size: 18px;
	font-weight: 400;
	line-height: 1.25;
	background-color: #2d323c;
	display: flex;
	flex-direction: column;
	min-height: 100vh;
	margin: 0;
	position: relative;
	overflow: hidden;
}

html {
	overflow-x: hidden;
	margin: 0;
	scroll-behavior: smooth;
}

h1, h2, h3, h4, h5, h6 {
	margin-bottom: 0.25em;
	margin-top: 0.75em;
	/* font-family: "Rufina", sans-serif; */
	line-height: 1.14;
	font-weight: 700;
	/* text-transform: uppercase; */
	color: #fff;
	font-weight: 800;
}

h1 {
	font-size: 2.25em;
	text-wrap: balance;
	column-fill: inherit;
}

h1:first-child {
	margin-top: 0;
}

h2 {
	font-size: 2em;
	text-wrap: balance;
}

h2.small {
	font-size: 1.25em;
	text-transform: uppercase;
	margin-bottom: 0;
}

.subline+h2 {
	margin-top: 0;
}

h3 {
	font-size: 1.35em;
}

h3 {
	font-size: 1.2em;
}

h4 {
	font-size: 1.1em;
	font-weight: 400;
}

h5 {
	font-size: 1.05em;
	font-weight: 400;
}

h5 {
	font-size: 1em;
	font-weight: 400;
}

h4.underline {
	width: fit-content;
	margin-bottom: 1em;
	padding-bottom: 1em;
	border-bottom: 1px solid #465948;
}

.img_right, .pimg_right {
	float: right;
	max-width: 320px;
	margin-left: 35px;
	margin-bottom: 20px;
	font-size: 0.9em;
	text-align: right;
}

.img_right {
	max-width: 50%;
}

.img_left, .pimg_left {
	float: left;
	max-width: 320px;
	margin-right: 35px;
	margin-bottom: 20px;
	font-size: 0.9em;
}

.img_left {
	max-width: 50%;
}

a {
	text-decoration: none;
	color: inherit;
	transition: all 0.3s ease;
	text-decoration: underline;
}

a:hover {
	text-decoration: underline;
	/* color: #1a2d65; */
}

p {
	margin-bottom: 0.66em;
	margin-top: 0;
	text-wrap: pretty;
}

.text-shadow {
	text-shadow: 2px 2px 5px black;
}

p:last-child {
	/* margin-bottom: 0; */
}

b {
	font-weight: 700;
}

.site-bg {
	position: absolute;
	height: 100%;
	width: 100%;
	background: #df2326 url(../../img/bg.svg);
	background-size: cover;
	background-position-x: center;
	background-position-y: top;
	z-index: -1;
	/* transition: all 0.1s linear; */
}

.site-bg:after {
	/* content: ""; */
	position: absolute;
	width: 500px;
	height: 200px;
	backdrop-filter: hue-rotate(246deg);
	clip-path: polygon(0% 0%, 100% 0%, 0% 100%);
}

.intro {
	padding: 00;
	position: relative;
	display: grid;
	grid-template-columns: auto 1fr 2fr!important;
	margin-bottom: 5em;
}

.intro>div {
	align-self: center;
	position: relative;
}

.intro .img-holder {
	--d-bgright: 27.1%;
	--d-bgrot: 15deg;
	/* border: 2px solid blue; */
	position: relative;
	scale: 1;
	margin: 0em -5em -5em;
}

.intro .img-holder>div {
	position: absolute;
	width: 100vw;
	right: var(--d-bgright);
	top: 0;
	transform: rotateZ(var(--d-bgrot));
	transform-origin: top right;
	z-index: -1;
}

.intro .img-holder>div>div {
	height: 6000px;
	width: 100%;
	backdrop-filter: hue-rotate(246deg);
	-webkit-backdrop-filter: hue-rotate(246deg);
	position: absolute;
	width: 150vw;
	right: 0;
	top: -2500px;
	z-index: -1;
}

.intro .img-holder>img {
	/* border: 2px solid green; */
	width: 100%;
}

.intro .text-holderl {
	z-index: 2;
	text-transform: uppercase;
	font-weight: 800;
	display: flex;
	flex-direction: column;
	font-size: 2.75em;
	color: #b2d9e5;
	line-height: 1;
	gap: 0.33em;
}

.intro .text-holderl>span {
	display: flex;
	flex-direction: column;
}

.intro .text-holderl>span>span {
	transform: rotateZ(-10deg);
	transform-origin: left center;
}

.intro .text-holderl .l1>span:last-child {
	padding-left: 2ch;
}

.intro .text-holderl .l2>span:last-child {
	padding-left: 3ch;
}

.intro .text-holderl .l3 {
	color: red;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.25em;
	margin-top: 0.33em;
}

.intro .text-holderl .l3>span>span {
	background-color: white;
	display: inline-block;
	padding: 0.15em 0.2em 0.2em 0.2em;
}

.intro .text-holderl .l3>span:last-child {
	padding-left: 3ch;
}

.intro .text-holderl .white {
	color: white;
	font-size: 1.5em;
}

.intro .text-holderl .whitem {
	color: white;
	font-size: 1.25em;
}

.intro .text-holderr h1 {
	color: #e7ff00;
	font-size: 4.5em;
	line-height: 1;
	text-align: center;
	text-shadow: 3px 6px 8px #0008;
	text-transform: uppercase;
}

.intro .text-holderr h1>span {
	font-size: 0.75em;
	line-height: 1;
	display: inline-block;
}

.intro .text-holderr .wedge {
	color: black;
	position: relative;
	margin-right: 3em;
	padding: 1em 3em;
}

.intro .text-holderr .wedge strong {
	padding-right: 2em;
	display: inline-block;
}

.intro .text-holderr .wedge:before {
	content: "";
	position: absolute;
	height: 100%;
	width: 111%;
	top: 0;
	right: 0;
	background-color: #fffd;
	transform: skewX(29deg);
	z-index: -1;
}

.intro .text-holderr .wedge-btn {
	position: absolute;
	right: 25%;
	font-size: 1.33em;
	text-decoration: none;
	padding: 0.5em 1.5em;
	text-transform: uppercase;
	font-weight: 700;
	display: flex;
	align-items: center;
	gap: 0.25em;
	transition: all 0.3s ease;
	z-index: 1;
}

.intro .text-holderr .wedge-btn:hover {
	scale: 1.1;
}

.intro .text-holderr .wedge-btn icon {
	font-size: 1.2em;
}

.intro .text-holderr .wedge-btn:before {
	content: "";
	background-color: #e7ff00;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
	position: absolute;
	right: 40%;
	transform: skewX(-10deg);
}

header {
	width: 100%;
	z-index: 3;
	position: sticky;
	transition: all 0.3s ease;
	display: grid;
	grid-template-columns: 1fr 3fr auto!important;
	margin: 2em 0;
}

header .nav-logo {
	grid-column: 3;
	grid-row: 1 / span 3;
	position: relative;
	margin-left: 3em;
	padding: 1.5em 4em;
	display: flex;
	justify-content: center;
	align-items: center;
}

header .nav-logo img {
	width: 240px;
}

header .nav-logo:after {
	content: "";
	background-color: #fff;
	position: absolute;
	height: 100%;
	width: 120%;
	left: 0;
	top: 0;
	transform: skewX(-20deg);
	z-index: -1;
	box-shadow: 4px 4px 10px #0008;
}

header .nav-top {
	grid-column: 2;
	position: relative;
	justify-self: center;
	padding: 0.5em 1em;
	margin-bottom: -0.25em;
	z-index: 2;
	text-transform: uppercase;
	font-weight: 800;
	/* display: flex; */
	font-size: 0.9em;
	text-align: center;
}

header .nav-top a {
	text-decoration: none;
}

header .nav-top a:hover icon {
	scale: 1.2;
}

header .nav-top:after {
	content: "";
	background-color: #e60005;
	position: absolute;
	height: 100%;
	width: 100%;
	right: 0;
	top: 0;
	transform: skewX(20deg);
	z-index: -1;
}

header nav {
	grid-column: 2;
	position: relative;
	color: #e60005;
	padding: 1em 2em;
	/* width: fit-content; */
	align-items: center;
	display: flex;
}

header nav>.nav-toggle {
	margin-left: auto;
	margin-bottom: 1em;
}

header nav:after {
	content: "";
	background-color: #fffd;
	position: absolute;
	height: 100%;
	width: 100vw;
	right: 0;
	top: 0;
	transform: skewX(-20deg);
	z-index: -2;
}

header .nav-wedge {
	grid-column: 1;
	position: relative;
	margin-top: -2em;
	padding: 0.5em 1em;
	text-transform: uppercase;
	display: flex;
	flex-direction: column;
	font-size: 1.25em;
	justify-content: center;
	align-items: center;
	text-decoration: none;
}

header .nav-wedge:hover {
	scale: 1.05;
}

header .nav-wedge>span:last-child {
	font-weight: bold;
}

header .nav-wedge:after {
	content: "";
	background-color: #e60005;
	position: absolute;
	height: 100%;
	width: 100vw;
	right: 0;
	top: 0;
	transform: skewX(10deg);
	z-index: -1;
}

nav ul, nav li {
	list-style: none;
	padding: 0;
	margin: 0;
	position: relative;
}

nav ul {
	display: flex;
}

nav a {
}

nav>ul {
	padding: 0;
	gap: 1em;
	justify-content: space-between;
	align-items: center;
	/* width: fit-content; */
	width: 100%;
}

nav .nav-icon {
	font-size: 1.75em;
}

nav .nav-icon icon {
	display: block;
}

nav>ul>li>a {
	/* padding: 0.75em; */
	position: relative;
	text-decoration: none;
	letter-spacing: 0.02em;
	cursor: pointer;
	text-transform: uppercase;
	padding-bottom: 0.25em;
	padding-top: 0.25em;
	display: block;
	font-size: 1.1em;
}

nav>ul>li>ul>li {
	margin: 0.2em 0;
	text-transform: uppercase;
	white-space: nowrap;
}

nav a:hover, nav a {
	text-decoration: none;
	display: block;
}

nav>ul>li>a:after {
	height: 1px;
	bottom: 0;
	left: 0;
	width: 100%;
	content: "";
	position: absolute;
	background-color: #e60005;
	transition: all 0.3s ease;
	transform: scaleX(0);
	transform-origin: left;
}

nav>ul>li.nav-icon>a:after {
	display: none;
}

nav>ul>li.nav-icon>a:hover {
	scale: 1.2;
}

nav>ul>li:hover>a:after {
	transform: scaleX(1);
}

nav>ul>li {
	/* margin: 0 0.25em; */
	/* flex-grow: 1; */
}

nav ul>li>ul {
	position: absolute;
	transition: all 0.3s ease;
	padding: 0.25em 0.5em 0.125em;
	display: flex;
	flex-direction: column;
	transform-origin: left;
	transform: scaleX(0);
	opacity: 0;
	/* border: 1px solid red; */
	top: calc(100% - 0px);
	left: -0.5em;
	background-color: white;
	min-width: calc(100% + 1em);
	box-shadow: 3px 6px 6px #0004;
}

nav ul>li:hover>ul {
	transform: scaleX(1);
	opacity: 1;
}

.nav-toggle {
	background-color: transparent;
	width: 4em;
	height: 4em;
	border: 1px solid white;
	align-self: center;
	display: flex;
	border-radius: 2px;
	flex-direction: column;
	padding: 0.75em;
	justify-content: space-between;
	display: none;
	background: white!important;
	outline: 4px solid white;
	grid-row: 2;
	grid-column: 2;
	border: 2px solid #e7130c;
	cursor: pointer;
	align-self: center;
	justify-self: center;
	font-size: 0.6em;
}

.nav-toggle>span {
	content: "";
	height: 2px;
	background-color: #e7130c;
	width: 100%;
	transition: all 0.3s ease;
	position: relative;
}

.nav-toggle:after {
	display: none;
}

.nav-toggle:hover {
	background: transparent;
}

.open .nav-toggle>:first-child {
	opacity: 0;
}

.open .nav-toggle>:last-child {
	opacity: 0;
}

.nav-toggle>span:nth-child(2):after {
	content: "";
	height: 100%;
	position: absolute;
	width: 100%;
	left: 0;
	top: 0;
	display: block;
	background-color: #e7130c;
	transition: all 0.3s ease;
}

.open .nav-toggle>span:nth-child(2):after {
	transform: rotateZ(90deg);
}

.open .nav-toggle>span:nth-child(2) {
	transform: rotateZ(-45deg);
}

.nav-top icon {
	padding: 0 0.33em;
	width: 1.5em;
	border-radius: 100%;
	transition: all 0.3s ease;
	vertical-align: bottom;
}

.reg {
	background-color: #0009;
	padding: 2em;
	margin: 2em 0;
}

footer {
	padding: 3em 0 2em;
	margin-top: 2em;
	background: linear-gradient(to bottom, rgb(0 0 0 / 40%) 10%, rgb(0 0 0 / 80%) 65%);
	position: relative;
	z-index: 1;
}

.footer-top {
	/* border:  2px solid red; */
	height: 1.35em;
	position: relative;
	background: linear-gradient(to top left, transparent 49%, #d3e29b 50%, #d3e29b 66%, #bdc2c9 67%, #bdc2c9 83%, #d3e29b 84%, #d3e29b 100%);
}

.footer-top:after {
	content: "";
	height: 100%;
	position: absolute;
	width: 100%;
	bottom: 100%;
	background: linear-gradient(to bottom right, transparent 49%, #d3e29b 50%, #d3e29b 66%, #bdc2c9 67%, #bdc2c9 83%, #d3e29b 84%, #d3e29b 100%);
}

.footer-main .logo img {
}

.footer-main {
	display: flex;
	gap: 30px;
	color: white;
	justify-content: space-between;
	margin-bottom: 2em;
}

.footer-main .logo {
	width: 340px;
}

.footer-main .address {
	font-size: 1em;
	display: flex;
	text-align: center;
	gap: 1.5em;
	align-self: center;
	display: grid;
	grid-template-columns: repeat(7, auto);
	margin: 0 auto;
}

.footer-main .address p {
	margin-bottom: 0;
}

.footer-main .address b {
	white-space: nowrap;
}

.footer-main .contact {
	text-align: right;
	text-transform: uppercase;
	display: flex;
	flex-direction: column;
	padding-bottom: 1em;
}

.footer-main .contact .emergency {
	color: #d3e29b;
	font-weight: bold;
}

.footer-main .contact a {
	text-decoration: none;
}

.footer-main .contact .imp {
	color: #d3e29b;
}

.footer-main .social a:hover {
	scale: 1.2
}

.footer-main .social a {
	margin-left: 0.5em;
	display: inline-block;
	font-size: 0.9em;
	margin-top: 0.5em;
}

.footer-soc {
	display: flex;
	gap: 0.5em;
	font-size: 2em;
	justify-content: center;
}

.footer-soc a {
	display: block;
	margin-bottom: 0.5em;
}

.footer-soc a:hover {
	scale: 1.1;
}

.footer-soc icon {
	filter: invert(1);
}

.footer-imp {
	text-align: center;
	font-size: 0.86em;
}

.footer-imp a {
	color: white;
	text-decoration: none;
}

.questions {
	position: relative;
	z-index: 1;
	margin-left: 0em;
	margin: 4em 2em;
}

.questions .text-holdert {
	position: relative;
	padding: 4em 4em;
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 2em;
}

.questions .text-holdert>div:last-child {
	display: flex;
	font-size: 1.75em;
	flex-grow: 1;
	justify-content: center;
}

.questions .text-holdert>div:last-child>div {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.25em;
}

.questions .text-holdert>div:last-child a {
	text-decoration: none;
	white-space: nowrap;
}

.questions .text-holdert>div:last-child icon {
	transition: all 0.3s ease;
	transform: translateY(0.2em);
	margin-right: 0.25em;
}

.questions .text-holdert>div:last-child a:hover icon {
	transform: translateY(0.2em) scale(1.2);
}

.questions .text-holdert p {
	max-width: 75ch;
}

.questions .text-holdert p:last-child {
	margin-bottom: 0;
}

.questions .text-holdert:before {
	content: "";
	position: absolute;
	background-color: #840000;
	width: 100%;
	height: 100%;
	left: 0;
	z-index: -1;
	top: 0;
	transform: skewX(-10deg);
}

.questions .text-holdert h2 {
	color: #e60005;
	font-size: 1.8em;
	margin-top: 0;
	margin-bottom: 1em;
	text-transform: uppercase;
}

.wachen {
	position: relative;
	margin: 6em 0;
	display: flex;
	flex-direction: column;
}
.wachen .img-holder {
	position: relative;
	/* border: 2px solid green; */
	width: 40%;
	left: 5%;
}
.wachen .img-wrapper {
	width: 100%;
	aspect-ratio: 315/547;
	position: relative;
	/* border: 1px solid blue; */
}
.wachen .img-wrapper img {
	filter: drop-shadow(2px 4px 6px #000a);
	position: absolute;
}
.wachen .lk-nm {
	top: 28.5%;
	left: 0%;
	width: 34.34%;
}
.wachen .lk-deg {
	top: 69.6%;
	left: 75%;
	width: 25.6%;
}
.wachen .lk-r {
	top: 46.4%;
	left: 21.05%;
	width: 39.2%;
}
.wachen .lk-sr {
	top: 56.6%;
	left: 44.96%;
	width: 35.0%;
}

.wachen .lk-as {
	top: 0;
	left: 0;
	width: 100%;
}

.wachen .wedge {
	width: 72%;
	color: #000;
	position: relative;
	padding: 1.66em 0 1em 3em;
}

.wachen .wedge:after {
	content: "";
	position: absolute;
	height: 100%;
	width: 200vw;
	top: 0;
	left: 0;
	background-color: #fffd;
	transform: skewX(-20deg);
	z-index: -1;
}

.wachen .text-holder h2 {
	font-size: 3.6em;
	width: 90%;
	text-align: center;
	margin-top: 0;
	text-transform: uppercase;
}

.wachen .text-holder h2>span {
	font-size: 0.7em;
	display: block;
	line-height: 1;
}

.wachen .text-holder {
	margin-bottom: -24em;
	position: relative;
	/* z-index: 1; */
	/* background: beige; */
	max-width: 50%;
	align-self: flex-end;
}

.wachen .item>div:nth-child(2){
	/* display: none; */
	position: absolute;
	bottom: 0;
	left: 0;
	display: flex;
	gap: 0em;
	z-index: 2;
	/* scale: 0; */
	filter: drop-shadow(2px 4px 6px #0008);
	transform: scaleY(0) translateX(-3em);
	transform-origin: bottom;
	opacity: 0;
	bottom: 1.2em;
	transition: all 0.3s ease;
	max-width: calc(100vw - 4em);
	padding: 0 2em;
}
.wachen .item.topside>div:nth-child(2){
	top: 1.2em;
	bottom: auto;
	transform-origin: top;
}
.wachen .item.leftside>div:nth-child(2){
	right: 0;
	left: auto; 
	transform: scaleY(0) translateX(3em);
}
.wachen .item.leftside.open>div:nth-child(2){
	right: 0;
	left: auto; 
	transform: scaleY(1) translateX(3em);
}
.wachen .item>div:nth-child(2):after{
	/* display: none; */
	position: absolute;
	content: "";
	background-color: white;
	height: 100%;
	width: calc(100% - 4em);
	transform: skewX(-8deg);
	z-index: -1;
}
.wachen .item.topside>div:nth-child(2):before{
	transform: skewY(45deg);
	bottom: calc(100% - 1em);
	top: auto; 
	left: 3em;
}
.wachen .item>div:nth-child(2):before{
	/* display: none; */
	position: absolute;
	content: "";
	background-color: white;
	height: 1.5em;
	width: 1.5em;
	transform: skewY(-45deg);
	z-index: -1;
	top: calc(100% - 1em);
	left: 3em;
}
.wachen .item.leftside>div:nth-child(2):before{
	transform: skewY(45deg);
	right: 3.5em;
	left: auto;
}
.wachen .item.topside.leftside>div:nth-child(2):before{
	transform: skewY(-45deg);
}
.wachen .item .fz{
	white-space: nowrap;
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 0.5em;
	margin-right: 1em;
}
.wachen .item .info{
	text-align: center;
	display: flex;
	flex-direction: column;
	gap: 0.5em;
	margin-bottom: -1em;
	padding: 0.66em 0 0;
	/* white-space: nowrap; */
}
.wachen .item .info span:nth-child(1){
	font-size: 1.25em; 
}
.wachen .item .info span:nth-child(2){
	font-size: 1.5em; 
	font-weight: bold; 
}
.wachen .item .info a{
	white-space: nowrap;
}
.wachen .item.leftside .info a{
	transform:translateX(-2em); 
}
.wachen .item .fz span{
	position: relative;
	z-index: 2; 
	font-weight: 700; 
}
.wachen .item .fz span:first-letter{
	position: relative;
	z-index: 2; 
	font-weight: 300; 
}
.wachen .item .fz span:before{
	content: ""; 
	background-color: #dafe51; 
	position: absolute; 
	width: 120%; 
	height: 120%; 
	left: -10%; 
	top: -10%; 
	z-index: -1;
	transform: skewX(7.5deg);
}

.wachen .item .close{
	background-color: black;
	width: 2.6em;
	aspect-ratio: 1;
	flex-shrink: 0;
	border-radius: 100%;
	transform: translateY(-1em) translateX(1.7em);
	position: relative;
	display: grid;
	align-self: flex-start;
	cursor: pointer;
}
.wachen .item .close:after,
.wachen .item .close:before{
	content: "";
	background-color: white;
	width: 60%;
	height: 0.25em;
	flex-shrink: 0;
	border-radius: 10px;
	position: relative;
	display: block;
	justify-self: center;
	align-self: center;
	grid-column: 1;
	grid-row: 1;
	transform: rotateZ(45deg);
}.wachen .item .close:before{
	transform: rotateZ(-45deg);
}
.wachen .item>div:nth-child(1){
	display: grid;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.15em;
	cursor: pointer;
	position: relative;
	/* display: none; */
	transition: all 0.3s ease;
}
.wachen .item.open>div:nth-child(1){
	transform: scaleY(0);
	opacity: 0; 
}
.wachen .item.open>div:nth-child(2){
	transform: scaleY(1)  translateX(-3em);
	opacity: 1;
}
.wachen .item>div:nth-child(1):before{
	content: "";
	/* position: absolute; */
	background-color: white;
	height: 100%;
	/* aspect-ratio: 0.85; */
	width: 2.2em;
	right: calc(100% );
	clip-path: polygon(100% 100%, 75% 65%, 0% 90%, 100% 0%);
	grid-column: 1;
	grid-row: span 2;
}
.wachen .item.topside>div:nth-child(1):before{
	transform: scaleY(-1);
}
.wachen .item>div:nth-child(1) span{
	background-color: white;
	padding: 0 0.125em;
	grid-column: 2;
	justify-self: start;
}
.wachen .item.leftside>div:nth-child(1) span{
	grid-column: 1;
	justify-self: end;
	grid-row: 1;
	text-align: right;
}
.wachen .item.leftside>div:nth-child(1):before{
	grid-column: 2;
	grid-row: span 2;
	transform: scaleX(-1);
}
.wachen .item.leftside.topside>div:nth-child(1):before{
	transform: scaleX(-1) scaleY(-1);
}
.wachen .item>div:nth-child(1) span:nth-child(2){
	font-weight: bold;
	grid-row: 2;
	white-space: nowrap;
}
.wachen .item{
	position:absolute;
	color: black;
	/* z-index: 2; */
	/* display: none; */
}

.wachen .item.w-wolfratshausen{
	top: 14.4%;
	right: 59.2%;
}
.wachen .item.w-geretsried{
	top: 24.4%;
	right: 52.2%;
}
.wachen .item.w-badtoelz{
	top: 44%;
	right: 32.1%;
}
.wachen .item.w-lenggries{
	top: 60%;
	right: 23.1%;
}
.wachen .item.w-kochel{
	top: 67%;
	left: 25.1%;
}
.wachen .item.w-benediktbeuern{
	top: 54.3%;
	right: 61.1%;
}


.jetzt{
	position: relative;
	z-index: 1;
	text-transform: uppercase; 
	
}
.jetzt .text-holdert{
	display: flex;
	flex-direction: column;
	position: relative;
	width: 70%;
	justify-self: flex-end;
	align-items: center;
	padding: 1.5em 1em 3.5em 1em;
	position: relative;
	gap: 0.5em;
}

.jetzt .text-holdert:after {
	content: "";
	position: absolute;
	height: 100%;
	width: 200vw;
	top: 0;
	left: 0;
	background-color: #e60005;
	transform: skewX(20deg);
	z-index: -1;
}

.jetzt .text-holdert span{
	font-size: 1.5em;
	text-wrap: pretty;
	text-align: center;
	font-weight:800;
}

.jetzt .text-holderb{
	display: flex;
	flex-direction: column;
	width: 66%;
	justify-self: flex-end;
	align-items: flex-start;
	margin-top: -2em;
}
.jetzt .text-holderb>span{
	color: #dafe51;
	margin-left: 2em;
}
.jetzt .text-holderb>div{
	position: relative;
	color: black;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 1em 2em;
	gap: 0.5em;
}
.jetzt .text-holderb>div:after{
	content: "";
	position: absolute;
	height: 100%;
	width: 200vw;
	top: 0;
	left: 0;
	background-color: #dafe51;
	transform: skewX(-20deg);
	z-index: -1;
}

.jetzt .text-holderb>div>a:first-child{
	font-size: 1.5em; font-weight:800; 
}
.jetzt .text-holderb>div>a:first-child icon{
	font-size: 1.25em;
	transform:translateY(0.125em);
	transition: all 0.3s ease;
}
.jetzt .text-holderb>div>a:first-child:hover icon{
	transform:translateY(0.125em) scale(1.15);
}
.jetzt .text-holderb>div>a:last-child:hover icon{
	transform: scale(1.15);
}
.jetzt .text-holderb>div>a:last-child icon{
	transition: all 0.3s ease;
}
.jetzt .text-holderb>div>a:first-child>span{
	font-size: 1.2em; font-weight:800; 
}

.jetzt a{
	text-decoration: none;
}


.btn{
	color: white; 
	transition: all 0.3s ease;
	position: relative; 
	z-index:1;
	padding: 0.5em 1.5em;
	text-decoration: none; 
	text-transform: uppercase; 
	display: inline-block;
	
}
.btn icon{
	transform: translateY(0.125em);
	
}
.btn:before{
	content: "";
	height: 100%;
	width: 100%;
	left: 0;
	top: 0;
	z-index: -1;
	position: absolute;
	background-color: black;
	transform: skewX(-10deg);
}
.btn:hover{
	transform: scale(1.15); 
	text-decoration: none; 
}

.btn-yellow:before{
	background-color: #dafe51;
}
.btn-yellow{
	color: black;
}

.funktion{
	margin: 4em 0;
}

.funktion ol{
	display: flex;
	flex-direction: column;
	align-items: center;
	font-size: 1.5em;
	gap: 1.5em;
	padding: 0;
}

.funktion li::marker{
}
.funktion li{
	text-align: center;
	display: flex;
	gap: 1em;
}
.funktion li:before{
	font-size: 3em;
	font-weight: 900;
	color: #dafe51;
}
.funktion li:nth-child(1):before{
	content: "1.";
}
.funktion li:nth-child(2):before{
	content: "2.";
}
.funktion li:nth-child(3):before{
	content: "3.";
}
.funktion li:nth-child(1)>div{
	max-width: 28ch; 
}
.funktion li:nth-child(2)>div{
	max-width: 45ch; 
	--d-angle: -10deg;
	--d-offsetY: 0.25em;
}
.funktion li:nth-child(3)>div{
	max-width: 37ch; 
}
.funktion li:nth-child(1) a{
	font-size: 0.5em;
	position: absolute;
	top:  100%;
	right: 2em;
	transform: translateY(-50%);
}

.funktion li:nth-child(1) a:hover{
	transform: translateY(-50%) scale(1.15);
}

.funktion li>div{
	--d-angle: 10deg;
	--d-offsetY: -0.25em;
	--d-offsetX: -0.25em;
	text-align: center;
	display: block;
	position: relative;
	padding: 0.75em 2em;
}
.funktion li>div:after,
.funktion li>div:before{
	content: ""; 
	border: 1px solid white; 
	position: absolute; 
	height: 100%; 
	width: 100%; 
	left: 0; 
	top: 0; 
	transform: skewX(var(--d-angle));
	z-index:-1;
}
.funktion li>div:before{
	border: none; 
	background-color: #0002; 
	transform: translateX(var(--d-offsetX)) translateY(var(--d-offsetY)) skewX(var(--d-angle));
}
.funktion h2{
	font-size:  3em;
	text-align: center;
	margin-bottom: 1em;
	text-transform: uppercase;
}
.funktion h2 span{
	color: #dafe51;
	display: block;
}


.vorteile{
	margin: 4em 0;
}
.vorteile .img-holder{
	grid-column-start: full-start;
	grid-column-end: centerline;
	filter: drop-shadow(3px 3px 6px #000a);
}
.vorteile .img-holder img{
	clip-path: polygon(0% 0%, 0% 100%, 90% 100%, 100% 0%);
	height: 100%;
	object-fit: cover;
	object-position: center right;
}
.vorteile .text-holder{
	grid-column-start: centerline;
	grid-column-end: content;
	align-self: center;
	position: relative;
	margin: 3em 0 3em 3em;
	padding-bottom: 2em; 
}

.vorteile .text-holder:after{
	content: "";
	width: 63vw;
	height: 100%;
	background-image:  linear-gradient(to right, #f0000fee, #f0000fee), url('../img/auto.webp');
	background-size: cover;
	background-position: center;
	position: absolute;
	left: -10vw;
	z-index: -1;
	top:0;
}

.vorteile h2{
	font-size: 3em;
	text-transform: uppercase;
}

.vorteile h2 span{
	color: #dafe51;
}

.vorteile .btn{
	position: absolute; 
	top: 100%;
	left: 50%; 
	transform: translateX(-50%) translateY(-50%);
}
.vorteile .btn:hover{
	transform: translateX(-50%) translateY(-50%) scale(1.15);
}

.vorteile li::marker{
	content: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" height="15" width="20" viewBox="0 0 48 48"><path fill="yellow" d="M37.821,26.685c0,0.635-0.52,1.152-1.152,1.152h-8.831v8.831c0,0.632-0.516,1.152-1.152,1.152h-5.372	c-0.635,0-1.152-0.52-1.152-1.152v-8.831h-8.831c-0.632,0-1.152-0.516-1.152-1.152v-5.372c0-0.635,0.52-1.152,1.152-1.152h8.831	V11.33c0-0.632,0.516-1.152,1.152-1.152h5.372c0.635,0,1.152,0.52,1.152,1.152v8.831h8.831c0.632,0,1.152,0.516,1.152,1.152V26.685z	 M24,0.199c-13.149,0-23.8,10.654-23.8,23.8c0,13.149,10.651,23.8,23.8,23.8s23.8-10.651,23.8-23.8	C47.8,10.854,37.15,0.199,24,0.199"/></svg>');
}
.vorteile li{
	padding-left: 0.5em;
	list-style-position: outside;
	margin-bottom: 0.5em;
}
.vorteile ul{
	padding: 0 0 0 1em ; 
	
}


@media (max-width: 1680px) {
	.footer-main .address {
		/* grid-template-columns: 1fr auto 1fr; */ font-size: 0.85em;
	}

	.footer-main .address hr:nth-of-type(2) {
		/* display: none; */
	}

	header .nav-top {
		grid-column: 1 / span 2;
	}

	header .nav-logo {
		padding: 1.5em 2em;
	}

	nav>ul>li>a {
		font-size: 0.85em;
	}

	
	.wachen .img-holder {
		font-size: 0.8em; 
	}
}

@media (max-width: 1450px) {
	body {
		/* font-size: 20px; */
	}

	header nav {
		grid-column: 1 / span 2;
	}

	header .nav-wedge {
		margin-top: -0.5em;
	}

	header .nav-logo {
		padding: 1em 2em;
	}

	header .nav-logo img {
		width: 200px;
		max-width: 15.4vw;
	}

	.intro .text-holderl {
		font-size: 2em;
	}

	.intro .text-holderr h1 {
		font-size: 3em;
	}

	.intro .text-holderr .wedge:before {
		transform: skewX(5deg);
	}

	.intro .text-holderr .wedge {
		color: black;
		position: relative;
		margin-right: 1em;
		padding: 1em 1em 1em 4em;
	}
}

@media (max-width: 1299px) {
	.footer-main .address {
		grid-template-columns: 1fr auto 1fr;
		font-size: 0.85em;
	}

	.footer-main .address hr:nth-of-type(2) {
		display: none;
	}

	.questions .text-holdert>div:last-child {
		font-size: 1.25em;
	}
	.vorteile h2{
		font-size: 2.5em;
	}
	.wachen .text-holder {
		margin-bottom: -18em;
	}
	.wachen .img-holder {
		font-size: 0.7em; 
	}
}

@media (max-width: 991px) {
	header .nav-top {
		font-size: 0.8em;
	}

	.footer-main {
		flex-wrap: wrap;
		justify-content: flex-start;
		flex-direction: column;
	}

	.footer-main .contact {
		text-align: left;
	}

	.footer-main spacer {
		height: 30px;
	}

	.footer-main .social a {
		margin-right: 0.5em;
		margin-left: 0;
	}

	.footer-main .logo {
		width: 50%;
		margin: 0 auto;
	}

	header nav {
		display: block;
		position: fixed;
		z-index: 2;
		background-color: #fff;
		top: 0;
		padding: 1em 1em 1em 2em;
		inset: 0;
		height: fit-content;
		max-height: 100dvh;
		overflow: auto;
		bottom: 100vw;
		transform: scaleY(0);
		transition: all 0.3s ease;
		transform-origin: top center;
		z-index: 21;
	}

	header.open nav {
		transform: scaleY(1);
	}

	header nav:after {
		display: none;
	}

	header nav ul {
		display: grid;
		grid-template-columns: auto auto auto 1fr;
	}

	header nav ul>li {
		grid-column: span 4;
		width: fit-content;
	}

	header nav ul>li.nav-icon {
		grid-column: span 1;
	}

	.nav-toggle {
		display: flex;
	}

	header .nav-wedge {
		margin-top: 1.5em;
	}

	header .nav-logo img {
		width: 200px;
		max-width: 50vw;
	}

	header .nav-top {
		max-width: 40ch;
		margin-bottom: 0;
	}

	header .nav-logo {
		margin: 0
	}

	nav>ul>li>a {
		font-size: 1em;
	}

	.intro {
		grid-template-columns: 1fr 2.3fr !important;
		margin-bottom: 2em;
	} 

	.intro .text-holderl {
		grid-column: 1 / span 2;
		grid-row: 2;
		flex-direction: row;
		margin-bottom: 0;
		justify-content: space-between;
		font-size: 3.5vw;
		align-items: center;
		margin-top: 90px;
	}

	.intro .text-holderl .l3 {
		margin-top: 0;
	}

	.questions .text-holdert {
		padding: 2em 3em;
		align-items: flex-start;
		gap: 2em;
		flex-direction: column;
	}

	.wachen .wedge {
		width: 45%;
		align-self: flex-end;
	}

	.wachen .text-holder h2 {
		width: 100%;
		font-size: 3em;
	}

	.wachen .text-holder {
		margin-bottom: -15em;
		max-width: 100%;
		display: flex;
		flex-direction: column;
	}

	.jetzt .text-holdert{
		width: 100%;
	}
	.jetzt .text-holderb{
		width: 100%;
	}
	
	.funktion h2{
		font-size:  2em;
	}

	.vorteile h2{
		font-size: 2em;
	}
	.vorteile .img-holder {
		grid-column-start: full-start;
		grid-column-end: full-end;
	}
	.vorteile .img-holder img {
		height: auto; 
	}
	.vorteile .text-holder {
		grid-column-start: full-start;
		grid-column-end: full-end;
		margin-top: 0; 
		padding-top: 1em; 
	}
	.vorteile .text-holder:after {
		width: 110vw;
		top: -2em; 
		height: calc(100% + 2em);
		left: 50%;
		transform: translateX(-50%);
	}

	header.sticky>.nav-toggle{
		position: fixed;
		right: 1.5em;
		top: 1.5em;
		z-index:20;
	}
}

@media (max-width: 768px) {
	.footer-main .address {
		grid-template-columns: 1fr;
		gap: 0.5em;
	}

	.footer-main .address hr:nth-of-type(2) {
		display: block;
	}

	.footer-main .address hr {
		width: 80px;
	}

	.footer-main .logo {
		width: 66%;
	}

	header .nav-wedge {
		grid-row: 4;
		margin-top: 0.5em;
	}

	.nav-toggle {
		display: flex;
		grid-row: 2 / span 2;
		grid-column: 1;
		justify-self: center;
		margin-left: 1em;
	}

	.intro {
		grid-template-columns: 1fr 1fr!important;
	}

	.intro .img-holder {
	}

	.intro .text-holderl {
		grid-column: 2;
		grid-row: 2;
		flex-direction: column;
		margin-top: 0;
	}

	.intro .text-holderr {
		grid-column: 1 / span 2;
		grid-row: 1;
		margin-bottom: 1em;
	}

	.intro .img-holder {
		grid-column: 1;
		grid-row: 2;
		margin: 0;
	}

	.intro .text-holderr .wedge {
		padding: 1em 2em;
		margin-bottom: 2em;
		margin-right: 0;
	}

	.intro .text-holderr .wedge:before {
		width: 100%;
		transform: skewX(10deg);
	}

	.intro .text-holderl {
		font-size: 1.5em;
	}

	.wachen .wedge {
		width: 80%;
	}

	.wachen .text-holder {
		margin-bottom: 2em;
	}



	.wachen .img-wrapper {
		/* aspect-ratio: 1 / 3.2; */
	}


	.wachen .img-holder {
		font-size: 0.7em; 
		width: 60%; 
		left: 20%; 
	}
}

@media (max-width: 599px) {
	body {
		font-size: 16px;
	}

	.footer-main .logo {
		width: 100%;
		max-width: 320px;
	}

	header {
		margin-top: 1em;
	}

	header .nav-top {
		grid-column: 1 / span 2;
		grid-row: 1;
		margin-bottom: 1rem;
	}

	header .nav-toggle {
		grid-column: 1;
		grid-row: 2;
	}

	header .nav-logo {
		grid-column: 2;
		grid-row: 2;
	}

	header .nav-wedge {
		grid-column: 1 / span 2;
		grid-row: 3;
		width: fit-content;
		margin-top: 1rem;
	}

	header {
		grid-template-columns: 1fr 1fr !important;
	}

	.questions {
		margin-left: 1em;
		margin-right: 1em;
	}

	.questions .text-holdert {
		padding: 2em 2em;
		align-items: flex-start;
		gap: 2em;
		flex-direction: column;
	}

	.questions .text-holdert:before {
		transform: skewX(-5deg);
	}

	.wachen .wedge:after {
		transform: skewX(-10deg);
	}
	.wachen .text-holder {
		/* margin-bottom: 0; */
	}


	.wachen .img-wrapper {
		/* aspect-ratio: 1 / 4.625; */
	}


	.wachen .img-holder {
		font-size: 2.25vw; 
		width: 100%; 
		left: 0%; 
	}

}

@media (max-width: 479px) {
	.intro .text-holderr .wedge {
		padding: 1em;
	}

	.intro .text-holderr .wedge:before {
		transform: skewX(5deg);
	}

	.intro .text-holderr .wedge-btn {
		inset: auto auto;
	}

	.intro {
		grid-template-columns: 1fr!important;
	}

	.intro .text-holderl {
		grid-column: 1;
		grid-row: 3;
		font-size: 8vw;
		margin-top: 1em;
	}

	.intro .text-holderr {
		grid-column: 1;
		grid-row: 1;
	}

	.intro .img-holder {
		grid-column: 1;
		grid-row: 2;
		margin: 0;
		max-width: 350px;
		justify-self: center;
	}

	.funktion li {
		gap: 0.5em;
		flex-direction: column;
	}
	.funktion ol {
		font-size: 1.25em;
	}
	.funktion li>div {
		padding: 0.75em 1em;
	}
	.funktion li:nth-child(1) a {
		font-size: 0.66em;
	}
	.reg {
		padding: 1em;
	}
}

@media (max-width: 399px) {
	.footer-main .address b {
		white-space: unset;
	}

	.intro .text-holderr .wedge:before {
		transform: skewX(2deg);
	}

	.intro .text-holderr h1 {
		font-size: 2.25em;
	}

	.questions .text-holdert:before {
		transform: skewX(-2deg);
	}

	.questions .text-holdert {
		padding: 2em 1em;
	}

	.questions .text-holdert>div:last-child {
		font-size: 1em;
	}

	.wachen .wedge:after {
		transform: skewX(-5deg);
	}

	
	.jetzt .text-holdert{
		width: 100%;
	}
	.jetzt .text-holderb{
		width: 100%;
	}
	.jetzt .text-holdert:after {
		transform: skewX(10deg);
	}
	.jetzt .text-holderb>div:after {
		transform: skewX(-10deg);
	}
	.wachen .item .info a {
		white-space: unset;;
	}
	.wachen .img-holder {
		font-size: 0.7em;
	}
}
