:root {
	--main-site-width: 1273px;
	--main-gutter-space: 30px;
	--half-gutter-space: 15px;
	--site-border-width: 20px;
}

html {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	display: block;
	height: 100%;
	font-size: 100%;
}

*,
*:before,
*:after {
	-webkit-box-sizing: inherit;
	box-sizing: inherit;
	margin: 0;
	padding: 0;
}

*:focus {
	outline-style: none;
}

::-moz-focus-inner {
	border: 0;
}

::selection {
	background: #23a638;
	color: #fff;
}

::-moz-selection {
	background: #23a638;
	color: #fff;
}

body {
	background: #fff;
	color: #4a4545;
	font-family: "Montserrat", sans-serif;
	font-size: 1.06rem;
	font-weight: 400;
	line-height: 1.6em;
}

img {
	max-width: 100%;
	height: auto;
	display: block;
}

a {
	color: #23a638;
	text-decoration: none;
	font-weight: 500;
}

a:hover,
a:focus {
	color: #da0812;
	text-decoration: none;
}

#main a:hover,
#right a:hover,
#footer a:hover,
#main a:focus,
#right a:focus,
#footer a:focus {
	text-decoration: underline;
}

a:active {
	color: #23a638;
	text-decoration: none;
}

#logo a:focus {
	outline: 3px solid #da0812;
}

#logo a:focus:not(:focus-visible) {
	outline: none !important;
}

a:focus img {
	outline: 6px solid #da0812;
}

a:focus:not(:focus-visible) img {
	outline: none !important;
}

h1,
h1 a,
h2,
h2 a,
h3,
h3 a,
.ui-accordion-header {
	font-family: "Epilogue", sans-serif;
}

h1 {
	font-size: 2.25rem;
	font-weight: 600;
	line-height: 1em;
	letter-spacing: 0.02em;
	margin-top: 0;
	margin-bottom: 0.6em;
}

h2 {
	font-size: 1.9rem;
	font-weight: 500;
	line-height: 1.3em;
	letter-spacing: 0.02em;
	margin-top: 0;
	margin-bottom: 0.3em;
}

h2 {
	min-height: 2.2em;
}

h2::after {
	content: ".";
	color: #da0812;
}

.ce_text > h2 {
	margin-bottom: 0.6em;
	border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}

h3 {
	font-size: 1.25rem;
	font-weight: 500;
	line-height: 1.4em;
	letter-spacing: 0.02em;
	margin-top: 1.5em;
	margin-bottom: 0.7em;
}

.ce_text > h3:first-child {
	margin-top: 0;
}

p {
	margin-bottom: 1.4em;
}

p:last-child {
	margin-bottom: 0;
}

b {
	font-weight: 500;
}

#header .inside,
#mm_overlay .inside,
.content-clamp {
	max-width: var(--main-site-width);
	margin: 0 auto;
	padding-left: var(--site-border-width);
	padding-right: var(--site-border-width);
}

/* Header
==============================*/

#header {
	position: fixed;
	z-index: 50;
	left: 0;
	right: 0;
	background-color: rgba(255, 255, 255, 0.9);
	padding-bottom: 14px;
	transition: all 0.3s ease;
}

#header.sticky {
	background-color: #fff;
	box-shadow: 0 5px 10px rgba(0, 0, 0, 0.04);
	padding-bottom: 7px;
}

#header .inside {
	display: flex;
	flex-flow: row nowrap;
}

/* Logo
----------------------------- */

#logo {
	background-image: url(../bilder/RAUbayern-Logo.svg);
	background-size: cover;
	background-repeat: no-repeat;
	display: block;
	width: 187.4px;
	height: 86px;
	margin-right: auto;
	margin-top: 10px;
	margin-bottom: 12px;
	transition: all 0.3s ease;
}

#header.sticky #logo {
	width: 146px;
	height: 67px;
	margin-top: 6px;
}

#logo a {
	display: block;
	width: 100%;
	height: 100%;
	font-size: 0;
}

/* Main Navigation
----------------------------- */

#main_nav {
	align-self: flex-end;
	font-family: "Epilogue", sans-serif;
}

#main_nav .level_1 {
	overflow: hidden;
	margin-bottom: 0;
}

#main_nav .level_1 > li {
	float: left;
	display: block;
	padding-right: 2.5em;
}

#main_nav .level_1 > li {
	float: left;
	overflow: hidden;
}

#main_nav .level_1 > li > a,
#main_nav .level_1 > li > strong {
	display: block;
	border: none;
	outline: none;
	padding: 0.3em 0 0.3em;
	color: #292c33;
	font-size: 1.1rem;
	font-weight: 400;
	border-bottom: 0.2em solid transparent;
}

#main_nav .level_2 {
	display: none;
	position: absolute;
	background-color: #fff;
	min-width: 160px;
	box-shadow: 0 8px 16px 0 rgba(0, 0, 0, 0.1);
	z-index: 1;
}

#main_nav .level_2 > li {
	float: none;
	display: block;
	text-align: left;
}

#main_nav .level_2 a,
#main_nav .level_2 strong {
	color: #292c33;
	padding: 0.7em 1em;
	display: block;
	font-weight: 400;
}

#main_nav .level_2 strong {
	color: #8f95a4;
}

#main_nav .level_1 > li:hover > a,
#main_nav .level_1 > li.trail > a,
#main_nav .level_1 > li > strong {
	border-color: #da0812;
}

#main_nav .level_1 > li:focus-within > a {
	border-color: #da0812;
}

#main_nav .level_2 > li a:hover,
#main_nav .level_2 > li a:focus {
	background-color: #f4f6fa;
	color: #da0812;
}

#main_nav .level_1 > .submenu:hover .level_2,
#main_nav .level_1 > .submenu:focus .level_2 {
	display: block;
}

#main_nav .level_1 > .submenu:focus-within .level_2 {
	display: block;
}

#main_nav .invisible:focus {
	clip: unset;
	height: auto;
	width: auto;
	display: block;
	margin-top: -0.5em;

	background-color: #fff;
	border-radius: 0;
	border: 2px solid #da0812;
	padding: 0.5em 1em;

	color: #4a4545;
}

/* Mobile Navigation
----------------------------- */

.mm_open_button {
	align-self: flex-end;
	font-size: 1.3em;
	line-height: 1.3em;
	margin-right: -0.3em;
}

#mm_open {
	display: block;
	padding: 0.3em;
	cursor: pointer;
}

#mm_open .icon_button__text {
	font-size: 0;
	display: none;
}

body {
	-webkit-transition: overflow 0s;
	transition: overflow 0s;
}

.noscroll {
	overflow: hidden;
}

#mm_overlay {
	-webkit-transition: opacity 0.3s ease-out, height 0.3s ease-out;
	transition: opacity 0.3s ease-out, height 0.3s ease-out;
	opacity: 0;
	height: 0;

	background-color: #f5f5f5;
	overflow: auto;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 999;
}

#mm_overlay.mm_aktive {
	opacity: 1;
	height: 100%;
	-webkit-transition: opacity 0.3s ease-out, height 0.3s ease-out;
	transition: opacity 0.3s ease-out, height 0.3s ease-out;
}

.mm_close_button {
	cursor: pointer;
	display: block;
	text-decoration: none;
	position: absolute;
	right: var(--site-border-width);
	top: 0;
	font-size: 1.8em;
}

.mm_close_button:hover {
	color: #da0812;
	-webkit-transition: 0.3s ease;
	transition: 0.3s ease;
}

#mm_overlay .mm_home i {
	color: #da0812;
}

#mm_overlay .mm_home a {
	font-weight: 700;
	color: #4a4545;
}

#mm_overlay .mm_home a:hover {
	color: #da0812;
	-webkit-transition: 0.3s ease;
	transition: 0.3s ease;
}

#main_nav_mobile {
	overflow: hidden;
	font-size: 1.2rem;
	-webkit-transition: 0.3s ease;
	transition: 0.3s ease;
	margin-top: 10px;
}

#main_nav_mobile.close {
	display: none;
}

#main_nav_mobile .level_1 {
	list-style-type: none;
	margin-bottom: 0;
	margin-top: 10px;
	overflow: hidden;
}

#main_nav_mobile .level_1 > li {
	margin-top: 0.5em;
}

#main_nav_mobile .level_1 > li > a,
#main_nav_mobile .level_1 > li > strong {
	margin-bottom: 0.3em;
}

#main_nav_mobile .level_1 > li > a,
#main_nav_mobile .level_1 > li > a:link,
#main_nav_mobile .level_1 > li > a:visited,
#main_nav_mobile .level_1 > li.active > strong,
#main_nav_mobile .level_1 > li.forward > strong {
	display: block;
	border: none;
	outline: none;
	padding: 0.3em 0 0.3em;
	color: #292c33;
	font-size: 1.1rem;
	font-weight: 500;
	border-bottom: 0.2em solid transparent;
}

#main_nav_mobile .level_1 li.trail,
#main_nav_mobile .level_1 li.active,
#main_nav_mobile .level_1 li.forward {
	display: block;
	text-decoration: none;
}

#main_nav_mobile .level_1 li a:hover,
#main_nav_mobile .level_1 li.first a:hover,
#main_nav_mobile .level_1 li a:focus {
	border-color: #da0812;
}

#main_nav_mobile .level_1 li.active,
#main_nav_mobile .level_1 li.active strong {
	color: #da0812;
}

#main_nav_mobile .level_2 {
	margin-bottom: 20px;
	font-size: 1rem;
}

#main_nav_mobile .level_2 li {
	width: 100%;
	margin-bottom: 0.5em;
	padding-bottom: 0.5em;
	border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}

#main_nav_mobile .level_2 a,
#main_nav_mobile .level_2 a:link,
#main_nav_mobile .level_2 a:visited,
#main_nav_mobile .level_2 li.trail span,
#main_nav_mobile .level_2 li.active strong,
#main_nav_mobile .level_2 li.forward span {
	text-transform: none;
	color: #4a4545;
	line-height: 1.3em;
	font-weight: 400;
	padding-top: 0.3em;
	padding-bottom: 0.3em;
}

#main_nav_mobile .level_2 li.active strong {
	font-weight: 400;
	color: #da0812;
}

#main_nav_mobile .level_2 li.trail,
#main_nav_mobile .level_2 li.active,
#main_nav_mobile .level_2 li.forward {
	display: block;
	text-decoration: none;
}

#main_nav_mobile .level_2 li a:hover,
#main_nav_mobile .level_2 li.first a:hover,
#main_nav_mobile .level_2 li.trail,
#main_nav_mobile .level_2 li.trail a,
#main_nav_mobile .level_2 li.active,
#main_nav_mobile .level_2 li.trail span,
#main_nav_mobile .level_2 li a:focus {
	color: #da0812;
}

/* Content
==============================*/

.mod_article {
	margin-bottom: 60px;
}

/* Header Artikel
----------------------------- */

.mod_article.header-article {
	padding-top: 200px;
	padding-bottom: 40px;
	min-height: 350px;
}

.mod_article.header-article .article__inside {
	flex-flow: column nowrap;
}

.home .mod_article.header-article .article__inside {
	min-height: 360px;
	margin-top: 110px;
}

.header-article.bg1 {
	background-color: #517930;
	background-image: url(../bilder/header_bg.jpg);
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}

.header-article__headline {
	background-color: rgba(0, 0, 0, 0.2);
	color: #fff;
	padding: 1.1rem;
}

.article__inside > .header-article__headline,
.article__inside > .header-article__button,
.mod_newsreader > .header-article__headline,
.mod_newsreader > .header-article__button {
	width: fit-content;
}

.mod_article.header-article .header-article__button {
	margin-top: auto;
	margin-bottom: 0 !important;
}

.header-article__button > p {
	display: flex;
	flex-flow: row wrap;
	column-gap: 0.7rem;
}

.header-article__button .dk_button {
	word-spacing: initial;
}

.header-article__button .dk_button + .dk_button {
	margin-left: 0;
}

/* Spalten
----------------------------- */

.dk_flex_a,
.article__inside,
.ce_form .formbody,
.ce_accordionStart .accordion > div,
.mod_newslist.news_teaser,
#main_nav_mobile .level_1 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-flow: row wrap;
	flex-flow: row wrap;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	margin-left: calc(0px - var(--half-gutter-space));
	margin-right: calc(0px - var(--half-gutter-space));
}

.dk_flex_a > *,
.article__inside > *,
.ce_form .formbody > *,
.ce_accordionStart .accordion > div > *,
.mod_newslist.news_teaser > *,
#main_nav_mobile .level_1 > * {
	margin-left: var(--half-gutter-space);
	margin-right: var(--half-gutter-space);
	width: 100%;
}

.article__inside > *:not(h1):not(h2):not(h3):not(h4):not(.ce_accordion):not(.mod_newslist),
.dk_flex_a > *:not(h1):not(h2):not(h3):not(h4):not(.ce_accordion):not(.mod_newslist) {
	margin-bottom: var(--main-gutter-space);
}

.mod_newslist.dk_flex_a {
	margin-left: 0 !important;
	margin-right: 0 !important;
}

.dk_col_1 {
	width: 100%;
}

.dk_col_2 {
	width: calc(100% / 2 - var(--main-gutter-space)) !important;
}

.dk_col_3 {
	width: calc(100% / 3 - var(--main-gutter-space)) !important;
}

.dk_col_3-2 {
	width: calc(100% / 3 * 2 - var(--main-gutter-space)) !important;
}

.dk_col_4 {
	width: calc(100% / 4 - var(--main-gutter-space)) !important;
}

.dk_col_4-2 {
	width: calc(100% / 4 * 2 - var(--main-gutter-space)) !important;
}

.dk_col_4-3 {
	width: calc(100% / 4 * 3 - var(--main-gutter-space)) !important;
}

.dk_col_5,
#main_nav_mobile .level_1 > li {
	width: calc(100% / 5 - var(--main-gutter-space)) !important;
}

.dk_col_5-2 {
	width: calc(100% / 5 * 2 - var(--main-gutter-space)) !important;
}

.dk_col_5-3 {
	width: calc(100% / 5 * 3 - var(--main-gutter-space)) !important;
}

.dk_col_5-4 {
	width: calc(100% / 5 * 4 - var(--main-gutter-space)) !important;
}

.dk_col_6 {
	width: calc(100% / 6 - var(--main-gutter-space)) !important;
}

div[class*="dk_col"] {
	margin-bottom: var(--main-gutter-space);
}

/* Button
----------------------------- */

.dk_button {
	margin-bottom: 12px;
	display: inline-block;
}

.dk_button a,
.back a,
.mod_newsarchive .pagination ul li a,
button,
.more a,
.pagination ul li a,
.pagination ul li strong,
.label_upload_button label {
	color: #fff;
	background-color: #23a638;
	padding: 0.2em 1em;
	border: 4px solid #23a638;
	display: inline-block;
	transition: color 0.3s ease;
	-webkit-transition: color 0.3s ease;
	-moz-transition: color 0.3s ease;
	font-weight: 400;
	font-size: 0.95rem;
	line-height: 1.7em;
}

.dk_button a:hover,
.dk_button a:focus,
.back a:hover,
.back a:focus,
.pagination ul li a:hover,
.pagination ul li a:focus,
button:hover,
button:focus,
.more a:hover,
.more a:focus,
.pagination ul li a:hover,
.pagination ul li a:focus,
.label_upload_button label:hover,
.label_upload_button label:focus,
.news_teaser .layout_latest:focus-within .more a {
	background-color: #fff;
	color: #4a4545;
	text-decoration: none !important;
	cursor: pointer;
}

.dk_button + .dk_button {
	margin-left: 10px;
}

.back {
	margin-top: 20px;
}

.alt_button a {
	background: #da0812;
	border: 4px solid #da0812;
	color: #fff;
}

.alt_button a:hover,
.alt_button a:focus {
	color: #4a4545;
	background: #ffffff;
}

/* Pagination
----------------------------- */

.pagination {
	margin-top: 20px;
}

.pagination p {
	float: left;
}

.pagination ul {
	float: right;
	margin-left: -10px;
}

.pagination ul li {
	float: left;
	margin-left: 10px;
	margin-bottom: 12px;
}

.pagination ul li a,
.pagination ul li strong {
	padding: 4px 12px;
}

.pagination ul li strong {
	background-color: #fff;
	color: #4a4545;
	border-color: #bebdbd;
	text-decoration: none;
	display: inline-block;
}

/* Icons
----------------------------- */

.dk_icon {
	display: inline-block;
	overflow: visible;
	margin-left: 1.75em;
}

.dk_icon::before {
	font-family: "Font Awesome 5 Free";
	display: inline-block;
	position: absolute;
	font-style: normal;
	font-variant: normal;
	text-rendering: auto;
	-webkit-font-smoothing: antialiased;
	color: #292c33;
	margin-left: -1.55em;
}

.dk_icon--home::before {
	font-weight: 900;
	content: "\f015";
}

.dk_icon--search::before {
	font-weight: 900;
	content: "\f002";
}

.dk_icon--member::before {
	font-weight: 900;
	content: "\f0c0";
}

.dk_icon--email::before {
	font-weight: 900;
	content: "\f2b6";
}

.dk_icon--phone::before {
	font-weight: 900;
	content: "\f095";
}

.dk_icon--mobile_phone::before {
	font-weight: 900;
	content: "\f10b";
	margin-left: -1.38em;
}

.dk_icon--fax::before {
	font-weight: 900;
	content: "\f02f";
}

.dk_icon--file::before {
	font-weight: 900;
	content: "\f15b";
}

.dk_icon--menu::before {
	font-weight: 900;
	content: "\f0c9";
}

.dk_icon--location::before {
	font-weight: 900;
	content: "\f3c5";
	margin-left: -1.4em;
}

.dk_icon--website::before {
	font-weight: 900;
	content: "\f7a2";
	margin-left: -1.5em;
}

.dk_icon--time::before {
	font-weight: 900;
	content: "\f017";
	margin-left: -1.5em;
}

a[target="_blank"]::after {
	font-family: "Font Awesome 5 Free";
	display: inline-block;
	text-rendering: auto;
	-webkit-font-smoothing: antialiased;
	font-weight: 900;
	content: "\f35d";
	font-size: 0.8em;
	margin-left: 0.2em;
	margin-right: 0.4em;
}

/* Teaser News/Referenzen
----------------------------- */

.teaser .layout_latest,
.teaser .event {
	display: flex;
	flex-flow: column nowrap;
}

.teaser .layout_latest > figure,
.teaser .event > figure {
	margin-bottom: 0;
}

.teaser .layout_latest h3,
.teaser .event h3 {
	min-height: 3.45em;
	padding-bottom: 0.6em;
	border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}

.teaser .layout_latest .ce_text,
.teaser .event .ce_text {
	font-size: 0.95rem;
	line-height: 1.55em;
	margin-bottom: 1em;
}

.teaser--news .layout_latest .more {
	margin-top: auto;
}

a.reference__more {
	position: relative;
	display: block;
	overflow: hidden;
}

a.reference__more::after {
	position: absolute;
	right: 20px;
	bottom: 0;

	display: flex;
	justify-content: center;
	align-items: center;

	background-color: #23a638;
	width: 40px;
	height: 40px;
	content: "\f067";

	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	font-size: 1.3rem;
	line-height: 0.9em;
	font-style: normal;
	font-variant: normal;
	text-rendering: auto;
	-webkit-font-smoothing: antialiased;
	color: #fff;

	transition: all 0.3s ease;
}

a.reference__more::before {
	position: absolute;
	bottom: -10px;

	content: "";
	background-color: #23a638;
	width: 100%;
	height: 10px;

	transition: all 0.3s ease;
}

a.reference__more:hover::before,
a.reference__more:focus::before {
	bottom: 0;
}

a.reference__more:hover::after,
a.reference__more:focus::after {
	bottom: 10px;
}

a.reference__more:focus img {
	outline: none;
}

.mod_newsreader {
	overflow: visible;
}

.header-article .mod_newsreader {
	overflow: visible;
	width: initial;
}

/* Bilder
----------------------------- */

.image_container img {
	margin: 0 auto;
}

.image_container.float_left {
	margin-right: var(--main-gutter-space);
	margin-bottom: var(--main-gutter-space);
}

.image_container.float_above {
	margin-bottom: var(--half-gutter-space);
}

.image_container.float_right {
	width: calc(100% / 3 - var(--main-gutter-space));
}

.image_container.float_right {
	margin-left: var(--main-gutter-space);
	margin-bottom: var(--main-gutter-space);
}

figcaption {
	background-color: #f7f7f7;
	color: #4a4545;
	padding: 5px 8px;
	font-size: 0.8rem;
}

/* Listen
----------------------------- */

.ce_text ul,
.ce_list ul,
.ce_text ol,
.ce_list ol {
	margin-bottom: 1.35em;
	margin-left: 2px;
	list-style: none;
}

.ce_text ol,
.ce_list ol {
	counter-reset: li;
}

.ce_text ul li,
.ce_list ul li,
.ce_text ol li,
.ce_list ol li {
	margin-bottom: 0.7em;
	margin-left: 1.5em;
}

.ce_text ol li,
.ce_list ol li {
	counter-increment: li;
}

.ce_text ul li::before,
.ce_list ul li::before {
	font-family: "Font Awesome 5 Free";
	text-rendering: auto;
	-webkit-font-smoothing: antialiased;
	font-weight: 900;
	content: "\f45c";
	color: #23a638;
	display: block;
	float: left;
	width: 2em;
	margin-left: -2.5em;
	font-size: 0.5rem;
}

.ce_text ol li::before,
.ce_list ol li::before {
	content: counter(li);
	color: #23a638;
	display: inline-block;
	font-weight: 600;
	width: 1em;
	margin-left: -1.5em;
	margin-right: 0.5em;
	text-align: right;
	direction: rtl;
}

/* Galeri
----------------------------- */

.ce_gallery {
	overflow: visible;
}

ul.dk_gallery {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-flow: row wrap;
	flex-flow: row wrap;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	margin-left: calc(0px - var(--half-gutter-space));
	margin-right: calc(0px - var(--half-gutter-space));
	list-style: none;
	overflow: visible;
}

ul.dk_gallery > li {
	margin-left: var(--half-gutter-space);
	margin-right: var(--half-gutter-space);
}

ul.dk_gallery li[class*="dk_col"] {
	margin-bottom: var(--main-gutter-space);
}

/* Akkordeon
----------------------------- */

.ce_accordion {
	margin-top: 20px;
}

.ce_accordion.first {
	margin-top: 0;
}

.ce_accordion.block {
	overflow: visible;
}

.ui-accordion-header {
	cursor: pointer;
	display: flex;
	flex-flow: row nowrap;
	justify-content: space-between;
	align-items: baseline;
	outline: none;
	padding: 11px 0;
	margin: 0;
	line-height: 1.3em;
	border-bottom: 1px solid rgba(0, 0, 0, 0.2);
}

.ui-accordion-header h2 {
	margin-right: 10px;
	min-height: unset;
	margin-bottom: 0;
}

.ui-accordion-header-icon {
	text-align: center;
	display: flex;
	flex-flow: row nowrap;
	justify-content: center;
	align-items: center;
	order: 2;
	color: #23a638;
	margin-left: 10px;
	font-size: 1.9rem;
}

.ui-accordion-header-icon::after {
	font-family: "Font Awesome 5 Free";
	display: inline-block;
	text-rendering: auto;
	-webkit-font-smoothing: antialiased;
	font-weight: 900;
	content: "\f067";
	width: 1.3em;
}

.ui-accordion-header:hover .ui-accordion-header-icon {
	color: #da0812;
}

.ui-accordion-header:focus .ui-accordion-header-icon {
	color: #da0812;
	outline: 4px solid #da0812;
}

.ui-accordion-header:focus:not(:focus-visible) .ui-accordion-header-icon {
	outline: none !important;
}

.ui-accordion-header-icon.ui-icon-triangle-1-s::after {
	content: "\f068";
	color: #da0812;
}

.ui-accordion-content {
	padding-top: var(--main-gutter-space);
}

/* Downloads
----------------------------- */

.download-element a span.size {
	font-size: 0.8rem;
	color: #808080;
	display: inline-block;
}

.download-element {
	padding: 9px 6px 9px 22px;
	border-bottom: 1px solid rgba(0, 0, 0, 0.1);
	margin-bottom: 5px;
}

.enclosure .download-element {
	border-bottom: none;
}

/* Big Slider
----------------------------- */

.mod_article.big_slider {
	--site-half-white-space: calc(calc(100vw - var(--main-site-width)) / 2);
	--big-slider-text-r-space: calc(var(--site-half-white-space) + var(--site-border-width));
	--big-slider-text-tlb-space: 6rem;
	display: flex;
	flex-flow: row wrap;
	background-color: #f7f7f7;
}

.big_slider__bild,
.big_slider__text {
	width: 50%;
}

.big_slider__bild--img {
	width: 100%;
}

.big_slider__text {
	padding-top: var(--big-slider-text-tlb-space);
	padding-right: var(--big-slider-text-r-space);
	padding-bottom: var(--big-slider-text-tlb-space);
	padding-left: var(--big-slider-text-tlb-space);
}

.big_slider__text .slick-container {
	display: flex;
	flex-flow: row wrap;
	height: 100%;
}

.slick-list {
	order: -1;
}

.slick-arrow {
	display: flex;
	width: 40px;
	height: 40px;
	padding: 0;
	margin-top: auto;
}

.slick-arrow i {
	margin: auto;
}

.slick-arrow .icon_button__text {
	font-size: 0;
	display: none;
}

.slick-prev {
	margin-left: auto;
	margin-right: 10px;
}

.slick-dots {
	display: block;
	position: absolute;
	bottom: 15px;
	right: var(--big-slider-text-tlb-space);
	margin: 0 auto;
	width: 100%;
	list-style: none;
	text-align: right;
}

.slick-dots li {
	position: relative;
	display: inline-block;
	width: 0.8rem;
	height: 0.8rem;
	margin: 0 0.7em;
	padding: 0;
}

.slick-dots li button {
	background-color: #ececec;
	display: block;
	width: 100%;
	height: 100%;
	border-radius: 20px;
	border: none;
	margin: 0;
	padding: 0;
	text-indent: -9999px;
}

.slick-dots li.slick-active button {
	background-color: #3d3d3c;
}

/* Youtube video
----------------------------- */

.ce_youtube {
	margin-bottom: var(--main-gutter-space);
}

.audio_container audio {
	max-width: 100%;
}

.video_container video {
	max-width: 100%;
	height: auto;
}

.responsive {
	position: relative;
	height: 0;
}

.responsive iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.responsive.ratio-169 {
	padding-bottom: 56.25%;
}

.responsive.ratio-1610 {
	padding-bottom: 62.5%;
}

.responsive.ratio-219 {
	padding-bottom: 42.8571%;
}

.responsive.ratio-43 {
	padding-bottom: 75%;
}

.responsive.ratio-32 {
	padding-bottom: 66.6666%;
}

/* Formular
----------------------------- */

.formbody .widget {
	margin-bottom: var(--half-gutter-space);
}

label,
.lable_style {
	display: inline;
	margin-left: 0.3em;
}

input,
textarea,
select {
	-webkit-appearance: none;
	font-size: 1rem;
	line-height: 1.8em;
	padding: 5px 10px;
	border: 2px solid rgba(0, 0, 0, 0.1);
	background-color: #fff;
	color: #000;
	display: block;
	width: 100%;
	max-width: 100%;
}

input,
label,
select,
textarea,
button {
	transition: 0.3s ease;
	-webkit-transition: 0.3s ease;
	-moz-transition: 0.3s ease;
}

input:focus,
select:focus,
textarea:focus {
	border-color: #23a638;
}

select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 448 512'%3E%3Cpath fill='%238a8a8a' d='M207.029 381.476L12.686 187.132c-9.373-9.373-9.373-24.569 0-33.941l22.667-22.667c9.357-9.357 24.522-9.375 33.901-.04L224 284.505l154.745-154.021c9.379-9.335 24.544-9.317 33.901.04l22.667 22.667c9.373 9.373 9.373 24.569 0 33.941L240.971 381.476c-9.373 9.372-24.569 9.372-33.942 0z'/%3E%3C/svg%3E");
	background-position: 98% center;
	background-repeat: no-repeat;
	background-size: 1em 1em;
}

textarea {
	overflow: auto;
	resize: vertical;
	line-height: 1.6em;
}

input,
select {
	height: 2.7em;
}

button,
input {
	overflow: visible;
}

.checkbox_container,
.radio_container {
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	padding: 0;
}

.checkbox_container input,
.radio_container input {
	opacity: 0 !important;
	height: 0 !important;
	width: 0 !important;
	padding: 0;
	position: absolute !important;
}

.checkbox_container legend {
	position: absolute;
	margin-left: 3em;
	line-height: 1.9em;
}

.checkbox_container label {
	width: 2em;
	height: 2em;
	background-color: #fff;
	border: 2px solid rgba(0, 0, 0, 0.1);
	text-align: center;
	position: relative;
	/* display: inline; */
	float: left;
	cursor: pointer;
	margin-right: 1em;
	text-indent: 5em;
	overflow: hidden;
}

.checkbox_container label:hover {
	border-color: #23a638;
}

.checkbox_container input:checked + label {
	background: #23a638;
	border-color: #23a638;
}

.checkbox_container input:checked + label:before {
	font-family: "Font Awesome 5 Free";
	text-rendering: auto;
	-webkit-font-smoothing: antialiased;
	font-weight: 900;
	content: "\f00c";
	color: #fff;
	width: 100%;
	height: 100%;
	line-height: 1.8em;
	margin-left: -4.55em;
	margin-right: 8em;
}

.radio_container label {
	line-height: 1.9em;
}

.radio_container label:before {
	content: "";
	display: block;
	float: left;
	width: 2em;
	height: 2em;
	background-color: #fff;
	border: 2px solid rgba(0, 0, 0, 0.1);
	text-align: center;
	margin-right: 0.6em;
}

.radio_container label:hover {
	cursor: pointer;
}

.radio_container label:hover:before {
	border-color: #23a638;
}

.radio_container input:checked + label:before {
	background: #fff;
	border-color: #23a638;
	border-width: 0.7em;
}

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

input[type="number"] {
	-moz-appearance: textfield;
}

input[type="file"]::-webkit-file-upload-button,
input[type="file"]::file-selector-button {
	display: none;
}

.label_upload_button {
	display: flex;
	flex-flow: row nowrap;
}

.label_upload_button label {
	flex-shrink: 0;
	margin-left: 0;
}

.label_upload_button input {
	border-left: none;
}

.widget-explanation > p:last-child,
.widget-explanation > h4:last-child {
	margin-bottom: 0;
}

span.mandatory {
	color: #da0812;
	margin-left: 0.15em;
}

.ce_form input[class*="dk_col"],
.ce_form label[class*="dk_col"],
.ce_form fieldset[class*="dk_col"],
.ce_form select[class*="dk_col"] {
	width: 100% !important;
}

.ce_form button[class*="dk_col"] {
	width: auto !important;
}

.contact_form .form_consent {
	margin-top: calc(var(--half-gutter-space) + var(--half-gutter-space));
}

.contact_form .widget-submit button {
	float: right;
}

p.error {
	color: brown;
}

/* Consent
----------------------------- */

.contao-cookiebar .highlight .cc-btn.success,
.contao-cookiebar .highlight .cc-btn.save {
	background: #4e9e3e;
	border-color: #3e7830;
	color: #fff;
}

/* Footer
==============================*/

.footer_part1__inside {
	display: flex;
	flex-flow: wrap wrap;
	padding-top: 35px;
	padding-bottom: 30px;
}

#footer_nav {
	overflow: visible;
}

#footer #footer_nav {
	margin-left: auto;
}

#footer_nav a,
#footer_nav strong {
	font-family: "Epilogue", sans-serif;
	font-size: 1.1rem;
	font-weight: 400;
	color: #4a4545;
	border-bottom: 3px solid transparent;
	padding-bottom: 10px;
}

#footer_nav a:hover,
#footer_nav a:focus {
	color: #4a4545;
	text-decoration: none;
	border-color: #da0812;
}

#footer_nav li {
	float: left;
	margin-right: 2em;
}

#footer_nav li.active strong {
	border-color: #da0812;
}

#footer_nav li.last {
	margin-right: 0;
}

.footer_part2 {
	font-size: 0.85rem;
}

.footer_part2 span {
	margin-right: 20px;
}

.footer_part2__inside {
	display: flex;
	flex-flow: row wrap;
	padding-top: 10px;
	padding-bottom: 12px;
}
