/* montserrat-regular - latin */
@font-face {
  font-display: swap;
  /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/montserrat-v29-latin-regular.woff2') format('woff2');
  /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* montserrat-700 - latin */
@font-face {
  font-display: swap;
  /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/montserrat-v29-latin-700.woff2') format('woff2');
  /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* montserrat-800 - latin */
@font-face {
  font-display: swap;
  /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  src: url('../fonts/montserrat-v29-latin-800.woff2') format('woff2');
  /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* montserrat-900 - latin */
@font-face {
  font-display: swap;
  /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  src: url('../fonts/montserrat-v29-latin-900.woff2') format('woff2');
  /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
@font-face {
  font-family: 'icons';
  src: url('../fonts/fontello.eot');
  /* IE9 Compat Modes */
  src: url('../fonts/fontello.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ url('../fonts/fontello.woff2') format('woff2'), /* Super Modern Browsers */ url('../fonts/fontello.woff') format('woff'), /* Pretty Modern Browsers */ url('../fonts/fontello.ttf') format('truetype'), /* Safari, Android, iOS */ url('../fonts/fontello.svg#svgFontName') format('svg');
  /* Legacy iOS */
}
#buttonDetail,
#buttonMap,
#button360,
.btn {
  color: #000000;
  text-decoration: none;
}
#buttonDetail:before,
#buttonMap:before,
#button360:before,
.btn:before {
  font-size: 50px;
  margin-right: 15px;
}
#buttonMap,
#buttonDetail,
.btn {
  display: -ms-flexbox;
  display: flex;
  line-height: 2.4rem;
}
#buttonMap:before,
#buttonDetail:before,
.btn:before {
  -ms-flex-line-pack: center;
      align-content: center;
  -ms-flex-align: center;
      align-items: center;
  background: #000000;
  border-radius: 25px;
  color: #FFFFFF;
  content: '\e802';
  display: -ms-flexbox;
  display: flex;
  font-family: 'icons';
  font-size: 18px;
  height: 50px;
  -ms-flex-pack: center;
      justify-content: center;
  overflow: hidden;
  width: 50px;
}
#buttonMap.hide,
#buttonDetail.hide,
.btn.hide {
  display: none;
}
.btn.js-toggle:before {
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
}
.btn.js-toggle.top:before {
  -webkit-transform: rotate(-90deg);
          transform: rotate(-90deg);
}
.btn.js-toggle > span {
  display: none;
}
#button360 {
  display: -ms-flexbox;
  display: flex;
  line-height: 2.4rem;
}
#button360:before {
  content: '\e801';
  font-family: 'icons';
  font-size: 40px;
  height: 50px;
  -ms-flex-pack: center;
      justify-content: center;
  overflow: hidden;
  width: 50px;
}
#closeIframe {
  -ms-flex-line-pack: center;
      align-content: center;
  -ms-flex-align: center;
      align-items: center;
  background: #009FE3;
  border-radius: 0;
  border: 0;
  display: -ms-flexbox;
  display: flex;
  height: 50px;
  -ms-flex-pack: center;
      justify-content: center;
  margin: 0;
  width: 50px;
}
#closeIframe:before {
  content: '\e810';
  font-family: 'icons';
  color: #FFFFFF;
  font-size: 30px;
  -ms-flex-pack: center;
      justify-content: center;
  overflow: hidden;
}
#closeIframe > span {
  display: none;
}
.cs-lightbox:before {
  content: '\e800';
  font-family: 'icons';
}
.cs-closer:before {
  content: '\e810';
  font-family: 'icons';
}
.cs-next:before {
  content: '\e802';
  font-family: 'icons';
}
.cs-back:before {
  content: '\e802';
  font-family: 'icons';
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}
#eFullScreen {
  display: none;
}
#eFullScreen.active {
  display: block;
}
.btn {
  cursor: pointer;
}
#buttonLegendClose {
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.25);
  position: absolute;
  top: 30px;
  right: 30px;
}
#buttonLegendClose > span {
  display: none;
}
* {
  box-sizing: border-box;
}
html,
body {
  background-color: #E7E387;
  background-image: url("../pics/strassen.png");
  background-position: 41px 68px;
  background-repeat: no-repeat;
  font-family: 'Montserrat';
  font-size: 21px;
  line-height: 160%;
  margin: 0;
  overflow: hidden;
  padding: 0;
}
h1 {
  font-family: 'Montserrat';
  font-weight: 800;
  font-size: 36px;
  line-height: 110%;
  text-transform: uppercase;
}
.header {
  background: #FFFFFF;
  bottom: 0;
  padding: 30px 60px 30px 30px;
  position: absolute;
  right: 0;
  top: 0;
  width: 528px;
  z-index: 101;
}
.logo-bbw {
  margin-bottom: 60px;
}
.logo-diakonie {
  position: absolute;
  bottom: 30px;
  left: 30px;
}
#fullscreen {
  bottom: 0;
  position: absolute;
  right: 0;
  z-index: 1001;
}
.iframe {
  display: inline-block;
  position: relative;
  z-index: 1000;
}
.iframe > iframe {
  border: 0;
}
.iframe .closeIframe {
  position: absolute;
  right: 30px;
  top: 30px;
}
.hide {
  display: none;
}
.wrap {
  position: relative;
}
button.button {
  -ms-flex-line-pack: center;
      align-content: center;
  -ms-flex-align: center;
      align-items: center;
  background: #fff;
  border-radius: 29px;
  border: 0;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.25);
  color: #000;
  height: 50px;
  -ms-flex-pack: center;
      justify-content: center;
  overflow: hidden;
  padding: 10px;
  position: absolute;
  right: 0;
  top: 0;
  width: 50px;
  font-size: 24px;
  font-family: 'Montserrat';
  font-weight: 800;
  display: -ms-flexbox;
  display: flex;
  right: auto;
}
#text {
  margin-bottom: 30px;
  margin-left: 70px;
}
#text p {
  margin: 0 0 10px 0;
}
#text p:first-child {
  padding-top: 10px;
}
#detail {
  background: #009FE3;
  bottom: 0;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
  z-index: 99;
}
#detail > .wrap {
  margin: 0 600px 0 140px;
}
#detailHeadline {
  margin: 165px 0 50px 0;
  font-size: 24px;
  font-weight: 800;
}
#detailGalery {
  height: 270px;
  margin-top: 60px;
  position: relative;
  width: 92%;
}
#detailGalery .cs-back {
  left: -70px;
  margin-top: -25px;
  position: absolute;
  top: 50%;
  cursor: pointer;
}
#detailGalery .cs-back.deactiv {
  opacity: 0.5;
}
#detailGalery .cs-next {
  margin-top: -25px;
  position: absolute;
  right: -70px;
  top: 50%;
  cursor: pointer;
}
#detailGalery .cs-next.deactiv {
  opacity: 0.5;
}
#detailGalery > .wrap {
  display: -ms-flexbox;
  display: flex;
  margin-left: -13px;
  margin-right: -13px;
  overflow: hidden;
}
#detailGalery > .wrap > .images {
  display: -ms-flexbox;
  display: flex;
  left: 0;
  position: relative;
  transition: left 0.25s linear;
}
#detailGalery > .wrap > .images > .image {
  -ms-flex-positive: 0;
      flex-grow: 0;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  margin: 0 13px;
  position: relative;
  width: 344px;
}
#detailGalery > .wrap > .images > .image > a {
  display: -ms-flexbox;
  display: flex;
}
#detailGalery > .wrap > .images > .image > a.js-lightbox {
  background-color: rgba(255, 255, 255, 0.5);
  background-image: url("../pics/loader.svg");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 45px 45px;
}
#detailGalery > .wrap > .images > .image img {
  height: auto;
  width: 100%;
}
#detailGalery > .wrap > .images > .image img.unload {
  visibility: hidden;
}
#location {
  left: 453px;
  position: absolute;
  top: 529px;
  z-index: 99;
}
.cs-video {
  -ms-flex-align: center;
      align-items: center;
  color: #000000;
  display: -ms-flexbox;
  display: flex;
  line-height: 160%;
  position: relative;
  text-decoration: none;
}
.cs-video:before {
  -ms-flex-line-pack: center;
      align-content: center;
  -ms-flex-align: center;
      align-items: center;
  background: #FFFFFF;
  border-radius: 25px;
  box-shadow: 0 0 15px rgba(0, 0, 0, 0.25);
  color: #000000;
  content: '\e80a';
  display: -ms-flexbox;
  display: flex;
  font-family: 'icons';
  font-size: 18px;
  height: 50px;
  min-height: 50px;
  -ms-flex-pack: center;
      justify-content: center;
  overflow: hidden;
  width: 50px;
  min-width: 50px;
  margin-right: 20px;
}
#detailVideos {
  display: -ms-flexbox;
  display: flex;
  margin-left: -20px;
  margin-right: -20px;
}
#detailVideos > .video {
  margin: 40px 20px 0 20px;
}
.map {
  list-style: none;
  margin: 0;
  position: relative;
  height: 1080px;
}
.map > li {
  margin: 0;
  padding: 0;
}
.map > li.gray img {
  -webkit-filter: grayscale();
          filter: grayscale();
}
.map > li.gray.button-1 img {
  -webkit-filter: brightness(150%) grayscale();
          filter: brightness(150%) grayscale();
}
.map > li.gray.button-3 img {
  -webkit-filter: brightness(400%) grayscale();
          filter: brightness(400%) grayscale();
}
.map > li.gray.button-5 img {
  -webkit-filter: brightness(300%) grayscale();
          filter: brightness(300%) grayscale();
}
.map > li.gray.button-7 img {
  -webkit-filter: brightness(300%) grayscale();
          filter: brightness(300%) grayscale();
}
.map > li.gray.button-8 img {
  -webkit-filter: brightness(150%) grayscale();
          filter: brightness(150%) grayscale();
}
.map > li.gray.button-9 img {
  -webkit-filter: brightness(700%) grayscale();
          filter: brightness(700%) grayscale();
}
.map > li.gray.button-10 img {
  -webkit-filter: brightness(400%) grayscale();
          filter: brightness(400%) grayscale();
}
.map > li.button-1 {
  position: absolute;
  left: 454px;
  top: 500px;
  z-index: 1;
}
.map > li.button-2 {
  position: absolute;
  left: 440px;
  top: 355px;
  z-index: 1;
}
.map > li.button-3 {
  position: absolute;
  left: 592px;
  top: 176px;
  z-index: 1;
}
.map > li.button-4A {
  position: absolute;
  left: 700px;
  top: 229px;
  z-index: 1;
}
.map > li.button-4B {
  position: absolute;
  left: 767px;
  top: 299px;
  z-index: 1;
}
.map > li.button-4C {
  position: absolute;
  left: 868px;
  top: 352px;
  z-index: 1;
}
.map > li.button-4D {
  position: absolute;
  left: 970px;
  top: 393px;
  z-index: 1;
}
.map > li.button-4E {
  position: absolute;
  left: 1077px;
  top: 424px;
  z-index: 1;
}
.map > li.button-4F {
  position: absolute;
  left: 1187px;
  top: 450px;
  z-index: 1;
}
.map > li.button-5 {
  position: absolute;
  left: 736px;
  top: 593px;
  z-index: 1;
}
.map > li.button-6 {
  position: absolute;
  left: 670px;
  top: 770px;
  z-index: 2;
}
.map > li.button-6 span {
  left: 40px;
}
.map > li.button-7 {
  position: absolute;
  left: 628px;
  top: 796px;
  z-index: 1;
}
.map > li.button-7 span {
  left: -20px;
}
.map > li.button-8 {
  position: absolute;
  left: 555px;
  top: 683px;
  z-index: 1;
}
.map > li.button-9 {
  position: absolute;
  left: 593px;
  top: 538px;
  z-index: 1;
}
.map > li.button-10 {
  position: absolute;
  left: 365px;
  top: 485px;
  z-index: 1;
}
.map > li.button-11 {
  position: absolute;
  left: 277px;
  top: 478px;
  z-index: 1;
}
.map > li.button-12 {
  position: absolute;
  left: 200px;
  top: 471px;
  z-index: 1;
}
li.button > button {
  margin: 0;
  padding: 0;
  background: none;
  border: 0;
  position: relative;
  cursor: pointer;
}
li.button > button > span {
  -ms-flex-line-pack: center;
      align-content: center;
  -ms-flex-align: center;
      align-items: center;
  background: #fff;
  border-radius: 29px;
  border: 0;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.25);
  color: #000;
  display: -ms-flexbox;
  display: flex;
  height: 50px;
  -ms-flex-pack: center;
      justify-content: center;
  overflow: hidden;
  padding: 10px;
  position: absolute;
  right: 0;
  top: 0;
  width: 50px;
  font-size: 24px;
  font-family: 'Montserrat';
  font-weight: 800;
}
li.button > button.active > span {
  background: #000;
  color: #fff;
}
.layer-legend {
  left: 0;
  position: absolute;
  top: 0;
  z-index: 97;
  pointer-events: none;
}
.legend {
  bottom: 40px;
  display: -ms-flexbox;
  display: flex;
  left: 900px;
  list-style: none;
  position: absolute;
  z-index: 98;
}
.legend > li {
  margin-left: 20px;
}
.legend > li a {
  -ms-flex-line-pack: center;
      align-content: center;
  -ms-flex-align: center;
      align-items: center;
  background: #009FE3;
  border-radius: 0;
  border: 0;
  display: -ms-flexbox;
  display: flex;
  height: 50px;
  -ms-flex-pack: center;
      justify-content: center;
  margin: 0;
  width: 50px;
  position: relative;
  text-decoration: none;
}
.legend > li a:before {
  color: #FFFFFF;
  font-family: 'icons';
}
.legend > li a.buttonRect-1:before {
  content: "\e807";
}
.legend > li a.buttonRect-2:before {
  content: "\e803";
}
.legend > li a.buttonRect-3:before {
  content: "\e808";
}
.legend > li a.buttonRect-4:before {
  content: "\e805";
}
.legend > li a.buttonRect-5:before {
  content: "\e806";
}
.legend > li a > span {
  display: none;
}
.legend > li a.active {
  background: #5C2483;
}
.legend > li a.active > span {
  background: #5C2483;
  top: -60px;
  color: #FFFFFF;
  display: block;
  position: absolute;
  padding: 5px 20px;
  white-space: nowrap;
}
.legend > li a.active > span:before {
  -webkit-transform: rotate(360deg);
  border-color: #5C2483 transparent transparent transparent;
  border-style: solid;
  border-width: 12px 7.5px 0 7.5px;
  content: "";
  height: 0px;
  left: 50%;
  margin-left: -7px;
  position: absolute;
  top: 100%;
  width: 0px;
}
ul.menu-legend {
  list-style: none;
  padding: 0;
}
ul.menu-legend > li {
  cursor: pointer;
  display: -ms-flexbox;
  display: flex;
  font-size: 16px;
  line-height: 120%;
  margin-bottom: 20px;
  position: relative;
}
ul.menu-legend > li > span {
  display: -ms-flexbox;
  display: flex;
  width: 85%;
  margin-left: 10px;
  -ms-flex-align: center;
      align-items: center;
}
ul.menu-legend > li > span:first-child {
  -ms-flex-line-pack: center;
      align-content: center;
  -ms-flex-align: center;
      align-items: center;
  border-radius: 25px;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
  display: -ms-flexbox;
  display: flex;
  font-size: 24px;
  font-family: 'Montserrat';
  font-weight: 800;
  height: 50px;
  -ms-flex-pack: center;
      justify-content: center;
  left: 0;
  margin-left: 0;
  position: relative;
  top: 0;
  width: 50px;
}
ul.menu-legend > li.list-1 > span:first-child {
  background-color: #009FE3;
  color: #FFFFFF;
}
ul.menu-legend > li.list-2 > span:first-child {
  background-color: #85C5C5;
  color: #FFFFFF;
}
ul.menu-legend > li.list-3 > span:first-child {
  background-color: #784BAA;
  color: #FFFFFF;
}
ul.menu-legend > li.list-4A > span:first-child,
ul.menu-legend > li.list-4B > span:first-child,
ul.menu-legend > li.list-4C > span:first-child,
ul.menu-legend > li.list-4D > span:first-child,
ul.menu-legend > li.list-4E > span:first-child,
ul.menu-legend > li.list-4F > span:first-child {
  background-color: #FFCC00;
}
ul.menu-legend > li.list-5 > span:first-child {
  background-color: #EF3A1C;
  color: #FFFFFF;
}
ul.menu-legend > li.list-6 > span:first-child {
  background-color: #3FA535;
  color: #FFFFFF;
}
ul.menu-legend > li.list-7 > span:first-child {
  background-color: #054838;
  color: #FFFFFF;
}
ul.menu-legend > li.list-8 > span:first-child {
  background-color: #3FA535;
  color: #FFFFFF;
}
ul.menu-legend > li.list-9 > span:first-child {
  background-color: #7F1340;
  color: #FFFFFF;
}
ul.menu-legend > li.list-10 > span:first-child {
  background-color: #253687;
  color: #FFFFFF;
}
ul.menu-legend > li.list-11 > span:first-child {
  background-color: #EDCBAC;
}
ul.menu-legend > li.list-12 > span:first-child {
  background-color: #9BD7FF;
}
ul.menu-legend > li.active > a {
  display: block;
}
.gray .menu-legend > li.js-menu:not(.active) span:first-child {
  background-color: #FFFFFF;
  color: #000000;
}
.js-detail {
  display: none;
  position: absolute;
  right: -40px;
  top: 0;
  z-index: 1000;
}
.js-detail.active {
  display: inline-block;
}
#lightbox {
  -ms-flex-line-pack: center;
      align-content: center;
  -ms-flex-align: center;
      align-items: center;
  background: rgba(0, 0, 0, 0.8);
  bottom: 0;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
  z-index: 10000;
}
#lightbox.hide {
  display: none;
}
#lightbox > .wrap {
  position: relative;
  max-width: 50%;
}
#lightbox > .wrap .image {
  margin: 0 auto;
  padding: 0;
}
#lightbox > .wrap .image > img {
  max-width: 100%;
}
#lightbox > .wrap .image > video {
  width: 100%;
  height: auto;
  display: none;
}
#lightbox > .wrap .image .cs-closer {
  position: absolute;
  right: -25px;
  top: -25px;
}
.cs-closer {
  -ms-flex-align: center;
  -ms-flex-line-pack: center;
      align-content: center;
  align-items: center;
  background: #FFFFFF;
  border-radius: 25px;
  color: #000000;
  display: -ms-flexbox;
  display: flex;
  height: 50px;
  -ms-flex-pack: center;
      justify-content: center;
  margin: 0;
  padding: 0;
  position: absolute;
  right: 0;
  top: 0;
  width: 50px;
}
.cs-lightbox {
  position: absolute;
  bottom: 65px;
  right: 15px;
}
.cs-lightbox:before {
  -ms-flex-align: center;
  -ms-flex-line-pack: center;
      align-content: center;
  align-items: center;
  background: #FFFFFF;
  border-radius: 25px;
  color: #000000;
  display: -ms-flexbox;
  display: flex;
  height: 50px;
  -ms-flex-pack: center;
      justify-content: center;
  margin: 0;
  padding: 0;
  position: absolute;
  right: 0;
  top: 0;
  width: 50px;
}
