

/* ############################################################
	FARBKLIMA
###############################################################
	
	1 Rot				#e30031 - rgba(227,0,49,1)
	  Weiss				#ffffff - rgba(255,255,255,1)
	  Schwarz			#000000 - rgba(0,0,0,1)
	
###############################################################
	ALLGEMEINES
############################################################ */

/* Resets */
* {
	margin: 0;
	padding: 0;
	outline: none;
}
*, *:before, *:after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
img, table, tr, td {
	border: 0;
}
fieldset {
	border: 0;
	margin: 0;
	padding: 0;
	min-inline-size: 0;
}
legend {
	margin: 0;
	padding: 0;
}


/* Variablen definieren */
:root {
	--main-color-1: #e30031;
	--main-color-white: #ffffff;
	--main-color-black: #000000;
	--main-color-error: #eb4462;
	--main-color-successful: #4fa158;
	--ph-color: var(--main-color-1);
	--gap: 10px;
	--cubic-bezier: cubic-bezier(0.41,0,0.51,1) 0s;
}
@media screen and (min-width: 992px) {
	:root {
		--gap: 17px;
	}
}


/* Allgemeines */
a, a:focus {
	outline: none;
}
a:focus-visible {
	outline: 4px solid var(--main-color-white);
    outline-offset: 3px;
}
/*header img, */main img {
	display: inline-block;
	max-width: 100%;
	height: auto;
	-ms-interpolation-mode: bicubic;
	image-rendering: optimizeQuality;
}
html, body {
	font-size: 100%;
	height: 100%;
}
html {
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}
body {
 	/*z-index: 0;*/
	overflow-x: hidden;
	display: flex;
	flex-direction: column;
	background-color: var(--main-color-1);
	font-family: "Google Sans";
	font-style: normal;
	font-weight: 500;
	color: var(--main-color-black);
}
body.blocked {
	overflow: hidden;
}
body.blocked {
	overflow: hidden;
}


/* Effekt: FadeIn / Lightning */
body:not(.cms-active) header,
body:not(.cms-active) main,
body:not(.cms-active) footer {
	opacity: 0;
}


/* Page-Loader */
@keyframes load-spinner {
  to {
		transform: rotate(360deg);
	}
}
#load-cover-spin {
	position: fixed;
	width: 100%;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	background-color: rgba(233,245,252,0.7);
	z-index: 9999;
	display: none;
}
#load-cover-spin::after {
	content: "";
	box-sizing: border-box;
	position: absolute;
	top: 50%;
	left: 50%;
	width: 50px;
	height: 50px;
	margin-top: -25px;
	margin-left: -25px;
	border-radius: 50%;
	border: 4px solid var(--main-color-2);
	border-top-color: var(--main-color-7);
	background-color: transparent;
	animation: load-spinner 600ms linear infinite;
}


/* Farben */
.color-error {
	color: var(--main-color-error);
}
.color-successful {
	color: var(--main-color-successful);
}
.color-white {
	color: var(--main-color-white);
}
.color-black {
	color: var(--main-color-black);
}
.color-1 {
	color: var(--main-color-1);
}
.bg-color-error {
	background-color: var(--main-color-error);
}
.bg-color-successful {
	background-color: var(--main-color-successful);
}
.bg-color-white {
	background-color: var(--main-color-white);
}
.bg-color-black {
	background-color: var(--main-color-black);
}
.bg-color-1 {
	background-color: var(--main-color-1);
}


/* ############################################################
	BARRIEREFREI
############################################################ */

.visuallyhidden {
	clip: rect(0 0 0 0) !important;
	border: 0 !important;
	height: 1px !important;
	margin: -1px !important;
	overflow: hidden !important;
	padding: 0 !important;
	position: absolute !important;
	width: 1px !important;
}
.skiplinks {
	position: fixed;
	display: inline-block;
	height: 0;
	z-index: 1000;
}
.skiplinks a, .skiplinks a:hover, .skiplinks a:active, .skiplinks a:focus {
	top: -9999px;
	position: absolute;
	display: inline-flex;
	align-items: center;
	border-radius: 5px;
	padding: 3px 8px 4px 8px;
	border: 2px solid var(--main-color-1);
	background-color: var(--main-color-white);
	font-weight: 700;
	font-size: 1rem; /* 16px */
	line-height: normal;
	letter-spacing: 0.32px;
	color: var(--main-color-1);
}
.skiplinks a:active, .skiplinks a:focus {
	left: 20px;
	right: auto;
	top: 20px;
}


/* ############################################################
	SCHRIFTEN / TEXTE / ABSÄTZE / TITEL
############################################################ */

/* Allgemeines */
main {
	font-size: 1rem; /* 16px */
	line-height: 1.5;
	letter-spacing: 0.32px;
}
footer {
	font-size: 0.875rem; /* 14px */
	line-height: 1.444;
	letter-spacing: 0.28px;
	color: var(--main-color-white);
}
@media screen and (min-width: 1200px) {
	main {
		font-size: 1.25rem; /* 20px */ 
		letter-spacing: 0.4px;
	}
	footer {
		font-size: 1.125rem; /* 18px */
		letter-spacing: 0.36px;
	}
}


/* Schnitte */
.font-regular {
	font-weight: 400 !important;
}
i, em, .italic {
	font-family: "Gilroy";
	font-style: italic;
	font-weight: 400;
}
b, strong, .bold {
	font-family: "Gilroy";
	font-style: normal;
	font-weight: 700;
}


/* Titel, Schriftgrössen */
h1, h2, h3, h4, .h2-modultitel {
	position: relative;
	margin: 0;
	padding: 0;
	font-family: "Gilroy";
	font-style: normal;
	font-weight: 700;
	letter-spacing: normal;
	color: inherit;
}
h2 {
	margin-bottom: 40px;
	font-style: italic;
	font-size: 2.25rem; /* 36px */
	line-height: 1.15;
	letter-spacing: 0.32px;
}
h2.modultitel, .h2-modultitel {
	display: inline-block;
	margin-bottom: 30px;
	padding-bottom: 2px;
	border-bottom: 3px solid var(--main-color-7);
	font-style: normal;
	font-size: 1.5rem; /* 24px */
	line-height: 1.25;
	letter-spacing: 0.48px;
}
footer h2 {
	display: block;
	margin-bottom: 11px;
	padding-bottom: 7px;
	border-bottom: 1px solid var(--main-color-white);
	font-style: italic;
	font-size: 1rem; /* 16px */
	line-height: 1.25;
	letter-spacing: 0.32px;
}
h3 {
	font-size: 1rem; /* 16px */
	line-height: 1.5;
	letter-spacing: 0.32px;
}
h3.line {
	margin-bottom: 7px;
	padding-bottom: 5px;
	border-bottom: 1px solid var(--main-color-2);
}
.font-small {
	font-size: 0.9375rem; /* 15px */
	line-height: 1.5;
	letter-spacing: 0.3px;
}
@media screen and (min-width: 1200px) {
	h2 {
		margin-bottom: 50px;
		font-size: 2.8125rem; /* 45px */
		letter-spacing: 0.9px;
	}
	h2.modultitel, .h2-modultitel {
		margin-bottom: 60px;
		padding-bottom: 4px;
		font-size: 1.875rem; /* 30px */
		letter-spacing: 0.6px;
	}
	footer h2 {
		margin-bottom: 27px;
		font-size: 1.125rem; /* 18px */
		letter-spacing: 0.36px;
	}
	h3 {
		font-size: 1.25rem; /* 20px */ 
		letter-spacing: 0.4px;
	}
	.font-small {
		font-size: 1.0625rem; /* 17px */
		letter-spacing: 0.34px;
	}
}


/* Absätze */
p + h2 {
	margin-top: 40px;
}
ul + h3, ul + p {
	margin-top: 36px;
}
p + ul {
	margin-top: 24px;
}
p {
	margin-bottom: 24px;
}
@media screen and (min-width: 1200px) {
	p + h2 {
		margin-top: 60px;
	}
	ul + h3, ul + p {
		margin-top: 45px;
	}
	p + ul {
		margin-top: 30px;
	}
	p {
		margin-bottom: 30px;
	}
}


/* Lange Sätze abschneiden */
.text-overflow-ellipsis {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}


/* Zeichen */
.text-uppercase {
	text-transform: uppercase;
}
.text-lowercase {
	text-transform: lowercase;
}


/* Silbentrennung */
.silbentrennung {
	hyphens: auto;
	-webkit-hyphens: auto;
	-ms-hyphens: auto;
	hyphenate-limit-chars: auto 3; /* wirkt in Chrome/Edge/Firefox, Safari ignoriert */
	/* Safari/iOS Safari Fallback (non-standard) */
	-webkit-hyphenate-limit-before: 3;
	-webkit-hyphenate-limit-after: 3;
	-webkit-hyphenate-limit-lines: 3;
}


/* ############################################################
	HYPERLINKS
############################################################ */

/* Allgemeines */
a {
	position: relative;
	text-decoration: none;
}
a, a:hover, a:focus {
	color: var(--main-color-1);
}
footer a, footer a:hover, footer a:focus {
	color: var(--main-color-white);
}
@media screen and (min-width: 992px) {
	a {
		transition: color 300ms var(--cubic-bezier);
	}
	a:hover, a:focus,
	footer a:hover, footer a:focus {
		color: var(--main-color-7);
	}
}


/* Button: Telefon/E-Mail */
a.link-btn, button.link-btn {
	display: inline-flex;
	align-items: center;
	border: none;
	border-radius: 5px;
	margin-right: 17px;
	margin-bottom: 11px;
	padding: 5px 8px 6px;
	background-color: var(--main-color-5);
	font-weight: 700;
	font-size: 0.9375rem; /* 15px */
	line-height: normal;
	letter-spacing: 0.3px;
	color: var(--main-color-1);
}
a.link-btn.white, button.link-btn.white {
	background-color: var(--main-color-white);
}
.col-2 > a.link-btn:last-child {
	margin-right: 0;
}
a.link-btn:hover, button.link-btn:hover {
	color: var(--main-color-1);
}
	/* PDF */
	a.link-btn span {
		display: inline-flex;
		align-items: center;
		border-radius: 3px;
		margin-left: 8px;
		padding: 2px 4px;
		background-color: var(--main-color-1);
		font-weight: 700;
		font-size: 0.8125rem; /* 13px */
		line-height: 1.0;
		letter-spacing: 0.75px;
		color: var(--main-color-5);
	}
@media screen and (min-width: 992px) {
	a.link-btn, button.link-btn, a.link-btn span {
		transition: all 300ms var(--cubic-bezier);
	}
	a.link-btn:hover, a.link-btn.white:hover, button.link-btn:hover, button.link-btn.white:hover {
		background-color: var(--main-color-7);
		color: var(--main-color-white);
	}
		a.link-btn:hover span {
			background-color: var(--main-color-white);
			color: var(--main-color-7);
		}
}
@media screen and (min-width: 1200px) {
	a.link-btn, button.link-btn {
		font-size: 1rem; /* 16px */
		letter-spacing: 0.32px;
	}
}


/* Button: Extern */
a.link-btn-extern {
	display: inline-flex;
	align-items: center;
	border-radius: 5px;
	padding: 5px 2px 6px 10px;
	background-color: var(--main-color-white);
	font-weight: 700;
	font-size: 1rem; /* 16px */
	line-height: normal;
	letter-spacing: 0.32px;
	color: var(--main-color-1);
}
a.link-btn-extern:hover {
	color: var(--main-color-1);
}
a.link-btn-extern.border {
	padding: 3px 0 4px 8px;
	border: 2px solid var(--main-color-1);
}
a.link-btn-extern::after {
	content: "";
	display: inline-block;
	width: 10px;
	height: 10px;
	margin-left: 7px;
	margin-right: 7px;
	background-image: url("../Images/Elemente/Arrow_Link_10x10_Blau.svg");
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
}
@media screen and (min-width: 992px) {
	a.link-btn-extern, a.link-btn-extern::after {
		transition: all 300ms var(--cubic-bezier);
	}
	a.link-btn-extern:not(.border):hover {
		background-color: var(--main-color-7);
		color: var(--main-color-white);
	}
	a.link-btn-extern.border:hover {
		border-color: var(--main-color-7);
		color: var(--main-color-7);
	}
	a.link-btn-extern:hover::after {
		background-image: url("../Images/Elemente/Arrow_Link_10x10_Weiss.svg");
	}
	a.link-btn-extern.border:hover::after {
		background-image: url("../Images/Elemente/Arrow_Link_10x10_Rot.svg");
	}
}


/* Hover-Effekte */
.no-hover,
.no-hover:hover,
.no-link,
.no-link:hover {
	cursor: default;
	color: inherit;
	text-decoration: none;
}
.pointer {
	cursor: pointer;
}


/* Lange Hyperlinks */
@media screen and (max-width: 767.98px) {
	main a {
		hyphens: auto;
		hyphenate-limit-chars: auto 3; /* wirkt in Chrome/Edge/Firefox, Safari ignoriert */
		/* Safari/iOS Safari Fallback (non-standard) */
		-webkit-hyphenate-limit-before: 3;
		-webkit-hyphenate-limit-after: 3;
		-webkit-hyphenate-limit-lines: 3;
	}
}


/* Anker */
a.nav-anchor {
	display: block;
	width: 0;
	height: 0;
	position: relative;
	top: 0 !important;
	top: -0px !important;
	visibility: hidden;
}
/* @media screen and (min-width: 1200px) {
	a.nav-anchor {
		top: -193px !important;
	}
} */


/* ############################################################
	PANELS/BOXEN
############################################################ */

/* Allgemein */
header, main, footer,
.main-header, .main-content,
.header-box, .nav-box, .content-box, .footer-box,
.header-inline, .nav-inline, .content-inline, .footer-inline,
.footer-col-1, .footer-col-2,
.mdl-container, .nav-line-1, .nav-line-2, .nav-line-3 {
	position: relative;
	width: 100%;
}
.header-box, .nav-box, .content-box, .footer-box {
	padding-right: 20px;
	padding-left: 20px;
}
.header-inline, .nav-inline, .content-inline, .footer-inline {
	margin: 0 auto 0 0;
}

/* Kopfzeile */
header {
	z-index: 10;
	position: fixed;
	top: 0;
	height: 110px;
	transition: top 300ms var(--cubic-bezier);
}
header:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	z-index: 4;
	width: 100%;
	height: 110px;
	background-color: var(--main-color-white);
}
header.scrolled {
	top: -110px;
}
body[class^="cms-"] header {
	z-index: 210;
	top: 51px;
}
body[class^="cms-"] header:before {
	z-index: 204;
}
body[class^="cms-"] header.scrolled {
	top: -161px;
}
	.header-inline {
		height: 110px;
	}

/* Inhalt */
main {
	flex: 1 0 auto;
	padding-top: 110px;
}
body[class^="cms-"] main {
	padding-top: 161px;
}

/* Fusszeile */
footer {
	flex-shrink: 0;
	display: flex;
	flex-direction: column;
	background: linear-gradient(172deg, var(--main-color-1) 30%, var(--main-color-3) 120%);
}
	footer .footer-box:nth-of-type(1) .footer-inline, footer .footer-box:nth-of-type(2) .footer-inline {
		display: inline-flex;
		flex-direction: row;
		flex-wrap: wrap;
	}
	/* 1. Zeile */
	footer .footer-box:nth-of-type(1) {
		padding-top: 27px;
		padding-bottom: 105px;
	}
		footer .footer-box:nth-of-type(1) [class^="contact-col-"] {
			width: calc((6 * var(--col-width-1)) + (5 * var(--gap)));
		}
		/* Kontaktdaten (1+2): Öffnungszeiten */
		footer .footer-box:nth-of-type(1) .contact-col-2, footer .footer-box:nth-of-type(1) .contact-col-4 {
			margin-left: var(--gap);
		}
		/* Kontaktdaten (2): EnergieLaden, Öffnungszeiten */
		footer .footer-box:nth-of-type(1) .contact-col-3, footer .footer-box:nth-of-type(1) .contact-col-4 {
			margin-top: 44px;
		}
	/* 2. Zeile */
	footer .footer-box:nth-of-type(2) {
		display: flex;
		flex-direction: row;
		height: 106px;
		margin-top: auto;
		background-color: var(--main-color-white);
	}
	footer .footer-box:nth-of-type(2)::before {
		content: "";
		display: block;
		position: absolute;
		top: -7vw;
		left: 0;
		width: 100vw;
		height: calc(7vw + 1px); /* Hack: Tennlinie verbergen. */
		background-color: var(--main-color-white);
		clip-path: polygon(100% 0, 100% 100%, 0 100%, 0 calc(100% - 1px));
	}
		footer .footer-box:nth-of-type(2) .footer-inline {
			align-items: flex-end;
			height: 73px;
			margin-top: 10px;
		}
			/* Socialmedia */
			footer .footer-box:nth-of-type(2) .nav-col-1 {
				order: 1;
				padding-bottom: 5px;
				font-size: 0;
				line-height: 0;
			}
			/* Energieportal */
			footer .footer-box:nth-of-type(2) .nav-col-2 {
				order: 0;
				align-self: flex-start;
				width: 100%;
				text-align: right;
			}
			/* Secondmenu */
			footer .footer-box:nth-of-type(2) .nav-col-3 {
				order: 2;
				margin-left: auto;
				padding-bottom: 3px;
			}
			/* Logo */
			footer .footer-box:nth-of-type(2) .nav-col-4 {
				order: 3;
				margin-left: auto;
				font-size: 0;
				line-height: 0;
			}
@media screen and (min-width: 768px) {
	/* Allgemein */
	.header-box, .nav-box, .content-box, .footer-box {
		padding-left: 50px;
		padding-right: 50px;
	}
	/* Fusszeile */
	/* 1. Zeile */
	footer .footer-box:nth-of-type(1) {
		padding-top: 52px;
		padding-bottom: 125px;
	}
}
@media screen and (min-width: 992px) {
	/* Fusszeile */
	/* 1. Zeile */
	footer .footer-box:nth-of-type(1) {
		padding-top: 73px;
		padding-bottom: 175px;
	}
		footer .footer-box:nth-of-type(1) [class^="contact-col-"] {
			width: calc((2 * var(--col-width-1)) + (2 * var(--gap)));
		}
		/* Kontaktdaten (1+2): Öffnungszeiten */
		footer .footer-box:nth-of-type(1) .contact-col-2, footer .footer-box:nth-of-type(1) .contact-col-4 {
			margin-left: var(--gap);
		}
		/* Kontaktdaten (2): EnergieLaden, Öffnungszeiten */
		footer .footer-box:nth-of-type(1) .contact-col-3, footer .footer-box:nth-of-type(1) .contact-col-4 {
			margin-top: 0;
		}
		/* Kontaktdaten (2): EnergieLaden */
		footer .footer-box:nth-of-type(1) .contact-col-3 {
			margin-left: calc((1 * var(--col-width-1)) + (1 * var(--gap)));
		}
	/* 2. Zeile */
	footer .footer-box:nth-of-type(2) {
		height: 130px;
	}
		footer .footer-box:nth-of-type(2) .footer-inline {
			height: 70px;
		}
			/* Socialmedia */
			footer .footer-box:nth-of-type(2) .nav-col-1 {
				order: 0;
				width: 150px;
			}
			/* Energieportal */
			footer .footer-box:nth-of-type(2) .nav-col-2 {
				order: 1;
				align-self: auto;
				width: 225px;
				text-align: left;
			}
			/* Secondmenu */
			footer .footer-box:nth-of-type(2) .nav-col-3 {
				margin-left: 0;
			}
}
@media screen and (min-width: 1200px) {
	/* Kopfzeile */
	header, .header-inline {
		height: 193px;
	}
	header:before {
		height: 193px;
	}
	header.scrolled {
		top: -193px;
	}
	body[class^="cms-"] header.scrolled {
		top: -244px;
	}

	/* Inhalt */
	main {
		padding-top: 193px;
	}
	body[class^="cms-"] main {
		padding-top: 244px;
	}

	/* Fusszeile */
	/* 1. Zeile */
	footer .footer-box:nth-of-type(1) {
		padding-top: 105px;
		padding-bottom: 250px;
	}
	/* 2. Zeile */
	footer .footer-box:nth-of-type(2) {
		height: 160px;
	}
		footer .footer-box:nth-of-type(2) .footer-inline {
			height: 100px;
		}
}
@media screen and (min-width: 1600px) {
	/* Allgemein */
	.header-box, .nav-box, .content-box, .footer-box {
		padding-left: 100px;
		padding-right: 100px;
	}
}


/* ############################################################
	NAVIGATIONSBOXEN
############################################################ */


/* Navigation */
@media screen and (max-width: 1199.98px) {
	nav.menu-box, nav.menu-box.open {
		transition: right 400ms var(--cubic-bezier), visibility 400ms var(--cubic-bezier);
	}
	nav.menu-box .slider {
		transition: transform 300ms var(--cubic-bezier);
	}
	nav.menu-box {
		z-index: 8;
		visibility: hidden;
		/* opacity: 0; */
		position: fixed;
		display: flex;
		flex-direction: column;
		justify-content: flex-start;
		top: 110px;
		bottom: 0;
		right: -100%;
		width: 100%;
		/*height: 100vh;*/
		/*min-height: calc(var(--nav-height, 1vh) * 100);*/
		background-color: var(--main-color-5);
		overflow-x: hidden;
		overflow-y: auto;
	}
	nav.menu-box.open {
		visibility: visible;
		/* opacity: 1; */
		right: 0;
	}
	body[class^="cms-"] nav.menu-box {
		z-index: 209;
		top: 161px;
	}
		nav.menu-box .nav-line-1 {
			flex-shrink: 0;
			height: auto;
			padding-top: 20px;
			padding-bottom: 30px;
			transition: height 250ms var(--cubic-bezier);
		}
		nav.menu-box .nav-line-2 {
			margin-top: auto;
			padding-bottom: 28px;
		}
		nav.menu-box .nav-line-3 {
			height: 66px;
			background-color: var(--main-color-white);
		}
		nav.menu-box .search-wrapper, nav.menu-box .location-wrapper {
			z-index: 2;
			pointer-events: none;
			visibility: hidden;
			position: absolute; 
			display: flex;
			flex-direction: column;
			justify-content: flex-start;
			bottom: 66px;
			right: 0;
			width: 100%;
			padding: 60px 50px;
			height: calc((var(--nav-height, 1vh) * 100) - 66px); /* 66px = nav-line-3 */
			background-color: var(--main-color-5);
		}
		nav.menu-box .location-wrapper {
			padding: 75px 50px;
		}
		body[class^="cms-"] nav.menu-box .search-wrapper, body[class^="cms-"] nav.menu-box .location-wrapper {
			z-index: 202;
		}
		nav.menu-box .search-wrapper.open-mobile, nav.menu-box .location-wrapper.open-mobile {
			pointer-events: auto;
			visibility: visible;
		}
}
@media screen and (max-width: 767.98px) {
	nav.menu-box .search-wrapper {
		padding: 60px 25px;
	}
	nav.menu-box .location-wrapper {
		padding: 75px 25px;
	}
}
@media screen and (min-width: 1200px) {
	.nav-meta-box, nav.menu-box .nav-line-1 {
		position: absolute;
		top: 41px;
		right: 0;
		width: calc(100% - 225px);
	}
	.nav-meta-box {
		z-index: 5;
	}
	body[class^="cms-"] .nav-meta-box {
		z-index: 205;
	}
	nav.menu-box .nav-line-1 {
		top: 130px;
		height: auto !important;
	}
	nav.menu-box .nav-line-3 {
		display: none;
	}
	nav.menu-box .nav-line-2, nav.menu-box.open-desktop .nav-line-2 {
		transition: bottom 400ms var(--cubic-bezier), visibility 400ms var(--cubic-bezier);
	}
	nav.menu-box .nav-line-2 {
		z-index: 2;
		visibility: hidden;
		display: block;
		position: fixed;
		bottom: 100vh;
		left: 0;
		right: 0;
		height: 106px;
		margin-top: auto;
		padding-bottom: 0;
		background-color: var(--main-color-white);
	}
	nav.menu-box.open-desktop .nav-line-2 {
		visibility: visible;
		bottom: 0;
	}
	body[class^="cms-"] nav.menu-box .nav-line-2 {
		z-index: 202;
	}
		nav.menu-box .nav-line-2 .nav-inline {
			display: inline-flex;
			flex-direction: row;
			align-items: baseline;
			height: 106px;
		}
	nav.menu-box .menu-wrapper, nav.menu-box.open-desktop .menu-wrapper {
		transition: top 400ms var(--cubic-bezier), visibility 400ms var(--cubic-bezier);
	}
	nav.menu-box .nav-megamenu, nav.menu-box .menu-wrapper {
		visibility: hidden;
		position: fixed;
		display: flex;
		flex-direction: column;
		justify-content: flex-start;
		top: -100vh;
		left: 0;
		right: 0;
		width: 100%;
	}
	nav.menu-box .nav-megamenu {
		z-index: 2;
		pointer-events: none;
		height: calc(100vh - 299px);
		padding: 60px calc(((1 * var(--col-width-1)) + (1 * var(--gap))) + 50px) 60px 50px;
		background-color: var(--main-color-5);
		transition: top 400ms var(--cubic-bezier), visibility 0s linear 400ms;
		overflow-y: auto;
	}
	body[class^="cms-"] nav.menu-box .nav-megamenu {
		z-index: 202;
		height: calc(100vh - 350px);
	}
	nav.menu-box.open-desktop .nav-megamenu {
		top: 193px;
	}
	body[class^="cms-"] nav.menu-box.open-desktop .nav-megamenu {
		top: 244px;
	}
	nav.menu-box.open-desktop .nav-megamenu.open {
		pointer-events: auto;
		visibility: visible;
		transition: top 400ms var(--cubic-bezier), visibility 0s linear 0s;
	}
	nav.menu-box.open-desktop .nav-megamenu:not(.open) {
		transition: top 400ms var(--cubic-bezier), visibility 0s linear 0s;
	}
	nav.menu-box .menu-wrapper {
		z-index: 1;
		visibility: visible;
		height: calc(100vh - 193px);
		background-color: var(--main-color-5);
	}
	body[class^="cms-"] nav.menu-box .menu-wrapper {
		z-index: 201;
		height: calc(100vh - 244px);
	}
	nav.menu-box.open-desktop .menu-wrapper {
		visibility: visible;
		top: 193px;
	}
	body[class^="cms-"] nav.menu-box.open-desktop .menu-wrapper {
		top: 244px;
	}
	nav.menu-box .search-wrapper, nav.menu-box .location-wrapper {
		z-index: 1;
		pointer-events: none;
		visibility: hidden;
		position: fixed;
		display: flex;
		flex-direction: column;
		justify-content: flex-start;
		top: -100vh;
		left: 0;
		right: 0;
		width: 100%;
		height: calc(100vh - 299px);
		padding: 60px 50px;
		background-color: var(--main-color-5);
		transition: top 400ms var(--cubic-bezier), visibility 0s linear 400ms;
		overflow-y: auto;
	}
	nav.menu-box .location-wrapper {
		padding-top: 86px;
		padding-bottom: 86px;
	}
	body[class^="cms-"] nav.menu-box .search-wrapper, body[class^="cms-"] nav.menu-box .location-wrapper {
		z-index: 201;
		height: calc(100vh - 350px);
	}
	nav.menu-box.open-desktop .search-wrapper, nav.menu-box.open-desktop .location-wrapper {
		top: 193px;
	}
	body[class^="cms-"] nav.menu-box.open-desktop .search-wrapper, body[class^="cms-"] nav.menu-box.open-desktop .location-wrapper {
		z-index: 202;
		top: 244px;
	}
	nav.menu-box.open-desktop .search-wrapper.open, nav.menu-box.open-desktop .location-wrapper.open {
		z-index: 2;
		pointer-events: auto;
		visibility: visible;
		transition: top 400ms var(--cubic-bezier), visibility 0s linear 0s;
	}
	nav.menu-box.open-desktop .search-wrapper:not(.open), nav.menu-box.open-desktop .location-wrapper:not(.open) {
		transition: top 400ms var(--cubic-bezier), visibility 0s linear 0s;
	}
}
@media screen and (min-width: 1600px) {
	nav.menu-box .nav-megamenu {
		padding: 120px calc(((2 * var(--col-width-1)) + (2 * var(--gap))) + 100px) 120px calc(((1 * var(--col-width-1)) + (1 * var(--gap))) + 100px);
	}
	nav.menu-box .search-wrapper {
		padding: 110px 100px;
	}
	nav.menu-box .location-wrapper {
		padding: 136px 100px;
	}
}
@media screen and (min-width: 1200px) and (max-height: 1079.98px) {
	nav.menu-box .nav-megamenu {
		padding-top: 60px;
		padding-bottom: 60px;
	}
	nav.menu-box .search-wrapper {
		padding-top: 60px;
		padding-bottom: 60px;
	}
	nav.menu-box .location-wrapper {
		padding-top: 86px;
		padding-bottom: 86px;
	}
}
@media screen and (min-width: 1200px) and (min-height: 1080px) {
	nav.menu-box .nav-megamenu {
		padding-top: 120px;
		padding-bottom: 120px;
	}
	nav.menu-box .search-wrapper {
		padding-top: 110px;
		padding-bottom: 110px;
	}
	nav.menu-box .location-wrapper {
		padding-top: 136px;
		padding-bottom: 136px;
	}
}


/* ############################################################
	SUCHFORMULAR
############################################################ */

/* Allgemeines */
.search-box, .search-form {
	position: relative;
	width: 100%;
}
.search-box input:focus, .search-box input:active {
	outline: none;
}
.search-box input {
	position: relative;
	width: 100%;
	height: 67px;
	padding-left: 20px;
	padding-right: 67px;
	border: none;
	border-radius: 5px;
	background-color: var(--main-color-white);
	font-family: "Gilroy";
	font-style: normal;
	font-weight: 400;
	font-size: 1.8125rem; /* 29px */
	line-height: 67px;
	letter-spacing: 0.725px;
	color: var(--main-color-1);
	-webkit-appearance: none;
	appearance: none;
}
.search-box input::placeholder { /* Standard (Chrome, Edge, Safari, Firefox modern) */
	color: var(--main-color-1);
	opacity: 1; /* wichtig für Firefox */
}
.search-box input::-webkit-input-placeholder { /* ältere WebKit/Blink-Varianten (Safari/Chrome) */
	color: var(--main-color-1);
	opacity: 1; /* wichtig für Firefox */
}
.search-box input::-moz-placeholder { /* Firefox (ältere Varianten) */
	color: var(--main-color-1);
	opacity: 1; /* wichtig für Firefox */
}
.search-box input.touched::placeholder {
	color: var(--main-color-error);
}
.search-box input.touched::-webkit-input-placeholder {
	color: var(--main-color-error);
}
.search-box input.touched::-moz-placeholder {
	color: var(--main-color-error);
}
.search-box input:required:valid::placeholder {
	color: var(--main-color-1);
}
.search-box input:required:valid::-webkit-input-placeholder {
	color: var(--main-color-1);
}
.search-box input:required:valid::-moz-placeholder {
	color: var(--main-color-1);
}
.search-box .send-button {
	display: inline-block;
	position: absolute;
	top: 0;
	right: 0;
	width: 67px;
	height: 67px;
	padding: 0;
	border: none;
	background-color: transparent;
	background-image: url("../Images/Elemente/Form_Search_Mobile_Blau.svg");
	background-position: center;
	background-repeat: no-repeat;
	background-size: 28px;
	font-size: 0;
	line-height: 0;
	letter-spacing: 0;
	cursor: pointer;
}
@media screen and (min-width: 992px) {
	.search-box .send-button {
		transition: background 300ms var(--cubic-bezier);
	}
	.search-box .send-button:hover {
		background-image: url("../Images/Elemente/Form_Search_Mobile_Rot.svg");
	}
}
@media screen and (min-width: 1200px) {
	.search-box {
		padding-left: calc(((1 * var(--col-width-1)) + (1 * var(--gap))) - 25px);
		padding-right: calc(((1 * var(--col-width-1)) + (1 * var(--gap))) - 25px);
	}
	.search-box input {
		height: 116px;
		padding-left: 40px;
		padding-right: 100px;
		font-size: 3.125rem; /* 50px */
		line-height: 116px; 
		letter-spacing: 1.25px;
	}
	.search-box .send-button {
		width: 116px;
		height: 116px;
		background-image: url("../Images/Elemente/Form_Search_Desktop_Blau.svg");
		background-size: 49px;
	}
	.search-box .send-button:hover {
		background-image: url("../Images/Elemente/Form_Search_Desktop_Rot.svg");
	}
}


/* ############################################################
	LKW-KARTE (LOCATION)
############################################################ */

/* Allgemeines */
.location-box {
	position: relative;
	width: 100%;
	font-size: 1rem; /* 16px */
	line-height: 1.5;
	letter-spacing: 0.32px;
}
.location-box h2.location {
	display: block;
	padding-bottom: 0;
	border-bottom: none;
	padding-left: 57px;
	font-weight: 400;
	font-size: 1.8125rem; /* 29px */
	line-height: 1.25;
	letter-spacing: 0.725px;
}
.location-box h2.location::before {
	content: "";
	display: inline-block;
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	width: 39px;
	height: 32px;
	background-image: url("../Images/Elemente/Icon_Location_Mobile.svg");
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
}
@media screen and (min-width: 1200px) {
	.location-box {
		padding-left: calc((1 * var(--col-width-1)) + (1 * var(--gap)));
		padding-right: calc((4 * var(--col-width-1)) + (4 * var(--gap)));
		font-size: 1.4375rem; /* 23px */
		letter-spacing: 0.46px;
	}
	.location-box h2.location {
		margin-bottom: 42px;
		padding-left: 100px;
		font-size: 3.125rem; /* 50px */
		letter-spacing: 1.25px;
	}
	.location-box h2.location::before {
		width: 68px;
		height: 55px;
		background-image: url("../Images/Elemente/Icon_Location_Desktop.svg");
	}
}
@media screen and (min-width: 1600px) {
	.location-box {
		padding-left: calc((1 * var(--col-width-1)) + (1 * var(--gap)));
		padding-right: calc((5 * var(--col-width-1)) + (5 * var(--gap)));
	}
}


/* ############################################################
	BILDER/ICONS
############################################################ */

/* Logo */
a.link-logo {
	display: inline-block;
	width: 153px;
	height: auto;
}
header a.link-logo {
	z-index: 5;
	position: absolute;
	top: 25px;
	left: 0;
}
body[class^="cms-"] header a.link-logo {
	z-index: 205;
}
	a.link-logo img {
		display: inline-block;
	}
@media screen and (min-width: 1200px) {
	a.link-logo {
		width: 225px;
	}
	header a.link-logo {
		top: 63px;
	}
}


/* Meta-Navigation */
a.link-search, a.link-location, a.link-webcam {
	cursor: pointer;
	position: relative;
	display: inline-block;
	width: 23px;
	height: 23px;
}
a.link-location {
	width: 32px;
	height: 26px;
}
a.link-webcam {
	width: 30px;
	height: 22px;
}
	a.link-search svg, a.link-location svg, a.link-webcam svg {
		fill: var(--main-color-1);
	}
	a.link-search.is-active-mobile svg, a.link-location.is-active-mobile svg {
		fill: var(--main-color-7);
	}
@media screen and (min-width: 992px) {
	a.link-search svg, a.link-location svg, a.link-webcam svg {
		transition: fill 300ms var(--cubic-bezier);
	}
	a.link-search:hover svg, a.link-location:hover svg, a.link-webcam:hover svg {
		fill: var(--main-color-7);
	}
}
@media screen and (min-width: 1200px) {
	a.link-search.is-active:not(.is-disabled) svg, a.link-location.is-active:not(.is-disabled) svg {
		fill: var(--main-color-7);
	}
}


/* Socialmedia */
a.link-socialmedia {
	position: relative;
	display: inline-block;
	width: 22px;
	height: 22px;
}
	a.link-socialmedia svg {
		fill: var(--main-color-1);
	}
@media screen and (min-width: 992px) {
	a.link-socialmedia svg {
		transition: fill 300ms var(--cubic-bezier);
	}
	a.link-socialmedia:hover svg {
		fill: var(--main-color-7);
	}
}


/* Hamburger */
.nav-button {
	z-index: 5;
	cursor: pointer;
	display: block;
	position: absolute;
	top: 25px;
	right: 0;
	width: 40px;
	height: 30px;
	overflow: hidden;
}
body[class^="cms-"] .nav-button {
	z-index: 205;
}
	.nav-button svg {
		display: block;
		width: 40px;
		height: auto;
		fill: var(--main-color-1);
	}
@media screen and (min-width: 1200px) {
	.nav-button {
		display: none !important;
	}
}
@media (prefers-contrast: more) {
	.nav-button svg {
		fill: var(--main-color-white);
	}
}


/* Button: Chat */
a.chat-button {
	z-index: 5;
	cursor: pointer;
	display: block;
	position: fixed;
	bottom: 25px;
	right: 30px;
	width: 74px;
	height: 74px;
	border-radius: 50%;
	border: 2px solid var(--main-color-5);
	background-color: var(--main-color-white);
	overflow: hidden;
	opacity: 0; /* startet unsichtbar */
	transform: translateY(12px); /* startet 12px tiefer */
	transition: opacity 300ms var(--cubic-bezier), transform 300ms var(--cubic-bezier);
}
a.chat-button.is-visible{
	opacity: 1;
	transform: translateY(0); /* gleitet zur Endposition */
}
a.chat-button.is-hidden{
	opacity: 0;
	transform: translateY(12px);
	pointer-events: none; /* verhindert Klicks im unsichtbaren Zustand */
}
body[class^="cms-"] a.chat-button {
	z-index: 205;
}
	a.chat-button svg .dots {
		fill: var(--main-color-1);
	}
	a.chat-button svg .speech-1 {
		fill: var(--main-color-5);
	}
	a.chat-button svg .speech-2 {
		fill: var(--main-color-4);
	}
@media screen and (min-width: 992px) {
	a.chat-button svg path {
		transition: fill 300ms var(--cubic-bezier);
	}
	a.chat-button:hover svg .dots {
		fill: var(--main-color-white);
	}
	a.chat-button:hover svg .speech-1 {
		fill: var(--main-color-7);
	}
	a.chat-button:hover svg .speech-2 {
		fill: var(--main-color-2);
	}
}
@media screen and (min-width: 1200px) {
	a.chat-button {
		bottom: 37px;
		width: 84px;
		height: 84px;
	}
}


/* ############################################################
	MODULE/TEMPLATES
############################################################ */

/* Module */
/* Horizontaler Abstand */
.mdl-container[class~="bg-color-6"] {
	width: calc(100% + 40px);
	margin-left: -20px;
	padding-left: 20px;
	padding-right: 20px;
}

/* Vertikaler Abstand */
.mdl-container.inner-abstand-top {
	padding-top: 50px;
}
.mdl-container.inner-abstand-topbottom {
	padding-top: 50px;
	padding-bottom: 65px;
}
.mdl-container.inner-abstand-bottom {
	padding-bottom: 65px;
}
@media screen and (min-width: 768px) {
	/* Horizontaler Abstand */
	.mdl-container[class~="bg-color-6"] {
		width: calc(100% + 100px);
		margin-left: -50px;
		padding-left: 50px;
		padding-right: 50px;
	}
}
@media screen and (min-width: 1200px) {
	/* Vertikaler Abstand */
	.mdl-container.inner-abstand-top {
		padding-top: 100px;
	}
	.mdl-container.inner-abstand-topbottom {
		padding-top: 100px;
		padding-bottom: 130px;
	}
	.mdl-container.inner-abstand-bottom {
		padding-bottom: 130px;
	}
}
@media screen and (min-width: 1600px) {
	/* Horizontaler Abstand */
	.mdl-container[class~="bg-color-6"] {
		width: calc(100% + 200px);
		margin-left: -100px;
		padding-left: 100px;
		padding-right: 100px;
	}
}


/* Templates */

/* Header (TopPanel) */
.top-template-1 {
	position: relative;
	display: inline-flex;
	flex-direction: column;
	width: 100%;
}
.top-template-1 .col-2 {
	margin-top: 60px;
}
	.top-template-1 .text-infobox {
		width: 100%;
		padding: 20px 17px;
		border-radius: 10px;
		background-color: var(--main-color-5);
		font-size: 0.9375rem; /* 15px */
		line-height: 1.5;
		letter-spacing: 0.3px;
		color: var(--main-color-1);
	}
		.top-template-1 .col-1 p:last-child, .top-template-1 .col-2 p:last-child {
			margin-bottom: 0;
		}
		.top-template-1 .text-infobox h3 {
			font-size: 1.5rem; /* 24px */
			line-height: 1.25;
			letter-spacing: 0.48px;
		}
		.top-template-1 .text-infobox h3 + p {
			margin-top: 20px;
		}
@media screen and (min-width: 768px) {
	.top-template-1 {
		flex-direction: row;
	}
		.top-template-1 .col-1 {
			width: calc((6 * var(--col-width-1)) + (5 * var(--gap)));
		}
		.top-template-1 .col-2 {
			width: calc((5 * var(--col-width-1)) + (4 * var(--gap)));
			margin-top: 0;
			margin-left: calc((1 * var(--col-width-1)) + (2 * var(--gap)));
		}
}
@media screen and (min-width: 1200px) {
	.top-template-1 .text-infobox {
		padding: 25px 30px;
		font-size: 1.0625rem; /* 17px */
		letter-spacing: 0.34px;
	}
		.top-template-1 .text-infobox h3 {
			font-size: 1.875rem; /* 30px */
			letter-spacing: 0.6px;
		}
		.top-template-1 .text-infobox h3 + p {
			margin-top: 26px;
		}
}
@media screen and (min-width: 1600px) {
	.top-template-1 .col-1 {
		width: calc((5 * var(--col-width-1)) + (4 * var(--gap)));
		margin-left: calc((1 * var(--col-width-1)) + (1 * var(--gap)));
	}
	.top-template-1 .col-2 {
		width: calc((4 * var(--col-width-1)) + (3 * var(--gap)));
	}
}
@media screen and (min-width: 1920px) {
	.top-template-1 .col-2 {
		width: calc((3 * var(--col-width-1)) + (2 * var(--gap)));
		margin-left: calc((2 * var(--col-width-1)) + (3 * var(--gap)));
	}
}


/* Content */

/* Template 1: 2 Textspalten (auto) über 8 Spalten */
.content-template-1 {
	position: relative;
	display: inline-flex;
	flex-direction: row;
	width: 100%;
}
	.content-template-1 .col-1 {
		width: 100%;
	}
		.content-template-1 .col-1 p:last-child {
			margin-bottom: 0;
		}
@media screen and (min-width: 768px) {
	.content-template-1 .col-1 {
		column-count: 2;
		column-gap: var(--gap); /* Spaltenabstand */
		column-fill: balance; /* Zeitung: Spalten möglichst gleich hoch */
	}
		.content-template-1 .col-1 p {
			break-inside: avoid; /* Absatz möglichst nicht über Spalten splitten */
			orphans: 3; /* mind. 3 Zeilen am Spaltenende */
			widows: 3; /* mind. 3 Zeilen am Spaltenanfang */
		}
}
@media screen and (min-width: 1600px) {
	.content-template-1 .col-1 {
		width: calc((8 * var(--col-width-1)) + (7 * var(--gap)));
	}
}


/* Template 2: 2 Textspalten (auto) mit Infobox über 12 Spalten */
.content-template-2 {
	position: relative;
	display: inline-flex;
	flex-direction: column;
	width: 100%;
}
.content-template-2 .col-2 {
	margin-top: 60px;
}
	.content-template-2 .text-infobox {
		width: 100%;
		padding: 20px 17px;
		border-radius: 10px;
		background-color: var(--main-color-5);
		font-size: 0.9375rem; /* 15px */
		line-height: 1.5;
		letter-spacing: 0.3px;
	}
		.content-template-2 .col-1 p:last-child, .content-template-2 .col-2 p:last-child {
			margin-bottom: 0;
		}
		.content-template-2 .text-infobox h3 {
			font-size: 1.5rem; /* 24px */
			line-height: 1.25;
			letter-spacing: 0.48px;
		}
		.content-template-2 .text-infobox h3 + p {
			margin-top: 20px;
		}
@media screen and (min-width: 768px) {
	.content-template-2 {
		flex-direction: row;
	}
		.content-template-2 .col-1 {
			width: calc((6 * var(--col-width-1)) + (5 * var(--gap)));
		}
		.content-template-2 .col-2 {
			width: calc((5 * var(--col-width-1)) + (4 * var(--gap)));
			margin-top: 0;
			margin-left: calc((1 * var(--col-width-1)) + (2 * var(--gap)));
		}
}
@media screen and (min-width: 1200px) {
	.content-template-2 .text-infobox {
		padding: 25px 30px;
		font-size: 1.0625rem; /* 17px */
		letter-spacing: 0.34px;
	}
		.content-template-2 .text-infobox h3 {
			font-size: 1.875rem; /* 30px */
			letter-spacing: 0.6px;
		}
		.content-template-2 .text-infobox h3 + p {
			margin-top: 26px;
		}
}
@media screen and (min-width: 1600px) {
	.content-template-2 .col-1 {
		width: calc((7 * var(--col-width-1)) + (6 * var(--gap)));
		column-count: 2;
		column-gap: var(--gap); /* Spaltenabstand */
		column-fill: balance; /* Zeitung: Spalten möglichst gleich hoch */
	}
		.content-template-2 .col-1 p {
			break-inside: avoid; /* Absatz möglichst nicht über Spalten splitten */
			orphans: 3; /* mind. 3 Zeilen am Spaltenende */
			widows: 3; /* mind. 3 Zeilen am Spaltenanfang */
		}
	.content-template-2 .col-2 {
		width: calc((4 * var(--col-width-1)) + (3 * var(--gap)));
		margin-left: calc((1 * var(--col-width-1)) + (2 * var(--gap)));
	}
}
@media screen and (min-width: 1920px) {
	.content-template-2 .col-1 {
		width: calc((8 * var(--col-width-1)) + (7 * var(--gap)));
	}
	.content-template-2 .col-2 {
		width: calc((3 * var(--col-width-1)) + (2 * var(--gap)));
	}
}

/* Template 3: 1 Textspalte über 8 Spalten */
.content-template-3 {
	position: relative;
	display: inline-flex;
	flex-direction: row;
	width: 100%;
}
	.content-template-3 .col-1 {
		width: 100%;
	}
		.content-template-3 .col-1 p:last-child {
			margin-bottom: 0;
		}
@media screen and (min-width: 1200px) {
	.content-template-3 .col-1 {
		width: calc((8 * var(--col-width-1)) + (7 * var(--gap)));
	}
}

/* Template 4: 2 Textspalten über 12 Spalten */
.content-template-4 {
	position: relative;
	display: inline-flex;
	flex-direction: column;
	width: 100%;
}
	.content-template-4 .col-1, .content-template-4 .col-2 {
		width: 100%;
	}
	.content-template-4 .col-2 {
		margin-top: 60px;
	}
		.content-template-4 .col-1 p:last-child, .content-template-4 .col-2 p:last-child {
			margin-bottom: 0;
		}
@media screen and (min-width: 992px) {
	.content-template-4 {
		flex-direction: row;
	}
		.content-template-4 .col-1, .content-template-4 .col-2 {
			width: calc((6 * var(--col-width-1)) + (5 * var(--gap)));
		}
		.content-template-4 .col-2 {
			margin-top: 0;
			margin-left: var(--gap);
		}
}


/* Scrollbare Tabellen (Mobile) */
.table-scrollable {
	width: 100%;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}
.table-fade {
	position: relative;
	width: 100%;
	--fade-bg: 255,255,255; /* Bei weissen Hintergrund. */
}
/* Wenn kein weisser Hintergrund. */
.mdl-container.bg-color-6:not(.mdl-art-180) .table-fade {
	--fade-bg: 213,237,250;
}
.table-fade::before, .table-fade::after {
	content:"";
	position: absolute;
	top: 0;
	width: 30px;
	height: 100%;
	pointer-events: none;
	transition: opacity .25s ease;
	z-index: 5;
}
.table-fade::before {
	left: 0;
	background: linear-gradient(to right, rgba(var(--fade-bg),1), rgba(var(--fade-bg),0));
	opacity: 0;
}
.table-fade::after {
	right: 0;
	background: linear-gradient(to left, rgba(var(--fade-bg),1), rgba(var(--fade-bg),0));
	opacity: 1;
}
.table-fade.scrolled-start::before {
	opacity: 1;
}
.table-fade.scrolled-end::after {
	opacity: 0;
}
.table-fade.no-scroll::before, .table-fade.no-scroll::after {
	opacity: 0;
}
@media screen and (min-width: 768px) {
	.table-fade::before, .table-fade::after {
		display: none !important;
	}
	.table-fade.fade-disabled::before, .table-fade.fade-disabled::after {
		opacity: 0 !important;
	}
}


/* ############################################################
	LISTEN
############################################################ */

/* Aufzählungslisten */
.mdl-container ul:not([class^="cmsmodule-nav"]):not([class^="slick-dots"]) {
	list-style: none;
	position: relative;
	padding: 0;
}


/* - (&ndash;) */
.mdl-container ul:not([class^="cmsmodule-nav"]):not([class^="slick-dots"]):not([class^="doc-list"]):not([class^="blog-list"]):not([class^="blog-filter-list"]):not([class^="news-list"]) li {
	margin-left: 15px;
	padding-left: 0;
}
.mdl-container ul:not([class^="cmsmodule-nav"]):not([class^="slick-dots"]):not([class^="doc-list"]):not([class^="blog-list"]):not([class^="blog-filter-list"]):not([class^="news-list"]) li:before {
	content: "\2013";
	position: absolute;
	margin-left: -15px;
}
@media screen and (min-width: 768px) {
	.mdl-container ul:not([class^="cmsmodule-nav"]):not([class^="slick-dots"]):not([class^="doc-list"]):not([class^="blog-list"]):not([class^="blog-filter-list"]):not([class^="news-list"]) li {
		margin-left: 0;
	}
}
@media screen and (min-width: 1200px) {
	.mdl-container ul:not([class^="cmsmodule-nav"]):not([class^="slick-dots"]):not([class^="doc-list"]):not([class^="blog-list"]):not([class^="blog-filter-list"]):not([class^="news-list"]) li:before {
		margin-left: -18px;
	}
}


/* ############################################################
	NAVIGATION
############################################################ */

/* Allgemeines */
ul.nav-mainmenu, ul.nav-mainmenu ul, ul.nav-mainmenu li,
ul.nav-secondmenu, ul.nav-secondmenu ul, ul.nav-secondmenu li,
ul.nav-thirdmenu, ul.nav-thirdmenu ul, ul.nav-thirdmenu li,
ul.nav-submenu, ul.nav-submenu ul, ul.nav-submenu li,
ul.nav-metamenu, ul.nav-metamenu ul, ul.nav-metamenu li {
	list-style: none;
	margin: 0;
	padding: 0;
}
ul.nav-submenu, footer ul.nav-thirdmenu {
	display: flex;
	flex-direction: column;
}
/*ul.nav-mainmenu li, */ul.nav-secondmenu li, ul.nav-thirdmenu li, ul.nav-submenu li, ul.nav-metamenu li {
	position: relative;
}


/*
1st-Menu
*/
nav.menu-box ul.nav-mainmenu {
	position: relative;
	display: flex;
	flex-direction: column;
	width: 100%;
	font-weight: 700;
	font-size: 1.75rem; /* 28px */
	line-height: 1.5;
	letter-spacing: 0.7px;
}
nav.menu-box ul.nav-mainmenu, nav.menu-box ul.nav-mainmenu ul {
	padding-left: 20px;
	padding-right: 20px;
}
nav.menu-box ul.nav-mainmenu ul {
	display: none;
	position: absolute;
	top: 0;
	left: 100%;
	width: 100%;
}
nav.menu-box ul.nav-mainmenu ul.slide-destroy {
	display: none !important;
}
	nav.menu-box ul.nav-mainmenu li {
		padding-top: 5px;
		padding-bottom: 5px;
		border-bottom: 1.5px var(--main-color-1) solid;
	}
	nav.menu-box ul.nav-lvl3 {
		font-weight: 400;
	}

/* Hyperlink-Status: Allgemein */
nav.menu-box ul.nav-mainmenu a {
	display: block;
}

/* Submenu vorhanden */
nav.menu-box ul.nav-mainmenu li.has-submenu > a {
	padding-right: 20px;
}
nav.menu-box ul.nav-mainmenu li.has-submenu > a::after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 11px;
	height: 100%;
	background-image: url("../Images/Elemente/Nav_HasSubmenu_Blau.svg");
	background-repeat: no-repeat;
	background-position: right center;
	background-size: 11px 17px;
}
/*nav.menu-box ul.nav-mainmenu li.has-submenu.active > a::after {
	background-image: url("../Images/Elemente/Nav_HasSubmenu_Rot.svg");
}*/

/* Hyperlink-Status: Level 1-3 */
nav.menu-box ul.nav-mainmenu li > a, nav.menu-box ul.nav-mainmenu li > a:hover, nav.menu-box ul.nav-mainmenu li > a:focus {
	color: var(--main-color-1);
}
nav.menu-box ul.nav-mainmenu li.active > a, nav.menu-box ul.nav-mainmenu li.active > a:hover, nav.menu-box ul.nav-mainmenu li.active > a:focus, nav.menu-box ul.nav-mainmenu li > a.is-active {
	color: var(--main-color-7);
}
nav.menu-box ul.nav-mainmenu li.active > a.is-disabled {
	color: var(--main-color-1);
}

/* Hyperlink: Zurück */
nav.menu-box a.nav-back-link {
	cursor: pointer;
	padding-left: 20px;
	font-weight: 700;
	color: var(--main-color-7) !important;
}
nav.menu-box a.nav-back-link::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 20px;
	height: 100%;
	background-image: url("../Images/Elemente/Nav_Back.svg");
	background-repeat: no-repeat;
	background-position: left center;
	background-size: 11px 17px;
}
@media screen and (min-width: 768px) {
	nav.menu-box ul.nav-mainmenu, nav.menu-box ul.nav-mainmenu ul {
		padding-left: 50px;
		padding-right: 50px;
	}
}
@media screen and (min-width: 992px) {
	nav.menu-box ul.nav-mainmenu li > a:hover {
		color: var(--main-color-7);
	}
	nav.menu-box ul.nav-mainmenu li.has-submenu > a::after {
		transition: background 300ms var(--cubic-bezier);
	}
	nav.menu-box ul.nav-mainmenu li.has-submenu > a:hover::after {
		background-image: url("../Images/Elemente/Nav_HasSubmenu_Rot.svg");
	}
}
@media screen and (min-width: 1200px) {
	/* Zurücksetzen */
	nav.menu-box ul.nav-mainmenu, nav.menu-box ul.nav-mainmenu ul, nav.menu-box ul.nav-mainmenu li {
		padding: 0;
		border-bottom: none;
	}
	nav.menu-box ul.nav-mainmenu a {
		display: inline-block;
	}
	nav.menu-box ul.nav-mainmenu a, nav.menu-box ul.nav-mainmenu li.has-submenu > a {
		padding: 0;
	}
	nav.menu-box ul.nav-mainmenu li.has-submenu > a::after {
		content: none;
	}
	nav.menu-box ul.nav-mainmenu ul {
		position: relative;
		top: auto;
		left: auto;
	}
	/* Aufbau */
	nav.menu-box ul.nav-mainmenu {
		flex-direction: row;
		justify-content: flex-end;
		font-size: 1.5625rem; /* 25px */
		letter-spacing: 0.625px; 
	}
	nav.menu-box ul.nav-mainmenu .nav-megamenu ul {
		display: block;
	}
		nav.menu-box ul.nav-mainmenu > li > a {
			z-index: 5;
		}
		body[class^="cms-"] nav.menu-box ul.nav-mainmenu > li > a {
			z-index: 205;
		}
		nav.menu-box ul.nav-mainmenu > li:not(:first-child) {
			margin-left: 30px;
		}
	/* Level 2 */
	nav.menu-box ul.nav-lvl2 {
		display: inline-flex !important;
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: flex-start;
		align-items: flex-start;
		width: 100%;
		font-size: 1.125rem; /* 18px */
		letter-spacing: 0.36px;
	}
		nav.menu-box ul.nav-lvl2 > li {
			position: relative;
			display: inline-block;
			width: calc(1/3*100% - (1 - 1/3)*var(--gap));
			margin-top: 50px;
			margin-right: var(--gap);
		}
		nav.menu-box ul.nav-lvl2 > li:not(.visible-xs):nth-child(3n+1),
		nav.menu-box ul.nav-lvl2 > li:not(.visible-xs):last-child {
			margin-right: 0;
		}
		nav.menu-box ul.nav-lvl2 > li:not(.visible-xs):nth-child(n+2):nth-child(-n+4) {
			margin-top: 0;
		}
			nav.menu-box ul.nav-lvl2 > li > a {
				display: block;
				padding-bottom: 4px !important;
				border-bottom: 1.5px solid var(--main-color-1);
			}
	/* Level 3 */
	nav.menu-box ul.nav-lvl3 {
		position: relative;
		display: block;
		padding-top: 8px !important;
		font-weight: 400;
		font-size: 1.4375rem; /* 23px */
		letter-spacing: 0.46px;
	}
		nav.menu-box ul.nav-lvl3 > li {
			margin-top: 6px;
		}
	
}
@media screen and (min-width: 1600px) {
	nav.menu-box ul.nav-mainmenu > li:not(:first-child) {
		margin-left: 40px;
	}
}


/*
2nd-Menu
*/
ul.nav-secondmenu {
	display: inline-flex;
	justify-content: flex-start;
	font-family: "Gilroy";
	font-style: normal;
	font-weight: 400;
	font-size: 0.9375rem; /* 15px */
	line-height: 1.0;
	letter-spacing: 0.375px;
}
footer ul.nav-secondmenu {
	justify-content: flex-end;
}
	ul.nav-secondmenu > li:not(:first-child) {
		margin-left: 20px;
	}
		ul.nav-secondmenu a, ul.nav-secondmenu a:hover, ul.nav-secondmenu a:focus {
			color: var(--main-color-1);
		}
@media screen and (min-width: 992px) {
	footer ul.nav-secondmenu {
		justify-content: flex-start;
	}
		ul.nav-secondmenu a:hover, ul.nav-secondmenu a:focus {
			color: var(--main-color-7);
		}
}


/*
Meta-Menu
*/
ul.nav-metamenu {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	width: 100%;
	height: 66px;
	font-size: 0;
	line-height: 0;
	letter-spacing: normal;
}
	ul.nav-metamenu > li:not(:first-child) {
		margin-left: 12px;
	}
	ul.nav-metamenu > li:last-child {
		margin-left: auto;
	}
@media screen and (min-width: 1200px) {
	ul.nav-metamenu {
		justify-content: flex-end;
		height: auto;
	}
		ul.nav-metamenu > li:not(:first-child) {
			margin-left: 12px;
		}
		ul.nav-metamenu > li:last-child {
			margin-left: 24px;
		}
}


/*
Socialmedia-Menu
*/
ul.nav-socialmedia {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	font-size: 0;
	line-height: 0;
	letter-spacing: normal;
}
nav.menu-box ul.nav-socialmedia {
	display: none;
}
	ul.nav-socialmedia > li:not(:first-child) {
		margin-left: 7px;
	}
@media screen and (min-width: 768px) {
	ul.nav-socialmedia > li:not(:first-child) {
		margin-left: 12px;
	}
}
@media screen and (min-width: 1200px) {
	nav.menu-box ul.nav-socialmedia {
		display: flex;
		width: 150px;
		height: 106px
	}
}

