@charset "UTF-8";
@import 'font-sourcesanspro.min.css';
* {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

html, body {
  height: 100%;
}

html {
  font-size: 1em;
}

body {
  font-family: "Source Sans Pro", Arial, Helvetica, sans-serif;
  font-weight: 400;
  font-size: 1em;
  line-height: 1em;
  color: #383634;
  overflow-x: hidden;
  overflow-y: scroll;
}

img {
  border: none;
  display: block;
}
.image img {
  width: 100%;
}

.invis {
  position: absolute;
  left: -999em;
  height: 0;
  display: inline;
}

.center {
  text-align: center;
}
.center img {
  margin: 0 auto 10px;
}

strong {
  font-weight: 600;
  color: #383634;
}

.italic {
  font-style: italic !important;
}

.kap {
  text-transform: uppercase !important;
}

.marker {
  font-weight: 600 !important;
  color: #ff6438 !important;
}

sup {
  vertical-align: text-top;
}

.small {
  font-style: italic;
}

.nowrapping {
  white-space: nowrap;
}

header {
  background: #565550;
}

main {
  margin-top: -90px;
  display: block;
}

.inner {
  width: calc(100% - 20px);
  margin: 0 auto;
}
main .inner {
  min-height: 110px;
  background: #fff;
}
@media (min-width: 480px) {
  .inner {
    width: 460px;
  }
}
@media (min-width: 760px) {
  .inner {
    width: 720px;
  }
}
@media (min-width: 1000px) {
  .inner {
    width: 850px;
  }
  header .inner {
    width: 950px;
  }
}
@media (min-width: 1200px) {
  .inner {
    width: 960px;
  }
  header .inner {
    width: 1140px;
  }
}
.inner .content {
  padding: 8px 10px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.inner .content:after {
  content: "";
  display: table;
  clear: both;
}
@media (min-width: 760px) {
  .inner .content {
    padding: 25px 30px 10px;
    display: block;
  }
}
.inner .content + figure {
  margin-top: 10px;
}
.inner .content:last-child {
  padding-bottom: 10px !important;
}
.inner .content > aside {
  margin: 0 0 20px;
  padding: 15px 20px 10px;
  border: 1px solid rgba(56, 54, 52, 0.3);
}
.inner .content > aside:first-child {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
@media (min-width: 760px) {
  .inner .content > aside:first-child {
    float: right;
    width: 35%;
    margin: 0 0 30px 20px;
  }
  .inner .content > aside:first-child ~ * {
    width: calc(65% - 30px);
  }
}
@media (min-width: 1000px) {
  .inner .content > aside:first-child {
    width: 31%;
  }
  .inner .content > aside:first-child ~ * {
    width: calc(69% - 30px);
  }
}
.inner .content aside.downloads,
.inner .content aside.subpages {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
  clear: both;
  float: none;
  width: 100% !important;
  margin: 0 0 20px;
  padding: 0 20px 1px;
  background: rgba(86, 85, 80, 0.1);
  border: none;
}
@media (min-width: 760px) {
  .inner .content aside.downloads,
.inner .content aside.subpages {
    margin: 0 0 30px;
  }
}
.inner .content aside.subpages {
  -webkit-box-ordinal-group: 1;
      -ms-flex-order: 0;
          order: 0;
  margin: 0;
  padding: 0;
  background: none;
}
@media (min-width: 760px) {
  .inner .content aside.subpages {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    width: calc(100% + 20px) !important;
    margin: 0 -10px;
  }
}
@media (min-width: 1000px) {
  .inner .content aside.subpages {
    width: calc(100% + 30px) !important;
    margin: 0 -15px;
  }
}
@media (min-width: 1200px) {
  .inner .content aside.subpages {
    -webkit-box-flex: 1;
        -ms-flex: 1 0 465px;
            flex: 1 0 465px;
  }
}
.inner .content aside.subpages .teaser {
  background: rgba(86, 85, 80, 0.1);
  margin-bottom: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media (min-width: 760px) {
  .inner .content aside.subpages .teaser {
    -webkit-box-flex: 1;
        -ms-flex: 1 1 33%;
            flex: 1 1 33%;
    margin: 0 10px 20px;
  }
}
@media (min-width: 1000px) {
  .inner .content aside.subpages .teaser {
    -webkit-box-flex: 1;
        -ms-flex: 1 1 27%;
            flex: 1 1 27%;
    margin: 0 15px 30px;
  }
}
.inner .content aside.subpages .teaser figure {
  position: relative;
}
.inner .content aside.subpages .teaser .teasertext {
  height: 100%;
  padding: 8px 15px 1px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.inner > figure:first-child ~ .content, .inner > .teaser-list ~ .content {
  padding: 0;
}
.inner > .content + .content {
  padding-top: 0;
  padding-bottom: 0;
}

.opening {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.opening.winter {
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
}
.opening dl {
  margin-bottom: 20px;
}
@media (min-width: 760px) {
  .opening dl {
    margin-bottom: 30px;
  }
}

.teaser-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.teaser-list:before {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 90px;
  background: #565550;
}
.teaser-list:after {
  content: "";
  -webkit-box-flex: 1;
      -ms-flex: 1 1 auto;
          flex: 1 1 auto;
}
@media (min-width: 760px) {
  .teaser-list:after {
    -webkit-box-flex: 0;
        -ms-flex: 0 1 350px;
            flex: 0 1 350px;
  }
}
@media (min-width: 1000px) {
  .teaser-list:after {
    -webkit-box-flex: 0;
        -ms-flex: 0 1 270px;
            flex: 0 1 270px;
  }
}
@media (min-width: 1200px) {
  .teaser-list:after {
    -webkit-box-flex: 0;
        -ms-flex: 0 1 300px;
            flex: 0 1 300px;
  }
}

.teaser {
  position: relative;
  z-index: 1;
  -webkit-box-flex: 1;
      -ms-flex: 1 1 auto;
          flex: 1 1 auto;
  margin-bottom: 10px;
}
@media (min-width: 760px) {
  .teaser {
    -webkit-box-flex: 0;
        -ms-flex: 0 1 350px;
            flex: 0 1 350px;
    margin-bottom: 20px;
  }
  .teaser.download + .teaser {
    -webkit-box-ordinal-group: 0;
        -ms-flex-order: -1;
            order: -1;
  }
}
@media (min-width: 1000px) {
  .teaser {
    -webkit-box-flex: 0;
        -ms-flex: 0 1 270px;
            flex: 0 1 270px;
    margin-bottom: 20px;
  }
  .teaser.download + .teaser + .teaser {
    -webkit-box-ordinal-group: 0;
        -ms-flex-order: -1;
            order: -1;
  }
}
@media (min-width: 1200px) {
  .teaser {
    -webkit-box-flex: 0;
        -ms-flex: 0 1 300px;
            flex: 0 1 300px;
    margin-bottom: 30px;
  }
}
.teaser figure {
  margin: 0 !important;
}
.teaser img {
  width: 100%;
}
.teaser figcaption {
  position: absolute;
  z-index: 1;
  bottom: 12px;
  left: 12px;
  width: calc(100% - 24px);
  padding: 6px 10px;
}
.teaser figcaption:after {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: rgba(255, 255, 255, 0.8);
  -webkit-transition: background 0.3s ease;
  -o-transition: background 0.3s ease;
  transition: background 0.3s ease;
  display: block;
}
.teaser a:hover figcaption:after {
  background: #fff;
}
.teaser-special {
  -webkit-box-flex: 1 !important;
      -ms-flex: 1 0 100% !important;
          flex: 1 0 100% !important;
  background: #fff;
  padding: 10px;
  border: 3px solid #565550;
}
@media (min-width: 760px) {
  .teaser-special {
    padding: 20px 30px;
  }
}
.teaser.download figcaption {
  top: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  min-height: 1px;
  padding: 50px 30px;
  border: 3px solid #565550;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -ms-flex-pack: distribute;
      justify-content: space-around;
}
.teaser.download figcaption:after {
  background: rgba(255, 255, 255, 0.65);
}

footer {
  padding: 30px 0;
  background: #565550;
}
footer .inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media (min-width: 760px) {
  footer .inner {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
  footer .inner nav:first-of-type {
    -webkit-box-ordinal-group: 0;
        -ms-flex-order: -1;
            order: -1;
  }
}
footer .inner address {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  margin-top: 20px;
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
@media (min-width: 760px) {
  footer .inner address {
    width: auto;
    margin: 0;
    -webkit-box-ordinal-group: 1;
        -ms-flex-order: 0;
            order: 0;
  }
}

#booking-box {
  position: fixed;
  z-index: 110;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.7);
  display: none;
}
#booking-box.open {
  display: block;
}
#booking-box-content {
  position: absolute;
  width: 90%;
  max-width: 760px;
  height: 80%;
  max-height: 610px;
  padding: 40px 20px 20px;
  background: #fff;
  border-radius: 3px;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  text-align: center;
}
#booking-box-content iframe {
  position: absolute;
  top: 32px;
  left: 0;
  width: 99%;
  height: calc(100% - 40px);
  border: none;
}
#booking-box #close {
  position: absolute;
  z-index: 10;
  right: 10px;
  top: 10px;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 20px;
  background: rgba(0, 0, 0, 0.2);
  height: 20px;
  width: 20px;
  border-radius: 50%;
  text-align: center;
  color: #fff;
  cursor: pointer;
}
#booking-box #close:hover {
  background: rgba(0, 0, 0, 0.7);
}

.main-menu {
  position: relative;
  z-index: 10;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 140px;
  padding: 25px 0;
}
@media (min-width: 760px) {
  .main-menu {
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
  }
}
@media (min-width: 1000px) {
  .main-menu {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.main-menu .logo {
  position: relative;
  z-index: 100;
  width: 140px;
  margin-right: 20px;
}
@media (min-width: 1200px) {
  .main-menu .logo {
    margin-right: 30px;
  }
}
.main-menu-trigger {
  position: absolute;
  z-index: 100;
  top: 66px;
  right: 0;
  font-size: 12px;
  font-weight: 600;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  width: 44px;
  padding: 28px 2px 4px;
  color: #fff;
  background: transparent;
  border: none;
  border-radius: 2px;
  cursor: pointer;
}
.main-menu-trigger:before, .main-menu-trigger:after {
  content: "";
  position: absolute;
  top: 4px;
  left: 4px;
  width: calc(100% - 8px);
  height: 4px;
  background: #fff;
  border-radius: 4px;
  -webkit-transition: top 0.1s ease-in-out, -webkit-transform 0.1s ease-in-out;
  transition: top 0.1s ease-in-out, -webkit-transform 0.1s ease-in-out;
  -o-transition: transform 0.1s ease-in-out, top 0.1s ease-in-out;
  transition: transform 0.1s ease-in-out, top 0.1s ease-in-out;
  transition: transform 0.1s ease-in-out, top 0.1s ease-in-out, -webkit-transform 0.1s ease-in-out;
}
.main-menu-trigger:after {
  top: 16px;
}
.open .main-menu-trigger {
  text-indent: -999em;
}
.open .main-menu-trigger:before, .open .main-menu-trigger:after {
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
  top: 15px;
}
.open .main-menu-trigger:after {
  -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

@media (min-width: 760px) {
  .main-menu-trigger {
    top: auto;
    right: auto;
    left: -999em;
  }
}
.main-menu-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  list-style: none;
  max-height: 0;
  overflow-y: hidden;
}
@media (min-width: 760px) {
  .main-menu-list {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    width: calc(100% - 150px);
    max-height: none;
    overflow: visible;
  }
}
@media (min-width: 1200px) {
  .main-menu-list {
    width: calc(100% - 170px);
  }
}
.main-menu-list > li {
  position: relative;
  padding-left: 10px;
}
.main-menu-list > li a {
  position: relative;
  font-size: 1.125rem;
  font-weight: 600;
  letter-spacing: 0.025em;
  text-decoration: none;
  padding: 10px 6px 6px;
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  white-space: nowrap;
}
@media (min-width: 1000px) {
  .main-menu-list > li a {
    padding: 10px 6px;
  }
}
@media (min-width: 1200px) {
  .main-menu-list > li a {
    font-size: 1.25rem;
    padding: 10px;
  }
}
.main-menu-list > li:not([class*=-shop]):not([class*=-lang]) > a:hover:after, .main-menu-list > li:not([class*=-shop]):not([class*=-lang]).dropdownOpen > a:after, .main-menu-list > li:not([class*=-shop]):not([class*=-lang]).active > a:after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0px;
  width: calc(100% - 12px);
  height: 2px;
  background: #fff;
  display: block;
}
@media (min-width: 760px) {
  .main-menu-list > li:not([class*=-shop]):not([class*=-lang]) > a:hover:after, .main-menu-list > li:not([class*=-shop]):not([class*=-lang]).dropdownOpen > a:after, .main-menu-list > li:not([class*=-shop]):not([class*=-lang]).active > a:after {
    left: 6px;
  }
}
@media (min-width: 1200px) {
  .main-menu-list > li:not([class*=-shop]):not([class*=-lang]) > a:hover:after, .main-menu-list > li:not([class*=-shop]):not([class*=-lang]).dropdownOpen > a:after, .main-menu-list > li:not([class*=-shop]):not([class*=-lang]).active > a:after {
    width: calc(100% - 20px);
    left: 10px;
  }
}
.main-menu-list-shop {
  padding: 0 !important;
  background: #565550;
}
@media (min-width: 760px) {
  .main-menu-list-shop {
    position: absolute !important;
    top: 25px;
    right: 100px;
    margin-left: auto;
    right: 0;
  }
}
@media (min-width: 1000px) {
  .main-menu-list-shop {
    position: relative !important;
    top: auto;
    right: auto;
  }
}
.main-menu-list-shop a {
  position: relative;
  font-size: 1rem !important;
  text-transform: uppercase;
  padding: 10px 28px 10px 14px !important;
  border: 2px solid #fff;
  -webkit-box-shadow: 0 3px 5px rgba(0, 0, 0, 0.3);
          box-shadow: 0 3px 5px rgba(0, 0, 0, 0.3);
  overflow: hidden;
}
.main-menu-list-shop a:before {
  content: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 25 25"><path fill="white" d="M5 2.5C5 3.9 3.9 5 2.5 5S0 3.9 0 2.5 1.1 0 2.5 0 5 1.1 5 2.5zM7.5 5C6.1 5 5 6.1 5 7.5S6.1 10 7.5 10 10 8.9 10 7.5 8.9 5 7.5 5zm5 5c-1.4 0-2.5 1.1-2.5 2.5s1.1 2.5 2.5 2.5 2.5-1.1 2.5-2.5-1.1-2.5-2.5-2.5zm5 5c-1.4 0-2.5 1.1-2.5 2.5s1.1 2.5 2.5 2.5 2.5-1.1 2.5-2.5-1.1-2.5-2.5-2.5zm5 5c-1.4 0-2.5 1.1-2.5 2.5s1.1 2.5 2.5 2.5 2.5-1.1 2.5-2.5-1.1-2.5-2.5-2.5z"/></svg>');
  position: absolute;
  top: -2px;
  right: -1px;
  width: 24px;
}
.main-menu-list-shop a:hover {
  background: #383634;
}
.main-menu-list-lang {
  padding-right: 0 !important;
}
@media (min-width: 760px) {
  .main-menu-list-lang {
    position: absolute !important;
    top: 25px;
    right: 10px;
    margin-left: 5px;
  }
}
@media (min-width: 1000px) {
  .main-menu-list-lang {
    position: relative !important;
    top: auto;
    right: auto;
  }
}
@media (min-width: 1200px) {
  .main-menu-list-lang {
    margin-left: 20px;
  }
}
.main-menu-list-lang a {
  text-indent: -999em;
}
.main-menu-list-lang a:after {
  content: "DE | EN";
  text-indent: 0;
  white-space: nowrap;
}
.main-menu-list-lang a[lang=de]:after {
  content: "EN | DE";
}
.main-menu-list-lang a:hover:after {
  padding: 0 0 8px;
  border-bottom: 2px solid #fff;
}
@media (min-width: 1000px) {
  .main-menu-list-lang a:hover:after {
    padding: 10px 0 8px;
  }
}
.main-menu-list.open {
  position: absolute;
  top: 130px;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 100vw;
  height: auto;
  max-height: 500vh;
  padding-bottom: 10px;
  background: #565550;
  -webkit-box-shadow: 0 3px 6px -3px rgba(0, 0, 0, 0.7);
          box-shadow: 0 3px 6px -3px rgba(0, 0, 0, 0.7);
  overflow-y: visible;
  -webkit-transition: max-height 0.218s ease-in-out;
  -o-transition: max-height 0.218s ease-in-out;
  transition: max-height 0.218s ease-in-out;
}
.main-menu-list.open * {
  color: #fff;
}
.main-menu-list.open li, .main-menu-list.open a {
  min-height: 36px;
  width: 100%;
  max-width: 440px;
  margin: 0 auto;
}
.main-menu-list.open li.main-menu-list-shop a, .main-menu-list.open a.main-menu-list-shop a {
  width: auto;
  display: inline-block;
}
.main-menu-list.open > li {
  width: calc(100% - 20px);
  padding-bottom: 20px !important;
  padding-left: 0;
}
.main-menu-list.open > li:first-of-type, .main-menu-list.open > li.main-menu-list-shop {
  -webkit-box-ordinal-group: 0;
      -ms-flex-order: -1;
          order: -1;
}
@media (max-width: 479px) {
  .main-menu-list.open > li {
    padding-right: 10px !important;
    padding-left: 10px !important;
  }
}
.main-menu-list.open > li > a {
  font-size: 1.25rem;
  padding-left: 0;
}
.main-menu-list.open > li > a:hover:after {
  left: 0 !important;
  width: 100% !important;
}
.main-menu-list.open > li > a + ul {
  padding-left: 30px;
}
.main-menu-list.open > li > a + ul a {
  padding: 10px 0 4px;
}
.main-menu-sublist {
  list-style: none;
  display: block;
  overflow: hidden;
  -webkit-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media (min-width: 760px) {
  .main-menu-sublist {
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    min-width: 100%;
    max-height: 0;
    padding: 0 16px;
    background: rgba(255, 255, 255, 0.95);
  }
}
@media (min-width: 1000px) {
  .main-menu-sublist {
    top: calc(100% + 10px);
  }
}
@media (min-width: 1200px) {
  .main-menu-sublist {
    padding: 0 20px;
  }
}
.main-menu-sublist li {
  margin-bottom: 4px;
}
@media (min-width: 760px) {
  .main-menu-sublist li:first-child {
    margin-top: 10px;
  }
  .main-menu-sublist li:last-child {
    margin-bottom: 15px;
  }
}
.main-menu-sublist li a {
  font-size: 1rem;
  line-height: 1;
  padding: 5px 0 4px;
  color: #383634;
  border-bottom: 2px solid transparent;
}
.main-menu-sublist li a:hover, .main-menu-sublist li.active a, .main-menu-sublist li.active a:hover {
  border-color: #fff;
}
@media (min-width: 760px) {
  .main-menu-sublist li a:hover, .main-menu-sublist li.active a, .main-menu-sublist li.active a:hover {
    border-color: #383634;
  }
}
.main-menu-list > li:hover > .main-menu-sublist {
  max-height: 500px;
}
@media (min-width: 760px) {
  .main-menu-list > li:hover > .main-menu-sublist {
    -webkit-box-shadow: 0 3px 5px rgba(0, 0, 0, 0.2);
            box-shadow: 0 3px 5px rgba(0, 0, 0, 0.2);
  }
}

.breadcrumb {
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  padding: 12px 10px 5px;
}
@media (min-width: 760px) {
  .breadcrumb {
    padding: 20px 30px 0;
  }
}
figure + .breadcrumb {
  margin-top: -5px;
  padding: 0 0 10px;
}
@media (min-width: 760px) {
  figure + .breadcrumb {
    margin-top: -15px;
    padding: 0 0 15px;
  }
}
.breadcrumb li, .breadcrumb a {
  position: relative;
  font-size: 0.875rem;
  line-height: 1;
  text-decoration: none;
  color: #787674 !important;
  border: none !important;
}
@media (min-width: 760px) {
  .breadcrumb li, .breadcrumb a {
    font-size: 1rem;
  }
}
.breadcrumb li:not(:first-of-type):before {
  content: "";
  position: absolute;
  top: calc(50% - 3px);
  left: -4px;
  width: 5px;
  height: 5px;
  border-width: 2px;
  border-style: solid solid none none;
  border-color: #787674;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
  display: block;
}
.breadcrumb li.active, .breadcrumb a {
  margin: 2px 1px;
  padding: 2px 8px;
  display: inline-block;
}
.breadcrumb li.active {
  font-style: italic;
}
.breadcrumb a:hover {
  text-decoration: underline;
}

footer nav ul {
  list-style: none;
}
footer nav li {
  margin-bottom: 5px;
}
footer nav:last-of-type li {
  text-align: right;
}
footer nav a {
  position: relative;
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.33;
  text-decoration: none;
  color: #fff;
  display: block;
}
@media (max-width: 479px) {
  footer nav a {
    font-size: 1rem;
  }
}
footer nav li.active a:after,
footer nav a:hover:after {
  content: "";
  position: absolute;
  bottom: -3px;
  left: 0;
  width: 100%;
  height: 0;
  border-bottom: 1px solid #fff;
}

h1 {
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.33;
  letter-spacing: 0.025em;
  text-align: center;
  color: #fff;
}
header h1 {
  margin: 0 auto;
  padding: 0 0 105px;
}
@media (min-width: 760px) {
  header h1 {
    font-size: 2rem;
  }
}
@media (min-width: 1000px) {
  header h1 {
    max-width: calc(100% - 130px);
  }
}
@media (min-width: 1200px) {
  header h1 {
    max-width: calc(100% - 210px);
  }
}
header .header-slider + h1, header .header-slider-box + h1 {
  padding-top: 20px;
}

h2 {
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.5;
  margin-bottom: 10px;
}

h3 {
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1.5;
  margin-bottom: 8px;
}

p {
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.6;
  margin-bottom: 10px;
}
@media (min-width: 760px) {
  p {
    font-size: 1.125rem;
    margin-bottom: 20px;
  }
}

.teaser figcaption * {
  font-size: 1rem;
  text-align: center;
  margin: 0;
  color: #383634;
}
.teaser h2 {
  font-weight: 700;
  line-height: 1.2;
  margin: 0;
}
.teaser time {
  font-weight: 400;
  line-height: 1.33;
}
.teaser a {
  color: #383634;
  text-decoration: none;
}
.teaser-special * {
  text-align: center;
}
.teaser-special * h2 {
  font-size: 1.25rem;
  font-weight: 700;
}
@media (min-width: 760px) {
  .teaser-special * h2 {
    font-size: 1.5rem;
    padding-bottom: 10px;
  }
}
.teaser-special * p {
  line-height: 1.5;
  margin: 0;
}
.teaser-special * p.more {
  padding-top: 15px;
}
@media (min-width: 760px) {
  .teaser-special * p {
    font-size: 1.125rem;
  }
}
.teaser-special * a {
  position: relative;
  font-weight: 600;
  margin: 0 auto;
  padding: 5px 26px 5px 16px;
  background: #fff;
  border: 1px solid #565550 !important;
  display: inline-block;
}
.teaser-special * a:hover {
  color: #fff;
  background: #565550;
}
.teaser-special * a:hover:after {
  border-color: #fff;
}
.teaser-special * a:after {
  content: "";
  position: absolute;
  top: calc(50% - 4px);
  right: 10px;
  width: 7px;
  height: 7px;
  border-width: 3px;
  border-style: solid solid none none;
  border-color: #565550;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
  display: block;
}
.teaser.download figcaption * {
  font-size: 1.5rem;
  font-weight: 700;
}
@media (min-width: 480px) {
  .teaser.download figcaption * {
    font-size: 1.75rem;
  }
}
.teaser.download p {
  line-height: 1.2;
}

main .inner figure {
  margin-bottom: 20px;
}
main .inner figure figcaption {
  font-size: 1rem;
  line-height: 1.5;
  text-align: center;
  padding: 5px;
}
@media (min-width: 760px) {
  main .inner figure figcaption {
    font-size: 1.125rem;
    padding: 5px 10px 0;
  }
}
@media (min-width: 760px) {
  main .inner figure {
    margin-bottom: 30px;
  }
}
main .inner img {
  width: 100%;
}
main .inner aside h2 {
  font-size: 1.125rem;
  font-style: normal;
  margin: 0 0 8px;
}
@media (min-width: 1000px) {
  main .inner aside h2 {
    font-size: 1.25rem;
  }
}
main .inner aside h3 {
  font-size: 1rem;
  font-style: normal;
  margin: 0 0 4px;
}
@media (min-width: 1000px) {
  main .inner aside h3 {
    font-size: 1.125rem;
  }
}
main .inner aside.downloads h2 {
  text-align: center;
  margin: 0 -20px 10px;
  padding: 5px 10px;
  color: #fff;
  background: rgba(86, 85, 80, 0.9);
}
main .inner aside.subpages > h3 {
  text-align: center;
  width: 100%;
  margin-bottom: 15px;
}
main .inner aside.subpages .more {
  text-align: center;
}
main .inner aside.subpages .more a {
  position: relative;
  font-weight: 600;
  margin: 0 auto;
  padding: 5px 26px 5px 16px;
  background: #fff;
  border: 1px solid #565550;
  display: inline-block;
}
main .inner aside.subpages .more a:hover {
  color: #fff;
  background: #565550;
}
main .inner aside.subpages .more a:hover:after {
  border-color: #fff;
}
main .inner aside.subpages .more a:after {
  content: "";
  position: absolute;
  top: calc(50% - 4px);
  right: 10px;
  width: 7px;
  height: 7px;
  border-width: 3px;
  border-style: solid solid none none;
  border-color: #565550;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
  display: block;
}
main .inner aside p, main .inner aside a {
  font-size: 1rem;
  font-style: normal;
  text-decoration: none;
  color: #383634;
}
main .inner aside p {
  margin-bottom: 10px;
}
main .inner aside #booking-btn {
  position: relative;
  font-size: 1rem;
  font-weight: 700;
  margin: 10px 0;
  padding: 4px 20px;
  color: #fff;
  background-color: #565550;
  border: 1px solid #383634;
  border-radius: 5px;
  -webkit-box-shadow: 0 4px 4px rgba(0, 0, 0, 0.3);
          box-shadow: 0 4px 4px rgba(0, 0, 0, 0.3);
  cursor: pointer;
}
main .inner aside #booking-btn:hover {
  margin: 12px 0 8px;
  -webkit-box-shadow: none;
          box-shadow: none;
}
main .inner aside.event-info .comment {
  margin-top: 15px;
  padding-top: 10px;
  border-top: 1px solid rgba(56, 54, 52, 0.3);
}
main .inner ul, main .inner ol:not(.breadcrumb) {
  list-style: none;
  margin-bottom: 10px;
}
@media (min-width: 760px) {
  main .inner ul, main .inner ol:not(.breadcrumb) {
    margin-bottom: 20px;
  }
}
main .inner ul li, main .inner ol:not(.breadcrumb) li {
  position: relative;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.6;
  padding-left: 21px;
}
main .inner ul li:before, main .inner ol:not(.breadcrumb) li:before {
  content: "";
  position: absolute;
  top: 0.5625em;
  left: 3px;
  width: 9px;
  height: 9px;
  background: rgba(86, 85, 80, 0.9);
  border-radius: 2px;
}
@media (min-width: 760px) {
  main .inner ul li, main .inner ol:not(.breadcrumb) li {
    font-size: 1.125rem;
  }
}
main .inner ol:not(.breadcrumb) {
  counter-reset: section;
}
main .inner ol:not(.breadcrumb) li {
  padding-left: 24px;
}
main .inner ol:not(.breadcrumb) li:before {
  content: counter(section) ".";
  counter-increment: section;
  top: 0;
  left: 2px;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.6;
  width: auto;
  height: auto;
  background: none;
  border: none;
}
@media (min-width: 760px) {
  main .inner ol:not(.breadcrumb) li:before {
    font-size: 1.125rem;
  }
}
main .inner a {
  color: #383634;
  text-decoration: none;
  border-bottom: 1px dotted #565550;
}
main .inner a:hover {
  border-bottom-style: solid;
}

dl.offer {
  margin-bottom: 20px;
}
@media (min-width: 760px) {
  dl.offer {
    margin-bottom: 30px;
  }
}
dl.offer dt {
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.5;
  margin-bottom: 5px;
  padding: 5px 10px;
  color: #565550;
  background: rgba(86, 85, 80, 0.1);
}
@media (min-width: 760px) {
  dl.offer dt {
    font-size: 1.125rem;
  }
}
dl.offer dt:not(:first-of-type) {
  margin-top: 20px;
}
dl.offer dt + dt {
  margin-top: 30px !important;
}
dl.offer dt time {
  margin: -5px 15px -5px -10px;
  padding: 5px 10px;
  color: #fff;
  background: rgba(86, 85, 80, 0.7);
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
}
dl.offer dd {
  padding: 0 10px;
}
dl.offer dd p {
  margin: 0 0 5px;
}
dl.offer dd.addon {
  font-size: 1rem;
  line-height: 1.5;
  font-style: italic;
}
@media (min-width: 760px) {
  dl.offer dd.addon {
    font-size: 1.125rem;
  }
}

.opening h2 {
  line-height: 1.33;
}
.opening small {
  font-size: 1rem;
  font-weight: 400;
}
@media (max-width: 479px) {
  .opening small {
    display: block;
  }
}
.opening dl dt, .opening dl dd {
  font-size: 1rem;
  line-height: 1.5;
}
@media (min-width: 760px) {
  .opening dl dt, .opening dl dd {
    font-size: 1.125rem;
  }
}
.opening dl dt {
  font-weight: 600;
  margin-bottom: 8px;
  padding: 5px 10px;
  color: #383634;
  background: rgba(86, 85, 80, 0.1);
  display: block;
}
.opening dl dt:after {
  content: "\a";
  white-space: pre;
}
.opening dl dt:not(:first-of-type) {
  margin-top: 12px;
}
.opening dl dd {
  padding-left: 10px;
  display: block;
}
@media (min-width: 760px) {
  .opening dl dd {
    padding-left: 0;
    display: inline-block;
  }
}
.opening dl dd:before {
  content: attr(data-location) ":  ";
}
@media (min-width: 760px) {
  .opening dl dd:nth-child(3n+2) {
    padding-left: 10px;
    /*&:after {
      content: '\0020|\0020';
    }*/
  }
}
@media (min-width: 760px) {
  .opening dl.annual dd {
    padding-left: 10px;
  }
}
.opening dl.annual dd:before, .opening dl.annual dd:after {
  display: none !important;
}

footer address p, footer address a {
  line-height: 1.5;
  font-style: normal;
  text-align: center;
  text-decoration: none;
  margin: 0;
  color: #fff;
}
footer address p > a:hover, footer address a > a:hover {
  border-bottom: 1px solid #fff;
}
@media (max-width: 479px) {
  footer address p, footer address a {
    font-size: 1rem;
  }
}
footer address ul {
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-top: 20px;
}
footer address ul li {
  margin: 0 5px;
}
footer address ul li:first-child {
  margin-left: 0;
}
footer address ul li a {
  position: relative;
  text-indent: -999em;
  width: 30px;
  height: 30px;
  display: block;
}
footer address ul li a:after {
  position: absolute;
  top: 0;
  left: 0;
  text-indent: 0;
  line-height: 0;
  width: 30px;
  display: block;
}
footer address ul li:nth-of-type(1) a:after {
  content: url(img/map-marker.svg);
}
footer address ul li:nth-of-type(2) a:after {
  content: url(img/facebook.svg);
  left: -2px;
}
footer address ul li:nth-of-type(3) a:after {
  content: url(img/instagram.svg);
}

.cc-window {
  position: fixed;
  top: 133px;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: 100;
  text-align: center;
  width: 80%;
  padding: 25px 10px;
  background: #383634;
  border-radius: 8px;
  -webkit-box-shadow: 0 0 6px 3px rgba(255, 255, 255, 0.5);
          box-shadow: 0 0 6px 3px rgba(255, 255, 255, 0.5);
}
@media (min-width: 480px) {
  .cc-window {
    min-width: 420px;
  }
}
.cc-window .cc-message {
  line-height: 1.8;
  color: #fff;
}
.cc-window .cc-link {
  text-decoration: none;
  margin: 0 10px;
  color: #fff;
  border-bottom: 1px dotted #fff;
  white-space: nowrap;
}
.cc-window .cc-link:before {
  content: "» ";
}
.cc-window .cc-link:after {
  content: " «";
}
.cc-window .cc-link:hover, .cc-window .cc-link:focus {
  borrder-bottom-style: solid;
}
.cc-window .cc-compliance {
  margin-top: 15px;
  display: block;
}
@media (min-width: 480px) {
  .cc-window .cc-compliance {
    margin-top: 0;
    display: inline-block;
  }
}
.cc-window .cc-dismiss {
  font-weight: 600;
  margin: 0 5px;
  padding: 2px 8px 3px 8px;
  color: #383634;
  background: #cecdc8;
  border-radius: 4px;
  cursor: pointer;
}
.cc-window.cc-invisible {
  display: none;
}

#dsgvo_bglayer {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 999;
  background-color: rgba(0, 0, 0, 0.6);
  -webkit-transition: all 0.25s;
  -o-transition: all 0.25s;
  transition: all 0.25s;
}

#dsgvo {
  text-align: center;
  position: fixed;
  color: #383634;
  -webkit-transition: all 0.25s;
  -o-transition: all 0.25s;
  transition: all 0.25s;
  width: calc(100% - 60px);
  z-index: 1000;
  opacity: 1;
  max-width: 400px;
}
#dsgvo > .content {
  padding: 15px;
  background-color: #fff;
  z-index: 1;
  position: relative;
}
#dsgvo > .content h2 {
  font-family: "Open Sans";
  font-size: 1.25rem;
  font-weight: 700;
  margin: 0;
  padding: 0;
  color: #383634;
}
#dsgvo > .content p {
  margin: 15px 0;
  font-size: 0.875rem;
  line-height: 1.33;
  font-weight: normal;
  padding: 0;
}
#dsgvo > .content p:last-child {
  margin-bottom: 0;
}
#dsgvo > .content a {
  font-size: 14px;
  line-height: 16px;
  color: #383634;
  text-decoration: none;
  padding: 0 1px;
  color: #383634;
  border-bottom: 1px dotted #565550;
}
#dsgvo > .content a:hover {
  border-bottom-style: solid;
}
#dsgvo > .content a.info {
  display: inline-block;
  margin-left: 5px;
}
#dsgvo > .content > div .cookie_group_wrap {
  border-top: 1px solid #565550;
}
#dsgvo > .content > div .cookie_group_wrap .cookie_group {
  padding: 0 2px;
  border-bottom: 1px solid #565550;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#dsgvo > .content > div .cookie_group_wrap .cookie_group label {
  position: relative;
  padding: 12px 5px 12px 40px;
  cursor: pointer;
}
#dsgvo > .content > div .cookie_group_wrap .cookie_group label:before {
  content: "";
  position: absolute;
  z-index: 1;
  top: 6px;
  left: 0;
  width: 24px;
  height: 24px;
  background: #fff;
  border: 2px solid #383634;
  border-radius: 3px;
}
#dsgvo > .content > div .cookie_group_wrap .cookie_group [type=checkbox] {
  position: absolute;
  opacity: 0;
}
#dsgvo > .content > div .cookie_group_wrap .cookie_group [type=checkbox]:checked + label:after {
  content: "";
  position: absolute;
  z-index: 2;
  left: 10px;
  top: 11px;
  width: 5px;
  height: 11px;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
  border-right: solid 3px #383634;
  border-bottom: solid 3px #383634;
  pointer-events: none;
}
#dsgvo > .content > div .cookie_group_wrap .cookie_group [type=checkbox]:checked:disabled + label {
  color: #999;
  pointer-events: none;
  cursor: inherit;
}
#dsgvo > .content > div .cookie_group_wrap .cookie_group [type=checkbox]:checked:disabled + label:before {
  background: #cecdc8;
  border-color: #999;
}
#dsgvo > .content > div .cookie_group_wrap .cookie_group [type=checkbox]:checked:disabled + label:after {
  border-color: #999;
}
#dsgvo > .content > div a {
  font-size: 0.875rem;
  text-decoration: none;
  padding: 2px 5px;
  color: #383634;
  border-bottom: 1px dotted #565550;
}
#dsgvo > .content > div a:hover {
  border-bottom-style: solid;
}
#dsgvo > .content > div .accept_wrap {
  padding-top: 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#dsgvo > .content > div .accept_wrap > a {
  text-decoration: none;
  margin-top: 5px;
  margin-bottom: 5px;
  padding: 8px 18px;
  width: 180px;
}
#dsgvo > .content > div .accept_wrap > a.accept {
  font-size: 1.125rem;
  font-weight: 700;
  color: #fff;
  background-color: #383634;
}
#dsgvo > .content > div .accept_wrap > a.accept:hover {
  color: #383634;
  background: #565550;
}
#dsgvo > .content > div .accept_wrap > a.accept2 {
  font-size: 0.875em;
  color: #999;
  background: transparent;
  border: 1px solid #ccc;
}
#dsgvo > .content > div .accept_wrap > a.accept2:hover {
  background: #ddd;
}
#dsgvo > .info {
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: calc(100%);
  max-height: 100%;
  overflow-y: auto;
  background-color: #fff;
  -webkit-transition: all 0.5s;
  -o-transition: all 0.5s;
  transition: all 0.5s;
  opacity: 0;
}
#dsgvo > .info .inner {
  width: 100%;
}
#dsgvo > .info p {
  padding: 15px;
  font-size: 14px;
  line-height: 16px;
}
#dsgvo > .info p a {
  font-size: 14px;
  line-height: 16px;
  text-decoration: none;
  padding: 2px 5px;
  color: #383634;
  color: #383634;
  border-bottom: 1px dotted #565550;
}
#dsgvo > .info p a:hover {
  border-bottom-style: solid;
}
#dsgvo > .info > .inner > .group p:first-of-type {
  font-weight: 700;
}
#dsgvo > .info > .inner > .group > .cookie {
  font-size: 0.8125rem;
  margin: 0 10px 15px;
  width: calc(100% - 20px);
  border-top: 1px solid #565550;
}
#dsgvo > .info > .inner > .group > .cookie .row {
  text-align: left;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin: 0 0 1px;
  padding: 8px 2px 0;
  border-bottom: 1px solid #565550;
}
#dsgvo > .info > .inner > .group > .cookie .row .label {
  font-weight: 600;
  text-align: left;
  padding-bottom: 10px;
  width: 120px;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 120px;
          flex: 0 0 120px;
}
#dsgvo > .info > .inner > .group > .cookie .row .value {
  width: calc(100% - 120px);
  padding-bottom: 10px;
}
#dsgvo.show_info > .info {
  opacity: 1;
  z-index: 2;
}
#dsgvo.ft {
  left: 30px;
  top: 30px;
}
#dsgvo.mt {
  left: 50%;
  top: 80px;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
}
#dsgvo.rt {
  right: 30px;
  top: 30px;
}
#dsgvo.lm {
  left: 30px;
  top: 50%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
}
#dsgvo.mm {
  left: 50%;
  top: 50%;
  -webkit-transform: translateX(-50%) translateY(-50%);
      -ms-transform: translateX(-50%) translateY(-50%);
          transform: translateX(-50%) translateY(-50%);
}
#dsgvo.rm {
  right: 30px;
  top: 50%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
}
#dsgvo.lb {
  left: 30px;
  bottom: 30px;
}
#dsgvo.mb {
  left: 50%;
  bottom: 30px;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
}
#dsgvo.rb {
  right: 30px;
  bottom: 30px;
}

#dsgvo.hide, #dsgvo_bglayer.hide {
  opacity: 0;
}

#dsgvo_info > .cookie {
  font-size: 0.875rem;
  margin: 0 0 25px;
  width: 100%;
  border-top: 1px solid #565550;
}
#dsgvo_info > .cookie:last-of-type {
  margin-bottom: 15px;
}
#dsgvo_info > .cookie .row {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin: 0 0 1px;
  padding: 8px 5px 0;
  border-bottom: 1px solid #565550;
}
#dsgvo_info > .cookie .row .label {
  font-weight: 700;
  padding-bottom: 10px;
  width: 125px;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 125px;
          flex: 0 0 125px;
}
#dsgvo_info > .cookie .row .value {
  width: calc(100% - 125px);
  padding-bottom: 10px;
}
#dsgvo_info .cookie-decision {
  font-size: 1rem;
  font-style: italic;
}
#dsgvo_info .reject {
  color: #ff6438;
}

button.dsgvo {
  font-size: 1rem;
  font-style: italic;
  background: none;
  border: none;
  color: #383634;
  border-bottom: 1px dotted #565550;
  cursor: pointer;
}
button.dsgvo:hover, button.dsgvo:focus {
  border-bottom-style: solid;
  outline: none;
}

.header-slider,
.main-slider,
.main-slider-full,
.logo-slider {
  position: relative;
  line-height: 0;
  width: 100%;
  margin: 0 auto;
}

.header-slider-box {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 41.6666%;
  overflow: hidden;
}
.header-slider-box .slider-progress {
  width: 100%;
  height: 3px;
  background: rgba(255, 255, 255, 0.3);
  position: absolute;
  top: 0;
  z-index: 1;
}
.header-slider-box .slider-progress .progress {
  width: 0%;
  height: 100%;
  background: rgba(255, 255, 255, 0.6);
}

.header-slider {
  height: 0;
  padding-bottom: 41.6666%;
  overflow: hidden;
}
.header-slider figure {
  position: relative;
}
.header-slider figure:not(:first-of-type) {
  display: none;
}
.js .header-slider figure:not(:first-of-type) {
  display: inherit;
}
.header-slider figure img {
  width: 100%;
}
.header-slider figure figcaption {
  position: absolute;
  z-index: 1;
  bottom: 14px;
  font-size: 16px;
  font-weight: 600;
  line-height: 1.33;
  text-align: center;
  width: 100%;
  color: #383634;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media (min-width: 480px) {
  .header-slider figure figcaption {
    bottom: 16px;
    font-size: 21px;
  }
}
@media (min-width: 760px) {
  .header-slider figure figcaption {
    bottom: 30px;
    font-size: 36px;
  }
}
@media (min-width: 1000px) {
  .header-slider figure figcaption {
    font-size: 48px;
  }
}
.header-slider figure figcaption span {
  position: relative;
  max-width: calc(100% - 16px);
  padding: 0 5px;
  display: inline-block;
}
@media (min-width: 480px) {
  .header-slider figure figcaption span {
    padding: 0 10px;
  }
}
@media (min-width: 760px) {
  .header-slider figure figcaption span {
    padding: 0 20px;
  }
}
.header-slider figure figcaption span:after {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: rgba(255, 255, 255, 0.7);
  display: block;
}

.logo-slider {
  margin: 20px auto 30px !important;
}
.logo-slider li {
  margin: 0 10px;
  padding: 0 !important;
}
.logo-slider li:before {
  display: none;
}
.logo-slider li img {
  width: auto;
  height: 100px;
}

.main-slider,
.main-slider-full {
  width: 100%;
  padding-bottom: 35px;
  overflow-x: hidden;
}
.main-slider .slick-list,
.main-slider-full .slick-list {
  width: calc(100% + 20px);
  margin: 0 -10px;
}
.main-slider figure,
.main-slider-full figure {
  height: 0;
  margin-bottom: 0 !important;
  padding: 0 10px 41.67%;
  max-width: 980px;
}
.main-slider figure figcaption,
.main-slider-full figure figcaption {
  margin-bottom: -1rem;
}

.slick-list {
  width: 100%;
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
}
.slick-list .slick-track {
  position: relative;
  top: 0;
  left: 0;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.slick-arrow {
  position: absolute;
  z-index: 10;
  bottom: 17px;
  text-indent: -999em;
  width: 18px;
  height: 18px;
  background: transparent;
  border: none;
  border-radius: 4px;
  cursor: pointer;
}
@media (min-width: 760px) {
  .slick-arrow {
    bottom: 20px;
  }
}
.slick-arrow:before {
  content: "";
  position: absolute;
  top: 5px;
  left: 6px;
  text-indent: 0;
  width: 6px;
  height: 6px;
  -webkit-transform: rotate(-135deg);
      -ms-transform: rotate(-135deg);
          transform: rotate(-135deg);
  border-width: 2px 2px 0 0;
  border-style: solid;
  border-color: #565550;
  display: block;
}
@media (min-width: 760px) {
  .slick-arrow:before {
    width: 10px;
    height: 10px;
  }
}
.slick-arrow.slick-prev {
  left: 12px;
}
.slick-arrow.slick-next {
  right: 12px;
  -webkit-transform: rotate(180deg);
      -ms-transform: rotate(180deg);
          transform: rotate(180deg);
}

.slick-dots {
  position: absolute;
  z-index: 1;
  bottom: 2px;
  list-style: none;
  width: 100%;
  height: 9px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media (min-width: 760px) {
  .slick-dots {
    bottom: 10px;
    height: 12px;
  }
}
.main-slider .slick-dots, .main-slider-full .slick-dots {
  position: relative;
  bottom: -9px;
  margin: 0;
}
@media (min-width: 760px) {
  .main-slider .slick-dots, .main-slider-full .slick-dots {
    bottom: -5px;
  }
}
.slick-dots li {
  margin: 0 3px;
  padding: 0 !important;
}
.slick-dots li:before {
  display: none;
}
@media (min-width: 760px) {
  .slick-dots li {
    margin: 0 5px;
  }
}
.slick-dots li button {
  text-indent: -999em;
  width: 7px;
  height: 7px;
  background: #383634;
  border: none;
  border-radius: 2px;
  -webkit-box-shadow: 0 0 1px 1px rgba(255, 255, 255, 0.3);
          box-shadow: 0 0 1px 1px rgba(255, 255, 255, 0.3);
  cursor: pointer;
}
@media (min-width: 760px) {
  .slick-dots li button {
    width: 10px;
    height: 10px;
    -webkit-box-shadow: 0 0 3px 1px rgba(255, 255, 255, 0.3);
            box-shadow: 0 0 3px 1px rgba(255, 255, 255, 0.3);
  }
}
.slick-dots li.slick-active button {
  background-color: #cecdc8;
}

.form-default {
  position: relative;
  margin-bottom: 20px;
  padding-top: 20px;
}
.form-default #meta {
  position: absolute;
  top: -120px;
}
.form-default .form-group {
  position: relative;
  min-height: 40px;
  margin-bottom: 15px;
}
.form-default .form-control {
  width: 100%;
  max-width: 460px;
  display: block;
}
.form-default input, .form-default select, .form-default option, .form-default textarea, .form-default .bootstrap-select .btn {
  font-family: "Source Sans Pro";
  font-size: 1rem;
  font-weight: 600;
  height: 40px;
  padding: 4px 20px;
  color: #383634;
  border: none;
  border-radius: 0;
  -webkit-box-shadow: none;
          box-shadow: none;
  background: #f3f3f3;
}
.form-default input:focus, .form-default select:focus, .form-default option:focus, .form-default textarea:focus, .form-default .bootstrap-select .btn:focus {
  outline: none;
  border: none;
  -webkit-box-shadow: none;
          box-shadow: none;
}
.form-default input::-webkit-input-placeholder, .form-default select::-webkit-input-placeholder, .form-default option::-webkit-input-placeholder, .form-default textarea::-webkit-input-placeholder, .form-default .bootstrap-select .btn::-webkit-input-placeholder {
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #383634;
  -webkit-transition: color ease 0.3s;
  transition: color ease 0.3s;
}
.form-default input::-moz-placeholder, .form-default select::-moz-placeholder, .form-default option::-moz-placeholder, .form-default textarea::-moz-placeholder, .form-default .bootstrap-select .btn::-moz-placeholder {
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #383634;
  -moz-transition: color ease 0.3s;
  transition: color ease 0.3s;
  opacity: 1;
}
.form-default input:-ms-input-placeholder, .form-default select:-ms-input-placeholder, .form-default option:-ms-input-placeholder, .form-default textarea:-ms-input-placeholder, .form-default .bootstrap-select .btn:-ms-input-placeholder {
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #383634;
  -ms-transition: color ease 0.3s;
  transition: color ease 0.3s;
}
.form-default input::-ms-input-placeholder, .form-default select::-ms-input-placeholder, .form-default option::-ms-input-placeholder, .form-default textarea::-ms-input-placeholder, .form-default .bootstrap-select .btn::-ms-input-placeholder {
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #383634;
  -ms-transition: color ease 0.3s;
  transition: color ease 0.3s;
}
.form-default input:placeholder, .form-default select:placeholder, .form-default option:placeholder, .form-default textarea:placeholder, .form-default .bootstrap-select .btn:placeholder {
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #383634;
  -webkit-transition: color ease 0.3s;
  -o-transition: color ease 0.3s;
  transition: color ease 0.3s;
}
.form-default input:focus::-webkit-input-placeholder, .form-default select:focus::-webkit-input-placeholder, .form-default option:focus::-webkit-input-placeholder, .form-default textarea:focus::-webkit-input-placeholder, .form-default .bootstrap-select .btn:focus::-webkit-input-placeholder {
  color: transparent;
}
.form-default input:focus::-moz-placeholder, .form-default select:focus::-moz-placeholder, .form-default option:focus::-moz-placeholder, .form-default textarea:focus::-moz-placeholder, .form-default .bootstrap-select .btn:focus::-moz-placeholder {
  color: transparent;
  opacity: 1;
}
.form-default input:focus:-ms-input-placeholder, .form-default select:focus:-ms-input-placeholder, .form-default option:focus:-ms-input-placeholder, .form-default textarea:focus:-ms-input-placeholder, .form-default .bootstrap-select .btn:focus:-ms-input-placeholder {
  color: transparent;
}
.form-default input:focus::-ms-input-placeholder, .form-default select:focus::-ms-input-placeholder, .form-default option:focus::-ms-input-placeholder, .form-default textarea:focus::-ms-input-placeholder, .form-default .bootstrap-select .btn:focus::-ms-input-placeholder {
  color: transparent;
}
.form-default input:focus:placeholder, .form-default select:focus:placeholder, .form-default option:focus:placeholder, .form-default textarea:focus:placeholder, .form-default .bootstrap-select .btn:focus:placeholder {
  color: transparent;
}
.form-default textarea {
  height: auto;
  padding: 10px 20px;
}
.form-default select {
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.form-default select option {
  background: #fff;
}
.form-default .bootstrap-select {
  width: 230px;
  display: block;
}
.form-default .bootstrap-select select {
  position: absolute;
  left: -100vw;
}
.form-default .bootstrap-select .btn {
  text-transform: uppercase;
  line-height: 2.3;
  letter-spacing: 0.1em;
  width: 100%;
}
.form-default .bootstrap-select .btn .bs-caret {
  display: none;
}
.form-default .bootstrap-select .btn:before {
  content: "";
  position: absolute;
  z-index: 1;
  right: 0;
  top: 50%;
  -webkit-transform: translate(-18px, -75%) rotate(45deg);
      -ms-transform: translate(-18px, -75%) rotate(45deg);
          transform: translate(-18px, -75%) rotate(45deg);
  width: 16px;
  height: 16px;
  border: 3px solid #383634;
  border-top: none;
  border-left: none;
  pointer-events: none;
}
.form-default .bootstrap-select.open .dropdown-menu {
  width: 100%;
  margin: 0;
  padding: 0;
  border: none;
}
.form-default .bootstrap-select.open .dropdown-menu.open {
  height: 0;
  overflow: visible !important;
}
.form-default .bootstrap-select.open .dropdown-menu.inner {
  border-radius: 0;
  -webkit-box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05);
          box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05);
  overflow-y: visible !important;
}
.form-default .bootstrap-select.open .dropdown-menu.inner a {
  width: 100%;
  height: 40px;
  line-height: 2.3;
  padding: 4px 20px !important;
  font-size: 1.125rem;
  font-weight: 600;
  color: #383634 !important;
  background: #fff !important;
  border-bottom: 1px solid #f3f3f3 !important;
  cursor: pointer;
}
.form-default .bootstrap-select.open .dropdown-menu.inner a:hover, .form-default .bootstrap-select.open .dropdown-menu.inner a:focus {
  color: #fff !important;
  background-color: #565550 !important;
  border-color: #f3f3f3 !important;
}
.form-default .bootstrap-select.open .dropdown-menu.inner a:focus, .form-default .bootstrap-select.open .dropdown-menu.inner a:active {
  outline: 0;
}
.form-default .bootstrap-select.open .dropdown-menu.inner .disabled a {
  position: relative;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #383634 !important;
  background-color: #f3f3f3 !important;
  border: none !important;
  pointer-events: none;
}
.form-default .bootstrap-select.open .dropdown-menu.inner .disabled a:before {
  content: "";
  position: absolute;
  z-index: 1;
  right: 0;
  top: 50%;
  -webkit-transform: translate(-18px, -75%) rotate(45deg);
      -ms-transform: translate(-18px, -75%) rotate(45deg);
          transform: translate(-18px, -75%) rotate(45deg);
  width: 16px;
  height: 16px;
  border: 3px solid #383634;
  border-top: none;
  border-left: none;
  pointer-events: none;
}
.form-default .checkbox, .form-default .radio {
  margin: 0;
}
.form-default .checkbox input[type=checkbox], .form-default .radio input[type=radio] {
  height: auto;
  margin-top: 20px;
  margin-bottom: 10px;
}
.form-default .labelBg {
  position: relative;
  line-height: 1.6;
  padding-left: 40px;
  padding-right: 10em;
  padding-bottom: 10px;
  cursor: pointer;
  display: block;
}
.form-default .labelBg:after {
  content: "";
  position: absolute;
  top: -4px;
  left: 0;
  width: 30px;
  height: 30px;
  background-color: #f3f3f3;
  display: block;
}
.form-default .labelBg.labelSelected:after {
  background-image: url(img/checkbox.png);
  background-position: center;
  background-repeat: no-repeat;
}
.form-default .btn-submit {
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.5;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  width: auto;
  margin: 15px 0;
  padding: 6px 20px;
  white-space: nowrap;
  vertical-align: middle;
  color: #fff;
  background: #969696;
  border: none;
  border-radius: 4px;
  -ms-touch-action: manipulation;
      touch-action: manipulation;
  cursor: pointer;
  display: inline-block;
}
.form-default .btn-submit:hover, .form-default .btn-submit:focus {
  background: #383634;
}
.form-default .error {
  position: absolute;
  z-index: 3;
  top: 0;
  right: 0;
  height: 100%;
  max-height: 40px;
  padding: 10px 10px 10px 3px;
  color: #fff;
  background: #ff6438;
  border: 1px solid #ff6438;
}
@media (max-width: 479px) {
  .form-default .error {
    width: 21px;
    color: transparent;
  }
}
.form-default .error:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 5px;
  left: -15px;
  width: 28px;
  height: 28px;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
  background: #ff6438;
  border: 1px solid #ff6438;
}
.form-default .select .dropdown-backdrop {
  z-index: 1;
}
.form-default .select .dropdown-menu {
  z-index: 1;
}
.form-default .select .dropdown-menu li {
  cursor: pointer;
  padding-bottom: 0;
}
.form-default .select .error {
  right: auto;
  left: 245px;
}
.form-default .select .bootstrap-select .btn:hover,
.form-default .select .bootstrap-select .btn:focus {
  color: #383634;
  background-color: #f3f3f3;
}
.form-default .element .validation {
  font-weight: 700;
  color: #ff6438;
  display: none;
}
.form-default .element.invalid .validation {
  margin: 10px 0 5px 100px;
  display: block !important;
}