@charset "UTF-8";
/* CSS Document */
@import 'fonts.css';

/* reset */
html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,font,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td { border:0; font-size:100%; margin:0; padding:0; }
a { outline:none; }
table { border-collapse:collapse; border-spacing:0; }
fieldset,img { border:0; }
del,ins { text-decoration:none; }
caption,th { text-align:left; }
h1,h2,h3,h4,h5,h6 { font-size:100%; font-weight:normal; }
q:before,q:after { content:''; }
abbr,acronym { border:0; font-variant:normal; }
sup,sub { vertical-align:baseline; }
legend { color:#000; }
input,button,textarea,select,optgroup,option { font-family:inherit; font-size:inherit; font-style:inherit; font-weight:inherit; }
input,button,textarea,select { font-size:100%; }

/* Clearfix */
.clearfix:before, .clearfix:after {content: " "; display: table;}
.clearfix:after {clear: both;}
/*.clearfix {*zoom: 1;} removed, is depricated and not linger neccessary*/

*, *:before, *:after {padding: 0; -webkit-box-sizing:border-box; -moz-box-sizing:border-box; -o-box-sizing:border-box; -ms-box-sizing:border-box; box-sizing:border-box;}
figure, figure:before, figure:after {padding: 0; margin: 0; -webkit-box-sizing:border-box; -moz-box-sizing:border-box; -o-box-sizing:border-box; -ms-box-sizing:border-box; box-sizing:border-box;}

html {-webkit-text-size-adjust: 100%;
--black: rgba(0,0,0,1);
--white: rgba(255,255,255,1);
--overlay: rgba(0,0,0,0.25);
--color: rgba(0,255,0,1);
--grey: rgba(217,218,218,1);
}

body {margin:0; font-family: 'Bitter', serif; color: var(--black); line-height: 1.5; background: var(--grey);}
body.open-panel {height: 100%; overflow: hidden;}

/***************************** FORMAT *****************************/
h1, h2 {font-size: 1.75em;}
h3, h4, h2.small {font-size: 1.375em;}
h5, h6, h3.small {font-size: 1.25em;}
h1 a, h2 a, h3 a, h4 a, h5 a, h6 a {color: inherit; border: 0 !important; text-decoration: none;}
.footer h1 {font-size: 1em;}

p + h1, p + h2, p + h3, p + h4, p + h5, p + h6,
ul + h1, ul + h2, ul + h3, ul + h4, ul + h5, ul + h6,
ol + h1, ol + h2, ol + h3, ol + h4, ol + h5, ol + h6 {margin-top: 0.75em;}

h1 + p, h2 + p, h3 + p, h4 + p, h5 + p, h6 + p,
h1 + ul, h2 + ul, h3 + ul, h4 + ul, h5 + ul, h6 + ul,
h1 + ol, h2 + ol, h3 + ol, h4 + ol, h5 + ol, h6 + ol {margin-top: 0.375em;}

hr + p, hr + ul, hr + ol, hr + h1, hr + h2, hr+ h3, hr + h4, hr + h5, hr + h6,
p + hr, ul + hr, ol + hr, h1 + hr, h2 + hr, h3 + hr, h4 + hr, h5 + hr, h6 + hr {margin-top: 1em;}

p + p, ul + p, ol + p {margin-top: 0.75rem;}
p + ul, p + ol {margin-top: 0.25rem;}
blockquote > *, .big {font-size: 1.125em;}

b, strong, .bold {font-variant: normal; font-weight: 600;}
.medium {font-weight: 500;}

ul {list-style-type: none;}
ul li {padding: 0 0 0.25rem 0.5rem; position: relative;}
ul li:before {content: '\00b7'; position: absolute; left: 0;}
ul li:last-of-type, ol li:last-of-type {padding-bottom: 0;}

ol {list-style: none; counter-reset: list-count;}
ol li {padding: 0 0 0.25rem 1.375rem; position: relative; counter-increment: list-count;}
ol li:before {content: counter(list-count) '.'; position: absolute; left: 0; vertical-align: bottom;}

sub, sup, .sub, .sup {font-size: 0.75em;}
sub, .sub {vertical-align: sub;}
sup, .sup {vertical-align: top;}

.white, .white:not(:hover) *, .white a.phone, .white a.phone:hover {color: var(--white);}

footer {font-style: inherit;}
footer li {padding: 0;}
footer li:before {content: '';}

.sr-only {position: absolute; text-indent: -9999em; color: rgba(255,255,255,1); width: 1px; height: 1px; overflow: hidden;}

/***************************** LINKS/SPANS *****************************/
a {text-decoration: none; color: inherit;
transition: color .3s, background-color .3s, background-size .3s, border .3s, opacity .3s;}
a:hover {color: rgba(127,127,127,1);}

a.phone, a.phone:hover {color: rgba(0,0,0,1); cursor: text;}

a:focus-visible, button:focus-visible {outline-style: auto;}

button {-webkit-appearance: none; -moz-appearance: none; appearance: none; background: none; border: none; border-radius: none;}
button:hover {cursor: pointer;}

.skip-link {display: block; padding: 0.5rem 1rem; background: var(--white); position: absolute; top: 0; left: 50%; transform: translate(-50%,-100%); transition: all .3s;}
.skip-link:focus {transform: translate(-50%,0); z-index: 10;}

.white .ul, .white .ul-rev {background-image: linear-gradient(0deg, var(--white), var(--white));}
.ul {background: linear-gradient(0deg, var(--black), var(--black)) no-repeat left bottom / 100% 0.0625em;}
.ul-rev {background: linear-gradient(0deg, var(--black), var(--black)) no-repeat right bottom / 0 0.0625em;}
.ul:hover, .ul:focus-visible, a:hover .ul, .ul.download:hover {background-size: 0 0.0625em; background-position-x: right;}
.ul-rev:hover, .ul-rev:focus-visible, a:hover .ul-rev {background-size: 100% 0.0625em; background-position-x: left;}

/***************************** LAYOUT *****************************/
/* BASIC */
.wrapper {height: auto; margin: 0 auto; max-width: 32rem; position: relative;}
.main-wrap {min-height: 100vh;}
main {display: block; padding-top: 2rem;}

/* HEADER */
#mh {position: relative; width: 100%; z-index: 2; padding-top: 1rem;}
.logo {height: 2.5rem; width: auto; margin: 0 auto;}
.logo svg {height: 100%; width: auto;}
.logo a {display: block; height: 100%; width: 100%;}

/*#mh.fixed {position: fixed; top: 0;}*/

/* NAVI */

/* nav pull */
#pull, .burger:before {top: 50%; -ms-transform: translateY(-50%); -webkit-transform: translateY(-50%); transform: translateY(-50%);}
#pull {width: 2.5rem; height: 2.5rem; padding: 0.625rem 0 0.625rem 0.75rem; position: absolute; top: 50%; right: 1rem; z-index: 12;}

.burger-wrap {position: relative; width: 100%; height: 100%;}

.burger, .burger:before, .burger:after {width: 100%; height: 0.25rem; display: block; background: rgba(0,0,0,1);
-webkit-transition: all 0.3s; -ms-transition: all 0.3s; transition: all 0.3s;}
.burger:before, .burger:after {position: absolute; content: '';}
.burger:after {bottom: 0; top: auto;}

.open .burger {background: none;}
.open .burger:before {top: 50%;
-webkit-transform: translateY(-50%) rotate(45deg); -ms-transform: translateY(-50%) rotate(45deg); transform: translateY(-50%) rotate(45deg);}
.open .burger:after {top: 50%; bottom: auto;
-webkit-transform: translateY(-50%) rotate(-45deg); -ms-transform: translateY(-50%) rotate(-45deg); transform: translateY(-50%) rotate(-45deg);}

/* IMAGES / SLIDER / MEDIA */
figure img, svg {width: 100%; display: block;}
.stretch-w img {width: 100%; height: auto;}
.stretch-h img {width: auto; height: 100%;}

.img-wrap {position: relative; width: 100%;}
.img-wrap img {position: absolute; top: 50%; left: 50%; -ms-transform: translate(-50%,-50%); -webkit-transform: translate(-50%,-50%); transform: translate(-50%,-50%);}
.img-low .img-wrap {padding-bottom: 56.25%;}
.img-mid .img-wrap {padding-bottom: 66.66%;}

.headimg figure {padding-bottom: 50%;}

@supports (object-fit: cover){
.stretch-w img, .stretch-h img {width: 100%; height: 100%; object-fit: cover;}
}
@supports (aspect-ratio: 1/ 1) {
.img-wrap {padding-bottom: 0 !important;}
.img-wrap img {position: relative; top: auto; left: auto; -ms-transform: translate(0,0); -webkit-transform: translate(0,0); transform: translate(0,0);}
.img-low .img-wrap {aspect-ratio: 16 / 9;}
.img-mid .img-wrap {aspect-ratio: 3 / 2;}
.headimg figure {aspect-ratio: 2 / 1;}
}
.video {padding-bottom: 56.25%; position: relative;}
.video iframe, .video video {width: 100%; height: 100%; position: absolute; top: 0; left: 0;}


.headimg {position: relative; max-height: 60vh;}
.headimg figure {min-width: 100%; max-width: 100%; height: 100%; max-height: 60vh !important;} /* um auch bei alten iOS die max-height richtig einzuhalten */

.headslider figcaption {position: absolute; top: 0; left: 0; background: rgba(255,255,255,0.5);}

.play-icon {position: relative; width: 2rem; height: 2rem; display: block; background: var(--black); border-radius: 50%; border: 0.0625rem solid var(--white); opacity: .66; transition: opacity .3s, border .3s; margin: 0 !important;}
.play-icon:after {content: ''; display: block; position: absolute; top: 50%; left: 50%; transition: border .3s;}
.play:after {width: 30%; height: 50%; border-left: 0.125rem solid var(--white); border-right: 0.125rem solid var(--white); transform: translate(-50%,-50%); -webkit-transform: translate(-50%,-50%);}
.pause:after {width: 0; height: 0; border-style: solid; border-width: 0.5rem 0 0.5rem 0.75rem; border-color: transparent transparent transparent var(--white); transform: translate(-33.33%,-50%); -webkit-transform: translate(-33.33%,-50%);}

.play-btn {padding: 1rem; position: absolute; bottom: 0; right: 0;}
.play-btn:focus-visible {outline: none;}
.play-btn:focus-visible .play-icon {outline: auto;}
.play-btn:hover .play-icon, .play-btn:focus-visible .play-icon {opacity: 1 !important; border-color: var(--color);}

.slick-arrows .play-btn {right: auto; bottom: auto; left: 50%; top: 50%; transform: translate(-50%,-50%); z-index: 1; pointer-events: auto;}
.slick-arrows .play-icon {opacity: 0;}
.slick-arrows:hover .play-btn .play-icon {opacity: 0.66;}
.slick-arrows .play-btn:hover .play-icon {opacity: 1;}

@media (prefers-reduced-motion: reduce) {
.slick-arrows .play-icon {opacity: 0.75;}
}

/* CLS Fix - Slider */
.headslider, .slider {display: -webkit-box; display: -moz-box; display: -ms-flexbox; display: -webkit-flex; display: flex; flex-flow: row nowrap; -ms-flex-wrap: nowrap; overflow: auto; width: 100%;}
.slide {-webkit-box-flex: initial; -webkit-flex: 1 0 auto; -ms-flex: 1 0 auto; flex: initial; position: relative; float: left; padding: 0; width: 100%; min-width: 100%;}
.slick-initialized .slide {min-width: initial;}

/* CONTENT */
.content {position: relative;}
.block, .cols, .col, .row, .single-head {position: relative; width: 100%;}
.col figure {overflow: hidden;}

.cols, .rows {display: -webkit-box; display: -moz-box; display: -ms-flexbox; display: -webkit-flex; display: flex; flex-flow: row wrap; -ms-flex-wrap: wrap;}
.col, .row {-webkit-box-flex: initial; -webkit-flex: 1 0 auto; -ms-flex: 1 0 auto; flex: initial; position: relative; float: left;}
.mob-cols .col {width: auto;}
.rows {flex-direction: column; flex-wrap: nowrap;}

.pad {padding: 1rem;}

.bg-img {position: relative; max-width: 64rem; z-index: -1; margin-left: auto; margin-top: auto;}

/* accordion */
/*.accordion.pad {padding: 0 1rem;} auskommentieren für farbige hintergründe */
.acc-head {position: relative; padding: 1rem 0;}
.acc-head button {width: 100%; justify-content: space-between; align-items: center;}
.acc-head span {padding-right: 1rem;}

.acc-head .cross {width: 1.375rem; height: 1.375rem; position: relative;}
.hidden-pull.open .cross:before {-ms-transform: translate(-50%,-50%) rotate(90deg); -webkit-transform: translate(-50%,-50%) rotate(90deg); transform: translate(-50%,-50%) rotate(90deg);}

.acc-entry + .acc-entry {border-top: 0.125rem solid var(--black);}

.acc-cont {padding: 0 0 1.5rem 0; display: none;}

@media (scripting: none){
.no-js .acc-cont {display: block;}
}


/* single page */
.single-head {padding-bottom: 0;}
.text-col-s + .text-col-l, .text-col-l + .text-col-s {margin-top: 1.25rem;}

/* map */
.map-wrap {width: 100%; height: 0; padding-bottom: 90%; position: relative; overflow: hidden;}
.map {width: 100%; height: 100%; position: absolute; left: 0; top: 0; z-index: 0;}
.popup-cont {display: none;}

/* SIDE PANEL */
.close-btn {position: absolute; top: 1rem; right: 1rem;}
.side-inner {padding: 0 0 2rem 0;}

.panel-foot {margin-top: 1.5rem; width: 100%; text-align: center;}
.panel-foot .close-small {width: auto; margin: 0 auto;}


/* loader */
.loader-wrap {width: 100%; height: 100%; /*max-height: 101vh;*/ position: absolute; top: 0; left: 0; background: rgba(255,255,255,1); z-index: 100; }
.loader {width: 20%; height: 0; padding-bottom: 20%; position: absolute; top: 50vh; left: 50%; transform: translate(-50%,-50%);}

.loader-icon {width: 100%; height: 100%; position: absolute; top: 50%; left: 50%;}

.loader-icon {background: url(../images/layout/loading-icon.svg) center center/ 50% auto no-repeat; z-index: 1; -ms-animation: rotate 2s infinite linear; -webkit-animation: rotate 2s infinite linear; animation: rotate 2s infinite linear;}

/* small close */
.close-small {align-items: center;}
.close-small .close {width: 1em; height: 1em; position: relative; transition: background .3s; margin-right: 0.5em;}
.close-small .cross {-ms-transform: rotate(45deg); -webkit-transform: rotate(45deg); transform: rotate(45deg);}

.cross:before, .cross:after {display: block; content: ''; width: 0.125rem; height: 100%; position: absolute; top: 50%; left: 50%; background: var(--black); transition: all .3s;}
.cross:before {-ms-transform: translate(-50%,-50%); -webkit-transform: translate(-50%,-50%); transform: translate(-50%,-50%);}
.cross:after {-ms-transform: translate(-50%,-50%) rotate(90deg); -webkit-transform: translate(-50%,-50%) rotate(90deg); transform: translate(-50%,-50%) rotate(90deg);}

/* FOOTER */
.footer {background: var(--black); position: relative;}
.mf-inner {padding: 1rem 0;}
.mf-icon svg {width: 2.5rem; fill: var(--white);}

.footer .main-col .col {width: 100%; max-width: 100%;}

/* back top*/
.arrow-top:before, .arrow-top:after {width: 0.125rem; height: 1rem; content: ''; position: absolute; display: block; background: rgba(255,255,255,1); top: 0;}

.arrow-top:before {transform: rotate(45deg); -webkit-transform: rotate(45deg); left: 0.625rem;}
.arrow-top:after {transform: rotate(-45deg); -webkit-transform: rotate(-45deg); right: 0.625rem;}

#back-top {width: 2.5rem; height: 2.5rem; position: fixed; right: 1rem; bottom: 1rem; display: none; z-index: 1;}
#back-top button, #back-top button:active {width: 2.5rem; height: 2.5rem; display: block; padding: 0.625rem 0.25rem; background: rgba(0,0,0,0.3); border-radius: 50%; -webkit-border-radius: 50%; transition: background 0.3s; -webkit-transition: background 0.3s;}
#back-top button:hover {background: rgba(0,0,0,1);}
#back-top .arrow-top {width: 2rem; height: 1.25rem; position: relative;}

#back-top button:hover .arrow-top {animation: pulse 0.5s 1;}

/* responsiveness
--------------------------------------------- */

/* small only */
@media screen and (max-width:48em) {
.lightbox .rows {flex-direction: row;}
.lightbox .row/*, .lightbox .col-m*/ {width: 50%; max-width: 50%;}

.footer .main-col .pad + .pad {padding-top: 0;}
}

/* medium */
@media screen and (min-width:48em) {

/***************************** LAYOUT *****************************/
/* BASIC */
.wrapper {max-width: 44rem;}

/* HEADER */
.logo {height: 3rem;}

/* NAVI */
.menu {width: 50%;}

/* CONTENT */
.col-s, .col-l-s {width: 33.33%; max-width: 33.33%;}
.col-m {width: 50%; max-width: 50%;}
.col-l, .col-l-m, .col-s-l {width: 66.66%; max-width: 66.66%;}

.bg-img {width: 75%; bottom: -3rem;}

/* map */
.map-wrap {padding-bottom: 56.25%;}

/* FOOTER */
.footer .main-col {flex-grow: 2;}
.footer .main-col .col {width: 33.33%; max-width: 33.33%;}
}

/* large */
@media screen and (min-width:64em) {

/***************************** LAYOUT *****************************/
/* BASIC */
.wrapper {max-width: 60rem;}

/* HEADER */
.logo {height: 3.5rem;}
#mh {padding-top: 2rem;}

/* NAVI */
.nav-panel, .menu {position: relative; width: auto; right: auto; top: auto; z-index: 0; height: auto; -ms-transform: translateX(0); -webkit-transform: translateX(0); transform: translateX(0);}
#mn {position: relative; width: auto; right: auto; top: auto; padding: 0 1rem 0 3rem; margin-left: auto;}
.menu {width: auto; max-width: 100%; position: relative; background: none; padding: 0; display: -webkit-box; display: -moz-box; display: -ms-flexbox; display: -webkit-flex; display: flex; flex-flow: row nowrap; -ms-flex-wrap: nowrap; justify-content: flex-end; align-items: center; overflow: initial;}

#mn li {border-top: none; padding: 0 0.5rem; margin: initial; -webkit-box-flex: initial; -webkit-flex: 1 0 auto; -ms-flex: 1 0 auto; flex: initial; position: relative; float: left;}
#mn li a {padding: 0.75rem 0 0 0;}
#mn li:first-of-type {padding-left: 0;}
#mn li:last-of-type {padding-right: 0;}

#mn.open ul {box-shadow: none;}

/* nav pull */
#pull {display: none;}

/* CONTENT */
.bg-img {max-width: 66.66%; bottom: -5rem;}

/* single page */
.single-page {}

.text-col-s + .text-col-l, .text-col-l + .text-col-s {margin-top: 0;}
.text-col-s {width: 30%; max-width: 30%;}
.text-col-l {width: 70%; max-width: 70%;}

.mc-right .text-col-s {padding-right: 0.75rem;}
.mc-right .text-col-l {padding-left: 1.5rem;}
.mc-left .text-col-s {padding-left: 0.75rem;}
.mc-left .text-col-l {padding-right: 1.5rem;}

.text-xl {width: 80%;}

/* FOOTER */
.mf-icon {padding-right: 2rem;}
}

@media screen and (min-width:74em) {

/***************************** LAYOUT *****************************/
/* HEADER */
.logo {height: 4rem;}
#mh {padding-top: 3rem;}

/* BASIC */
.wrapper {max-width: 70rem;}

.bg-img {width: 60%;}
}

@media screen and (min-width:100em) {
/* HEADER */
.logo {height: 4.5rem;}
#mh {padding-top: 4rem;}

.bg-img {width: 50%; bottom: -7.5rem;}
}

@media screen and (min-width:120em) {
body {font-size: 1.2em;}

/* BASIC */
.wrapper {max-width: 90rem;}

/* FOOTER */
.mf-icon {padding-right: 2.5rem;}
.mf-icon svg {width: 3rem;}
}
/* end responsiveness
--------------------------------------------- */

* + .no-marg, .footer p + p, .footer h1 + p {margin-top: 0;}


@-webkit-keyframes pulse {
0%, 100% {transform: scale(1);}
50% {transform: scale(1.1);}
}
@-moz-keyframes pulse {
0%, 100% {transform: scale(1);}
50% {transform: scale(1.1);}
}
@keyframes pulse {
0%, 100% {transform: scale(1);}
50% {transform: scale(1.1);}
}

@-webkit-keyframes rotate {
0% {transform: translate(-50%,-50%) rotate(0deg);}
100% {transform: translate(-50%,-50%) rotate(360deg);}
}
@-moz-keyframes rotate {
0% {transform: translate(-50%,-50%) rotate(0deg);}
100% {transform: translate(-50%,-50%) rotate(360deg);}
}
@keyframes rotate {
0% {transform: translate(-50%,-50%) rotate(0deg);}
100% {transform: translate(-50%,-50%) rotate(360deg);}
}
