/* FARBEN 
dunkelblau - #5c6c79
hellblau   - #cdd5d8
dunkelrot  - #a02a3a
*/

/* ################################################# SCHRIFTEN   */

/* montserrat-300 - latin */
@font-face {
  font-display: swap;
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 300;
  src: url('/fonts/montserrat-v26-latin-300.woff2') format('woff2'); 
}
/* montserrat-regular - latin */
@font-face {
  font-display: swap;
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  src: url('/fonts/montserrat-v26-latin-regular.woff2') format('woff2'); 
}
/* montserrat-500 - latin */
@font-face {
  font-display: swap;
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 500;
  src: url('/fonts/montserrat-v26-latin-500.woff2') format('woff2'); 
}
/* montserrat-600 - latin */
@font-face {
  font-display: swap; 
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 600;
  src: url('/fonts/montserrat-v26-latin-600.woff2') format('woff2'); 
}
/* montserrat-700 - latin */
@font-face {
  font-display: swap; 
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  src: url('/fonts/montserrat-v26-latin-700.woff2') format('woff2'); 
}


/* ################################################# RESET - ALLGEMEIN */
* {
    font-family: "Montserrat", "Source Serif Pro", serif;
    font-weight: 400;
    font-size: 21px;
    line-height: 26px;
    font-size: 18px;
    line-height: 25px;
    box-sizing: border-box;
    text-decoration: none;
}

html,
body {
    background-color: rgba(249, 248, 243, 0.8);
    background-color: rgba(205, 213, 216, 0.25);
    color: #666666;
    color: #333333;
    padding: 0;
    margin: 0;
    /* padding-top: 50px; */
}
:focus {
    outline: 0;
}

.container {
    width: 100%;
    /* max-width: 1499px; */
    margin: 0 auto;
    /* background-color: white; */
    padding: 0 0px;
}
.limit,
.spalten.limit {
    width: 100%;
    max-width: 1499px;
    margin-left:auto;
    margin-right:auto;
    padding: 0;
}

/* ################################################# TYPO */

p {
    display: block;
    margin: 0 0 15px 0;
}
sub, sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
}
sup {
    top: -0.5em;
}
sub {
    bottom: -0.25em;
}
a {
    color: inherit;
}
a:hover {
    color: inherit;
    text-decoration: underline;
}
a[href$=".pdf"],
a.linkbutton {
    color: #9aa3a8;
    text-decoration: none;
}
a[href$=".pdf"]:hover,
a.linkbutton:hover {
    color: white;
    text-decoration: none;
}

.SEITE_131 a[href$=".pdf"] {
    color: black;
    background-color: transparent;
    text-decoration: none;
    border:1px solid black;
    border-radius: 24px;
    padding:10px 25px;
    display: inline-block;
}
.SEITE_131 a[href$=".pdf"]:hover {
    background-color: white;
}

h2 {
    font-family: "Montserrat", sans-serif;
    font-weight: normal;
    margin: 0;
    font-size: 42px;
    line-height: 44px;
    font-weight: 700;
    font-weight: 600;
    text-transform: uppercase;
}
h3 {
    font-family: "Montserrat", sans-serif;
    font-weight: 300;
    margin: 0;
    font-size: 28px;
    line-height: 38px;
    text-transform: uppercase;
}
h4 {
    font-family: "Montserrat", sans-serif;
    font-weight: 700;
    font-weight: 600;
    margin: 0;
    font-size: 28px;
    line-height: 38px;
/*     text-transform: uppercase; */
    margin-bottom:16px;
}

b,
strong {
    font-weight: 700;
    font-weight: 600;
}
em,
i {
    color: #ffd318 !important;
    font-style: normal;
}
.text-center {
    text-align: center;
}
.text-left {
    text-align: left;
    text-align: justify;
}
.text-right {
    text-align: right;
}
.text-text-justify {
    text-align: justify;
}

.hyphens {
    hyphens: auto;
}

/* ################################################# FARBEN   */

.text-grau {
    color: #666666 !important;
}
.text-beige {
    color: #c5b58d !important;
}
.text-weiss {
    color: #ffffff !important;
}
/* .text-grau.schatten {
    text-shadow: 0px 0px 20px white;
}
.text-weiss.schatten, 
.text-beige.schatten {
    text-shadow: 0px 0px 20px black;
} */


hr.text-grau {
    background-color: #666666 !important;
}
hr.text-beige {
    background-color: #c5b58d !important;
}
hr.text-weiss {
    background-color: #ffffff !important;
}


.hintergrund-schwarz {
    background-color: #000000;
}
.hintergrund-weiss {
    background-color: #ffffff;
}

/* -------------- HINTERGRUND TRANSPARENT   */

.hintergrund-transparent-schwarz {
  background-color:rgba(0, 0, 0, 0.9);
  color:white;
}
.hintergrund-transparent-gruen {
  background-color:rgba(10, 61, 43, 0.9);
  color:white;
}
.hintergrund-transparent-grau {
    background-color: rgba(102, 102, 102, 0.9);
    color: white;
}
.hintergrund-transparent-beige {
    background-color: rgba(237, 231, 217, 0.9);
    color: #666666;
}
.hintergrund-transparent-weiss {
    background-color: rgba(255, 255, 255, 0.9);
    color: #666666;
}

.hintergrund-transparent-schwarz,
.hintergrund-transparent-schwarz h4,
.hintergrund-transparent-schwarz a,
.hintergrund-transparent-schwarz a:hover,
.hintergrund-transparent-grau,
.hintergrund-transparent-grau h4,
.hintergrund-transparent-grau a,
.hintergrund-transparent-grau a:hover,
.hintergrund-transparent-gruen,
.hintergrund-transparent-gruen h4,
.hintergrund-transparent-gruen a,
.hintergrund-transparent-gruen a:hover {
    color: white;
}
.hintergrund-transparent-schwarz #close:before, 
.hintergrund-transparent-schwarz #close:after,
.hintergrund-transparent-grau #close:before, 
.hintergrund-transparent-grau #close:after,
.hintergrund-transparent-gruen #close:before, 
.hintergrund-transparent-gruen #close:after {
    background-color: white;
}

.hintergrund-transparent-beige,
.hintergrund-transparent-beige h4,
.hintergrund-transparent-beige a,
.hintergrund-transparent-beige a:hover,
.hintergrund-transparent-weiss,
.hintergrund-transparent-weiss h4,
.hintergrund-transparent-weiss a,
.hintergrund-transparent-weiss a:hover {
    color: #666666;
}
.hintergrund-transparent-beige #close:before, 
.hintergrund-transparent-beige #close:after,
.hintergrund-transparent-weiss #close:before, 
.hintergrund-transparent-weiss #close:after {
    background-color: #666666;
}

a.boxlink:hover {
    font-weight: 700;
}

/* ################################################# AKTUELLES   */

#aktuelles {
  width:100%;
  max-width: 360px;
  position: fixed;
  position: absolute;
  top:180px;
  right:20px;
  padding: 40px 20px 25px 20px;
  z-index: 70000;
  /* background: rgba(255,255,255,0.95); */
  margin: 0 auto;
}
#aktuelles a {
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  display: block;
  text-align: center;
  padding: 7px 20px 6px 20px;
  text-transform: uppercase;
  background-color: #c5b58d !important;
  color:white !important;
}
#aktuelles a:hover {
  color:#666666 !important;
  color:#333333 !important;
}
#aktuelles h2 {
  font-size: 26px;
  line-height: 28px;
  font-weight: 400;
}
#aktuelles * {
font-size: 17px;
line-height: 20px;
}
#close {
  position: absolute;
  right: 16px;
  top: 16px;
  width: 32px;
  height: 32px;
  width: 16px;
  height: 16px;
  opacity: 0.5;
}
#close:hover {
  opacity: 1;
  cursor:pointer;
}
#close:before, #close:after {
  position: absolute;
  left: 8px;
  content: ' ';
  height: 16px;
  width: 2px;
  background-color: black;
}
#close:before {
  transform: rotate(45deg);
}
#close:after {
  transform: rotate(-45deg);
}

/* ################################################# AKTUELLES MEHRERE BLOECKE  */

#aktuelles2 {
  width:100%;
  max-width: 360px;
  position: absolute;
  top:110px;
  right:0px;
  padding: 0px;
  z-index: 70000;
  /* background: rgba(255,255,255,0.9); */
  margin: 0 auto;
}
#aktuelles2 a {
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  display: block;
  text-align: center;
  padding: 7px 20px 6px 20px;
  text-transform: uppercase;
  background-color: #c5b58d !important;
  color:white !important;
}
#aktuelles2 a:hover {
  color:#666666 !important;
}
#aktuelles2 h2 {
  font-size: 26px;
  line-height: 28px;
}
#aktuelles2 * {
font-size: 18px;
line-height: 22px;
}
.close {
  position: absolute;
  right: 16px;
  top: 16px;
  width: 32px;
  height: 32px;
  opacity: 0.5;
}
.close:hover {
  opacity: 1;
  cursor:pointer;
}
.close:before, .close:after {
  position: absolute;
  left: 15px;
  content: ' ';
  height: 33px;
  width: 2px;
  background-color: black;
}
.close:before {
  transform: rotate(45deg);
}
.close:after {
  transform: rotate(-45deg);
}

/* ################################################# HEADER   */

header {
    position: fixed;
    top:0;
    left:0;
    right:0;
    z-index: 80000;
    background: #f2f2f0;
    background: rgba(242, 242, 240, 0.9);
    background: rgba(255, 255, 255, 0.9);
    /* box-shadow: 0 5px 10px rgba(0,0,0,0.5); */
}

header .limit {
    text-align: center;
    display: flex;
    flex-direction: row;
    height:100px;
    justify-content: space-between;
}
#header {
    position: relative;
    z-index: 80000;
    text-align: center;
}
.logo {
  width:256px;
  height:
    margin: 0px 20px 0px 20px;
    
}
#logo img {
  width:auto;
  height: 205px;
  transition: height ease-in-out .5s; 
}
body.smaller #logo img {
  height: 100px;
  transition: height ease-in-out .5s;
    
}

/* ################################################# ARTICLE / MAIN  */

article {
  min-height:75vh;
  min-height: calc(100vh - 430px);
  margin-top: 100px;
}

article a {
  color: inherit;
  text-decoration: underline;
  text-underline-position: under;
  text-decoration-thickness: 2px;
  text-underline-offset: -2px;
  text-decoration-color: var(--signal);
}
article a:hover {
  color: var(--signal);
  text-decoration-color: var(--signal);
}
/* ################################################# Tooltipp  */

.tooltip {
    display:none;
    position:absolute;
    background-color:black;
    border-radius:4px;
    padding:4px 10px;
    color:#fff;
    font-weight: 700;
    font-family: "Montserrat", sans-serif;
    font-size:18px;
    text-transform: uppercase;
    letter-spacing: 1px;
    z-index: 99999;
}
.tooltip:after {
    content: "";
    position: absolute;
    top: 7px;
    left: -20px;
    border-width: 10px;
    border-style: solid;
    border-color: transparent black transparent transparent;
}

/* ################################################# FOTOBOX BREIT  */

.spalten.links {
    flex-direction: row-reverse;
}
.spalten.rechts {
    flex-direction: row;
}
.spalten.oben {
    align-items: flex-start;
}
.spalten.unten,
.spalte.unten {
    align-items: flex-end;
}
.spalte.foto.unten {
    justify-content: flex-end;
}
.spalten.links .spalte.foto {
    text-align: right;
}
.spalte.foto {
    padding-top: 40px;
    padding-bottom: 40px;
    padding-top: 0;
    padding-bottom: 0;
}
.spalte.text {
    padding-bottom: 40px;
}
.spalte .link a {
    display: block;
    /* background: silver; */
    text-align: center;
    font-family: "Montserrat", sans-serif;
    font-weight: 700;
    margin: 0;
    font-size: 20px;
    line-height: 38px;
    text-transform: uppercase;
    
    background: transparent;
    /* background-color: rgba(0,0,0,0.05); */
    border: 1px solid;
    border-radius: 12px;
    font-weight: 400;
    /* color: #333; */
    font-size: inherit;
}
.spalte .link a:hover {
  color: white;
  background-color: #333;
  text-decoration: none;
}
/* ################################################# FOTOSLIDER - MASKE - TEXT - LINK  */
#startbox {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
}

.foto_slider.slick-initialized.slick-slider.slick-dotted {
    /* max-height: 300px !important; */
}
.slickslider {
    position: relative;
    width: 100%;
}
.slick-slider .slick-track {
    display: flex;
}
.slick-slide {
    height: auto !important;
}
.slide img,
.maske img {
    width: 100%;
    max-width: 100%;
    height: auto;
}
.slick-prev,
.slick-next {
    font-size: 0;
    line-height: 0;

    position: absolute;
    bottom: 25%;
    display: block;
    width: 35px;
    height: 60px;
    padding: 0;

    cursor: pointer;

    color: transparent;
    border: none;
    outline: none;
    background: transparent;
}

.slick-prev {
    left: 25px;
    z-index: 8888;
    background-image: url(/resources/arrow-left.svg);
}
.slick-next {
    right: 25px;
    z-index: 8888;
    background-image: url(/resources/arrow-right.svg);
}

/* .maske {
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    position: absolute;
} */

.stoerer {
    position: absolute;
    bottom: 10%;
    width: 90%;
    padding: 0 0 0 20%;
    color: white;
    /* transform: scale(1.5) */
}
.stoerer h3 {
  position: relative;
  top:40px;
  font-size: clamp(20px, 2.6vw, 28px);
  line-height: 120%;
  opacity:0;
  transition-delay: 0s, 0s;
  transition-duration: .1s, .1s;
  transition-property: opacity, top;
  font-size: 28px;
  line-height: 38px;
  text-shadow: 2px 2px 5px black;
}
body.loaded .stoerer h3 {
  opacity:1;
  top:0px;
  transition-delay: 1.4s, 1.4s;
  transition-duration: .5s, .5s;
  transition-property: opacity, top;
  font-size: 28px;
  line-height: 38px;
  text-shadow: 2px 2px 5px black;
}
.stoerer h2 {
  position: relative;
  top:40px;
  font-size: clamp(24px, 3.6vw, 42px);
  line-height: 120%;
  opacity:0;
  transition-delay: 0s, 0s;
  transition-duration: .1s, .1s;
  transition-property: opacity, top;
  font-size: 42px;
  line-height: 44px;
  text-shadow: 2px 2px 5px black;
}
body.loaded .stoerer h2 {
  opacity:1;
  top:0px;
  transition-delay: 2s, 2s;
  transition-duration: .5s, .5s;
  transition-property: opacity, top;
  font-size: 42px;
  line-height: 44px;
  text-shadow: 2px 2px 5px black;
}



.topfotoslider .swiper-pagination-bullet {
  opacity:.8;
  background: black;
  height:8px;
  width:8px;
}
.topfotoslider .swiper-pagination-bullet.swiper-pagination-bullet-active {
  opacity:1;
  background: white;
  height:8px;
  width:8px;
}
.topfotoslider .swiper-slide .mystoerer {
    position: absolute;
    opacity: 1;
    bottom: 7%;
    width: 90%;
    padding: 0 0 0 20%;
    color: white;
    transform: scale(1.5);
}
/* .topfotoslider .swiper-slide.swiper-slide-active .mystoerer {
  opacity: 1;
  bottom:10%;
  transition: all 2s;
} */
.topfotoslider .swiper-slide .mystoerer h3 {
  position: relative;
  top:40px;
  font-size: clamp(20px, 2.6vw, 28px);
  line-height: 120%;
  opacity:0;
  transition-delay: 0s, 0s;
  transition-duration: .1s, .1s;
  transition-property: opacity, top;
  font-size: 28px;
  line-height: 38px;
  /* transition: opacity .1s, top .1s; */
}
.topfotoslider .swiper-slide.swiper-slide-active .mystoerer h3 {
  opacity:1;
  top:0px;
  transition-delay: 1.4s, 1.4s;
  transition-duration: .5s, .5s;
  transition-property: opacity, top;
  font-size: 28px;
  line-height: 38px;
  /* transition: opacity .4s .5s, top .4s .5s; */
}
.topfotoslider .mystoerer h2 {
  position: relative;
  top:40px;
  font-size: clamp(24px, 3.6vw, 42px);
  line-height: 120%;
  opacity:0;
  transition-delay: 0s, 0s;
  transition-duration: .1s, .1s;
  transition-property: opacity, top;
  font-size: 42px;
  line-height: 44px;
  /* transition: opacity .1s, top .1s; */
}
.topfotoslider .swiper-slide.swiper-slide-active .mystoerer h2 {
  opacity:1;
  top:0px;
  transition-delay: 2s, 2s;
  transition-duration: .5s, .5s;
  transition-property: opacity, top;
  font-size: 42px;
  line-height: 44px;
  /* transition: opacity 2s .5s, top 2s .5s; */
}
.myfotoinfobox {
    position: absolute;
    top:0px;
    right:0px;
    bottom: 0px;
    width: 50%;
    max-width:420px;
    padding:  140px 40px 25px 40px;
    color: white;
    background-color: rgba(0,0,0,0.5);
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    z-index: 300;
}
.myfotoinfobox_mobile {
    display: none;
    background-color: rgba(0,0,0,0.35);
    padding:  40px 40px 25px 40px;
    width: 100%;
}
.myfotoinfobox *,
.myfotoinfobox_mobile * {
    color:white !important;
}

.myfotoinfobox.hintergrund-gruen,
.myfotoinfobox_mobile.hintergrund-gruen {
    background-color: rgba(10, 61, 43, 0.7);
}
.myfotoinfobox.hintergrund-gruen *,
.myfotoinfobox_mobile.hintergrund-gruen * {
    color: white3 !important;
}

.myfotoinfobox.hintergrund-grau,
.myfotoinfobox_mobile.hintergrund-grau {
    background-color: rgba(0,0,0,0.5);
}
.myfotoinfobox.hintergrund-grau *,
.myfotoinfobox_mobile.hintergrund-grau * {
    color: white3 !important;
}

.myfotoinfobox.hintergrund-beige,
.myfotoinfobox_mobile.hintergrund-beige {
    background-color:rgba(237, 231, 217, 0.85);
}
.myfotoinfobox.hintergrund-beige *,
.myfotoinfobox_mobile.hintergrund-beige * {
    color: #333333 !important;
}

.myfotoinfobox.hintergrund-weiss,
.myfotoinfobox_mobile.hintergrund-weiss {
    background-color: rgba(255,255,255,0.8);
}
.myfotoinfobox.hintergrund-weiss *,
.myfotoinfobox_mobile.hintergrund-weiss * {
    color: #333333 !important;
}

.fotoinfobox {
    position: absolute;
    top:20px;
    right:0px;
    bottom: 20px;
    width: 50%;
    max-width:420px;
    padding:  40px 40px 25px 40px;
    color: white;
    background-color: rgba(0,0,0,0.5);
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.fotoinfobox_mobile {
    display: none;
    background-color: rgba(0,0,0,0.35);
    padding:  40px 40px 25px 40px;
    width: 100%;
}
.fotoinfobox *,
.fotoinfobox_mobile * {
    color:white !important;
}

.fillfull {
  position: absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
}

/* ################################################# DOTS   */

.foto_slider.slick-dotted.slick-slider {
    margin-bottom: 0px;
}

.mehrere_produkte.slick-dotted.slick-slider,
.mehrere_texte.slick-dotted.slick-slider {
    margin-bottom: 10px;
}

.slick-dots {
    position: absolute;
    bottom:60px;
    display: block;
    width: 100%;
    padding: 0;
    margin: 0;
    list-style: none;
    text-align: center;
}
.foto_slider .slick-dots {
    bottom: 5px;
    /* display: none !important; */
}
/* .mehrere_produkte .slick-dots,
.mehrere_texte .slick-dots {
    bottom:60px;
} */
.slick-dots li {
    position: relative;
    display: inline-block;
    width: 20px;
    height: 20px;
    margin: 0 5px;
    padding: 0;
    cursor: pointer;
}
.slick-dots li button {
    font-size: 0;
    line-height: 0;
    display: block;
    width: 20px;
    height: 20px;
    padding: 5px;
    cursor: pointer;
    color: transparent;
    border: 0;
    outline: none;
    background: transparent;
}
.slick-dots li button:hover,
.slick-dots li button:focus {
    outline: none;
}
.slick-dots li button:hover:before,
.slick-dots li button:focus:before {
    opacity: 1;
}
.slick-dots li button:before {
    font-size: 48px;
    line-height: 20px;
    position: absolute;
    top: 0;
    left: 0;
    width: 20px;
    height: 20px;
    content: "•";
    text-align: center;
    opacity: 0.25;
    color: white;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.slick-dots li.slick-active button:before {
    opacity: 0.75;
    color: white;
}

/* ################################################# SPALTEN   */

.spalten {
    width: 100%;
    display: flex;
    flex-direction: row;
    justify-content: center;
}
.spalte {
    width: 100%;
    max-width:960px;
    /* margin: auto; */
    padding: 30px 60px 0px 60px;
}

/* ################################################# ABSTÄNDE   */

.abstand_keiner {
    /* padding: 0; */
    margin-top: 0px;
    margin-bottom:0px;
}
.abstand_oben_und_unten {
    /* padding: 80px 0; */
    margin-top: 80px;
    margin-bottom:80px;
    margin-top: 40px;
    margin-bottom:40px;
}
.doppelter_abstand_oben_und_unten {
    /* padding: 160px 0; */
    margin-top: 160px;
    margin-bottom:160px;
    margin-top: 80px;
    margin-bottom:80px;
}
.abstand_oben {
    /* padding: 80px 0 0 0; */
    margin-top: 80px;
    margin-top: 40px;
}
.abstand_unten {
    /* padding: 0 0 80px 0; */
    margin-bottom:80px;
    margin-bottom:40px;
}

img.foto {
    max-width: 100%;
}

body.SEITE_4 .spalte.foto.icon {
  background-position: 40px center !important;
  background-size: 120px 120px !important;
}
/* ################################################# HINTERGRUNDFARBEN */

.weiss {
    /* background-color: white; */
    color: #666666;
    color: #333333;
}
.weiss h2,
.weiss h3 {
    color: black;
}

.gelb {
    color: white;
    background-color: #333333;
}
.gelb a {
    color: white;
    text-decoration: none;
}
.gelb a:hover {
    color: #938f72;
    text-decoration: none;
}
.beige {
    color: white;
    background-color: rgba(187, 179, 169, 1);
    background-color: rgba(148, 143, 115, 0.5);
    font-size: larger;
}
.beige h2,
.beige h3 {
    color: white;
}
.hellbeige {
    color: black;
    color: #333333;
    background-color: rgba(187, 179, 169, 0.5);
    background-color: rgba(187, 179, 169, 0.2);
    font-size: larger;
}
.hellbeige h2,
.hellbeige h3 {
    color: #938f72;
}

/* ################################################# TEXTSLIDER mit FOTO und TEXT - PRODUKTE */

.text_slider .spalte,
.mehrere_texte.text_slider .spalte {
    margin: 10px 20px 10px 20px;
    background-color: rgba(255, 255, 255, 0.2);
    min-height: 340px;
    color: black;
}
.mehrere_produkte.text_slider .spalte {
    margin: 10px 20px 10px 20px;
    background-color: rgba(187, 179, 169, 0.2);
    min-height: 420px;
}
.mehrere_produkte.text_slider .spalte h3,
.mehrere_texte.text_slider .spalte h3 {
    color: #938f72;
    margin-bottom: 20px;
}
.mehrere_texte.text_slider .spalte {
    margin: 10px 20px 10px 20px;
    background-color: rgba(187, 179, 169, 0.2);
    min-height: 340px;
    color: black;
}

.text_slider a.button {
    border: 1px solid #333333;
    border-radius: 4px;
    padding: 2px 10px;
    color: #333333;
}
.text_slider a.button:hover {
    border: 1px solid #333333;
    background-color: #333333;
    text-decoration: none;
    color: white
}
.spalte a.button {
    font-family: "Montserrat", sans-serif;
    text-transform: uppercase;
    /* font-weight: 700; */
    border: 1px solid #333333;
    border-radius: 4px;
    padding: 5px 20px;
    color: #333333;
}
.spalte a.button:hover {
/*     border: 1px solid white; */
    background-color: #333333;
    text-decoration: none;
    color: white;
}

.spalte ul {
    padding: 0 0 0 12px;
}
.spalte ul li::marker {
    color: #ffd318;
    color: #bbb3a9;
    font-size: small;
}

/* ################################################# VIDEO   */

.responsive-video {
    position: relative;
    width: 100%;
    max-width: 100%;
    overflow: hidden;
}

.responsive-video video {
    width: 100%;
    height: auto;
}

.responsive-video .stoerer {
    position: absolute;
    bottom: 10%;
    width: 90%;
    padding: 0 0 0 20%;
    color: white;
    /* transform: scale(1.5) */
}
.responsive-video .stoerer h3 {
  position: relative;
  top:40px;
  font-size: clamp(20px, 2.6vw, 28px);
  line-height: 120%;
  opacity:0;
  transition-delay: 0s, 0s;
  transition-duration: .1s, .1s;
  transition-property: opacity, top;
  font-size: 28px;
  line-height: 38px;
}
body.loaded .responsive-video .stoerer h3 {
  opacity:1;
  top:0px;
  transition-delay: 1.4s, 1.4s;
  transition-duration: .5s, .5s;
  transition-property: opacity, top;
  font-size: 28px;
  line-height: 38px;
}
.responsive-video .stoerer h2 {
  position: relative;
  top:40px;
  font-size: clamp(20px, 2.6vw, 28px);
  line-height: 120%;
  opacity:0;
  transition-delay: 0s, 0s;
  transition-duration: .1s, .1s;
  transition-property: opacity, top;
  font-size: 42px;
  line-height: 44px;
}
body.loaded .responsive-video .stoerer h2 {
  opacity:1;
  top:0px;
  transition-delay: 2s, 2s;
  transition-duration: .5s, .5s;
  transition-property: opacity, top;
  font-size: 42px;
  line-height: 44px;
}
/* ################################################# FOTO - GANZE BREITE */

.foto {
    position: relative;
    line-height: 0;
}
.fotoganzebreite {
    line-height: 0;
    position: relative;
    width: 100%;
    max-width: 100%;
    height: auto;
}

.foto .fototitel {
    position: absolute;
    top: 15%;
    left: 20%;
    width: 60%;
    color: white;
    font-size: 48px;
    line-height: 48px;
    font-family: "Montserrat", sans-serif;
    text-shadow: 0 0 4px rgba(0, 0, 0, 0.5);
    text-shadow: 0 0 4px rgba(148, 143, 115, 1);
    font-weight: 700;
}
.foto .fototitel span,
.foto .fototitel a,
.foto .fototitel a:hover {
    color: white;
    font-size: 36px;
    line-height: 36px;
    font-family: "Montserrat", sans-serif;
    font-weight: 700;
    text-decoration: none;
    margin-top: 20px;
    display: inline-block;
}


/* ################################################# FOOTER */

footer {
    background-color: #c4c2b3;
    background-color: #ede7d9;
    background-color: #5c6c79;
    background-color: #cdd5d8;

    /* padding: 0 40px; */
}
footer *{
    font-family: "Montserrat", sans-serif !important;
}
footer .spalten {
    justify-content: space-between;
}
/* footer .spalte:first-child{
    margin-left: 20%;
    padding: 20px 0px;
}
footer .spalte:last-child{
    margin-right:20%;
    padding: 20px 0px;
    padding-left:230px;
    text-align: left !important;
} */
footer .beige {
    color: #666666 !important;
    color: #333333 !important;
    background-color: #c4c2b3;
    background-color: #ede7d9;
}
footer .spalte {
  padding-top: 10px;
}
footer a {
    text-decoration: none;
    color: #666666;
    color: #333333;
}
footer a:hover {
    text-decoration: underline;
    color: #666666;
    color: #333333;
}
footer hr {display:none;}


footer a.footerlink {
    display:inline-block;
    padding: 0px 20px 0 72px;
    background-color: rgba(255,255,255,0.3);
    color: #666666;
    color: #333333;
    text-transform: uppercase;
    text-align: left;
    position: relative;
    min-width: 306px;
    height:42px;
    text-decoration: none;
    line-height: 42px;
    font-weight: 700;
    letter-spacing: 1px;
}
footer a.footerlink:hover {
    background-color: rgba(0,0,0,0.25);
    background-color: rgba(255,255,255,0.7);
    color: white;
    color: #666666;
    color: #333333;
    text-transform: uppercase;
    text-decoration: none;
}
footer a.footerlink span img {
    position: absolute;
    left:0;
    width:42px;
    height:42px;
}
footer img {
    width:42px;
    height:42px;
    /* width:36px;
    height:36px; */
    opacity: 0.6;
}
.fusszeile {
    color: white;
    background-color: #333333;
    background-color: rgba(51, 51, 51, 0.5);
}
.fusszeile a {
    color: white;
    text-decoration: none;
    font-size: 14px;
}
.fusszeile a:hover {
    color: #938f72;
    text-decoration: none;
}
footer #impressum_top a {
    display: inline-block;
    padding: 3px;
    border: solid white;
    border-width: 0 2px 2px 0;
    transform: rotate(-135deg);
    width:15px;
    height:15px;
}
footer .fusszeile .limit {
    display: flex;
    justify-content: space-between;
}
footer h2.text-grau,
footer h3.text-grau {
  color:white !important;
  color:#666666 !important;
}

/* ################################################# IMPRESSIONEN UND FANCY BOX  */

.fotogalerie {
  display:flex;
  flex-wrap:wrap;
  line-height:0px;
}
.box {
  width: 25%;
  height: auto;
  line-height: 0px;
  overflow: hidden;
  background-color: black;
  }
.box img {
  width: 100%;
  max-width: 100%;
  height: auto;
  transform: scale(1.0);
  opacity: 1;
  transition: all ease-in-out 1s;
}
.box:hover img {
  transform: scale(1.1);
  opacity: .5;
  transition: all ease-in-out 1s;
  cursor: move;
}
.fancybox-thumbs , .fancybox-thumbs > ul {
    background-color: black;
}
.fancybox-thumbs > ul > li:before {
    border: 4px solid white;
}
.fancybox-thumbs {
    width: 108px;
}
.fancybox-show-thumbs .fancybox-inner {
    right: 108px;
}
.fancybox-thumbs > ul > li {
    padding: 0;
    margin: 2px;
    width: 100px;
    height: 75px;
    max-width: calc(100% - 4px);
    max-height: calc(100% - 8px);
}

/* ################################################# LOGIN   */

form label {
  /* display:none; */
  font-size: 9px;
  line-height: 11px;
  margin-bottom: -6px;
  display: block;
}
form input {
  display:block;
  width:100%;
  border:0px;
  margin:8px 0;
  background-color: white;
  text-align: center;
}
form button {
  display: block;
  width:100%;
  padding: 4px 20px;
  text-align: center;
  margin:8px 0;
  text-transform: uppercase;
  background: transparent;
  border: 1px solid #333;
  border-radius: 12px;
  font-weight: 400;
  color: #333;

}
form button:hover {
  color: white;
  background-color: #333;
  text-decoration: none;
}

/* ################################################# GAESTEBUCH   */

.limit.guestbook_input,
.limit.guestbook_liste {
  padding-left:20px;
  padding-right:20px;
}

.limit.guestbook_input textarea {
  width:100%; 
  max-width:100%;
  border: 0;
}