

/* ############################################################
	FARBKLIMA
###############################################################
	
	1 Dunkelblau		#003061 - rgba(0,48,97,1)
	2 Blau				#0074af - rgba(0,116,175,1)
	3 Rot				#e30a0a - rgba(227,10,10,1)
	4 Hellblau			#e8ecf2 - rgba(232,236,242,1)
	  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;
}


/* Variablen definieren */
:root {
	--main-color-1: #003061;
	--main-color-2: #0074af;
	--main-color-3: #e30a0a;
	--main-color-4: #e8ecf2;
	--main-color-white: #ffffff;
	--main-color-black: #000000;
	--main-color-error: #eb4462;
	--main-color-successful: #4fa158;
	--gap: 14px;
	--cubic-bezier: cubic-bezier(0.41,0,0.51,1) 0s;
}
@media screen and (min-width: 768px) {
	:root {
		--gap: 40px;
	}
}


/* Allgemeines */
a, a:focus {
	outline: none;
}
/*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 {
	overflow-x: hidden;
	display: flex;
	flex-direction: column;
	background-color: var(--main-color-white);
	font-family: "Canaro-Book";
	font-style: normal;
	font-weight: normal;
	color: var(--main-color-1);
}
html.open, body.open {
	overflow: hidden;
}


/* Effekt: FadeIn / Lightning */
body:not(.cms-active) header, body:not(.cms-active) main, body:not(.cms-active) footer,
body:not(.cms-active) .fixed-pikett-box {
	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(232,236,242,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-1);
	border-top-color: var(--main-color-3);
	background-color: transparent;
	-webkit-animation: load-spinner 600ms linear infinite;
	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-2 {
	background-color: var(--main-color-2);
}
.bg-color-3 {
	background-color: var(--main-color-3);
}
.bg-color-4 {
	background-color: var(--main-color-4);
}


/* ############################################################
	SCHRIFTEN / TEXTE / ABSÄTZE / TITEL
############################################################ */

/* Allgemeines */
main {
	font-size: 1.1875rem; /* 19px */
	line-height: 1.333;
}
footer, nav .nav-mobile-kontakt-1 {
	font-size: 1.1875rem; /* 19px */
	line-height: 1.4;
}
nav .nav-mobile-secondmenu {
	font-size: 0.9375rem; /* 15px */
	line-height: 1.333;
}
footer {
	color: var(--main-color-white);
}
@media screen and (min-width: 1200px) {
	main {
		font-size: 1.3125rem; /* 21px */
	}
	footer, nav .nav-mobile-kontakt-1 {
		font-size: 1.25rem; /* 20px */
	}
	nav .nav-mobile-secondmenu {
		font-size: 1rem; /* 16px */
	}
}


/* Schnitte */
b, strong, .bold {
	font-family: "Canaro-Bold";
	font-weight: normal;
}


/* Titel, Schriftgrössen */
h1, h2, h3 {
	position: relative;
	margin: 0;
	padding: 0;
	font-family: "Canaro-Bold";
	font-style: inherit;
	font-weight: inherit;
	letter-spacing: normal;
	color: inherit;
}
h1 {
	font-family: "Canaro-Book";
	font-size: 2.4375rem; /* 39px */
	line-height: 1.176;
}
	h1 b, h1 strong {
		font-size: 2.625rem; /* 42px */
		color: var(--main-color-2);
	}
h2, h2.modultitel {
	margin-bottom: 26px;
	font-size: 2.1875rem; /* 35px */
	line-height: 1.145;
}
h3 {
	margin-bottom: 10px;
	font-size: 1.4375rem; /* 23px */
	line-height: 1.269;
	letter-spacing: 0.115px;
}
.hinweis-footer {
	font-size: 1.625rem; /* 26px */
	line-height: 1.25;
}
.einleitung {
	font-family: "Canaro-Bold";
	font-size: 1.4375rem; /* 23px */
	line-height: 1.269;
	letter-spacing: 0.115px;
}
.left__panel, .right__panel {
	font-size: 1.4375rem; /* 23px */
	line-height: 1.423;
}
@media screen and (min-width: 1200px) {
	h1 {
		font-size: 3.1875rem; /* 51px */
		line-height: 1.176;
	}
		h1 b, h1 strong {
			font-size: 3.4375rem; /* 55px */
		}
	h2, h2.modultitel {
		margin-bottom: 34px;
		font-size: 3rem; /* 48px */
	}
	h2.modultitel {
		margin-bottom: 54px;
	}
	h3 {
		font-size: 1.625rem; /* 26px */
		letter-spacing: 0.13px;
	}
	.hinweis-footer {
		font-size: 2.5rem; /* 40px */
		line-height: 1.25;
	}
	.einleitung {
		font-size: 1.625rem; /* 26px */
		letter-spacing: 0.13px;
	}
	.left__panel, .right__panel {
		font-size: 1.625rem; /* 26px */
	}
}


/* Absätze */
/* Left-/RightPanel */
.left__panel h1 + p, .right__panel h1 + p {
	margin-top: 45px;
}
.left__panel p + p, .right__panel p + p {
	margin-top: 30px;
}
.left__panel p + h3, .right__panel p + h3 {
	margin-top: 39px;
}

/* MiddlePanel */
.middle__panel p + h2, .middle__panel ul + h2, .middle__panel h3 + h2 {
	margin-top: 40px;
}
.middle__panel p + p {
	margin-top: 27px;
}
.middle__panel h3 + ul {
	margin-top: 10px;
}
.middle__panel p + h3, .middle__panel ul + h3 {
	margin-top: 37px;
}
@media screen and (min-width: 1200px) {
	/* Left-/RightPanel */
	.left__panel h1 + p, .right__panel h1 + p {
		margin-top: 60px;
	}
	.left__panel p + p, .right__panel p + p {
		margin-top: 37px;
	}
	.left__panel p + h3, .right__panel p + h3 {
		margin-top: 41px;
	}

	/* MiddlePanel */
	.middle__panel p + h2, .middle__panel ul + h2, .middle__panel h3 + h2 {
		margin-top: 54px;
	}
	.middle__panel p + p {
		margin-top: 30px;
	}
	.middle__panel h3 + ul {
		margin-top: 12px;
	}
	.middle__panel p + h3, .middle__panel ul + h3 {
		margin-top: 41px;
	}
}


/* 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 {
	-ms-hyphens: auto;
	-moz-hyphens: auto;
	-webkit-hyphens: auto;
	hyphens: auto;
	-ms-hyphenate-limit-chars: auto 3;
	-moz-hyphenate-limit-chars: auto 3;
	-webkit-hyphenate-limit-chars: auto 3;
	hyphenate-limit-chars: auto 3;
	-ms-hyphenate-limit-lines: 3;
	-moz-hyphenate-limit-lines: 3;
	-webkit-hyphenate-limit-lines: 3;
	/*hyphenate-limit-lines: 3;*/
}


/* ############################################################
	HYPERLINKS
############################################################ */

/* Allgemeines */
a, a:hover, a:focus {
	position: relative;
	text-decoration: none;
	color: var(--main-color-3);
}
a.shrink {
	display: inline-block;
}
nav .nav-mobile-kontakt-1 a, nav .nav-mobile-kontakt-1 a:hover,
nav .nav-mobile-secondmenu a, nav .nav-mobile-secondmenu a:hover {
	color: var(--main-color-1);
}
@media screen and (min-width: 992px) {
	a {
		-o-transition: all 300ms var(--cubic-bezier);
		-ms-transition: all 300ms var(--cubic-bezier);
		-moz-transition: all 300ms var(--cubic-bezier);
		-webkit-transition: all 300ms var(--cubic-bezier);
		transition: all 300ms var(--cubic-bezier);
	}
	a:hover, a:focus {
		color: var(--main-color-2);
	}
}


/* Hyperlinks */

/* Button */
a.link-btn {
	display: inline-block;
	position: relative;
	padding: 8px 12px 7px;
	border-radius: 18px;
	font-size: 1rem; /* 16px */
	line-height: 1.3;
	color: var(--main-color-white);
	white-space: nowrap;
}
a.link-btn.blau {
	background-color: var(--main-color-2);
}
a.link-btn.rot {
	background-color: var(--main-color-3);
}
a.link-btn:hover {
	color: var(--main-color-white);
}

/* Arrow Right */
a.link-arrow-right {
	display: inline-block;
	position: relative;
	margin-bottom: 4px;
	padding-left: 27px;
	color: var(--main-color-1);
	white-space: nowrap;
	transform-origin: center left;
}
footer a.link-arrow-right {
	margin-bottom: 6px;
}
footer a.link-arrow-right, footer a.link-arrow-right:hover {
	color: var(--main-color-white);
}
a.link-arrow-right:before {
	content: "";
	position: absolute;
	top: 5px;
	left: 0;
	width: 15px;
	height: 14px;
	background-image: url("../Images/Elemente/Arrow_Right_Red.svg");
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
}
.left__panel a.link-arrow-right, .right__panel a.link-arrow-right {
	margin-bottom: 4px;
	padding-left: 30px;
	font-size: 1.4375rem; /* 23px */
}
.left__panel a.link-arrow-right:before, .right__panel a.link-arrow-right:before {
	top: 6px;
	width: 20px;
	height: 19px;
}
@media screen and (min-width: 992px) {
	/* Button */
	a.link-btn.blau:hover {
		background-color: var(--main-color-3);
	}
	a.link-btn.rot:hover {
		background-color: var(--main-color-2);
	}

	/* Arrow Right */
	a.link-arrow-right:before {
		-o-transition: all 300ms var(--cubic-bezier);
		-ms-transition: all 300ms var(--cubic-bezier);
		-moz-transition: all 300ms var(--cubic-bezier);
		-webkit-transition: all 300ms var(--cubic-bezier);
		transition: all 300ms var(--cubic-bezier);
	}
	footer a.link-arrow-right:hover {
		color: var(--main-color-white);
	}
}
@media screen and (min-width: 1200px) {
	/* Button */
	a.link-btn {
		padding: 10px 16px 9px;
		border-radius: 22px;
		font-size: 1.25rem; /* 20px */
	}

	/* Arrow Right */
	a.link-arrow-right {
		font-size: 1.25rem; /* 20px */
	}
	a.link-arrow-right:before {
		width: 17px;
		height: 16px;
	}
	.left__panel a.link-arrow-right, .right__panel a.link-arrow-right {
		padding-left: 34px;
		font-size: 1.625rem; /* 26px */
	}
	.left__panel a.link-arrow-right:before, .right__panel a.link-arrow-right:before {
		width: 23px;
		height: 22px;
	}
}


/* Reset: Margin-Bottom */
nav .nav-mobile-kontakt-1 a.link-arrow-right:last-of-type, .footer-col-1 a.link-arrow-right:last-of-type, .footer-col-3 ul.nav-secondmenu li:last-of-type a.link-arrow-right,
.mdl210-modul-box a.link-arrow-right:last-of-type, .mdl211-modul-box a.link-arrow-right:last-of-type {
	margin-bottom: 0;
}


/* Shrink-Animation */
@media screen and (min-width: 992px) {
	a.shrink:hover,
	a.link-arrow-right.shrink:hover:before {
		-webkit-transform: scale(0.955);
		-moz-transform: scale(0.955);
		-ms-transform: scale(0.955);
		-o-transform: scale(0.955);
		transform: scale(0.955);
	}
	nav ul.nav-mainmenu a.shrink:hover {
		-webkit-transform: none;
		-moz-transform: none;
		-ms-transform: none;
		-o-transform: none;
		transform: none;
	}
}


/* 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 {
		-ms-hyphens: auto;
		-moz-hyphens: auto;
		-webkit-hyphens: auto;
		hyphens: auto;
		-ms-hyphenate-limit-chars: auto 3;
		-moz-hyphenate-limit-chars: auto 3;
		-webkit-hyphenate-limit-chars: auto 3;
		hyphenate-limit-chars: auto 3;
		-ms-hyphenate-limit-lines: 3;
		-moz-hyphenate-limit-lines: 3;
		-webkit-hyphenate-limit-lines: 3;
		/*hyphenate-limit-lines: 3;*/
	}
}


/* Anker */
/*a.nav-anchor[name] {*/
a.nav-anchor {
	display: block;
	width: 0;
	height: 0;
	position: relative;
	top: 0 !important;
	top: -95px !important;
	visibility: hidden;
}
@media screen and (min-width: 992px) {
	a.nav-anchor {
		top: -200px !important;
	}
}


/* ############################################################
	BILDER/ICONS
############################################################ */

/* Logo */
a.link-logo {
	display: inline-block;
	position: absolute;
	top: 13px;
	left: 0;
	width: 159px;
	height: 35px;
}
	a.link-logo img {
		display: inline-block;
	}
@media screen and (min-width: 768px) {
	a.link-logo {
		top: 35px;
		width: 300px;
		height: 65px;
	}
}


/* Fixed: Button: 24h-Pikett */
.fixed-pikett-box {
	z-index: 5;
	display: inline-block;
	position: fixed;
	bottom: 20px;
	right: 20px;
}
@media screen and (min-width: 768px) {
	.fixed-pikett-box {
		bottom: 50px;
		right: 50px;
	}
}


/* Socialmedia */
a.link-socialmedia {
	position: relative;
	display: inline-block;
	width: 43px;
	height: 43px;
	border-radius: 50%;
	background-color: var(--main-color-white);
}
	a.link-socialmedia svg {
		fill: var(--main-color-1);
	}
nav a.link-socialmedia {
	background-color: var(--main-color-1);
}
	nav a.link-socialmedia svg {
		fill: var(--main-color-white);
	}
nav a.link-socialmedia.instagram, nav a.link-socialmedia.facebook {
	margin-bottom: 15px;
}
footer a.link-socialmedia.instagram, footer a.link-socialmedia.facebook {
	margin-right: 15px;
}
@media screen and (min-width: 992px) {
	a.link-socialmedia {
		-o-transition: all 300ms var(--cubic-bezier);
		-ms-transition: all 300ms var(--cubic-bezier);
		-moz-transition: all 300ms var(--cubic-bezier);
		-webkit-transition: all 300ms var(--cubic-bezier);
		transition: all 300ms var(--cubic-bezier);
	}
	a.link-socialmedia:hover {
		background-color: var(--main-color-2);
	}
		a.link-socialmedia svg {
			-o-transition: all 300ms var(--cubic-bezier);
			-ms-transition: all 300ms var(--cubic-bezier);
			-moz-transition: all 300ms var(--cubic-bezier);
			-webkit-transition: all 300ms var(--cubic-bezier);
			transition: all 300ms var(--cubic-bezier);
		}
		a.link-socialmedia:hover svg {
			fill: var(--main-color-white);
		}
}
@media screen and (min-width: 1200px) {
	a.link-socialmedia {
		width: 45px;
		height: 45px;
	}
}


/* Hamburger */
a.nav-button {
	cursor: pointer;
	position: absolute;
	display: block;
	top: 18px;
	right: -5px;
	width: 33px;
	height: 24px;
	padding: 5px;
	font-size: 0;
	line-height: 0;
	overflow: hidden;
}
	a.nav-button svg {
		display: block;
		width: auto;
		height: 14px;
		margin: 0 auto;
		fill: var(--main-color-1);
	}
	a.nav-button.open svg.open, a.nav-button svg.close {
		display: none;
	}
	a.nav-button.open svg.close {
		display: block;
	}
@media screen and (min-width: 768px) {
	a.nav-button {
		top: 54px;
		right: 0;
		width: 45px;
		height: 27px;
		padding: 0;
	}
		a.nav-button svg {
			height: 27px;
		}
}


/* Icons */
.icon-box {
	display: block;
	width: auto;
	height: 40px;
	margin-top: 27px;
}
	.icon-box svg {
		display: inline-block;
		width: auto;
		height: 40px;
		fill: var(--main-color-2);
	}
@media screen and (min-width: 1200px) {
	.icon-box {
		height: 45px;
		margin-top: 30px;
	}
		.icon-box svg {
			height: 45px;
		}
}


/* ############################################################
	PANELS/BOXEN
############################################################ */

/* Allgemein */
header, main, footer,
.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 {
	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 {
	/* max-width: 1640px; */
	margin: 0 auto 0 0;
}

/* Kopfzeile */
header {
	z-index: 10;
	position: fixed;
	top: 0;
	height: 60px;
    background-color: var(--main-color-white);
	-o-transition: top 300ms var(--cubic-bezier), background 200ms var(--cubic-bezier);
	-ms-transition: top 300ms var(--cubic-bezier), background 200ms var(--cubic-bezier);
	-moz-transition: top 300ms var(--cubic-bezier), background 200ms var(--cubic-bezier);
	-webkit-transition: top 300ms var(--cubic-bezier), background 200ms var(--cubic-bezier);
	transition: top 300ms var(--cubic-bezier), background 200ms var(--cubic-bezier);
}
body[class^="cms-"] header {
	z-index: 210;
	top: 51px;
}
header.scrolled {
	top: -60px;
}
header.open {
	background-color: var(--main-color-4);
}
body[class^="cms-"] header.scrolled {
	top: -111px;
}
	.header-inline {
		height: 60px;
	}

/* Navigation */
nav, nav.open {
	-o-transition: top 500ms var(--cubic-bezier);
	-ms-transition: top 500ms var(--cubic-bezier);
	-moz-transition: top 500ms var(--cubic-bezier);
	-webkit-transition: top 500ms var(--cubic-bezier);
	transition: top 500ms var(--cubic-bezier);
}
nav {
	z-index: 9;
	opacity: 0;
	position: fixed;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	top: calc((var(--nav-height, 1vh) * 100) * -1);
	left: 0;
	width: 100%;
	height: 100vh;
	height: calc(var(--nav-height, 1vh) * 100);
	overflow-x: hidden;
	overflow-y: auto;
	background-color: var(--main-color-4);
}
nav.open {
	opacity: 1;
	top: 60px;
}
body[class^="cms-"] nav.open {
	z-index: 209;
	top: 111px;
}
	.nav-inline {
		display: flex;
		flex-direction: column;
		justify-content: flex-start;
		height: calc(var(--nav-height, 1vh) * 100);
	}
		.nav-line-1 {
			padding-top: 56px;
			padding-bottom: 100px;
		}
		.nav-line-2 {
			display: flex;
			justify-content: flex-start;
			margin-top: auto;
			padding-bottom: 20px;
		}
			.nav-inline-1, .nav-inline-2 {
				display: flex;
				flex-direction: column;
				justify-content: flex-end;
			}
			.nav-inline-2 {
				width: 45px;
				margin-bottom: 6px;
				margin-left: auto;
			}
				.nav-mobile-secondmenu {
					margin-top: 21px;
				}

/* Inhalt */
main {
	flex: 1 0 auto;
	padding-top: 60px;
}
body[class^="cms-"] main {
	padding-top: 111px;
}

/* Fusszeile */
footer {
	flex-shrink: 0;
	padding-top: 50px;
	padding-bottom: 125px;
	background-image: url("../Images/Elemente/BG_Footer_Mobile.svg");
	background-repeat: no-repeat;
	background-position: right bottom;
	background-size: 365px 78px;
}
	.footer-inline {
		display: flex;
		flex-direction: column;
	}
		.footer-col-1, .footer-col-2, .footer-col-3 {
			width: auto;
		}
		.footer-col-2 {
			margin-top: 90px;
		}
		.footer-col-3 {
			margin-top: 32px;
		}
			.footer-kontakt-1 {
				margin-top: 46px;
			}
			.footer-kontakt-2 {
				margin-top: 26px;
			}
@media screen and (min-width: 768px) {
	/* Allgemein */
	.header-box, .nav-box, .content-box, .footer-box {
		padding-left: 50px;
		padding-right: 50px;
	}

	/* Kopfzeile */
	header, .header-inline {
		height: 135px;
	}
	body[class^="cms-"] header {
		top: 51px;
	}
	header.scrolled {
		top: -135px;
	}
	body[class^="cms-"] header.scrolled {
		top: -186px;
	}

	/* Navigation */
	nav.open {
		top: 135px;
	}
	body[class^="cms-"] nav.open {
		top: 186px;
	}
		.nav-line-2 {
			padding-bottom: 50px;
		}

	/* Inhalt */
	main {
		padding-top: 135px;
	}
	body[class^="cms-"] main {
		padding-top: 186px;
	}
	
	/* Fusszeile */
	footer {
		padding-top: 100px;
		padding-bottom: 85px;
		background-image: url("../Images/Elemente/BG_Footer_Desktop.svg");
		background-position: right -80px bottom;
		background-size: 768px 175px;
	}
		.footer-inline {
			flex-direction: row;
		}
			.footer-col-2 {
				width: 170px;
				margin-top: 0;
				margin-left: auto;
				text-align: right;
			}
			.footer-col-3 {
				width: 150px;
				margin-top: 0;
				margin-left: var(--gap);
			}
}
@media screen and (min-width: 992px) {
	/* Fusszeile */
	footer {
		background-position: right -80px bottom;
		background-size: 970px 220px;
	}
		.footer-col-2 {
			width: 170px;
		}
		.footer-col-3 {
			width: 230px;
		}
			.footer-kontakt-1 {
				margin-top: 99px;
			}
			.footer-kontakt-2 {
				margin-top: 30px;
			}
}
@media screen and (min-width: 1200px) {
	/* Allgemein */
	.header-box, .nav-box, .content-box, .footer-box {
		padding-left: 80px;
		padding-right: 80px;
	}

	/* Kopfzeile */
	.nav-mainmenu-box {
		display: flex;
		align-items: center;
		justify-content: right;
		position: absolute;
		top: 54px;
		right: 170px;
		width: auto;
		height: 45px;
	}
		.header-pikett-box {
			display: inline-block;
			position: absolute;
			top: 50px;
			right: 0;
		}
	
	/* Navigation */
	nav {
		display: none;
	}
	
	/* Fusszeile */
	footer {
		background-position: right bottom;
	}
		.footer-pikett-box {
			margin-top: 40px;
		}
}
@media screen and (min-width: 1600px) {
	/* Allgemein */
	.header-box, .nav-box, .content-box, .footer-box {
		padding-left: 170px;
		padding-right: 170px;
	}

	/* Kopfzeile */
	.nav-mainmenu-box {
		right: 220px;
	}
}


/* ############################################################
	LISTEN
############################################################ */

/* Aufzählungslisten */
.mdl-container ul:not([class^="cmsmodule-nav"]):not([class^="slick-dots"]) {
	list-style: none;
	position: relative;
	padding: 0;
}


/* Stil: Linien */
.mdl-container ul.list-lines li {
	position: relative;
	margin-left: 0;
	padding: 6px 0;
	border-bottom: 1px solid var(--main-color-1);
}
.mdl-container ul.list-lines li:first-child {
	border-top: 1px solid var(--main-color-1);
}
@media screen and (min-width: 1200px) {
	.mdl-container ul.list-lines li {
		padding-top: 7px;
		padding-bottom: 7px;
	}
}


/* Stil: Dots */
.mdl-container ul:not([class^="cmsmodule-nav"]):not(.list-lines) {
	margin-top: 27px;
	margin-bottom: 27px;
}
.mdl-container ul:not([class^="cmsmodule-nav"]):not(.list-lines) li {
	position: relative;
	margin-left: 27px;
	padding-left: 0;
}
.mdl-container ul:not([class^="cmsmodule-nav"]):not(.list-lines) li:not(:first-child) {
	margin-top: 10px;
}
.mdl-container ul:not([class^="cmsmodule-nav"]):not(.list-lines) li:before {
	content: "\2022";
	position: absolute;
	top: 0;
	left: -20px;
	font-size: 1.1875rem; /* 19px */
	line-height: 1.333;
}
@media screen and (min-width: 1200px) {
	.mdl-container ul:not([class^="cmsmodule-nav"]):not(.list-lines) {
		margin-top: 30px;
		margin-bottom: 30px;
	}
		.mdl-container ul:not([class^="cmsmodule-nav"]):not(.list-lines) li {
			margin-left: 30px;
			font-size: 1.3125rem; /* 21px */
		}
		.mdl-container ul:not([class^="cmsmodule-nav"]):not(.list-lines) li:before {
			left: -20px;
		}
}


/* ############################################################
	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-secondmenu, 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 ul.nav-mainmenu {
	display: flex;
	flex-direction: column;
	width: 100%;
	font-family: "Canaro-Bold";
	font-size: 2.4375rem; /* 39px */
	line-height: 1.2;
}
	/* Level 1 */
	nav ul.nav-mainmenu > li:not(:first-child) {
		margin-top: 16px;
	}
		/* Level 2 */
		nav ul.nav-mainmenu > li > ul {
			margin-top: 12px;
			margin-bottom: 22px;
			font-family: "Canaro-Book";
			font-size: 1.375rem; /* 22px */
			line-height: 1.2;
		}
			nav ul.nav-mainmenu > li > ul > li {
				border-bottom: 1px solid var(--main-color-white);
			}
				nav ul.nav-mainmenu > li > ul > li a {
					padding-top: 8px;
					padding-bottom: 8px;
				}
				nav ul.nav-mainmenu > li > ul > li:first-child a {
					padding-bottom: 8px;
				}

/* Hyperlink-Status: Allgemein */
nav ul.nav-mainmenu a {
	display: block;
}

/* Hyperlink-Status: Level 1 */
nav ul.nav-mainmenu > li > a, nav ul.nav-mainmenu > li > a:hover,
header ul.nav-mainmenu > li > a, header ul.nav-mainmenu > li > a:hover {
	color: var(--main-color-1);
}
nav ul.nav-mainmenu > li.open > a, nav ul.nav-mainmenu > li.active > a {
	color: var(--main-color-2);
}

/* Hyperlink-Status: Level 2 */
nav ul.nav-mainmenu > li > ul > li > a, nav ul.nav-mainmenu > li.active > ul > li > a, nav ul.nav-mainmenu > li > ul > li > a:hover,
header ul.nav-mainmenu > li > ul > li > a, header ul.nav-mainmenu > li.active > ul > li > a, header ul.nav-mainmenu > li > ul > li > a:hover {
	color: var(--main-color-1);
}
nav ul.nav-mainmenu > li > ul > li.active > a {
	color: var(--main-color-2);
}
@media screen and (min-width: 1200px) {
	header ul.nav-mainmenu {
		display: flex;
		flex-direction: row;
		justify-content: flex-end;
		font-size: 1.375rem; /* 22px */
		line-height: 1.375;
	}
		/* Level 1 */
		header ul.nav-mainmenu > li:not(:first-child) {
			margin-left: 34px;
		}
			header ul.nav-mainmenu > li > a {
				padding-top: 8px;
				padding-bottom: 7px;
			}
			header ul.nav-mainmenu > li.has-submenu > a {
				padding-bottom: 17px;
			}
		
		/* Level 2 */
		header ul.nav-mainmenu > li > ul {
			position: absolute;
			display: none;
			top: 55px;
			left: -17px;
			width: 360px;
			padding: 30px 20px 30px 40px;
			border-radius: 24px;
			background-color: var(--main-color-4);
			font-size: 1.25rem; /* 20px */
			line-height: 1.375;
		}
			header ul.nav-mainmenu > li > ul > li {
				display: block;
				opacity: 0;
			}
			header ul.nav-mainmenu > li > ul > li:not(:first-child) {
				margin-top: 8px;
			}
				header ul.nav-mainmenu > li > ul > li > a {
					padding-top: 3px;
					padding-bottom: 3px;
				}
}
@media screen and (min-width: 1600px) {
	/* Level 1 */
	header ul.nav-mainmenu > li:not(:first-child) {
		margin-left: 80px;
	}
	
	/* Level 2 */
	header ul.nav-mainmenu > li > ul {
		left: -40px;
	}
}

