

/* ############################################################
	FARBKLIMA
###############################################################
	
	1 Antrazit			#141414 - rgba(20,20,20,1)		Laufschrift, Button, Linie
	2 Cremebeige		#e7e1d0 - rgba(231,225,208,1)	Hintergrund, Fläche, Linie, Schrift
	3 Signalorange		#ff5638 - rgba(255,86,56,1)		Button, Fläche
	  Weiss				#ffffff - rgba(255,255,255,1)
	  Schwarz			#000000 - rgba(0,0,0,1)
	  Hellgrau			#f3f3f3 - rgba(243,243,243,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;
}
.reset-font {
	font-size: 0;
	line-height: 0;
	letter-spacing: normal;
}


/* Variablen definieren */
:root {
	--main-color-1: #141414;
	--main-color-2: #e7e1d0;
	--main-color-3: #ff5638;
	--main-color-white: #ffffff;
	--main-color-black: #000000;
	--main-color-error: #eb4462;
	--main-color-successful: #4fa158;
	--ph-color: var(--main-color-1);
	--cubic-bezier: cubic-bezier(0.41,0,0.51,1) 0s;
}


/* Allgemeines */
a, a:focus {
	outline: none;
}
a:focus-visible, button:focus-visible {
	outline: 4px solid var(--main-color-3);
    outline-offset: 2px;
}
/*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-2);
	font-family: "Switzer";
	font-style: normal;
	font-weight: 400;
	color: var(--main-color-1);
}
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);
}
.color-2 {
	color: var(--main-color-2);
}
.color-3 {
	color: var(--main-color-3);
}
.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);
}
.bg-color-3 {
	background-color: var(--main-color-3);
}


/* ############################################################
	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 {
	display: inline-flex;
	position: absolute;
	top: -9999px;
	justify-content: space-between;
	align-items: center;
	border: none;
	border-radius: 15px;
	padding: 8px 16px;
	background-color: var(--main-color-1);
	font-size: 0.875rem; /* 14px */
	line-height: 1.0;
	letter-spacing: 0.14px;
	color: var(--main-color-2);
}
.skiplinks a:active, .skiplinks a:focus {
	left: 20px;
	right: auto;
	top: 20px;
}
@media (min-width: 1024px) {
	.skiplinks a {
		padding: 10px 20px 11px;
		border-radius: 20px;
		font-size: 1rem; /* 16px */
		letter-spacing: 0.16px;
		transition: border-radius 300ms var(--cubic-bezier);
	}
	.skiplinks a:hover {
		border-radius: 0;
	}
}


/* ############################################################
	SCHRIFTEN / TEXTE / ABSÄTZE / TITEL
############################################################ */

/* Allgemeines */
main {
	font-size: 0.875rem; /* 14px */
	line-height: 1.25;
	letter-spacing: 0.14px;
}
nav.mobile-nav, footer {
	font-size: 0.75rem; /* 12px */
	line-height: 1.25;
	letter-spacing: 0.12px;
	color: var(--main-color-2);
}
@media (min-width: 1024px) {
	nav.mobile-nav, main, footer {
		font-size: 1rem; /* 16px */
		letter-spacing: 0.16px;
	}
}


/* Schnitte */
.font-regular {
	font-weight: 400 !important;
}
i, em, .italic {
	font-family: "Switzer";
	font-style: italic;
	font-weight: 400;
}
b, strong, .semibold {
	font-family: "Switzer";
	font-style: normal;
	font-weight: 600;
}


/* Titel, Schriftgrössen */
h1, h2, h3, h4, .h2-modultitel, .h2-modultitel-big {
	position: relative;
	margin: 0;
	padding: 0;
	font-family: "Switzer";
	font-style: normal;
	font-weight: 600;
	letter-spacing: normal;
	color: inherit;
}
h2.modultitel, .h2-modultitel {
	margin-bottom: 7px;
	font-weight: 400;
	font-size: 0.75rem; /* 12px */
	line-height: 1.25;
	letter-spacing: 0.24px;
	text-transform: uppercase;
}
h2.modultitel-big, h3.h2-modultitel-big {
	margin-bottom: 7px;
	font-weight: 600;
	font-size: 2.25rem; /* 36px */
	line-height: 1.05;
	letter-spacing: -0.36px;
	text-transform: none;
}
h3 {
	margin-bottom: 10px;
	font-size: 1.25rem; /* 20px */
	line-height: 1.2;
	letter-spacing: -0.2px;
}
h4 {
	font-size: 0.875rem; /* 14px */
	line-height: 1.25;
	letter-spacing: 0.14px;
}
.lead {
	margin-bottom: 14px;
	font-weight: 600;
	font-size: 1.25rem; /* 20px */
	line-height: 1.2;
	letter-spacing: -0.2px;
}
.footer-titel {
	color: var(--main-color-3);
}
@media (max-width: 1023.98px) {
	footer .font-small {
		font-size: 0.625rem; /* 10px */
		letter-spacing: 0.1px;
	}
}
@media (min-width: 1024px) {
	h2.modultitel, .h2-modultitel {
		margin-bottom: 11px;
		font-size: 0.875rem; /* 14px */
		letter-spacing: 0.28px;
	}
	h2.modultitel-big, h3.h2-modultitel-big {
		margin-bottom: 11px;
		font-size: 3rem; /* 48px */
		letter-spacing: -0.48px;
	}
	h3 {
		margin-bottom: 12px;
		font-size: 1.625rem; /* 26px */
		letter-spacing: -0.26px;
	}
	h4 {
		font-size: 1rem; /* 16px */
		letter-spacing: 0.16px;
	}
	.lead {
		margin-bottom: 16px;
		font-size: 1.625rem; /* 26px */
		letter-spacing: -0.26px;
	}
}


/* Absätze */
main p + h2 {
	margin-top: 40px;
}
main p + h3, main ul + h3,
main p + .lead, main ul + .lead {
	margin-top: 21px;
}
main p + ul, main ul + p {
	margin-top: 14px;
}
main p {
	margin-bottom: 14px;
}
.footer-titel + p {
	margin-top: 10px;
}
.footer-titel + nav {
	margin-top: 14px;
}
/* Absätze mit Hyperlink */
main p:has(> .link-btn:only-child) {
	margin-bottom: 10px;
}
main :not(p:has(> .link-btn:only-child)) + p:has(> .link-btn:only-child):not(:first-child) {
	margin-top: 24px;
}
/* Absätze mit Bilder */
main p:has(> img:only-child) > img {
	display: block; /* keine unerwarteten kleinen Abstände */
}
main p:has(> img:only-child) {
	margin-top: 0;
	margin-bottom: 0;
}
main * + p:has(> img:only-child) {
	margin-top: 28px;
}
main p:has(> img:only-child):has(+ *) {
	margin-bottom: 28px;
}
@media (min-width: 1024px) {
	main p + h2 {
		margin-top: 60px;
	}
	main p + h3, main ul + h3,
	main p + .lead, main ul + .lead {
		margin-top: 26px;
	}
	main p + ul, main ul + p {
		margin-top: 16px;
	}
	main p {
		margin-bottom: 16px;
	}
	main :not(p:has(> .link-btn:only-child)) + p:has(> .link-btn:only-child):not(:first-child) {
		margin-top: 30px;
	}
	main * + p:has(> img:only-child) {
		margin-top: 46px;
	}
	main p:has(> img:only-child):has(+ *) {
		margin-bottom: 46px;
	}
}


/* 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,
h2, h3, h4, .lead {
	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 {
	color: var(--main-color-1);
}
a {
	text-decoration-line: underline;
	text-decoration-color: var(--main-color-1);
	text-decoration-thickness: 1px;
	text-underline-offset: 0.125em; /* 2px zur Schriftgrösse */
}
nav a, nav a:hover,
footer a, footer a:hover {
	color: var(--main-color-2);
	text-decoration: none;
}
@media (min-width: 1024px) {
	a {
		transition: text-decoration-color 300ms var(--cubic-bezier);
	}
	a:hover {
		text-decoration-color: var(--main-color-3);
	}
	nav a, footer a {
		transition: color 300ms var(--cubic-bezier);
	}
	nav a:hover,
	footer a:hover {
		color: var(--main-color-3);
	}
}


/* Button: Intern, Extern, Download */
.link-btn {
	display: inline-flex;
	justify-content: space-between;
	align-items: center;
	border: none;
	border-radius: 15px;
	padding: 8px 16px;
	background-color: var(--main-color-1);
	font-size: 0.875rem; /* 14px */
	line-height: 1.0;
	letter-spacing: 0.14px;
	color: var(--main-color-2);
	text-decoration: none;
}
.link-btn:hover {
	color: var(--main-color-2);
}
.link-btn.signalorange {
	background-color: var(--main-color-3);
	color: var(--main-color-1);
}
.link-btn.signalorange:hover {
	color: var(--main-color-1);
}
.link-btn.big {
	border-radius: 22px;
/*	padding: 12px 20px;*/
	padding: 12px 18px;
	font-weight: 600;
	font-size: 1.25rem; /* 20px */
	letter-spacing: -0.2px;
}
main .link-btn.big {
	width: 100%;
}
.link-btn.big.intern, .link-btn.big.download {
/*	padding-right: 21px;*/
	padding-right: 18px;
}
.link-btn.extern {
	padding-top: 10px;
	padding-bottom: 10px;
}
.link-btn.download::after, .link-btn.intern::after, .link-btn.extern::after,
.link-btn.big.intern::after, .link-btn.big.download::after {
	content: "";
	display: inline-block;
	width: 13px;
	height: 13px;
	margin-left: 10px;
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: 100% 100%;
}
.link-btn.extern::after {
	width: 9px;
	height: 9px;
}
.link-btn.big.intern::after, .link-btn.big.download::after {
	width: 21px;
	height: 21px;
/*	margin-left: 20px;*/
	margin-left: 10px;
}
.link-btn.download::after {
	background-image: url("../Images/Elemente/Arrow_Down_13x13_Creme.svg");
}
	.link-btn.signalorange.download::after {
		background-image: url("../Images/Elemente/Arrow_Down_13x13_Black.svg");
	}
.link-btn.intern::after {
	background-image: url("../Images/Elemente/Arrow_Right_13x13_Creme.svg");
}
	.link-btn.signalorange.intern::after {
		background-image: url("../Images/Elemente/Arrow_Right_13x13_Black.svg");
	}
.link-btn.extern::after {
	background-image: url("../Images/Elemente/Arrow_RightUp_9x9_Creme.svg");
}
	.link-btn.signalorange.extern::after {
		background-image: url("../Images/Elemente/Arrow_RightUp_9x9_Black.svg");
	}
.link-btn.big.intern::after {
	background-image: url("../Images/Elemente/Arrow_Right_21x21_Creme.svg");
}
	.link-btn.big.signalorange.intern::after {
		background-image: url("../Images/Elemente/Arrow_Right_21x21_Black.svg");
	}
.link-btn.big.download::after {
	background-image: url("../Images/Elemente/Arrow_Down_21x21_Creme.svg");
}
	.link-btn.big.signalorange.download::after {
		background-image: url("../Images/Elemente/Arrow_Down_21x21_Black.svg");
	}
@media (min-width: 1024px) {
	.link-btn {
		padding: 10px 20px;
		border-radius: 20px;
		font-size: 1rem; /* 16px */
		letter-spacing: 0.16px;
		transition: border-radius 300ms var(--cubic-bezier);
	}
	.link-btn:hover {
		border-radius: 0;
	}
	.link-btn.extern {
		padding-top: 12px;
		padding-bottom: 12px;
	}
	.link-btn.big {
		border-radius: 53px;
		padding: 26px 60px 32px;
		font-size: 3rem; /* 48px */
		letter-spacing: -0.48px;
		transition: border-radius 300ms var(--cubic-bezier);
	}
	.link-btn.big:hover {
		border-radius: 0;
	}
	.link-btn.big.intern, .link-btn.big.download {
		padding-right: 43px;
	}
	.link-btn.download::after, .link-btn.intern::after, .link-btn.extern::after {
		width: 19px;
		height: 19px;
		margin-left: 12px;
	}
	.link-btn.extern::after {
		width: 13px;
		height: 13px;
	}
	.link-btn.big.intern::after, .link-btn.big.download::after {
		width: 43px;
		height: 43px;
		margin-left: 26px;
	}
	.link-btn.download::after {
		background-image: url("../Images/Elemente/Arrow_Down_19x19_Creme.svg");
	}
		.link-btn.signalorange.download::after {
			background-image: url("../Images/Elemente/Arrow_Down_19x19_Black.svg");
		}
	.link-btn.intern::after {
		background-image: url("../Images/Elemente/Arrow_Right_19x19_Creme.svg");
	}
		.link-btn.signalorange.intern::after {
			background-image: url("../Images/Elemente/Arrow_Right_19x19_Black.svg");
		}
	.link-btn.extern::after {
		background-image: url("../Images/Elemente/Arrow_RightUp_13x13_Creme.svg");
	}
		.link-btn.signalorange.extern::after {
			background-image: url("../Images/Elemente/Arrow_RightUp_13x13_Black.svg");
		}
	.link-btn.big.intern::after {
		background-image: url("../Images/Elemente/Arrow_Right_43x43_Creme.svg");
	}
		.link-btn.big.signalorange.intern::after {
			background-image: url("../Images/Elemente/Arrow_Right_43x43_Black.svg");
		}
	.link-btn.big.download::after {
		background-image: url("../Images/Elemente/Arrow_Down_43x43_Creme.svg");
	}
		.link-btn.big.signalorange.download::after {
			background-image: url("../Images/Elemente/Arrow_Down_43x43_Black.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 (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 {
	position: relative;
	visibility: hidden;
	display: block;
	width: 0;
	height: 0;
	font-size: 0;
	line-height: 0;
	scroll-margin-top: 71px;
}
@media (min-width: 1024px) {
	a.nav-anchor {
		scroll-margin-top: 100px;
	}
}


/* ############################################################
	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: 30px;
	padding-left: 30px;
}
.header-inline, .nav-inline, .content-inline, .footer-inline {
	max-width: 1344px;
	margin: 0 auto;
}

/* Kopfzeile */
header {
	z-index: 10;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 71px;
}
body[class^="cms-"] header {
	z-index: 210;
	top: 51px;
}
	.header-inline {
		height: 71px;
	}

/* Navigation */
nav.mobile-nav {
	--nav-abstand: 28px;
	--nav-abstand-large: 35px;
	z-index: 15;
	position: fixed;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	inset: 0;
	width: 100%;
	height: calc(var(--nav-height, 1vh) * 100);
	background-color: var(--main-color-1);
	overflow-x: hidden;
	overflow-y: auto;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity 300ms var(--cubic-bezier), visibility 0ms linear 300ms;
}
nav.mobile-nav.is-visible {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transition: opacity 300ms var(--cubic-bezier), visibility 0ms linear 0ms;
}
body[class^="cms-"] nav.mobile-nav {
	z-index: 215;
	top: 51px;
	height: calc((var(--nav-height, 1vh) * 100) - 51px);
}
	nav.mobile-nav .nav-box.line-2 {
		margin-top: var(--nav-abstand);
		margin-bottom: var(--nav-abstand);
	}
	nav.mobile-nav .nav-box.line-3 {
		margin-top: auto;
		margin-bottom: var(--nav-abstand);
	}
	nav.mobile-nav .nav-box.line-1 {
		margin-top: var(--nav-abstand-large);
	}

/* Inhalt */
main {
	flex: 1 0 auto;
}

/* Fusszeile */
footer {
	--footer-abstand: 30px;
	flex-shrink: 0;
	background: var(--main-color-1);
	padding-top: 26px;
	padding-bottom: 20px;
}
	footer .footer-box.line-2, footer .footer-box.line-3, footer .footer-box.line-4 {
		margin-top: var(--footer-abstand);
	}
@media (min-width: 768px) {
	/* Navigation */
	nav.mobile-nav .nav-box.line-1 .grid > div:last-child {
		display: inline-flex;
		flex-direction: column;
	}
	nav.mobile-nav .nav-box.line-1 .link-btn {
		margin-top: auto;
		align-self: flex-start;
	}

	/* Fusszeile */
	footer {
		padding-bottom: 29px;
	}
}
@media (min-width: 1024px) {
	/* Allgemein */
	.header-box, .nav-box, .content-box, .footer-box {
		padding-left: 48px;
		padding-right: 48px;
	}

	/* Kopfzeile */
	header, .header-inline {
		height: 100px;
	}

	/* Navigation */
	nav.mobile-nav {
		--nav-abstand: 50px;
		--nav-abstand-large: var(--nav-abstand);
	}

	/* Fusszeile */
	footer {
		--footer-abstand: 40px;
		padding-bottom: 44px;
	}
}


/* ############################################################
	LINIEN-RASTER
############################################################ */

/* Navigation & Fusszeile */
/* obere horizontale Linie */
nav.mobile-nav .grid.line-top::before, nav.mobile-nav .grid.line-all::before,
footer .grid.line-top::before, footer .grid.line-all::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 0;
	border-top: 1px solid var(--main-color-2);
}
nav.mobile-nav .line-1 .grid.line-top::before {
	right: 43px;
}
	nav.mobile-nav .grid.inner-abstand > *,
	footer .grid.inner-abstand > * {
		padding-top: 12px;
	}
@media (max-width: 1023.98px) {
	/* Abstand nach oben bei zusätzlicher Zeile */
	nav.mobile-nav .grid.line-all > :nth-child(n + 3) {
		margin-top: var(--nav-abstand);
	}
	footer .grid.line-all > :nth-child(n + 3) {
		margin-top: var(--footer-abstand);
	}
	/* horizontale Linie */
	nav.mobile-nav .grid.line-all > :nth-child(n + 3)::after,
	footer .grid.line-all > :nth-child(n + 3)::after {
		content: "";
		position: absolute;
		top: 0;
		height: 0;
		border-top: 1px solid var(--main-color-2);
	}
	nav.mobile-nav .grid.line-all > :nth-child(n + 3):nth-child(odd)::after,
	footer .grid.line-all > :nth-child(n + 3):nth-child(odd)::after {
		left: 0;
		width: calc(100% + var(--gap-half));
	}
	nav.mobile-nav .grid.line-all > :nth-child(n + 4):nth-child(even)::after,
	footer .grid.line-all > :nth-child(n + 4):nth-child(even)::after {
		left: calc(var(--gap-half) * -1);
		width: calc(100% + var(--gap-half));
	}
	/* vertikale Linie */
	nav.mobile-nav .grid.line-all > :nth-child(2n)::before,
	footer .grid.line-all > :nth-child(2n)::before {
		content: "";
		position: absolute;
		top: 0;
		bottom: 0;
		left: calc(var(--gap-half) * -1);
		width: 0;
		border-left: 1px solid var(--main-color-2);
	}
}
@media (min-width: 1024px) {
	/* obere horizontale Linie */
	nav.mobile-nav .line-1 .grid.line-top::before {
		right: 70px;
	}
	/* Abstand nach oben bei zusätzlicher Zeile */
	nav.mobile-nav .grid.line-all > :nth-child(n + 5) {
		margin-top: var(--nav-abstand);
	}
	footer .grid.line-all > :nth-child(n + 5) {
		margin-top: var(--footer-abstand);
	}
	/* horizontale Linie */
	nav.mobile-nav .grid.line-all > :nth-child(n + 5)::after,
	footer .grid.line-all > :nth-child(n + 5)::after {
		content: "";
		position: absolute;
		top: 0;
		height: 0;
		border-top: 1px solid var(--main-color-2);
	}
	nav.mobile-nav .grid.line-all > :nth-child(n + 5):nth-child(4n + 1)::after,
	footer .grid.line-all > :nth-child(n + 5):nth-child(4n + 1)::after {
		left: 0;
		right: calc(var(--gap-half) * -1);
	}
	nav.mobile-nav .grid.line-all > :nth-child(n + 5):nth-child(4n + 2)::after, nav.mobile-nav .grid.line-all > :nth-child(n + 5):nth-child(4n + 3)::after,
	footer .grid.line-all > :nth-child(n + 5):nth-child(4n + 2)::after, footer .grid.line-all > :nth-child(n + 5):nth-child(4n + 3)::after {
		left: calc(var(--gap-half) * -1);
		right: calc(var(--gap-half) * -1);
	}
	nav.mobile-nav .grid.line-all > :nth-child(n + 5):nth-child(4n)::after,
	footer .grid.line-all > :nth-child(n + 5):nth-child(4n)::after {
		left: calc(var(--gap-half) * -1);
		right: 0;
	}
	/* vertikale Linie */
	nav.mobile-nav .grid.line-all > :not(:nth-child(4n + 1))::before,
	footer .grid.line-all > :not(:nth-child(4n + 1))::before {
		content: "";
		position: absolute;
		top: 0;
		bottom: 0;
		left: calc(var(--gap-half) * -1);
		width: 0;
		border-left: 1px solid var(--main-color-2);
	}
}


/* ############################################################
	BILDER/ICONS
############################################################ */

/* Logo */
a.link-logo, a.link-wortmarke {
	display: inline-block;
	height: auto;
}
header a.link-logo {
	z-index: 2;
}
header a.link-wortmarke {
	position: absolute;
	top: 23px;
	left: 0;
	width: 198px;
}
footer a.link-logo {
	width: 123px;
}
	a.link-logo img, a.link-wortmarke img {
		display: inline-block;
	}
@media (min-width: 1024px) {
	header a.link-logo {
		top: 30px;
		left: -8px;
		width: 160px;
	}
	header a.link-wortmarke {
		top: 38px;
		width: 387px;
	}
	footer a.link-logo {
		width: 130px;
	}
}


/* Socialmedia */
a.link-socialmedia {
	position: relative;
	display: inline-block;
	width: 24px;
	height: 24px;
}
	a.link-socialmedia svg {
		fill: var(--main-color-2);
	}
@media (min-width: 1024px) {
	a.link-socialmedia {
		width: 30px;
		height: 30px;
	}
	a.link-socialmedia svg {
		transition: fill 300ms var(--cubic-bezier);
	}
	a.link-socialmedia:hover svg {
		fill: var(--main-color-3);
	}
}


/* Hamburger */
.nav-open-btn, .nav-close-btn {
	display: flex;
	justify-content: center;
	align-items: center;
	border: none;
	border-radius: 15px;
	cursor: pointer;
	font-size: 0;
	line-height: 0;
	letter-spacing: normal;
}
.nav-open-btn {
	position: fixed;
	top: 20px;
	right: max(30px, calc((100% - 1344px) / 2));
	/* right: 30px; */
	width: 68px;
	height: 30px;
	background-color: var(--main-color-1);
	font-size: 0.875rem; /* 14px */
	line-height: 1.0;
	letter-spacing: 0.14px;
	color: var(--main-color-2);
}
body[class^="cms-"] .nav-open-btn {
	top: 71px;
}
.nav-close-btn {
	z-index: 2;
	position: absolute;
	top: -15px;
	right: 0;
	width: 30px;
	height: 30px;
	border-radius: 15px;
	background-color: var(--main-color-3);
	background-image: url("../Images/Elemente/Nav_Close_30x30.svg");
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: 100% 100%;
}
@media (min-width: 1024px) {
	.nav-open-btn, .nav-close-btn {
		border-radius: 20px;
		transition: border-radius 300ms var(--cubic-bezier);
	}
	.nav-open-btn:hover, .nav-close-btn:hover {
		border-radius: 0;
	}
	.nav-open-btn {
		top: 30px;
		right: max(48px, calc((100% - 1344px) / 2));
		/* right: 48px; */
		width: 82px;
		height: 40px;
		font-size: 1rem; /* 16px */
		letter-spacing: 0.16px;
	}
	body[class^="cms-"] .nav-open-btn {
		top: 81px;
	}
	.nav-close-btn {
		top: -20px;
		width: 40px;
		height: 40px;
		background-image: url("../Images/Elemente/Nav_Close_40x40.svg");
	}
}


/* ############################################################
	MODULE/TEMPLATES
############################################################ */

/* Module */
/* Vertikaler Abstand */
.mdl-container.inner-abstand-top {
	padding-top: 60px;
}
.mdl-container.inner-abstand-top.small {
	padding-top: 30px;
}
@media (min-width: 1024px) {
	/* Vertikaler Abstand */
	.mdl-container.inner-abstand-top {
		padding-top: 100px;
	}
	.mdl-container.inner-abstand-top.small {
		padding-top: 50px;
	}
}


/* Templates */

/* Allgemeines */
[class^="template-"] {
	position: relative;
}
[class^="template-"] + [class^="template-"] {
	margin-top: 60px;
}
	[class^="template-"] div > p:last-of-type {
		margin-bottom: 0;
	}
[class^="template-"] .grid.line-top::before,
[class^="template-"] .grid.line-all::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 0;
	border-top: 1px solid var(--main-color-1);
}
[class^="template-"] .grid.inner-abstand > * {
	position: relative;
	padding-top: 12px;
}
[class^="template-"] .grid.inner-abstand > *:has(> p:first-child > img:only-child),
[class^="template-"] .grid.inner-abstand > *:has(> p:first-child > a:only-child > img:only-child) {
	padding-top: 15px;
}
@media (min-width: 1024px) {
	[class^="template-"] + [class^="template-"] {
		margin-top: 100px;
	}
	[class^="template-"] .grid.inner-abstand > *:has(> p:first-child > img:only-child),
	[class^="template-"] .grid.inner-abstand > *:has(> p:first-child > a:only-child > img:only-child) {
		padding-top: 18px;
	}
}

/* Template 1:
   - TextModul — 2 Spalten ohne Trennline
   - TextModul — 2 Spalten mit Trennline */
@media (max-width: 767.98px) {
	/* Abstand nach oben ab zweitem Element */
	.template-1 .grid.line-all > :nth-child(2),
	.template-1 .grid.line-inline > :nth-child(2) {
		margin-top: 30px;
	}
	/* horizontale Linie oberhalb jedes weiteren Elements */
	.template-1 .grid.line-all > :nth-child(2)::after,
	.template-1 .grid.line-inline > :nth-child(2)::after {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		height: 0;
		border-top: 1px solid var(--main-color-1);
	}
}
@media (min-width: 768px) {
	/* vertikale Linie zwischen Spalte 1 + 2 */
	.template-1 .grid.line-all > :nth-child(2)::before,
	.template-1 .grid.line-inline > :nth-child(2)::before {
		content: "";
		position: absolute;
		top: 0;
		bottom: 0;
		left: calc(var(--gap-half) * -1);
		width: 0;
		border-left: 1px solid var(--main-color-1);
	}
}

/* Template 2:
   - TextModul — 3 Spalten (50% / 25% / 25%) mit Trennline */
@media (max-width: 767.98px) {
	/* Abstand nach oben ab zweitem Element */
	.template-2 .grid.line-all > :nth-child(n + 2),
	.template-2 .grid.line-inline > :nth-child(n + 2) {
		margin-top: 30px;
	}
	/* horizontale Linie oberhalb jedes weiteren Elements */
	.template-2 .grid.line-all > :nth-child(n + 2)::after,
	.template-2 .grid.line-inline > :nth-child(n + 2)::after {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		height: 0;
		border-top: 1px solid var(--main-color-1);
	}
}
@media (min-width: 768px) and (max-width: 1023.98px) {
	/* zweite Zeile bekommt Abstand nach oben */
	.template-2 .grid.line-all > :nth-child(2),
	.template-2 .grid.line-all > :nth-child(3),
	.template-2 .grid.line-inline > :nth-child(2),
	.template-2 .grid.line-inline > :nth-child(3) {
		margin-top: 30px;
	}
	/* horizontale Linie zwischen Zeile 1 und Zeile 2 */
	.template-2 .grid.line-all > :nth-child(2)::after,
	.template-2 .grid.line-all > :nth-child(3)::after,
	.template-2 .grid.line-inline > :nth-child(2)::after,
	.template-2 .grid.line-inline > :nth-child(3)::after {
		content: "";
		position: absolute;
		top: 0;
		height: 0;
		border-top: 1px solid var(--main-color-1);
	}
	/* Linie über linker Zelle der zweiten Zeile */
	.template-2 .grid.line-all > :nth-child(2)::after,
	.template-2 .grid.line-inline > :nth-child(2)::after {
		left: 0;
		width: calc(100% + var(--gap-half));
	}
	/* Linie über rechter Zelle der zweiten Zeile */
	.template-2 .grid.line-all > :nth-child(3)::after,
	.template-2 .grid.line-inline > :nth-child(3)::after {
		left: calc(var(--gap-half) * -1);
		width: calc(100% + var(--gap-half));
	}
	/* vertikale Linie zwischen Zelle 2 und 3 */
	.template-2 .grid.line-all > :nth-child(3)::before,
	.template-2 .grid.line-inline > :nth-child(3)::before {
		content: "";
		position: absolute;
		top: 0;
		bottom: 0;
		left: calc(var(--gap-half) * -1);
		width: 0;
		border-left: 1px solid var(--main-color-1);
	}
}
@media (min-width: 1024px) {
	/* vertikale Linie zwischen Spalte 1 und 2 */
	.template-2 .grid.line-all > :nth-child(2)::before,
	.template-2 .grid.line-all > :nth-child(3)::before,
	.template-2 .grid.line-inline > :nth-child(2)::before,
	.template-2 .grid.line-inline > :nth-child(3)::before {
		content: "";
		position: absolute;
		top: 0;
		bottom: 0;
		left: calc(var(--gap-half) * -1);
		width: 0;
		border-left: 1px solid var(--main-color-1);
	}
}

/* Template 3:
   - TextModul — 3 Spalten (25% / 25% / 50%) mit Trennline */
@media (max-width: 767.98px) {
	/* Mobile: alle Zellen untereinander, horizontale Linie zwischen den Zellen */
	/* Abstand nach oben ab zweitem Element */
	.template-3 .grid.line-all > :nth-child(n + 2),
	.template-3 .grid.line-inline > :nth-child(n + 2) {
		margin-top: 30px;
	}
	/* horizontale Linie oberhalb jedes weiteren Elements */
	.template-3 .grid.line-all > :nth-child(n + 2)::after,
	.template-3 .grid.line-inline > :nth-child(n + 2)::after {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		height: 0;
		border-top: 1px solid var(--main-color-1);
	}
}
@media (min-width: 768px) and (max-width: 1023.98px) {
	/* Tablet: 1. + 2. Zelle je 50% darunter, 1. Zelle volle Breite */
	/* zweite Zeile bekommt Abstand nach oben */
	.template-3 .grid.line-all > :nth-child(3),
	.template-3 .grid.line-inline > :nth-child(3) {
		margin-top: 30px;
	}
	/* horizontale Linie oberhalb der 3. Zelle */
	.template-3 .grid.line-all > :nth-child(3)::after,
	.template-3 .grid.line-inline > :nth-child(3)::after {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 0;
		border-top: 1px solid var(--main-color-1);
	}
	/* vertikale Linie zwischen Zelle 1 und 2 */
	.template-3 .grid.line-all > :nth-child(2)::before,
	.template-3 .grid.line-inline > :nth-child(2)::before {
		content: "";
		position: absolute;
		top: 0;
		bottom: 0;
		left: calc(var(--gap-half) * -1);
		width: 0;
		border-left: 1px solid var(--main-color-1);
	}
}
@media (min-width: 1024px) {
	/* vertikale Linie zwischen Spalte 1 und 2 */
	.template-3 .grid.line-all > :nth-child(2)::before,
	.template-3 .grid.line-all > :nth-child(3)::before,
	.template-3 .grid.line-inline > :nth-child(2)::before,
	.template-3 .grid.line-inline > :nth-child(3)::before {
		content: "";
		position: absolute;
		top: 0;
		bottom: 0;
		left: calc(var(--gap-half) * -1);
		width: 0;
		border-left: 1px solid var(--main-color-1);
	}
}

/* Template 4:
   - TextModul — 3 Spalten 33% / 33% / 33% mit Trennline */
@media (max-width: 767.98px) {
	/* Abstand nach oben ab zweitem Element */
	.template-4 .grid.line-all > :nth-child(n + 2),
	.template-4 .grid.line-inline > :nth-child(n + 2) {
		margin-top: 30px;
	}
	/* horizontale Linie oberhalb jedes weiteren Elements */
	.template-4 .grid.line-all > :nth-child(n + 2)::after,
	.template-4 .grid.line-inline > :nth-child(n + 2)::after {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		height: 0;
		border-top: 1px solid var(--main-color-1);
	}
}
@media (min-width: 768px) {
	/* vertikale Linie zwischen Spalte 1 + 2 und 2 + 3 */
	.template-4 .grid.line-all > :nth-child(2)::before,
	.template-4 .grid.line-all > :nth-child(3)::before,
	.template-4 .grid.line-inline > :nth-child(2)::before,
	.template-4 .grid.line-inline > :nth-child(3)::before {
		content: "";
		position: absolute;
		top: 0;
		bottom: 0;
		left: calc(var(--gap-half) * -1);
		width: 0;
		border-left: 1px solid var(--main-color-1);
	}
}

/* Template 5:
   - TextModul — 4 Spalten 25% / 25% / 25% / 25% mit Trennline */
@media (max-width: 767.98px) {
	/* Abstand nach oben ab zweitem Element */
	.template-5 .grid.line-all > :nth-child(n + 2),
	.template-5 .grid.line-inline > :nth-child(n + 2) {
		margin-top: 30px;
	}
	/* horizontale Linie oberhalb jedes weiteren Elements */
	.template-5 .grid.line-all > :nth-child(n + 2)::after,
	.template-5 .grid.line-inline > :nth-child(n + 2)::after {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		height: 0;
		border-top: 1px solid var(--main-color-1);
	}
}
@media (min-width: 768px) and (max-width: 1023.98px) {
	/* zweite Zeile bekommt Abstand nach oben */
	.template-5 .grid.line-all > :nth-child(3),
	.template-5 .grid.line-all > :nth-child(4),
	.template-5 .grid.line-inline > :nth-child(3),
	.template-5 .grid.line-inline > :nth-child(4) {
		margin-top: 30px;
	}
	/* horizontale Linie zwischen Zeile 1 und 2 */
	.template-5 .grid.line-all > :nth-child(3)::after,
	.template-5 .grid.line-all > :nth-child(4)::after,
	.template-5 .grid.line-inline > :nth-child(3)::after,
	.template-5 .grid.line-inline > :nth-child(4)::after {
		content: "";
		position: absolute;
		top: 0;
		height: 0;
		border-top: 1px solid var(--main-color-1);
	}
	/* Linie über linker Zelle der zweiten Zeile */
	.template-5 .grid.line-all > :nth-child(3)::after,
	.template-5 .grid.line-inline > :nth-child(3)::after {
		left: 0;
		width: calc(100% + var(--gap-half));
	}
	/* Linie über rechter Zelle der zweiten Zeile */
	.template-5 .grid.line-all > :nth-child(4)::after,
	.template-5 .grid.line-inline > :nth-child(4)::after {
		left: calc(var(--gap-half) * -1);
		width: calc(100% + var(--gap-half));
	}
	/* vertikale Linie zwischen Zelle 1 + 2 und 3 + 4 */
	.template-5 .grid.line-all > :nth-child(2)::before,
	.template-5 .grid.line-all > :nth-child(4)::before,
	.template-5 .grid.line-inline > :nth-child(2)::before,
	.template-5 .grid.line-inline > :nth-child(4)::before {
		content: "";
		position: absolute;
		top: 0;
		bottom: 0;
		left: calc(var(--gap-half) * -1);
		width: 0;
		border-left: 1px solid var(--main-color-1);
	}
}
@media (min-width: 1024px) {
	/* vertikale Linie zwischen Spalte 1 + 2 und 2 + 3 */
	.template-5 .grid.line-all > :nth-child(2)::before,
	.template-5 .grid.line-all > :nth-child(3)::before,
	.template-5 .grid.line-all > :nth-child(4)::before,
	.template-5 .grid.line-inline > :nth-child(2)::before,
	.template-5 .grid.line-inline > :nth-child(3)::before,
	.template-5 .grid.line-inline > :nth-child(4)::before {
		content: "";
		position: absolute;
		top: 0;
		bottom: 0;
		left: calc(var(--gap-half) * -1);
		width: 0;
		border-left: 1px solid var(--main-color-1);
	}
}


/* ############################################################
	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: 20px;
	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: "\2014";
	position: absolute;
	margin-left: -20px;
}
.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:not(:first-of-type) {
	margin-top: 4px;
}
@media (min-width: 1024px) {
	.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: 22px;
	}
	.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: -22px;
	}
	.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:not(:first-of-type) {
		margin-top: 5px;
	}
}


/* ############################################################
	NAVIGATION
############################################################ */

/* Allgemeines */
ul.nav-mainmenu, ul.nav-mainmenu ul,
ul.nav-secondmenu, ul.nav-secondmenu ul,
ul.nav-thirdmenu, ul.nav-socialmedia {
	list-style: none;
	margin: 0;
	padding: 0;
}
ul.nav-mainmenu li, ul.nav-secondmenu li, ul.nav-thirdmenu li, ul.nav-submenu li, ul.nav-metamenu li, ul.nav-socialmedia li {
	position: relative;
}


/*
1st-Menu
*/
ul.nav-mainmenu {
	display: flex;
	flex-direction: column;
	font-weight: 600;
	font-size: 2.25rem; /* 36px */
	line-height: 1.08;
	letter-spacing: normal;
}
footer ul.nav-mainmenu {
	font-size: 1.25rem; /* 20px */
	line-height: 1.25;
}
	ul.nav-mainmenu a {
		display: inline-flex;
		align-items: center;
	}
	ul.nav-mainmenu a, ul.nav-mainmenu a:hover {
		color: var(--main-color-2);
	}
	ul.nav-mainmenu a::after {
		content: "";
		position: relative;
		width: 27px;
		height: 27px;
		margin-left: 11px;
		background-image: url("../Images/Elemente/Arrow_Right_27x27_Creme.svg");
		background-repeat: no-repeat;
		background-position: 0 0;
		background-size: 100% 100%;
	}
	footer ul.nav-mainmenu a::after {
		width: 16px;
		height: 16px;
		margin-left: 9px;
		background-image: url("../Images/Elemente/Arrow_Right_16x16_Creme.svg");
	}
@media (min-width: 1024px) {
	ul.nav-mainmenu {
		font-size: 3.75rem; /* 60px */
		line-height: 1.1;
	}
	footer ul.nav-mainmenu {
		font-size: 1.625rem; /* 26px */
	}
		ul.nav-mainmenu a {
			transition: color 300ms var(--cubic-bezier);
		}
		ul.nav-mainmenu a:hover {
			color: var(--main-color-3);
		}
		ul.nav-mainmenu a::after {
			width: 43px;
			height: 43px;
			margin-left: 18px;
			background-image: url("../Images/Elemente/Arrow_Right_43x43_Creme.svg");
			transition: background 300ms var(--cubic-bezier);
		}
		ul.nav-mainmenu a:hover::after {
			background-image: url("../Images/Elemente/Arrow_Right_43x43_Signalorange.svg");
		}
		footer ul.nav-mainmenu a::after {
			width: 19px;
			height: 19px;
			margin-left: 10px;
			background-image: url("../Images/Elemente/Arrow_Right_19x19_Creme.svg");
		}
		footer ul.nav-mainmenu a:hover::after {
			background-image: url("../Images/Elemente/Arrow_Right_19x19_Signalorange.svg");
		}
}


/*
2nd-Menu
*/
ul.nav-secondmenu {
	display: flex;
	flex-direction: column;
}
nav.mobile-nav ul.nav-secondmenu {
	font-weight: 600;
	font-size: 1.125rem; /* 18px */
	line-height: 1.25;
	letter-spacing: normal;
	color: var(--main-color-2);
}
	/* Level 1 */
	ul.nav-secondmenu > li {
		color: var(--main-color-3);
	}
		ul.nav-secondmenu > li a, ul.nav-secondmenu > li a:hover {
			color: var(--main-color-3);
		}
		/* Level 2 */
		ul.nav-secondmenu > li > ul {
			margin-top: 10px;
		}
		nav.mobile-nav ul.nav-secondmenu > li > ul {
			margin-top: 12px;
		}
			ul.nav-secondmenu > li > ul > li a, ul.nav-secondmenu > li > ul > li a:hover {
				color: var(--main-color-2);
			}
@media (min-width: 1024px) {
	/* Level 1 */
	nav.mobile-nav ul.nav-secondmenu > li {
		font-size: 1.75rem; /* 28px */
		letter-spacing: 0.28px;
	}
		/* Level 2 */
		nav.mobile-nav ul.nav-secondmenu > li > ul {
			font-size: 1.625rem; /* 26px */
			line-height: 1.34;
		}
	ul.nav-secondmenu > li a:hover, ul.nav-secondmenu > li > ul > li a:hover {
		color: var(--main-color-3);
	}
}


/*
3rd-Menu
*/
ul.nav-thirdmenu {
	display: flex;
	justify-content: left;
	flex-wrap: wrap;
}
	ul.nav-thirdmenu > li:not(:last-child) {
		margin-right: 6px;
	}
		ul.nav-thirdmenu a, ul.nav-thirdmenu a:hover {
			color: var(--main-color-2);
		}
@media (min-width: 1024px) {
	ul.nav-thirdmenu > li:not(:last-child) {
		margin-right: 10px;
	}
		ul.nav-thirdmenu a:hover {
			color: var(--main-color-3);
		}
}


/*
Socialmedia-Menu
*/
ul.nav-socialmedia {
	display: flex;
	justify-content: left;
	flex-wrap: wrap;
}
	ul.nav-socialmedia > li:not(:last-child) {
		margin-right: 12px;
	}

