:root {
    --light: #f7f6f6;
    --light-rgb: 247,246,246;
    --light-grey: #a59f9f;
    --light-grey-rgb: 165,159,159;
    --red: #841f27;
    --red-rgb: 132,31,39;
    --white: #fff;
    --white-rgb: 255,255,255;
    --dark: #535455;
    --dark-rgb: 83,84,85;
    --verydark: var(--dark);
    --verydark-rgb: var(--dark-rgb);
    --base-color: var(--light);
    --base-color-rgb: var(--light-rgb);
    --text-color: var(--dark);
    --highlight-color: var(--tuerkis);
    --highlight-color-rgb: var(--tuerkis-rgb);
    --main-font: 'Montserrat', sans-serif;
    --highlight-font: var(--main-font);
    --highlight-font2: var(--main-font);
    --shadow: 0 0 5px rgba(var(--verydark-rgb),0.5);
    --shadow2: 0 0 5px rgba(var(--verydark-rgb),0.9);
    --padding: 26px;
    --max-width: 1800px;
    --flex-base: 150px;
    --base-font-size: 20px;
    --font-weight: 300;
    --transition-time: 0;
}


html {
    font-size: 16px;
    margin: 0;
    padding: 0;
    width: 100%;
    max-width: 100vw;
    overflow-x: hidden;
}
body {
    margin: 0;
    padding: 0;
    font-weight: 400;
    font-family: var(--main-font);
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    -webkit-appearance: none;
    margin: 0;
    padding: 0;
    min-height: 100%;
    min-width: 300px;
    height: auto;
    position: relative;
    background-color: var(--light);
    color: var(--text-color);
	overflow-x: hidden;
}
body * {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    box-sizing: border-box;
    opacity: 1;
}
h1, .h1, h2, .h2, h3, .h3 {
    font-weight: 400;
    margin: 25px 0 12.5px;
}
h1 {
    font-size: 2rem;
    color: var(--red);
    font-weight: 500;
    margin: 20px 0 10px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}
h2 {
    text-transform: uppercase;
    letter-spacing: 0.14em;
    font-weight: 500;
    font-size: 1.5rem;
    margin-bottom: 1rem;
    margin-top: 1.5rem;
}
h3 {
    color: var(--red);
    font-size: 1.5rem;
    font-weight: 600;
    margin: 30px 0 10px;
}
h4 {
    color: var(--red);
    font-size: 1.2rem;
    font-weight: 600;
    margin-top: 2em;
}
h5 {
    font-size: 1rem;
    margin-bottom: 6px;
    font-weight: 600;
}
p {
    line-height: 1.6em;
}
a {
    color: var(--red);
    text-decoration: none;
    transition: color var(--transition-time) ease-in;
}
a:hover {
    color: var(--text-color);
}
a.action {
    display: block;
    margin-top: 0.5em;
    margin-left: 0.5px;
}
.box1 {flex: 1 1 100px;margin:20px;}
.box2 {flex: 2 1 240px;margin:20px;}
.box3 {flex: 3 1 380px;margin:20px;}
.box4 {flex: 4 1 520px;margin:20px;}
.box5 {flex: 5 1 660px;margin:20px;}
.box5 {flex: 6 1 800px;margin:20px;}
.boxfull {flex: 1 1 100%;}
.boxfull.margin {margin:20px;}
.box1, .box2,.box3,.box4,.box5, .boxfull {
    padding: 30px;
}
img.round-border {
    border-radius: 100%;
    border: 10px solid #a0a0a0;
    padding: 0;
}
.wrapper {
    position: relative;
    margin: 0 auto;
    max-width: 1600px;
    display: flex;
    flex-flow: row wrap;
    padding: 18px;
}
#logo {
    position: relative;
    padding: 3vh 0;
    display: block;
    margin: 0;
    width: 100%;
}
#logo a {
    display: block;
    margin: 0 auto;
    position: relative;
    width: 80%;
    min-width: 300px;
    max-width: 482px;
}
#logo img {
    display: block;
    height: 20vh;
    width: 100%;
    object-fit: contain;
    min-height: 100px;
    max-height: 190px;
}
.menu {
    position: absolute;
    z-index: 1000;
    width: 100%;
}
nav {
    padding-top: 0px;
    padding-bottom: 0px;
    text-transform: uppercase;
    color: var(--text-color);
    font-size: 20px;
    position: relative;
    white-space: nowrap;
    transition: background var(--transition-time) ease-in;
}
.menu.open nav {
    background: var(--white);
}
nav.wrapper.mainnav {
    padding: 10px 18px;
}
nav ul {
    list-style: none;
}
nav > ul {
    padding: 0 15px;
}
nav > ul li {
    position: relative;
    cursor: pointer;
}
nav > ul li a, nav > ul li span {
    color: var(--text-color);
    transition: color var(--transition-time) ease-in;
    display: inline-block;
    margin: 0 1vw;
}
nav ul li:hover > a, nav ul li:hover > span, nav ul li.active > a, nav ul li.active > span {
    color: var(--red);
}
nav ul li.active > a, nav ul li.active > span {
    font-weight: 500;
}

/* Normales Menü */
@media (min-width:1101px) {
.sticked section.menu {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 100;
    background: #fff;
}
nav .navbutton {
    display: none;
}
nav .navi {
    display: flex;
    flex-flow: row;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    width: 100%;
} 
nav > ul li .sub{
    position: absolute;
    display: block;
    top: calc(100% + 10px);
    left: 0px;
    height: auto;
    padding: 0px;
    z-index: 2;
    background-color: #fff;
    transition: padding var(--transition-time) ease-in;
	text-transform: none;
} 
nav > ul li .sub li{
    height: auto;
    max-height: 0px;
    opacity: 0;
    transition: max-height var(--transition-time) ease-in, opacity var(--transition-time) ease-in;
    overflow: hidden;
    white-space: normal;
    font-size: 0.9rem;
}
nav > ul li.showsub .sub, nav > ul li:hover .sub{
    padding: 10px 0;
    z-index: 3;
}
nav > ul li .sub li a {
    margin-bottom: 0.5em;
}
nav > ul li.showsub .sub li, nav > ul li:hover .sub li{
    max-height: 120px;
    opacity: 1;
}
}

/* Dropdown Menü */
@media (max-width:1100px) {
nav {
    white-space: normal;
    font-size: 20px;
    }
nav .navbutton {
    display: block;
    margin-bottom: 10px;
}
nav .navi {
    display: block;
    width: 100%;
    margin: 0 auto 0 0;
    text-align: center;
} 
nav > ul > li:not(.navbutton){
    display: block;
    height: auto;
    padding: 0;
    max-height: 0px;
    opacity: 0;
    transition: max-height var(--transition-time) ease-in, opacity var(--transition-time) ease-in, padding var(--transition-time) ease-in;
    overflow: hidden;
} 
.open nav > ul > li:not(.navbutton){
    padding: 5px 0;
    max-height: 600px;
    opacity: 1;
}
nav ul li > a, nav ul li > span {
    margin: 0;
}
nav > ul li .sub{
    height: auto;
    padding: 0;
    transition: padding var(--transition-time) ease-in;
	text-transform: none;
} 
nav > ul li .sub li{
    height: auto;
    max-height: 0px;
    opacity: 0;
    padding: 0 10px;
    transition: max-height var(--transition-time) ease-in, opacity var(--transition-time) ease-in, padding var(--transition-time) ease-in;
    overflow: hidden;
}
nav > ul li.showsub .sub{
    padding: 6px 0;
} 
nav > ul li.showsub .sub li{
    max-height: 60px;
    opacity: 1;
    padding: 4px 10px;
}
}

/* Breadcrumbs */
nav#breadcrumbs {
    color: #c4c4c4;
    display: flex;
    flex-flow: row wrap;
    align-items: center;
    align-content: center;
    justify-content: space-between;
    padding: 0 50px;
    font-size: 1rem;
}
nav#breadcrumbs a {
    font-weight: 400;
}
nav#breadcrumbs .ssm {
    font-size: 1.4em;
    cursor: pointer;
}

/* Sitemap */ 
aside.embsm {
    position: fixed;
    width: 300px;
    height: 100%;
    top: 0;
    left: -300px;
    background-color: #fff;
    transition: left var(--transition-time) ease-in;
    padding: 0 20px;
    z-index: 1000;
    overflow-y: scroll;
    scrollbar-width: thin;
}
aside.smloaded.embsm {
    left: 0px;
}
aside.embsm .csm {
    position: absolute;
    right: 20px;
    top: 20px;
    cursor: pointer;
    color: #ddd;
    z-index: 1;
    transition: all var(--transition-time) ease-in;
}
aside.embsm .csm:hover {
    color: #bfb8b8;
} 
aside.embsm ul {
    list-style: none;
    padding: 0;
}
#main ul.sm li {
    position: relative;
}
#main ul.sm.l1 {
    padding: 0;
}
i.tsm {
    color: #bfb8b8;
    cursor: pointer;
    border-radius: 100%;
    background-color: transparent;
    transform: rotate(0deg);
    height: 1em;
    width: 1em;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all var(--transition-time) ease-in;
}
i.tsm:hover {
    color: #fff;
    background-color: #bfb8b8;
}
.sm-open > i.tsm {
    transform: rotate(-45deg);
}
aside.embsm li > .sm {
    overflow: hidden;
    height: auto;
    max-height: 0px;
    opacity: 0;
    margin-left: 1em;
    padding-left: 1em;
    transition: all var(--transition-time) ease-in;
}
aside.embsm li.sm-open > .sm {
    max-height: 2000px;
    opacity: 1;
}
li > .sm > li {
    position: relative;
}
li > .sm > li:before, li > .sm > li:after {
    content: "";
    display: block;
    position: absolute;
    background-color:  #bfb8b8;
    left: -1em;
} 
li > .sm > li:before {
    height: 1px;
    width: 0.8em;
    top: 0.7em;
}
li > .sm > li:after {
    height: 100%;
    width: 1px;
    top: -0.7em;
}
li > .sm > li:last-child:after {
    height: 1.4em;
}

/* Header */
header {
    position: relative;
    height: 60vh;
    min-height: 420px;
    max-height: 900px;
    background-position: center top;
    display: flex;
    flex-flow: column;
    justify-content: flex-start;
    align-content: flex-start;
    background-image: url('../img/general/header.png');
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-position: 100% 50%;
    margin-bottom: -160px;
}
header.large {
    height: 80vh;
    min-height: 420px;
    max-height: 900px;
    background-position: 100% 40%;
    margin-bottom: 0;
}
header  > * {
    width: 100%;
}
header .headerimage {
    align-self: stretch;
    display: flex;
    flex-flow: row wrap;
    flex: 1 1 150px;
}
header .headerimage > * {
    flex: 1 1 100%;
}
header .headertext {
    align-self: flex-end;
    text-align: center;
    text-transform: uppercase;
    font-size: 3.1111rem;
    letter-spacing: 0.14em;
    color: var(--red);
    font-weight: 500;
    margin: 0 0 5vh;
}
header .headertext small {
    display: block;
    font-size: 1.33333rem;
    color: var(--text-color);
    line-height: 1em;
}
/* Quicklinks */
.quicklinks {
    padding: 18px;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: stretch;
    margin-bottom: -60px;
}
.quicklinks > a {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    margin: 10px;
    transition: all var(--transition-time) ease-in;
}
.quicklinks.qltoggle  > a {
    padding: 10px;
    margin: 20px;
}
.quicklinks > * p {
    font-size: 1.2rem;
    font-weight: 500;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    margin: 0;
    max-width: 220px;
}
.quicklinks .qlitem {
    display: flex;
    flex-flow: row;
    justify-content: flex-start;
    align-items: center;
}
.quicklinks .qlitem i {
    font-size: 4.5rem;
    color: var(--text-color);
    margin-right: 1rem;
    transition: color var(--transition-time) ease-in;
}
.quicklinks a:hover .qlitem i {
    color: var(--red);
}
/* Content */
.flex {
    display: flex;
    flex-flow: row wrap;
    margin: 0 -50px;
}
.home .content {
    margin-top: 90px;
}
.content > * {
    padding: 0px 30px 60px;
    position: relative;
}
.content #main .contbox {
    display: flex;
    flex-flow: row wrap;
    align-items: flex-start;
    justify-content: flex-start;
    margin: 60px -50px -60px;
}
.modbox:before {
    content: '';
    display: block;
    height: 80px;
    margin-top: -80px;
    visibility: hidden;
}
.content #main .contbox.team > div {
}
.content #main .contbox.team > div h3{
    margin: 0;
    font-size: 1rem;
}
.content #main .contbox.team > div img {
    border-radius: 50%;
    width: 220px;
    display: block;
    margin: 0 auto 10px -25px;
    border: 10px solid #fff;
}
img.contentteam {
    border-radius: 50%;
    width: 220px;
    margin: 25px;
    border: 10px solid #fff;
    background-color: #fff;
}
.content #main .teamwrapper {
    position: relative;
}
.content #main .teamwrapper h3 {
    font-size: 1rem;
}
.content #main .teamwrapper h3 a {
    display: inline-block;
    margin-right: 20px;
}
.content #main .teamwrapper h3 a.active {
    font-weight: 400;
}
.content #main .team-members {
    margin: 0 -20px;
    position: relative;
    max-height: 0px;
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transition-time) ease-in;
}
.content #main .team-members.topen {
    opacity: 1;
    max-height: 3000px;
}
.content #main .team-members p {
    margin: 0;
}
.content #main .team-members > div {
    padding: 20px;
}
.content #main .team-members > div > div {
    padding: 10px;
}
.content #main .team-members > div > div ul {
    padding-left: 1em;
    margin: 5px 0;
    -webkit-hyphens: auto;
    -moz-hyphens: auto;
    hyphens: auto;
}
.content #main .news-list-item {
    margin-bottom: 20px;
    padding-bottom: 20px;
    border-bottom: 1px solid #ddd;
    display: flex;
    flex-flow: row wrap;
    align-items: flex-start;
}
.content #main .news-list-item > div {
    flex: 2 1 400px;
    margin-right: 20px;
}
.content #main .news-list-item small {
    display: block;
    margin-bottom: 0.5rem;
}
.content #main .news-list-item > img {
    display: block;
    object-fit: cover;
    object-position: center;
    height: 150px;
    width: 150px;
    flex: 0 0 150px;
	border:none;
}
.floatimgr {
    float: right;
    padding: 15px;
}
.floatimgl {
    float: left;
    padding: 15px;
}
.content #main .news-list-item:first-of-type {
    margin-top: 20px;
}
.content #main .news-list-item:last-of-type {
    margin-bottom: 0px;
    border-bottom: 0px solid #ddd;
}
.content .pagination li {
    border: none;
}
.content .pagination li span.active {
    color: #fff;
    background-color: #bfb8b8;
}
.tpl-newsitem h1 {
    letter-spacing: 0em;
    text-transform: none;
}
#main li:not(.slider),
#main a,
#main span,
#main p {
  font-weight: 400;
}
#main ul:not(.slider) {
    list-style: none;
    padding: 0;
}
#main ul li:not(.slider) {
    margin: 0.3rem 0;
    line-height: 1.6rem;
    padding-left: 1em;
    text-indent: -1em;
}
#main ul li > *:not(.slider) {
    text-indent: 0;
}
#main ul li > *:first-child:not(.slider) {
    display: inline-block;
}
#main ul li:not(.slider):before {
    content: '•';
    color: #bfb8b8;
    display: inline-block;
    margin-right: 0.5em;
    width: 0.5em;
    text-indent: 0;
}
#main > p:last-child {
    margin-bottom: 60px;
}
#main .relatedpages {
    display: flex;
    flex-flow: row wrap;
    margin: 50px -20px 0;
    border-top: 1px solid #ddd;
    padding-top: 40px;
}
#main .relatedpages > * {
    padding: 20px;
    margin: 0;
}
#main .relatedpages img {
    display: block;
    margin-bottom: 2rem;
}
/* Sidebar */
.right {
    padding-top: 40px;
}
.right > * {
    padding-bottom: 125px;
}
.right .sideimg, .right img {
    display: block;
    width: 100%;
    max-width: 250px;
    margin: -20px -10px 0 auto;
    z-index: 11;
    position: relative;
}
.tpl-newsitem .right .sideimg {
    object-fit: contain;
    object-position: left top;
    max-height: 600px;
}
.right ul {
    list-style: none;
    padding: 0;
}
.right > .sb > ul {
    list-style: none;
    padding: 50px 20px 100px 50px;
    margin: -20px -20px -80px;
    position: relative;
    border-radius: 40px 0 0 40px;
	width: 100%;
}
.right > .sb > ul:last-of-type {
    padding: 50px 20px 20px 50px;
    margin: -20px -20px 0px;
}
.right ul::after {
    content: '';
    display: block;
    position: absolute;
    height: 100%;
    width: 100%;
    top: 0;
    left: 100%;
}
.subnav {
    text-transform: uppercase;
    letter-spacing: 0.14em;
    background-color: #c0bcbd;
}
.subnav li a {
    color: #fff;
    font-size: 1.2rem;
}
.subnav::after {
    background-color: #c0bcbd;
}
.newslist, .archives {
    background-color: #fff;
}
.newslist::after, .archives::after {
    background-color: #fff;
}
.right h2, .right h2 a {
    color: #5f5f5f;
    font-size: 1rem;
    margin-top: 0;
    font-weight: 600;
}
.right li h3{
    font-size: 1.875rem;
    margin: 0;
}
.right ul li:not(.heading) {
    padding-bottom: 20px;
}
.right .newslist li {
    display: flex;
    flex-flow: row wrap;
    align-content: center;
    align-items: center;
    margin: -5px -10px;
}
.right .newslist li > * {
    padding:  5px 10px;
}
.right .newslist li > h3 {
    flex: 1 1 100%;
    font-size: 1.1rem;
    /* text-transform: uppercase;
    letter-spacing: 0.14em; */
}
.right .newslist li p, .right .newslist li img {
    flex: 1 1 200px;
}
.right .newslist li p a {
    white-space: nowrap;
}
.right .newslist li img {
    display: block;
    object-fit: cover;
    object-position: center;
    max-height: 250px;
    width: 150px;
    flex: 0 0 150px;
    margin: 0 0 -150px auto;
    padding: 0;
	border: none !important;
}
.right .newslist li h3 small {
    font-size: 1rem;
    line-height: 1em;
    color: #5f5f5f;
    display: block;
}
.right .archives ul .year {
    cursor: pointer;
    font-weight: 400;
    color: var(--red);
}
.right .archives ul .year i {
    display: inline-block;
    transform: rotate(0deg);
    transition: transform var(--transition-time) ease-in;
}
.right .archives ul.shmo .year i {
    transform: rotate(-180deg);
}
.right .archives ul li {
    padding: 0;
}
.right .archives ul li:not(.year) {
    height: auto;
    max-height: 0;
    overflow: hidden;
}
.right .archives ul li:not(.year) {
    height: auto;
    max-height: 0;
    overflow: hidden;
    transition: max-height var(--transition-time) ease-in;
}
.right .archives ul.shmo li:not(.year) {
    max-height: 30px;
}
.right .links {
    display: flex;
    flex-flow: row wrap;
    align-items: center;
    justify-content: flex-start;
    align-content: flex-end;
    margin: 50px 20px -10px;
}
.right ul.links li {
    padding: 10px;
    margin: 10px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 80px;
}
.right ul.links li.small {
    flex: 1 1 50px;
}
.right ul.links li.large {
    flex: 1 1 100px;
}
.right ul.links li.wide {
    flex: 1 1 100%;
}
.right ul.openings li {
    padding-bottom: 5px;
}
.right .links li a, .right .links li img {
    display: block;
}
.openings > span, .openings > li:not(.heading) {
    display: flex;
}
.openings > span span, .openings > li:not(.heading) span {
    display: inline-block;
    flex: 3 1 210px;
}
.openings > span span.day, .openings > li:not(.heading) span.day {
    flex: 1 1 70px;
}
.right .subnav li a.active {
    font-weight: 700;
}
.right .subnav li:last-child a {
    border-bottom: 0;
}
.nowrap {
  white-space: nowrap;
}
.imgframe {
    border: 0.5px solid #ccc;
}
#main img {
    max-width: 100%;
    height: auto;
}
.float-right {
	float: right;
	margin: 50px !important;
}
.float-left {
	float: left;
	margin: 50px !important;
}

@media (max-width: 800px){
.float-right {
	float: none;
}
.float-left {
	float: none;
}
}

.gallery {
    display: flex;
    flex-flow: row wrap;
    justify-content: flex-start;
    align-items: flex-start;
}
.gallery img {
    display: block;
    flex: 0 0 200px;
}
.gallery a {
    flex: 1 1 200px;
}

button , .button {
    background-color: #bfb8b8;
    display: inline-block;
    margin-bottom: 0;
    font-weight: normal;
    color: #fff;
    text-align: center;
    vertical-align: middle;
    touch-action: manipulation;
    cursor: pointer;
    border: none;
    padding: 30px;
    font-size: 18px;
    line-height: 1em;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    transition: background-color var(--transition-time) ease-in;
}
button , .button:hover {
    background-color: var(--red);
}
.button > * {
    white-space: nowrap;
}
/* Formular */
form {
    text-align: left;
    display: flex;
    flex-flow: row wrap;
    width: calc(100% + 40px);
    margin: 0px -20px;
    padding: 0px;
}
form .form-field, form .form-spacer, .form-actions.secondary-accent, form > label {
    display: block;
    width: 100%;
    margin: 0px 0px 20px;
    padding: 0px 20px;
}
form .form-field.empty {
    margin-bottom: 0;
    margin-top: 0;
    padding-bottom: 0;
    padding-top: 0;
}
form .form-spacer {
    margin-top: -20px;
}
form .form-field {
    box-sizing: border-box;
}
form .form-field.half {
    flex: 1 1 350px;
}
form .form-field.full {
    flex: 1 1 100%;
}
form .form-field .form-label {
    margin-bottom: 5px;
}
form .form-field.default .form-data {
    display: none;
}
.form-input-wrapper, .form-input-wrapper input  {
    width: 100%;
    max-width: none;
}
form .checkboxes {
    display: block;
}
form .checkboxes > label {
    padding: 0;
    margin: 0;
}
.buttons {
    width: 100%;
    flex: 1 1 350px;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    box-sizing: border-box;
    align-self: flex-end;
}
.buttons button {
    border: none;
    box-sizing: border-box;
    flex: 1 1 150px;
    margin: 20px;
}
.form-textarea-wrapper, .form-textarea-wrapper textarea {
    width: 100%;
}
.form-textarea-wrapper textarea {
    min-width: 100%;
    max-width: 100%;
    min-height: 200px;
    resize: none;
}
input, textarea, button {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    font-family: var(--main-font);
} 
input, textarea {
    border: none;
    padding: 5px;
    font-size: 1em;
    box-sizing: border-box;
    font-weight: 300;
    background-color: #fff;
    color: #444;
    border: 5px solid transparent;
    transition: border var(--transition-time) ease-in;
}
input:focus, textarea:focus {
    border: 5px solid #bfb8b8;
}
input[readonly="readonly"] {
    cursor: not-allowed;
    background-color: rgba(255,255,255,0.1);
    color: #fff;
}
.radio {
	display: block;
}
form input[type='checkbox'],
form input[type='radio'] {
  width:auto;
  float:left;
  margin-right: .75em;
  background:transparent;
  border:none;
}

form input[type='checkbox']:checked,
form input[type='checkbox']:not(:checked),
form input[type='radio']:checked,
form input[type='radio']:not(:checked) {
  background: transparent;
  position: absolute;
  visibility: hidden;
  margin:0;
  padding:0;
}

form input[type='checkbox'] + label,
form input[type='radio'] + label {
    cursor: pointer;
    text-indent: -21px;
    display: block;
}

form input[type='checkbox']:checked + label::before,
form input[type='checkbox']:not(:checked) + label::before,
form input[type='radio']:checked + label::before,
form input[type='radio']:not(:checked) + label::before {
    content: '' !important;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 17px;
    height:17px;
    border-radius: 50%;
    position: relative;
    top:-5px;
    background-color: var(--red);
    background-image: url(../img/general/check.png);
    margin-right: 2px;
    background-size: 0%;
    background-repeat: no-repeat;
    background-position: center;
    transition: all .2s ease-in;
    text-align: center;
    font-size: 2rem;
    line-height: 0.5em;
    text-indent: 0px;
    border: none;
}
form input[type=radio]:checked + label::before,
form input[type=radio]:not(:checked) + label::before {
  border-radius: 50%;
}

form input[type='checkbox']:hover  + label::before,
form input[type='radio']:hover  + label::before {
    background-color: var(--red);
    background-size: 65%;
    background-repeat: no-repeat;
    background-position: center;
    transition: all .2s ease-in;
}

form input[type='checkbox']:checked  + label::before,
form input[type='radio']:checked  + label::before {
    background-color: #bfb8b8;
    background-size: 70%;
    background-repeat: no-repeat;
    background-position: center;
    transition: all .2s ease-in;
}
#form-result {
    position: fixed;
    box-shadow: 0 0 10px rgba(0,0,0,0.5);
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 35%;
    height: 35%;
    max-width: 500px;
    max-height: 500px;
    transform: scale(0);
    opacity: 0;
    pointer-events: none;
    transition: all var(--transition-time) ease-in;
    z-index: 200000;
}
#form-result.shownotice {
    opacity: 1;
    transform: scale(1);
    pointer-events: all;
}
div.notices {
    position: absolute;
    height: 100%;
    padding: 0 20px;
    margin: 0;
    position: relative;
    z-index: 2000;
    width: 100%;
    background-color: transparent;
    box-sizing: border-box;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
}
div.notices p > i {
    display: block;
    font-size: 4em;
    margin: -0.3em 0 0.3em;
}
#form-result.shownotice div.notices p > i.fa-check-circle {
    animation: bubb 5s linear;
}

#form-result.shownotice div.notices p > i.fa-circle-notch {
    animation: turn 1s linear infinite;
}
@keyframes bubb {
    0% {transform: scale(1);}
    7% {transform: scale(1);}
    10% {transform: scale(1.1);}
    13% {transform: scale(1);}
    16% {transform: scale(1.1);}
    19% {transform: scale(1);}
    100% {transform: scale(1);}
}
@keyframes turn {
    0% {transform: rotate(0deg);}
    100% {transform: rotate(360deg);}
}
#closeform {
    position: absolute;
    top: 15px;
    right: 15px;
    z-index: 10000;
    cursor: pointer;
}
div.notices.yellow {
    border-left: 0px solid #ba9800 !important;
    background: #fff;
    color: #d89b26 !important;
}
div.notices.red {
    border-left: 0px solid #f14101 !important;
    background: #fff;
    color: #9f1d1d !important;
}
div.notices.blue {
    border-left: 0px solid #005498 !important;
    background: #fff;
    color: #0d5d7f !important;
}
div.notices.green {
    border-left: 0px solid #1d4774 !important;
    background: #fff;
    color: #1d4e1d !important;
}
div.notices p {
    margin: 0 !important;
}

/* Footer */
section.map {
    position: relative;
}
section.map > * {
    display: block;
}
section.map > small {
    position: absolute;
    right: 0;
    bottom: 0;
    padding: 10px 20px;
    border-radius: 20px 0 0 0;
    background-color: #fff;
}
div.prefooter {
    background-color: var(--red);
}
div.prefooter section * {
    color: #fff;
}
.fsubnavi {
    text-align: left;
    -webkit-columns: 80px;
    columns: 80px;
    column-count: auto;
    -webkit-column-gap: 40px;
    column-gap: 40px;
    -webkit-column-count: 2;
    column-count: 2;
    column-fill: balance;
}
.plinks {
    display: flex;
    padding: calc(1em + 25px) 0 0 0;
    justify-content: flex-start;
    align-items: center;
    flex-flow: row wrap;
    align-content: space-around;
}
.plinks > a {
    background-color: #fff;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    border-radius: 100%;
    width: 70px;
    height: 70px;
    margin: 5px;
}
.plinks > a > i {
    color: var(--light-grey);
    font-size: 2.6666rem;
}
.plinks > a > img {
    width: 85%;
}
.certi {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 200px;
    height: 200px;
    margin: 60px 15px 0;
    padding: 0;
}
.certi img {
    min-width: 150px;
    max-width: 150px;
    padding: 25px;
    background-color: #fff;
    border-radius: 100%;
}
.footerbottom {
    padding: 0;
    text-align: center;
}

/* Shariff */
.sharebox {
    width: auto;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    padding: 10px 38px 0;
    box-sizing: border-box;
    z-index: 4;
    position: absolute;
    right: 0;
}
.share {
    display: flex;
    flex-flow: row;
    align-items: center;
    position: relative;
}
.share > p  {
    display: inline-flex;
    cursor: pointer;
    margin: 0;
    height: 21px;
    align-items: center;
    margin-left: 1em;
}
.share > p i {
    line-height: 1em;
    font-size: 19px;
    display: block;
}
.sharebuttons {
    overflow: hidden;
    max-height: 0px;
    width: auto;
    transition: all var(--transition-time) ease-in;
    display: flex;
    flex-flow: column;
    position: relative;
    height: auto;
}
.sharebuttons.visible {
    max-height: 200px;
    opacity: 1;
}
.sharebuttons > div:not(.tosoc) {
    padding: 5px 10px !important;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    background-color: #fff !important;
    width: 100% !important;
    text-align: left;
    height: auto;
}
.sharebuttons > div.tosoc {
    padding: 0px 10px !important;
    display: block;
    background-color: #fff !important;
    width: 100% !important;
    text-align: left;
    height: auto;
}
.sharebuttons .shariff .orientation-horizontal {
    justify-content: flex-start;
}
.sharebuttons .shariff .orientation-horizontal li {
    margin-bottom: 5px;
    margin-right: 5px;
}
.sharebuttons .shariff li,.sharebuttons .shariff li a {
    height: 35px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 35px;
    border-radius: 100%;
}
.sharebuttons > .tosoc p {
    color: #606060;
    margin: 0;
    -webkit-hyphens: auto;
    -moz-hyphens: auto;
    hyphens: auto;
    font-size: 0.8rem;
    line-height: 1.3em;
}
.sharebuttons > div:first-of-type {
    padding-top: 10px!important;
}
.sharebuttons > div:last-child, .sharebuttons > div:only-child {
    padding-bottom: 10px!important;
}
/* Lightbox */
img.pu {
    cursor: pointer;
}
.pu-imagebox {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    max-width: 100vw;
    max-height: 100vh;
    background-color: rgba(0,0,0,0.7);
    z-index: 2000;
    width: auto;
    height: auto;
    padding: 40px;
    display: flex;
    flex-flow: column;
    align-items: center;
    justify-content: space-between;
    box-sizing: border-box;
    pointer-events: none;
    opacity: 0;
    transition: opacity var(--transition-time) ease-in;
}
.pu-imagebox.pu-show {
    pointer-events: all;
    opacity: 1;
    transition: opacity var(--transition-time) ease-in;
}
.pu-sign {
    color: #fff;
    cursor: pointer;
    font-size: 3rem;
    position: absolute;
    -ms-user-select: none;
    -moz-user-select: none;
    -webkit-user-select: none; 
    opacity: 0.7;
    transition: opacity var(--transition-time) ease-in;
}
.pu-sign:hover {
    opacity: 1;
}
.pu-arr {
    top: 0;
    bottom: 0;
    margin: auto;
    height: 1em;
}
.pu-arr#pu-left {
    left: 20px;
}
.pu-arr#pu-right {
    right: 20px;
}
.pu-close {
    top: 15px;
    right: 20px;
}
.pu-imagewrapper {
    position: relative;
    height: calc(100% - 80px);
    width: calc(100% - 80px);
    margin: 0 auto;
}
.pu-imagewrapper img {
    max-width: 100%;
    max-height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    animation: pu-fadein var(--transition-time) ease-in;
}
@keyframes pu-fadein {
    0% {opacity: 0;}
    100% {opacity: 1;}
}
.pu-text {
    color: #fff;
    font-size: 1.5rem;
    text-align: center;
}
@media (max-width:780px){
    
header .headertext {
align-self: flex-end;
font-size: 1.8rem;
}
header .headertext small {
font-size: 1rem;
}
header.large, header {
    height: 50vh;
    min-height: 0;
    background-size: 200% auto;
}
header.large {
    height: 65vh;
    min-height: 350px;
}
.quicklinks .qlitem i {
font-size: 2rem;
}
h1, .h1, h2, .h2, h3, .h3 {
    -webkit-hyphens: auto;
    -moz-hyphens: auto;
    hyphens: auto;
}
h1 {
    font-size: 1.3rem;
}
h2 {
    font-size: 1.1rem;
}
h3 {
	font-size: 1rem;
}
header {
    height: 60vh;
    min-height: 350px;
}
header .htext {
    padding: 0;
}
header .htext .hdeco {
    font-size: 7vw;
    margin-bottom: 0em;
}    
.quicklinks, wrapper {
    padding: 10px 0;
}
.box1, .box2, .box3, .box4, .box5, .boxfull {
    padding: 20px;
}
.content {
    padding: 0;
}
.content > * {
    padding: 0 0px 20px;
}
.flex {
    margin: 0 -40px;
}
.right li h3 {
    font-size: 1.5rem;
}
.sharebox {
    justify-content: flex-end;
    padding: 15px 0 0;
    position: relative;
    width: 100%;
    background-color: #fff;
}
.share > p {
    margin-right: 1em;
}
nav#breadcrumbs {
    display: none;
}
.quicklinks {
    align-items: stretch;
    padding: 10px 15px;
}
.quicklinks > a {
    max-height: 160px;
    padding: 10px;
    margin: 20px 5px -10px;
    min-height: 60px;
}
.quicklinks > * p {
    font-size: 16px;
}
}

@media (max-width:580px){
.datenschutz .box4{
	max-width: calc(100% - 40px);
}
.subnav {
    letter-spacing: 0;
}
}
.empty {
    min-height: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    margin-top: 0 !important;
    opacity: 0 !important;
    margin-bottom: 0 !important;
}

/* SLIDER */

.sliderbox {
    width: 100%;
    height: 400px;
    transition: all var(--transition-time) ease-in;
}

@media (max-width: 600px) {
.sliderbox {
    height: 500px;
    transition: all var(--transition-time) ease-in;
} 
.floatimgr, .floatimgl {
    float: none;
}
.certi {
    margin: 0px;
}
}

@media (max-width: 400px) {
.sliderbox {
    height: 600px;
    transition: all var(--transition-time) ease-in;
}    
}

.slider {
    width: 100%;
    height: 100%;
    overflow: hidden;
    position: relative;
}
.slider ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.slider ul.sslides li {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.slider ul li.slitem .sltext {
    position: absolute;
    z-index: 2;
    font-weight: 300;
    transform: translateX(100%);
    opacity: 0;
    padding: 60px;
}
.slider ul li.slitem .sltext p {
    margin: 0;
}
.slider ul li.slitem .sltext p span {
    display: block;
    font-size: 3rem;
    line-height: 1em;
    letter-spacing: 0.14em;
    margin-bottom: 0.1em;
}
.slider ul li.slitem.slactive .sltext {
    transform: translateX(0);
    transition: transform 1s ease-in-out 1s, opacity 1s ease-in-out 1s;
    opacity: 1;
}
.slider ul li.slitem.slout .sltext {
    transform: translateX(-100vw);
    transition: transform 1s ease-in-out, opacity 1s ease-in-out;
}
.slider ul.slpag {
    z-index: 100;
    position: absolute;
    bottom: 70px;
    left: 0;
    right: 0;
    text-align: center;
    pointer-events: none;
}
.slider ul.slpag li {
    display: inline-block;
    width: 15px;
    height: 15px;
    margin: 5px;
    background-color:rgb(192,188,189);
    border-radius: 100%;
    cursor: pointer;
    transition: all var(--transition-time) ease-in;
    box-shadow: 0 0 0 0 rgba(255,255,255,0);
    pointer-events: auto;
}
.slider ul.slpag li.slsel {
    background-color:rgb(var(--red-rgb));
}
.slider ul.slpag li:hover {
    box-shadow: 0 0 0px 20px rgba(var(--red-rgb),0.1);
}
.slider .slarr {
    position: absolute;
    z-index: 100;
    top: 0;
    bottom: 0;
    height: 100%;
    width: 20px;
    margin: auto;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
}
.slider .slarr i {
    display: block;
    width: 1em;
    height: 1em;
    border-radius: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: rgba(var(--red-rgb),0);
    box-shadow: 0 0 0 0 rgba(255,255,255,0);
    transition: all var(--transition-time) ease-in;
}
.slider .slarr:hover i {
    background-color: rgba(var(--red-rgb),0.1);
    box-shadow: 0 0 0 50px rgba(255,255,255,0.1);
}
.slider .slarr#prev {
    left: 10px;
}
.slider .slarr#next {
    right: 10px;
}

@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(../fonts/montserrat.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Montserrat';
  font-style: italic;
  font-weight: 100 900;
  font-display: swap;
  src: url(../fonts/montserrat-italic.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

body.loaded {
    --transition-time: .5s;
    opacity: 1;
}