/*genrated on 2023-21-12 13:49:06********************************************************************************************/
/* outfit-100 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 100;
  src: url('/_libs/fonts/google/outfit-v11-latin-100.woff2') format('woff2');
}
/* outfit-200 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 200;
  src: url('/_libs/fonts/google/outfit-v11-latin-200.woff2') format('woff2');
}
/* outfit-300 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 300;
  src: url('/_libs/fonts/google/outfit-v11-latin-300.woff2') format('woff2');
}
/* outfit-regular - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 400;
  src: url('/_libs/fonts/google/outfit-v11-latin-regular.woff2') format('woff2');
}
/* outfit-500 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 500;
  src: url('/_libs/fonts/google/outfit-v11-latin-500.woff2') format('woff2');
}
/* outfit-600 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 600;
  src: url('/_libs/fonts/google/outfit-v11-latin-600.woff2') format('woff2');
}
/* outfit-700 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 700;
  src: url('/_libs/fonts/google/outfit-v11-latin-700.woff2') format('woff2');
}
/* outfit-800 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 800;
  src: url('/_libs/fonts/google/outfit-v11-latin-800.woff2') format('woff2');
}
/* outfit-900 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 900;
  src: url('/_libs/fonts/google/outfit-v11-latin-900.woff2') format('woff2');
}
/* noto-serif-300 - latin */
@font-face {
  font-display: swap;
  font-family: 'Noto Serif';
  font-style: normal;
  font-weight: 300;
  src: url('/_libs/fonts/google/noto-serif-v22-latin-300.woff2') format('woff2');
}
/* noto-serif-regular - latin */
@font-face {
  font-display: swap;
  font-family: 'Noto Serif';
  font-style: normal;
  font-weight: 400;
  src: url('/_libs/fonts/google/noto-serif-v22-latin-regular.woff2') format('woff2');
}
/* noto-serif-italic - latin */
@font-face {
  font-display: swap;
  font-family: 'Noto Serif';
  font-style: italic;
  font-weight: 400;
  src: url('/_libs/fonts/google/noto-serif-v22-latin-italic.woff2') format('woff2');
}
/* noto-serif-500 - latin */
@font-face {
  font-display: swap;
  font-family: 'Noto Serif';
  font-style: normal;
  font-weight: 500;
  src: url('/_libs/fonts/google/noto-serif-v22-latin-500.woff2') format('woff2');
}
/* noto-serif-500italic - latin */
@font-face {
  font-display: swap;
  font-family: 'Noto Serif';
  font-style: italic;
  font-weight: 500;
  src: url('/_libs/fonts/google/noto-serif-v22-latin-500italic.woff2') format('woff2');
}
/* noto-serif-600 - latin */
@font-face {
  font-display: swap;
  font-family: 'Noto Serif';
  font-style: normal;
  font-weight: 600;
  src: url('/_libs/fonts/google/noto-serif-v22-latin-600.woff2') format('woff2');
}
/* noto-serif-600italic - latin */
@font-face {
  font-display: swap;
  font-family: 'Noto Serif';
  font-style: italic;
  font-weight: 600;
  src: url('/_libs/fonts/google/noto-serif-v22-latin-600italic.woff2') format('woff2');
}
/* Feel free to change duration  */
.animated {
  -webkit-animation-duration: 1000 ms  ;
  animation-duration: 1000 ms  ;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}
/* .owl-animated-out - only for current item */
/* This is very important class. Use z-index if you want move Out item above In item */
.owl-animated-out {
  z-index: 1;
}
/* .owl-animated-in - only for upcoming item
/* This is very important class. Use z-index if you want move In item above Out item */
.owl-animated-in {
  z-index: 0;
}
/* .fadeOut is style taken from Animation.css and this is how it looks in owl.carousel.css:  */
.fadeOut {
  -webkit-animation-name: fadeOut;
  animation-name: fadeOut;
}
@-webkit-keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
/* outfit-100 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 100;
  src: url('/_libs/fonts/google/outfit-v11-latin-100.woff2') format('woff2');
}
/* outfit-200 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 200;
  src: url('/_libs/fonts/google/outfit-v11-latin-200.woff2') format('woff2');
}
/* outfit-300 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 300;
  src: url('/_libs/fonts/google/outfit-v11-latin-300.woff2') format('woff2');
}
/* outfit-regular - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 400;
  src: url('/_libs/fonts/google/outfit-v11-latin-regular.woff2') format('woff2');
}
/* outfit-500 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 500;
  src: url('/_libs/fonts/google/outfit-v11-latin-500.woff2') format('woff2');
}
/* outfit-600 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 600;
  src: url('/_libs/fonts/google/outfit-v11-latin-600.woff2') format('woff2');
}
/* outfit-700 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 700;
  src: url('/_libs/fonts/google/outfit-v11-latin-700.woff2') format('woff2');
}
/* outfit-800 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 800;
  src: url('/_libs/fonts/google/outfit-v11-latin-800.woff2') format('woff2');
}
/* outfit-900 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 900;
  src: url('/_libs/fonts/google/outfit-v11-latin-900.woff2') format('woff2');
}
/* noto-serif-300 - latin */
@font-face {
  font-display: swap;
  font-family: 'Noto Serif';
  font-style: normal;
  font-weight: 300;
  src: url('/_libs/fonts/google/noto-serif-v22-latin-300.woff2') format('woff2');
}
/* noto-serif-regular - latin */
@font-face {
  font-display: swap;
  font-family: 'Noto Serif';
  font-style: normal;
  font-weight: 400;
  src: url('/_libs/fonts/google/noto-serif-v22-latin-regular.woff2') format('woff2');
}
/* noto-serif-italic - latin */
@font-face {
  font-display: swap;
  font-family: 'Noto Serif';
  font-style: italic;
  font-weight: 400;
  src: url('/_libs/fonts/google/noto-serif-v22-latin-italic.woff2') format('woff2');
}
/* noto-serif-500 - latin */
@font-face {
  font-display: swap;
  font-family: 'Noto Serif';
  font-style: normal;
  font-weight: 500;
  src: url('/_libs/fonts/google/noto-serif-v22-latin-500.woff2') format('woff2');
}
/* noto-serif-500italic - latin */
@font-face {
  font-display: swap;
  font-family: 'Noto Serif';
  font-style: italic;
  font-weight: 500;
  src: url('/_libs/fonts/google/noto-serif-v22-latin-500italic.woff2') format('woff2');
}
/* noto-serif-600 - latin */
@font-face {
  font-display: swap;
  font-family: 'Noto Serif';
  font-style: normal;
  font-weight: 600;
  src: url('/_libs/fonts/google/noto-serif-v22-latin-600.woff2') format('woff2');
}
/* noto-serif-600italic - latin */
@font-face {
  font-display: swap;
  font-family: 'Noto Serif';
  font-style: italic;
  font-weight: 600;
  src: url('/_libs/fonts/google/noto-serif-v22-latin-600italic.woff2') format('woff2');
}
/* outfit-100 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 100;
  src: url('/_libs/fonts/google/outfit-v11-latin-100.woff2') format('woff2');
}
/* outfit-200 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 200;
  src: url('/_libs/fonts/google/outfit-v11-latin-200.woff2') format('woff2');
}
/* outfit-300 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 300;
  src: url('/_libs/fonts/google/outfit-v11-latin-300.woff2') format('woff2');
}
/* outfit-regular - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 400;
  src: url('/_libs/fonts/google/outfit-v11-latin-regular.woff2') format('woff2');
}
/* outfit-500 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 500;
  src: url('/_libs/fonts/google/outfit-v11-latin-500.woff2') format('woff2');
}
/* outfit-600 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 600;
  src: url('/_libs/fonts/google/outfit-v11-latin-600.woff2') format('woff2');
}
/* outfit-700 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 700;
  src: url('/_libs/fonts/google/outfit-v11-latin-700.woff2') format('woff2');
}
/* outfit-800 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 800;
  src: url('/_libs/fonts/google/outfit-v11-latin-800.woff2') format('woff2');
}
/* outfit-900 - latin */
@font-face {
  font-display: swap;
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 900;
  src: url('/_libs/fonts/google/outfit-v11-latin-900.woff2') format('woff2');
}
/* noto-serif-300 - latin */
@font-face {
  font-display: swap;
  font-family: 'Noto Serif';
  font-style: normal;
  font-weight: 300;
  src: url('/_libs/fonts/google/noto-serif-v22-latin-300.woff2') format('woff2');
}
/* noto-serif-regular - latin */
@font-face {
  font-display: swap;
  font-family: 'Noto Serif';
  font-style: normal;
  font-weight: 400;
  src: url('/_libs/fonts/google/noto-serif-v22-latin-regular.woff2') format('woff2');
}
/* noto-serif-italic - latin */
@font-face {
  font-display: swap;
  font-family: 'Noto Serif';
  font-style: italic;
  font-weight: 400;
  src: url('/_libs/fonts/google/noto-serif-v22-latin-italic.woff2') format('woff2');
}
/* noto-serif-500 - latin */
@font-face {
  font-display: swap;
  font-family: 'Noto Serif';
  font-style: normal;
  font-weight: 500;
  src: url('/_libs/fonts/google/noto-serif-v22-latin-500.woff2') format('woff2');
}
/* noto-serif-500italic - latin */
@font-face {
  font-display: swap;
  font-family: 'Noto Serif';
  font-style: italic;
  font-weight: 500;
  src: url('/_libs/fonts/google/noto-serif-v22-latin-500italic.woff2') format('woff2');
}
/* noto-serif-600 - latin */
@font-face {
  font-display: swap;
  font-family: 'Noto Serif';
  font-style: normal;
  font-weight: 600;
  src: url('/_libs/fonts/google/noto-serif-v22-latin-600.woff2') format('woff2');
}
/* noto-serif-600italic - latin */
@font-face {
  font-display: swap;
  font-family: 'Noto Serif';
  font-style: italic;
  font-weight: 600;
  src: url('/_libs/fonts/google/noto-serif-v22-latin-600italic.woff2') format('woff2');
}
td,
body {
  font-family: 'Outfit' !important;
  font-size: 16px !important;
  line-height: 26px;
  font-weight: 300;
}
table {
  width: 100%;
}
td {
  padding: 0px;
  vertical-align: top;
}
a img {
  border: none;
}
a {
  color: #A20000;
}
h1,
h2,
h3 {
  color: #A20000;
}
h1 {
  font-size: 27px;
  font-weight: 400;
  line-height: 29px;
  margin-top: 0px;
  margin-bottom: 6px;
}
h2 {
  margin-top: 0px;
  margin-bottom: 6px;
  font-size: 23px;
  font-weight: 400;
  line-height: 27px;
}
h3 {
  margin-top: 0px;
  margin-bottom: 4px;
  font-size: 19px;
  font-weight: 400;
  line-height: 24px;
}
ul {
  padding-left: 50px;
  margin: 15px 0px 15px 0px;
}
li {
  position: relative;
  list-style: none;
  line-height: 30px;
}
li::before {
  width: 13px;
  height: 13px;
  position: absolute;
  top: 9px;
  left: -23px;
  content: "";
  background-color: #A20000;
}
p {
  margin-top: 6px;
  margin-bottom: 4px;
  padding-bottom: 0.5em;
}
body,
html {
  font-family: 'Outfit';
  margin: 0px;
  padding: 0px;
  text-align: center;
  font-size: 16px;
  font-weight: 300;
  color: #333333;
  background-color: #F7F7F5;
}
.BodyHolder {
  width: 100%;
  min-height: 100vh;
  height: 100%;
  float: left;
}
/*useful config (don't delete)*/
.loading a {
  pointer-events: none;
}
html {
  overflow-y: scroll;
}
span a {
  cursor: pointer;
}
form {
  margin: 0px;
}
a {
  outline: none;
  color: #a20000;
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
}
div,
a,
span,
section {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}
/* Basis layout */
div#container {
  text-align: left;
  width: 100%;
  min-height: calc(30vh - 470px);
  background-color: #F7F7F5;
  display: block;
  float: left;
  z-index: 1;
  position: relative;
}
div#container.containerStart {
  -webkit-box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.1);
  -moz-box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.1);
  box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.1);
}
div#container.containerTop {
  padding-top: 170px;
}
div#container.containerMaps {
  padding-top: 50px;
  min-height: 100vh;
}
div#container div#containerInlay,
div#container div.containerInlay {
  text-align: left;
  width: 100%;
  max-width: 1640px;
  padding-left: 20px;
  padding-right: 20px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 35px;
}
div#container div#containerInlay.containerProjects,
div#container div.containerInlay.containerProjects {
  max-width: 100%;
  padding-left: 0px;
  padding-right: 0px;
}
div#container div#containerInlay.containerProjects div#middle,
div#container div.containerInlay.containerProjects div#middle {
  max-width: 100%;
}
div#container div#containerInlay.containerInlayWide,
div#container div.containerInlay.containerInlayWide {
  max-width: 100%;
  padding-left: 0px;
  padding-right: 0;
}
div#container div#containerInlay.containerInlayWide #middle,
div#container div.containerInlay.containerInlayWide #middle {
  max-width: 100%;
}
div#topContainer.scroll {
  height: 60px;
  -webkit-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.2);
  -moz-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.2);
  box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.2);
  border-color: transparent;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease 0s;
  -moz-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  -ms-transition: all 0.5s ease 0s;
}
div#topContainer.scroll div#top,
div#topContainer.scroll div#topInlay {
  height: 60px;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease 0s;
  -moz-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  -ms-transition: all 0.5s ease 0s;
}
div#topContainer.scroll div#top div#topInlay a.logo {
  bottom: 8px;
  width: 125px;
  height: 45px;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease 0s;
  -moz-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  -ms-transition: all 0.5s ease 0s;
}
div#topContainer.scroll .contactInfo {
  top: -115px;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease 0s;
  -moz-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  -ms-transition: all 0.5s ease 0s;
}
div#topContainer.scroll .topInfo {
  padding-bottom: 0px;
  padding-top: 0;
  max-height: 0;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease 0s;
  -moz-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  -ms-transition: all 0.5s ease 0s;
}
div#topContainer.scroll div#navigation {
  height: 48px;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease 0s;
  -moz-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  -ms-transition: all 0.5s ease 0s;
}
div#topContainer.scroll div#navigation .navbutton {
  height: 48px;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease 0s;
  -moz-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  -ms-transition: all 0.5s ease 0s;
}
/*div#topContainer.scroll */
@keyframes maxHeight {
  0% {
    max-height: 100vw;
  }
  100% {
    max-height: unset;
  }
}
@keyframes layerRef {
  0% {
    max-width: 0;
  }
  100% {
    max-width: 100%;
  }
}
@keyframes layerRefText {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
    filter: alpha(opacity = 0 );
  }
  80% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
    filter: alpha(opacity = 0 );
  }
  100% {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
    filter: alpha(opacity = 100 );
  }
}
@keyframes solutions {
  0% {
    max-width: 0;
  }
  50% {
    max-width: 90vw;
  }
  100% {
    max-width: 77vw;
  }
}
@keyframes solutions2 {
  0% {
    max-width: 77vw;
  }
  100% {
    max-width: 0%;
  }
}
@keyframes galleryOP {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
    filter: alpha(opacity = 0 );
    transform: translateX(2260px);
  }
  70% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
    filter: alpha(opacity = 0 );
    transform: translateX(2230px);
  }
  100% {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
    filter: alpha(opacity = 100 );
    transform: translateX(0px);
  }
}
@keyframes scrollOP {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
    filter: alpha(opacity = 0 );
  }
  70% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
    filter: alpha(opacity = 0 );
  }
  100% {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
    filter: alpha(opacity = 100 );
  }
}
@keyframes scrollOP2 {
  0% {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
    filter: alpha(opacity = 100 );
  }
  100% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
    filter: alpha(opacity = 0 );
  }
}
@keyframes refShow {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
    filter: alpha(opacity = 0 );
  }
  70% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
    filter: alpha(opacity = 0 );
  }
  100% {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
    filter: alpha(opacity = 100 );
  }
}
.BodyHolder.scroll .stage .infoText {
  width: 100%;
}
.BodyHolder.scroll .stage .infoText .infoTextInner {
  animation: solutions2 1.9s cubic-bezier(0.77, 0, 0.175, 1);
  width: 100%;
  max-width: 0;
}
.BodyHolder.scroll .stage .infoText .infoTextInner .infoTextLeft,
.BodyHolder.scroll .stage .infoText .infoTextInner .infoTextRight {
  animation-name: scrollOP2;
  animation-duration: 1.4s;
  animation-delay: 0s;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 0 );
  transition: all 1.6s linear 0s;
  -webkit-transition: all 1.6s linear 0s;
  -moz-transition: all 1.6s linear 0s;
  -o-transition: all 1.6s linear 0s;
  -ms-transition: all 1.6s linear 0s;
}
.BodyHolder.scroll .stage .infoText .scrollAction {
  animation-name: scrollOP2;
  animation-duration: 1.4s;
  animation-delay: 0s;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 0 );
  transition: all 1.6s linear 0s;
  -webkit-transition: all 1.6s linear 0s;
  -moz-transition: all 1.6s linear 0s;
  -o-transition: all 1.6s linear 0s;
  -ms-transition: all 1.6s linear 0s;
}
#topContainer {
  width: 100%;
  height: 135px;
  position: fixed;
  background-color: #FFF;
  border-bottom: 1px solid #e8e8e8;
  z-index: 2;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease 0s;
  -moz-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  -ms-transition: all 0.5s ease 0s;
}
body.site_id_1.site_level_1 {
  border-color: transparent;
}
div#top {
  width: 100%;
  height: 135px;
  position: relative;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease 0s;
  -moz-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  -ms-transition: all 0.5s ease 0s;
  /*div#topInlay*/
}
div#top .topInfo {
  width: 100%;
  padding-bottom: 7px;
  padding-top: 5px;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  max-height: 31px;
  background-color: #af181e;
  overflow: hidden;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease 0s;
  -moz-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  -ms-transition: all 0.5s ease 0s;
}
div#top .topInfo .topInfoInner {
  text-align: left;
  width: 100%;
  max-width: 1640px;
  padding-left: 20px;
  padding-right: 20px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  line-height: 19px;
}
div#top .topInfo .topInfoInner div {
  width: calc(100% * (1/3) - 0px);
}
div#top .topInfo .manufacture {
  display: flex;
  justify-content: center;
}
div#top .topInfo .manufacture span {
  background-image: url("/_skins/base/images/icon_austria_flag.svg");
  background-position: 0px center;
  background-repeat: no-repeat;
  background-size: 14px auto;
  padding-left: 20px;
  font-size: 13px;
  font-weight: 300;
  letter-spacing: 0.25px;
  color: #E1DCDC;
  text-transform: uppercase;
}
div#top .topInfo .contactInfo {
  display: flex;
  justify-content: right;
}
div#top .topInfo a.tel,
div#top .topInfo a.mail {
  background-image: url("/_skins/base/images/icon_mail.svg");
  background-position: 0px center;
  background-repeat: no-repeat;
  background-size: 17px auto;
  text-decoration: none;
  height: 100%;
  letter-spacing: 0.25px;
  font-size: 13px;
  font-weight: 300;
  padding-left: 20px;
  line-height: inherit;
  color: #FFF;
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
}
div#top .topInfo a.tel:hover,
div#top .topInfo a.mail:hover {
  text-decoration: underline;
}
div#top .topInfo a.tel {
  padding-left: 22px;
  background-image: url("/_skins/base/images/icon_phone.svg");
  background-position: 0px center;
  background-repeat: no-repeat;
  background-size: 14px auto;
  margin-right: 25px;
}
div#top div#topInlay {
  width: 100%;
  max-width: 1640px;
  padding-left: 20px;
  padding-right: 20px;
  margin-left: auto;
  margin-right: auto;
  height: 135px;
  position: relative;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease 0s;
  -moz-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  -ms-transition: all 0.5s ease 0s;
  /*a.logo*/
}
div#top div#topInlay a.logo {
  width: 200px;
  height: 75px;
  display: block;
  pointer-events: auto;
  bottom: 15px;
  position: absolute;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease 0s;
  -moz-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  -ms-transition: all 0.5s ease 0s;
}
div#top div#topInlay a.logo img {
  margin: 0px 0px 0px 0px;
  width: 100%;
  height: auto;
}
div#top div#topInlay a.logo:hover {
  cursor: pointer;
}
/*div#top */
.contactInfo.contactInfoMobile {
  display: none;
}
div#middle {
  width: 100%;
  max-width: 1620px;
  float: left;
  min-height: 130px;
}
.stageOuter {
  width: 100%;
  overflow: hidden;
  float: left;
  display: block;
  height: calc((100vw / 1.5) + 0px);
  max-height: calc(100vh - 0px);
  height: 100vh;
}
.stage {
  width: 100%;
  float: none;
  margin: 0px auto 0px auto;
  display: block;
  top: 0px;
  position: fixed;
  max-width: 1920px;
  max-height: calc(100vh - 0px);
  height: calc(100vh - 0px);
  /*.stageInner*/
  /*.slide*/
}
.stage .infoText {
  width: 100%;
  height: 200px;
  position: fixed;
  bottom: 0px;
  overflow: hidden;
  z-index: 1;
}
.stage .infoText .infoTextInner {
  position: absolute;
  bottom: 0px;
  width: 100%;
  background-color: #952a16;
  height: 200px;
  z-index: 2;
  display: flex;
  flex-wrap: wrap;
}
.stage .infoText .infoTextInner.active {
  max-width: 77vw;
  transform-origin: right top;
  animation-name: solutions;
  animation-duration: 1.6s;
}
.stage .infoText .infoTextInner .infoTextLeft,
.stage .infoText .infoTextInner .infoTextRight {
  width: 100%;
  max-width: 40%;
  display: flex;
  flex-wrap: wrap;
  align-content: center;
  text-align: left;
  justify-content: center;
  height: 100%;
  animation-name: scrollOP;
  animation-duration: 1.8s;
  animation-delay: 0s;
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 100 );
}
.stage .infoText .infoTextInner .infoTextLeft .subtitle,
.stage .infoText .infoTextInner .infoTextRight .subtitle,
.stage .infoText .infoTextInner .infoTextLeft .title,
.stage .infoText .infoTextInner .infoTextRight .title,
.stage .infoText .infoTextInner .infoTextLeft .text,
.stage .infoText .infoTextInner .infoTextRight .text {
  width: 100%;
}
.stage .infoText .infoTextInner .infoTextLeft .subtitle,
.stage .infoText .infoTextInner .infoTextRight .subtitle {
  letter-spacing: 1.95px;
  color: #B4B4B4;
  text-transform: uppercase;
  font-weight: 600;
  font-size: 13px;
  line-height: 16px;
  max-width: 490px;
}
.stage .infoText .infoTextInner .infoTextLeft .title,
.stage .infoText .infoTextInner .infoTextRight .title {
  letter-spacing: 0.15px;
  color: #F6F6F6;
  font-weight: 600;
  font-size: 27px;
  line-height: 33px;
  max-width: 490px;
}
.stage .infoText .infoTextInner .infoTextLeft .text,
.stage .infoText .infoTextInner .infoTextRight .text {
  letter-spacing: 0.25px;
  color: #FFFFFF;
  font-weight: 400;
  font-size: 16px;
  line-height: 28px;
  max-width: 480px;
  padding: 0 40px;
}
.stage .infoText .infoTextInner .infoTextLeft {
  padding-left: 95px;
  max-width: 60%;
  border-right: 1px solid #a24031;
}
.stage .infoText .scrollAction {
  background-image: url("/_skins/base/images/icon_scroll.svg");
  background-position: 0px center;
  background-repeat: no-repeat;
  background-size: 100% auto;
  width: 45px;
  height: 125px;
  display: block;
  position: absolute;
  right: calc(23vw - 120px);
  bottom: 40px;
  z-index: 1;
  animation-name: scrollOP;
  animation-duration: 1.8s;
  animation-delay: 0s;
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 100 );
}
.stage .stageInner {
  width: 100%;
  min-height: 100%;
  max-width: 100%;
  float: left;
  display: block;
  position: relative;
  pointer-events: none;
}
.stage .stageInner:hover {
  pointer-events: none;
}
.stage .slide {
  width: 100%;
  min-height: 600px;
  float: left;
  display: block;
  overflow: hidden;
  /*.bild */
}
.stage .slide .bild {
  width: 100%;
  height: inherit;
  min-height: inherit;
  display: block;
  max-height: 955px;
  padding: 0;
  position: relative;
  margin: 0;
}
.stage .slide .bild img {
  width: 100%;
  height: auto;
  object-fit: contain;
  height: 100%;
  object-fit: cover;
}
/*.stage */
div.scrollDown {
  position: absolute;
  bottom: -10px;
  display: block;
  height: 24px;
  width: 24px;
  left: 50%;
  transform: translateX(-50%);
}
div.scrollDown .containerScroll {
  position: relative;
  width: 24px;
  height: 24px;
}
div.scrollDown .arrow {
  position: absolute;
  width: 22px;
  height: 5px;
  opacity: 0;
  transform: scale3d(0.5, 0.5, 0.5);
  animation: move 2.5s ease-out infinite;
}
div.scrollDown .arrow:first-child {
  animation: move 2.5s ease-out 1s infinite;
}
div.scrollDown .arrow:nth-child(2) {
  animation: move 2.5s ease-out 2s infinite;
}
div.scrollDown .arrow:before,
div.scrollDown .arrow:after {
  content: ' ';
  position: absolute;
  top: 0;
  height: 30%;
  width: 51%;
  background: #fff;
}
div.scrollDown .arrow:before {
  left: 0;
  transform: skew(0deg, 40deg);
}
div.scrollDown .arrow:after {
  right: 0;
  width: 50%;
  transform: skew(0deg, -40deg);
}
@keyframes move {
  25% {
    opacity: 1;
  }
  33% {
    opacity: 1;
    transform: translateY(20px);
  }
  67% {
    opacity: 1;
    transform: translateY(30px);
  }
  100% {
    opacity: 0;
    transform: translateY(45px) scale3d(0.5, 0.5, 0.5);
  }
}
@keyframes sliderIcon {
  from {
    transform: translateX(-100%);
    opacity: 0.25;
  }
  to {
    transform: translateX(0%);
    opacity: 1;
  }
}
div#footer.scroll {
  z-index: 0;
  visibility: visible;
}
div#footer {
  position: fixed;
  background-color: #333333;
  min-height: 430px;
  clear: left;
  z-index: -1;
  border-top: 1px solid #d4d4d4;
  visibility: hidden;
  color: #fff;
  bottom: 0;
  left: 0;
  right: 0;
  background: #333333;
  background: -moz-linear-gradient(top, #333333 0%, #353535 100%);
  background: -webkit-gradient(left top, left bottom, color-stop(0%, #333333), color-stop(100%, #353535));
  background: -webkit-linear-gradient(top, #333333 0%, #353535 100%);
  background: -o-linear-gradient(top, #333333 0%, #353535 100%);
  background: -ms-linear-gradient(top, #333333 0%, #353535 100%);
  background: linear-gradient(to bottom, #333333 0%, #353535 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#333333', endColorstr='#353535', GradientType=0);
}
div#footer #footerInner {
  max-width: 990px;
  padding: 40px 20px 15px 20px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  text-align: left;
}
div#footer #footerInner .leftPart {
  width: 395px;
}
div#footer #footerInner .leftPart a {
  font: normal normal 300 17px/26px Outfit Thin;
  letter-spacing: 0.09px;
  font-family: 'Outfit';
  color: #FFFFFF;
  width: 100%;
  text-decoration: none;
}
div#footer #footerInner .leftPart a:hover {
  color: #a80e04;
}
div#footer #footerInner .leftPart .adress {
  padding-left: 20px;
  line-height: 26px;
}
div#footer #footerInner .leftPart .logo {
  width: 100%;
  max-width: 230px;
  display: block;
  margin-bottom: 40px;
}
div#footer #footerInner .leftPart .logo img {
  width: 100%;
  height: auto;
  display: block;
}
div#footer #footerInner .leftPart .contacts {
  margin: 20px 0 20px 0;
}
div#footer #footerInner .leftPart .contacts a {
  line-height: 40px;
  width: 100%;
  display: block;
}
div#footer #footerInner .leftPart .smIcons {
  text-align: center;
  margin-top: 10px;
  height: 42px;
  max-width: 105px;
  margin-left: 0;
  margin-right: auto;
}
div#footer #footerInner .leftPart a.smIcon {
  width: 24px;
  height: 24px;
  float: left;
  display: block;
}
div#footer #footerInner .leftPart a.smIcon.insta {
  background-image: url("/_skins/base/images/icon_insta_logo_small.svg");
  background-position: top center;
  background-repeat: no-repeat;
  background-size: 100% auto;
  margin-right: 0;
  width: 24px;
}
div#footer #footerInner .leftPart a.smIcon.fb {
  background-image: url("/_skins/base/images/icon_fb_logo_small.svg");
  background-position: top center;
  background-repeat: no-repeat;
  background-size: 100% auto;
  margin-right: 20px;
}
div#footer #footerInner .rightPart {
  max-width: calc(100% - 395px);
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  padding-top: 76px;
}
div#footer #footerInner .rightPart .info {
  width: 50%;
}
div#footer #footerInner .rightPart .info .caption {
  font: normal normal 600 19px/26px Outfit Thin;
  letter-spacing: 0.1px;
  font-family: 'Outfit';
  color: #AF181E;
}
div#footer #footerInner .rightPart .info .list a {
  font: normal normal 300 17px/26px Outfit Thin;
  letter-spacing: 0.09px;
  font-family: 'Outfit';
  color: #FFFFFF;
  width: 100%;
  display: block;
  line-height: 40px;
  text-decoration: none;
}
div#footer #footerInner .rightPart .info .list a:hover {
  color: #a80e04;
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
}
div#footer #footerInner .bottomPart {
  font-size: 14px;
  color: #BFBFBF;
  padding: 15px 20px 0 20px;
}
div#footer #footerInner .bottomPart a {
  color: #BFBFBF;
  text-decoration: none;
}
#footerSpacer {
  min-height: 430px;
  width: 100%;
  position: relative;
}
/* @end */
.galleryContainer {
  padding-left: 100px;
  position: relative;
  padding-bottom: 30px;
}
.moreProjects {
  margin: 5px auto 0 auto;
  font-size: 15px;
  text-decoration: none;
  width: auto;
  height: 42px;
  line-height: 42px;
  padding: 0px 25px 0px 25px;
  background-color: #333;
  font-weight: 300;
  color: #FFF;
  border-radius: 25px;
  text-transform: uppercase;
  border: none;
  display: block;
  max-width: fit-content;
  transition: all 0.4s ease 0s;
  -webkit-transition: all 0.4s ease 0s;
  -moz-transition: all 0.4s ease 0s;
  -o-transition: all 0.4s ease 0s;
  -ms-transition: all 0.4s ease 0s;
}
.moreProjects:hover {
  background-color: #a20000;
  transition: all 0.4s ease 0s;
  -webkit-transition: all 0.4s ease 0s;
  -moz-transition: all 0.4s ease 0s;
  -o-transition: all 0.4s ease 0s;
  -ms-transition: all 0.4s ease 0s;
}
.galleryContainer::after {
  background-image: url("/_skins/base/images/icon_slide.svg");
  background-position: 0px center;
  background-repeat: no-repeat;
  background-size: 100% auto;
  content: ' ';
  position: absolute;
  height: 50px;
  width: 55px;
  left: 30px;
  bottom: 5px;
  animation-name: sliderIcon;
  animation-duration: 1.9s;
  animation-delay: 0s;
  animation-iteration-count: 5;
}
.containerTeamFotos .teamFotos .teamFotosInner {
  display: flex;
  flex-wrap: wrap;
}
.containerTeamFotos .teamFotos .teamFotosInner .teamFoto {
  max-width: calc(((100%) * 1/4) - 0px);
  margin: 0 0px 0px 0px;
  animation-name: refShow;
  animation-duration: 1.6s;
  position: relative;
  transition: all 0.4s linear 0s;
  -webkit-transition: all 0.4s linear 0s;
  -moz-transition: all 0.4s linear 0s;
  -o-transition: all 0.4s linear 0s;
  -ms-transition: all 0.4s linear 0s;
}
.containerTeamFotos .teamFotos .teamFotosInner .teamFoto img {
  width: 100%;
  height: auto;
  display: block;
}
.containerTeamFotos .teamFotos .teamFotosInner .teamFoto a.layer {
  max-width: 100%;
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  max-height: 100%;
  z-index: 9;
}
.containerTeamFotos .teamFotos .teamFotosInner .teamFoto a.layer .layerInner {
  background-color: rgba(139, 20, 0, 0.4);
  width: 100%;
  height: 100%;
  position: absolute;
  overflow: hidden;
  max-width: 0;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 0 );
  transition: all 0.4s ease 0s;
  -webkit-transition: all 0.4s ease 0s;
  -moz-transition: all 0.4s ease 0s;
  -o-transition: all 0.4s ease 0s;
  -ms-transition: all 0.4s ease 0s;
}
.containerTeamFotos .teamFotos .teamFotosInner .teamFoto a.layer .layerInner::after {
  position: absolute;
  top: 0;
  margin: auto;
  max-width: 160px;
  color: white;
  content: 'Bild ansehen';
  left: -200px;
  right: 0;
  bottom: 0;
  height: 20px;
  font-size: 21px;
  min-width: 150px;
  display: inline-block;
  text-align: center;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 0 );
  transition: all 0.4s ease 0s;
  -webkit-transition: all 0.4s ease 0s;
  -moz-transition: all 0.4s ease 0s;
  -o-transition: all 0.4s ease 0s;
  -ms-transition: all 0.4s ease 0s;
}
.containerTeamFotos .teamFotos .teamFotosInner .teamFoto a.layer:hover {
  cursor: pointer;
}
.containerTeamFotos .teamFotos .teamFotosInner .teamFoto a.layer:hover .layerInner {
  max-width: 100%;
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 100 );
  transform-origin: right top;
  animation-name: layerRef;
  animation-duration: 0.7s;
}
.containerTeamFotos .teamFotos .teamFotosInner .teamFoto a.layer:hover .layerInner::after {
  animation-name: layerRefText;
  animation-duration: 0.7s;
  animation-delay: 0.2s;
  left: 0;
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 100 );
  transition: all 0.4s ease 0.3s;
  -webkit-transition: all 0.4s ease 0.3s;
  -moz-transition: all 0.4s ease 0.3s;
  -o-transition: all 0.4s ease 0.3s;
  -ms-transition: all 0.4s ease 0.3s;
}
.containerRefs .galleryContainer::after {
  display: none;
}
.containerRefs .galleryContainer {
  padding-left: 0;
}
.containerRefs .projektGallerien .projektGallerienInner {
  display: flex;
  flex-wrap: wrap;
}
.containerRefs .projektGallerien .projektGallerienInner .projektGallerie {
  max-width: calc(((100%) * 1/2) - 10px);
  margin: 0 5px 35px 5px;
  animation-name: refShow;
  animation-duration: 1.6s;
  transition: all 0.4s linear 0s;
  -webkit-transition: all 0.4s linear 0s;
  -moz-transition: all 0.4s linear 0s;
  -o-transition: all 0.4s linear 0s;
  -ms-transition: all 0.4s linear 0s;
}
.containerRefs .projektGallerien .projektGallerienInner .projektGallerie.projektGallerie_withText {
  max-width: 100%;
  display: flex;
  margin: 0 0 35px 5px;
  flex-wrap: wrap;
}
.containerRefs .projektGallerien .projektGallerienInner .projektGallerie.projektGallerie_withText .projektGallerieInner {
  max-width: calc(50% - 5px);
  position: relative;
}
.containerRefs .projektGallerien .projektGallerienInner .projektGallerie.projektGallerie_withText .textInfos {
  width: 100%;
  max-width: calc(50% + 5px);
  display: flex;
  flex-wrap: wrap;
  align-content: center;
  padding: 30px;
  max-height: calc(100% - 27px);
}
.containerRefs .projektGallerien .projektGallerienInner .projektGallerie.projektGallerie_withText .textInfos h2 {
  text-transform: uppercase;
  text-align: left;
  font-family: 'Noto Serif';
  letter-spacing: 0px;
  font-size: 36px;
  font-weight: 400;
  line-height: 52px;
  color: #A20000;
}
.containerRefs .projektGallerien .projektGallerienInner .projektGallerie img {
  max-width: 100%;
  transition: all 0.3s linear 0s;
  -webkit-transition: all 0.3s linear 0s;
  -moz-transition: all 0.3s linear 0s;
  -o-transition: all 0.3s linear 0s;
  -ms-transition: all 0.3s linear 0s;
}
.containerRefs .projektGallerien .projektGallerienInner .projektGallerie:hover {
  cursor: pointer;
}
.containerRefs .projektGallerien .projektGallerienInner .projektGallerie:hover img {
  transition: all 0.3s linear 0s;
  -webkit-transition: all 0.3s linear 0s;
  -moz-transition: all 0.3s linear 0s;
  -o-transition: all 0.3s linear 0s;
  -ms-transition: all 0.3s linear 0s;
}
.containerRefs .projektGallerien .projektGallerienInner:hover {
  cursor: pointer;
}
.projektGallerien {
  width: 100%;
}
.projektGallerien .projektGallerie {
  animation-name: galleryOP;
  animation-duration: 1.6s;
  animation-delay: 0s;
  position: relative;
  margin: 0 5px;
  max-width: 700px;
  transition: all 1.6s linear 0s;
  -webkit-transition: all 1.6s linear 0s;
  -moz-transition: all 1.6s linear 0s;
  -o-transition: all 1.6s linear 0s;
  -ms-transition: all 1.6s linear 0s;
}
.projektGallerien .projektGallerie a.layer {
  max-width: 100%;
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  max-height: calc(100% - 27px);
  z-index: 9;
}
.projektGallerien .projektGallerie a.layer .layerInner {
  background-color: rgba(139, 20, 0, 0.4);
  width: 100%;
  height: 100%;
  position: absolute;
  overflow: hidden;
  max-width: 0;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 0 );
  transition: all 0.4s ease 0s;
  -webkit-transition: all 0.4s ease 0s;
  -moz-transition: all 0.4s ease 0s;
  -o-transition: all 0.4s ease 0s;
  -ms-transition: all 0.4s ease 0s;
}
.projektGallerien .projektGallerie a.layer .layerInner::after {
  position: absolute;
  top: 0;
  margin: auto;
  max-width: 160px;
  color: white;
  content: 'Bilder ansehen';
  left: -200px;
  right: 0;
  bottom: 0;
  height: 20px;
  font-size: 21px;
  min-width: 150px;
  display: inline-block;
  text-align: center;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 0 );
  transition: all 0.4s ease 0s;
  -webkit-transition: all 0.4s ease 0s;
  -moz-transition: all 0.4s ease 0s;
  -o-transition: all 0.4s ease 0s;
  -ms-transition: all 0.4s ease 0s;
}
.projektGallerien .projektGallerie a.layer:hover .layerInner {
  max-width: 100%;
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 100 );
  transform-origin: right top;
  animation-name: layerRef;
  animation-duration: 0.7s;
}
.projektGallerien .projektGallerie a.layer:hover .layerInner::after {
  animation-name: layerRefText;
  animation-duration: 0.7s;
  animation-delay: 0.2s;
  left: 0;
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 100 );
  transition: all 0.4s ease 0.3s;
  -webkit-transition: all 0.4s ease 0.3s;
  -moz-transition: all 0.4s ease 0.3s;
  -o-transition: all 0.4s ease 0.3s;
  -ms-transition: all 0.4s ease 0.3s;
}
.projektGallerien .projektGallerie img {
  width: 100%;
  max-width: 700px;
  height: auto;
  display: block;
}
.projektGallerien .projektGallerie .counter {
  background-color: rgba(255, 255, 255, 0.2);
  -moz-backdrop-filter: blur(10px);
  -o-backdrop-filter: blur(10px);
  -ms-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  text-align: center;
  height: 30px;
  padding: 0 10px 0 10px;
  font-size: 15px;
  letter-spacing: 0.1px;
  color: #333333;
  position: absolute;
  right: 0;
  bottom: 55px;
  z-index: 10;
  line-height: 30px;
  font-weight: 300;
}
.projektGallerien .projektGallerie .counter strong {
  font-weight: 600;
}
.projektGallerien .projektGallerie .caption {
  font-size: 16px;
  color: #333333;
  display: flex;
  margin: 5px 0 0 5px;
  letter-spacing: 0.10px;
}
.projektGallerien .projektGallerie .caption .title {
  font-weight: 600;
}
.projektGallerien .projektGallerie .caption .location {
  font-weight: 300;
  border-left: 1px solid #333333;
  padding-left: 10px;
  margin-left: 10px;
}
.projektGallerien .projektGallerie .caption .copyright {
  position: absolute;
  right: 5px;
  font-size: 12px;
}
.projektGallerien .projektGallerie:hover {
  cursor: pointer;
}
.filterArea {
  width: 100%;
  background-color: #FFF;
  height: 105px;
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  margin-top: 50px;
  margin-bottom: 30px;
}
.filterArea .filterPart {
  margin: auto;
  width: auto;
  display: inline-block;
}
.filterArea .filterBox {
  display: inline-block;
}
.filterArea .filterBox a {
  height: 100%;
  text-decoration: none;
  text-transform: uppercase;
  font-size: 13px;
  color: #004A3C;
  padding: 0 30px;
  display: flex;
  flex-wrap: wrap;
  text-align: center;
  font-weight: 500;
  max-height: 65px;
}
.filterArea .filterBox a:hover {
  color: #A20000;
}
.filterArea .filterBox a.active {
  color: #A20000;
}
.filterArea .filterBox a.active span.title::after {
  background-color: #A20000;
  content: '';
  bottom: 0;
  left: 0;
  right: 0;
  height: 2px;
  position: absolute;
}
.filterArea .filterBox span.title {
  position: relative;
  display: inline-block;
  width: auto;
  margin: 0 auto;
}
.filterArea .filterBox span {
  width: 100%;
}
.filterArea .filterBox_mod2 {
  border-left: 1px solid #004A3C;
  border-right: 1px solid #004A3C;
}
.filterArea .filterBox .icon {
  background-position: center center;
  background-repeat: no-repeat;
  display: inline-block;
  min-height: 45px;
}
.filterArea .filterBox_Wohnen .icon {
  background-image: url("/_skins/base/images/icon_living.svg");
  background-size: 65px auto;
  min-width: 65px;
}
.filterArea .filterBox_Gastronomie__Hotelerie .icon {
  background-image: url("/_skins/base/images/icon_hotel.svg");
  background-size: 53px auto;
  min-width: 53px;
}
.filterArea .filterBox_Arbeiten .icon {
  background-image: url("/_skins/base/images/icon_business.svg");
  background-size: 38px auto;
  min-width: 38px;
}
.galleryDetail {
  width: 100vw;
  height: 100vh;
  background-color: rgba(255, 255, 255, 0.5);
  -webkit-backdrop-filter: blur(4px);
  -moz-backdrop-filter: blur(4px);
  -o-backdrop-filter: blur(4px);
  -ms-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
  padding: 0px;
  margin: 0px;
  /*.counter*/
  /*.counter*/
  /*owl-item*/
  /*.button_left, .button_right*/
  /*.button_left*/
  /*.button_right*/
}
.galleryDetail .owl-item .item {
  height: 100vh;
  padding-top: 5vh;
}
.galleryDetail .galleryDetailInner {
  width: 100%;
  height: 100%;
  display: block;
  overflow: hidden;
}
.galleryDetail .copyright {
  position: absolute;
  bottom: -40px;
  left: 20px;
  font-size: 13px;
  color: #333;
}
.galleryDetail #counter {
  font-style: italic;
  font-weight: 300;
  position: absolute;
  left: 0%;
  right: 0;
  bottom: -17px;
  margin: 0 auto;
  padding: 8px 10px 8px 10px;
  box-shadow: 0px 3px 6px #00000029;
  max-width: fit-content;
  font-size: 18px;
  color: #232323;
  background-color: rgba(255, 255, 255, 0.5);
  -webkit-backdrop-filter: blur(30px);
  -moz-backdrop-filter: blur(30px);
  -o-backdrop-filter: blur(30px);
  -ms-backdrop-filter: blur(30px);
  backdrop-filter: blur(30px);
  width: 90px;
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 100 );
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
}
.galleryDetail #counter span {
  font-weight: 500;
}
.galleryDetail #beschreibung {
  font-weight: 300;
  position: absolute;
  left: 0%;
  right: 0;
  top: 0vw;
  margin: 0 auto;
  padding: 8px 15px 8px 15px;
  box-shadow: 0px 3px 6px #00000029;
  width: auto;
  max-width: fit-content;
  font-size: 18px;
  color: #232323;
  background-color: rgba(255, 255, 255, 0.5);
  -webkit-backdrop-filter: blur(30px);
  -moz-backdrop-filter: blur(30px);
  -o-backdrop-filter: blur(30px);
  -ms-backdrop-filter: blur(30px);
  backdrop-filter: blur(30px);
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 100 );
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
}
.galleryDetail .owl-item .item.currentItem_0::before {
  background-image: url("/_skins/base/images/loading.svg");
  background-repeat: no-repeat;
  background-size: auto 70px;
  background-position: 0px 0px;
  margin: -25px 0px 0px -25px;
  content: "";
  height: 70px;
  opacity: 0.8;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 80 );
  left: 50%;
  top: 50%;
  position: absolute;
  width: 70px;
}
.galleryDetail .owl_navigation {
  width: 100vw;
  height: 100vh;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  pointer-events: none;
  display: block;
  position: absolute;
  z-index: 999;
}
.galleryDetail .button_left,
.galleryDetail .button_right {
  width: 15vw;
  display: block;
  position: absolute;
  z-index: 999;
}
.galleryDetail .button_left a,
.galleryDetail .button_right a {
  display: block;
  height: inherit;
  width: inherit;
  opacity: 0.35;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 35 );
  text-indent: -10000px;
  pointer-events: auto;
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
}
.galleryDetail .button_left a:hover,
.galleryDetail .button_right a:hover {
  opacity: 0.9;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 90 );
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
}
.galleryDetail .button_left {
  left: 0px;
  top: 50px;
  height: calc(100vh - 120px);
  /*a*/
}
.galleryDetail .button_left a {
  background-image: url("/_skins/base/images/arrow_left.svg");
  background-repeat: no-repeat;
  background-size: auto 30vh;
  background-position: right center;
}
.galleryDetail .button_right {
  right: 0px;
  top: 50px;
  height: calc(100vh - 120px);
  /*a*/
}
.galleryDetail .button_right a {
  background-image: url("/_skins/base/images/arrow_right.svg");
  background-repeat: no-repeat;
  background-size: auto 30vh;
  background-position: 0 center;
}
/*.galleryDetail */
.backLinkCross {
  position: fixed;
  top: -140px;
  right: 40px;
  width: 40px;
  height: 40px;
  z-index: 99999;
  text-decoration: none;
  display: block;
  transition: all 0.35s ease 1s;
  -webkit-transition: all 0.35s ease 1s;
  -moz-transition: all 0.35s ease 1s;
  -o-transition: all 0.35s ease 1s;
  -ms-transition: all 0.35s ease 1s;
}
.backLinkCross .closeInner {
  width: 40px;
  height: 4px;
  display: block;
  position: absolute;
  left: 0;
  top: 17px;
  z-index: 99999;
  text-decoration: none;
}
.backLinkCross .closeInner:hover {
  cursor: pointer;
}
.backLinkCross:hover {
  cursor: pointer;
}
.backLinkCross.backLinkCrossActive {
  top: 15px;
  transition: all 0.35s ease 1s;
  -webkit-transition: all 0.35s ease 1s;
  -moz-transition: all 0.35s ease 1s;
  -o-transition: all 0.35s ease 1s;
  -ms-transition: all 0.35s ease 1s;
}
.backLinkCross .closeInner::before,
.backLinkCross .closeInner::after {
  background-color: #555;
  content: "";
  height: 100%;
  left: 0px;
  position: absolute;
  width: 100%;
  text-decoration: none;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease 0s;
  -moz-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  -ms-transition: all 0.5s ease 0s;
}
.backLinkCross .closeInner::before {
  bottom: 0px;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.backLinkCross .closeInner::after {
  top: 0px;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
.errorInfo {
  background-color: #e60000;
  color: #ffffff;
  font-size: 14px;
  padding-left: 20px;
  padding-right: 20px;
  text-align: center;
}
.services .servicesInner {
  display: flex;
  position: relative;
  min-height: calc(42vw * 0.689);
  flex-direction: column;
  padding-top: 3vw;
}
.services .servicesInner .left {
  width: 100%;
  max-width: calc(50% - 120px);
  min-width: calc(50% - 120px);
  border-bottom: 1px solid #333;
  padding-right: 45px;
  margin-right: 120px;
  position: relative;
  padding-bottom: 15px;
}
.services .servicesInner .left .title {
  letter-spacing: 0.15px;
  font-size: 25px;
  color: #A20000;
  line-height: 40px;
  min-height: 40px;
  font-weight: 400;
  font-family: 'Noto Serif';
  display: flex;
  align-items: center;
  padding-top: 10px;
}
.services .servicesInner .left .text {
  font-size: 16px;
  max-height: 0;
  overflow: hidden;
  padding-bottom: 0px;
  transition: all 0.4s ease 0.1s;
  -webkit-transition: all 0.4s ease 0.1s;
  -moz-transition: all 0.4s ease 0.1s;
  -o-transition: all 0.4s ease 0.1s;
  -ms-transition: all 0.4s ease 0.1s;
}
.services .servicesInner .left .opener {
  position: absolute;
  top: 0;
  width: 100%;
  max-width: calc(100% - 70px);
  height: 60px;
  right: 70px;
  pointer-events: auto;
  display: block !important;
}
.services .servicesInner .left .opener .icon {
  width: 40px;
  height: 40px;
  border: 0;
  position: absolute;
  right: -70px;
  top: 10px;
}
.services .servicesInner .left .opener .icon span {
  position: absolute;
  transition: 300ms;
  background-color: #333;
}
.services .servicesInner .left .opener .icon span:first-child {
  top: 25%;
  bottom: 25%;
  width: 2px;
  left: 19px;
}
.services .servicesInner .left .opener .icon span:last-child {
  left: 25%;
  right: 25%;
  height: 2px;
  top: 19px;
}
.services .servicesInner .left .opener.active .icon span {
  transform: rotate(90deg);
}
.services .servicesInner .left .opener.active .icon span:last-child {
  left: 50%;
  right: 50%;
}
.services .servicesInner .left .opener:hover {
  cursor: pointer;
}
.services .servicesInner .right {
  width: 100%;
  max-width: 42vw;
  min-width: 50%;
  position: absolute;
  right: 0;
  top: 0;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 0 );
  visibility: hidden;
  transition: all 0.5s ease 0.1s;
  -webkit-transition: all 0.5s ease 0.1s;
  -moz-transition: all 0.5s ease 0.1s;
  -o-transition: all 0.5s ease 0.1s;
  -ms-transition: all 0.5s ease 0.1s;
}
.services .servicesInner .right img {
  width: 100%;
  height: auto;
  display: block;
}
.services .servicesInner .serviceContainer.last .left {
  border-bottom: none;
}
.services .servicesInner .serviceContainer.show .left .text {
  max-height: 400px;
  transition: all 0.5s ease 0.1s;
  -webkit-transition: all 0.5s ease 0.1s;
  -moz-transition: all 0.5s ease 0.1s;
  -o-transition: all 0.5s ease 0.1s;
  -ms-transition: all 0.5s ease 0.1s;
}
.services .servicesInner .serviceContainer.show .left .text p {
  padding-bottom: 0;
}
.services .servicesInner .serviceContainer.show .opener .icon span {
  transform: rotate(90deg);
}
.services .servicesInner .serviceContainer.show .opener .icon span:last-child {
  left: 50%;
  right: 50%;
}
.services .servicesInner .serviceContainer.show .right {
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 100 );
  visibility: visible;
  transition: all 0.5s ease 0.1s;
  -webkit-transition: all 0.5s ease 0.1s;
  -moz-transition: all 0.5s ease 0.1s;
  -o-transition: all 0.5s ease 0.1s;
  -ms-transition: all 0.5s ease 0.1s;
}
.contentElemente {
  width: 100%;
  float: left;
  min-height: 25px;
  max-width: 1565px;
  margin: 150px 0px 80px 0px;
  /*.contentElement*/
}
.contentElemente .contentElement {
  width: 100%;
  float: left;
  min-height: 25px;
  display: flex;
  justify-content: center;
  align-items: center;
  /*.ceText*/
  /*.ceImg*/
  /*&.contentEven*/
}
.contentElemente .contentElement h2 {
  font-size: 26px;
  line-height: 25px;
}
.contentElemente .contentElement .ceText {
  width: 50%;
  max-width: 810px;
  float: left;
  min-height: 25px;
  height: 100%;
}
.contentElemente .contentElement .ceText .inner {
  max-width: 790px;
  margin: auto;
  padding: 0 40px;
  align-self: center;
}
.contentElemente .contentElement .ceText .inner h2.title {
  width: 100%;
  text-transform: uppercase;
  margin: 0px 0px 30px 0px;
  text-align: left;
  font-family: 'Noto Serif';
  letter-spacing: 0px;
  font-size: 36px;
  font-weight: 400;
  line-height: 52px;
  color: #A20000;
}
.contentElemente .contentElement .ceText .inner h2.title p {
  padding-bottom: 0;
}
.contentElemente .contentElement .ceText .inner .txt {
  text-align: left;
  letter-spacing: 0.08px;
  font-family: 'Outfit';
  font-size: 16px;
  line-height: 26px;
  color: #333333;
  opacity: 1;
}
.contentElemente .contentElement .ceText .inner .link {
  margin: 35px 0px 0 0;
  font-size: 15px;
  text-decoration: none;
  width: auto;
  height: 42px;
  line-height: 42px;
  padding: 0px 25px 0px 25px;
  background-color: #333;
  font-weight: 300;
  color: #FFF;
  border-radius: 25px;
  text-transform: uppercase;
  border: none;
  display: block;
  max-width: fit-content;
  transition: all 0.2s ease 0s;
  -webkit-transition: all 0.2s ease 0s;
  -moz-transition: all 0.2s ease 0s;
  -o-transition: all 0.2s ease 0s;
  -ms-transition: all 0.2s ease 0s;
}
.contentElemente .contentElement .ceText .inner .link:hover {
  background-color: #a20000;
  transition: all 0.2s ease 0s;
  -webkit-transition: all 0.2s ease 0s;
  -moz-transition: all 0.2s ease 0s;
  -o-transition: all 0.2s ease 0s;
  -ms-transition: all 0.2s ease 0s;
}
.contentElemente .contentElement .ceImg {
  width: 50%;
  max-width: 810px;
  float: left;
  min-height: 100px;
}
.contentElemente .contentElement .ceImg img {
  width: 100%;
  height: auto;
  display: block;
}
.contentElemente .contentElement.contentEven {
  /*.ceText*/
}
.contentElemente .contentElement.contentEven .ceText a {
  text-decoration: underline;
}
.contentElemente .contentElement.contentEven .ceText .inner h2.title {
  text-align: left;
}
.contentElemente .contentElement .ceText .inner {
  /*.link.download*/
}
.contentElemente .contentElement .ceText .inner .link.download {
  background-image: url("/_skins/base/images/icon_download.svg");
  background-position: 15px 10px;
  background-repeat: no-repeat;
  background-size: 25px auto;
  min-width: 240px;
  position: relative;
  line-height: 30px;
  padding-top: 5px;
  padding-bottom: 5px;
  border: none;
  text-align: left;
  margin-left: 0;
  padding-left: 50px;
  /*&:hover*/
}
.contentElemente .contentElement .ceText .inner .link.download .fileInfo {
  font-size: 13px;
  width: 100%;
  display: block;
  line-height: 23px;
  text-transform: uppercase;
  color: #868686;
  letter-spacing: 0.3px;
  font-weight: 300;
}
.contentElemente .contentElement .ceText .inner .link.download:hover {
  background-color: transparent;
  color: red;
  border: none;
}
.contentElemente .contentElement .ceText .inner .link.download:hover .fileInfo {
  color: #868686;
}
.contentElemente .contentElement .ceText .inner .link.download_2 {
  margin-top: 10px;
}
/*.contentElemente*/
.contentElemente .contentElement.contentEven.noContent {
  background-color: transparent;
}
.contentElementVO {
  width: 100%;
  float: left;
}
.contentElementVO .inner {
  width: 100%;
  padding: 0 5px 50px 5px;
  padding-bottom: 50px;
  float: left;
  /*.details*/
  /*.ceImg*/
}
.contentElementVO .inner .details {
  width: 50%;
  max-width: 810px;
  float: left;
  min-height: 25px;
  height: 100%;
  padding-right: 90px;
}
.contentElementVO .inner .details h1.title {
  width: 100%;
  text-transform: uppercase;
  margin: 0px 0px 30px 0px;
  text-align: left;
  font-family: 'Noto Serif';
  letter-spacing: 0px;
  font-size: 36px;
  font-weight: 400;
  line-height: 52px;
  color: #A20000;
}
.contentElementVO .inner .details .txt {
  margin-bottom: 50px;
}
.contentElementVO .inner .details .txt,
.contentElementVO .inner .details .langtxt {
  text-align: left;
  letter-spacing: 0.15px;
  font-weight: 300;
  font-size: 16px;
  line-height: 26px;
  font-family: 'Outfit';
  color: #333333;
}
.contentElementVO .inner .ceImg {
  width: 50%;
  max-width: 810px;
  float: left;
  min-height: 100px;
}
.contentElementVO .inner .ceImg img {
  width: 100%;
  height: auto;
  display: block;
}
.contentElementVO .containerRefs {
  margin: 30px 0px 10px 0px;
}
.contentElementVO h2.title {
  width: 100%;
  text-transform: uppercase;
  margin: 0px 0px 10px 0px;
  text-align: left;
  font-family: 'Noto Serif';
  letter-spacing: 0px;
  font-size: 36px;
  font-weight: 400;
  line-height: 52px;
  color: #A20000;
}
.historyBlocks::before {
  content: '';
  width: 4px;
  height: 100%;
  position: absolute;
  left: calc(50% - 2px);
  top: 0;
  bottom: 0;
  background: linear-gradient(145deg, #af181e, #e11f26);
  display: block;
}
.historyBlock::before {
  content: '';
  position: absolute;
  left: calc(50% - 18px);
  top: calc(50% - 18px);
  border-radius: 90px;
  display: block;
  width: 20px;
  height: 20px;
  border: 8px solid #f7f7f5;
  background-color: #fff;
  background: linear-gradient(145deg, #af181e, #e11f26);
  filter: drop-shadow(2px 0px 4px rgba(12, 50, 86, 0.2));
}
.historyBlock.historyBlock_first::before {
  top: 0;
}
.historyBlocks {
  width: 100%;
  float: left;
  min-height: 25px;
  max-width: 1565px;
  position: relative;
  margin: 150px 0px 80px 0px;
  /*.historyBlock*/
}
.historyBlocks .historyBlock {
  width: 100%;
  float: left;
  min-height: 25px;
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 50px;
  /*.ceText*/
  /*.ceImg*/
  /*&.contentEven*/
}
.historyBlocks .historyBlock h3 {
  margin-top: 0px;
  margin-bottom: 4px;
  font-size: 19px;
  line-height: 24px;
  margin-bottom: 5px;
  font-family: 'Noto Serif';
  letter-spacing: 0px;
  font-size: 27px;
  font-weight: 400;
  line-height: 37px;
}
.historyBlocks .historyBlock .elements {
  width: 45%;
  max-width: 810px;
  float: left;
  min-height: 25px;
  height: 100%;
}
.historyBlocks .historyBlock .elements .inner {
  max-width: 790px;
  margin: auto;
  padding: 0 40px;
  align-self: center;
}
.historyBlocks .historyBlock .elements .inner h2.title {
  width: 100%;
  text-transform: uppercase;
  margin: 0px 0px 30px 0px;
  text-align: left;
  font-family: 'Noto Serif';
  letter-spacing: 0px;
  font-size: 36px;
  font-weight: 400;
  line-height: 52px;
  color: #A20000;
}
.historyBlocks .historyBlock .elements .inner .txt {
  text-align: left;
  font: normal normal 300 16px/26px Outfit Thin;
  letter-spacing: 0.08px;
  font-family: 'Outfit';
  color: #333333;
  opacity: 1;
}
.historyBlocks .historyBlock .hBimg {
  width: 45%;
  max-width: 810px;
  float: left;
  min-height: 100px;
}
.historyBlocks .historyBlock .hBimg img {
  width: 100%;
  height: auto;
  display: block;
}
.historyBlocks .historyBlock.contentEven {
  /*.ceText*/
}
.historyBlocks .historyBlock.contentEven .ceText a {
  text-decoration: underline;
}
.historyBlocks .historyBlock.contentEven .ceText .inner h2.title {
  text-align: left;
}
/*.historyBlocks*/
.TextItem {
  width: 100%;
  max-width: 930px;
  margin: 0px auto;
  text-align: center;
}
.TextItem div,
.TextItem h1 {
  width: 100%;
  display: block;
}
.TextItem div {
  line-height: 26px;
}
.TextItem h1 {
  margin-bottom: 20px;
  font-family: 'Noto Serif';
  letter-spacing: 0px;
  font-size: 27px;
  font-weight: 400;
  line-height: 37px;
  color: #A20000;
}
.TextItem h1 p {
  padding-bottom: 0;
}
.TextItem .img {
  max-width: 950px;
  margin-top: 30px;
}
.TextItem .img img {
  width: 100%;
  height: auto;
  display: block;
}
.TextItem.TextItem_1 {
  margin-top: 50px;
}
/*.TextItem */
.textSite .TextItem {
  text-align: left;
}
.TextItem p,
.TextItem .Text p {
  padding-bottom: 0.5em;
}
.grid-item,
.grid-sizer {
  width: calc(25% - 15px);
}
.facebookItems {
  margin-top: 5px;
  width: 100%;
  float: left;
  min-height: 100px;
  padding-left: 25px;
  padding-right: 25px;
  padding-top: 18px;
  /*.facebookItem*/
}
.facebookItems .fbItem_mod4 .facebookItem {
  margin-right: 0;
}
.facebookItems .facebookItem {
  width: calc(25% - 15px);
  max-width: 395px;
  float: left;
  min-height: 100px;
  margin: 0px 15px 30px 0px;
  position: relative;
  overflow: hidden;
  text-decoration: none;
  background-color: #FFF;
  text-align: left;
  font-weight: 300;
  font-size: 15px;
  z-index: 999;
  border-radius: 30px;
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
  /*.img*/
  /*.inlay*/
  /*.title */
  /*.autor*/
  /*.txt*/
  /*.txt.inlay */
  /*.autor.inlay */
  /*&:hover */
  /*.img::after*/
}
.facebookItems .facebookItem a {
  text-decoration: none;
  float: left;
}
.facebookItems .facebookItem a.opener {
  width: 100%;
  min-height: 90px;
}
.facebookItems .facebookItem a.opener:hover {
  cursor: pointer;
}
.facebookItems .facebookItem .img {
  max-width: 395px;
  width: calc(100% - 0px);
  overflow: hidden;
  display: inline-block;
  position: relative;
  text-align: center;
  background-size: cover;
  max-height: 395px;
  margin: 10px auto;
  display: block;
  /*img*/
}
.facebookItems .facebookItem .img img {
  width: 100%;
  height: auto;
  display: block;
  text-align: left;
  object-fit: cover;
  min-height: 200px;
}
.facebookItems .facebookItem .img img.fbImage {
  position: absolute;
  left: 0px;
}
.facebookItems .facebookItem .img img.default {
  width: 319px;
  height: auto;
}
.facebookItems .facebookItem .img.imgHort {
  background-image: none !important;
}
.facebookItems .facebookItem .img.imgVert {
  position: relative;
}
.facebookItems .facebookItem .img.imgVert .imgBgd {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0px;
  filter: blur(7px);
  -webkit-filter: blur(7px);
  background-position: center 10px;
  background-repeat: no-repeat;
  background-size: auto 120%;
  width: 100%;
  height: 100%;
  display: block;
  z-index: 0;
}
.facebookItems .facebookItem .img.imgVert img {
  object-fit: contain;
  width: calc(100% + 30px);
  -webkit-transform: translateX(-15px) translateY(0);
  transform: translateX(-15px) translateY(0%);
  z-index: 1;
  position: relative;
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
}
.facebookItems .facebookItem .img.imgEmpty {
  height: 150px;
}
.facebookItems .facebookItem .inlay {
  width: 100%;
  padding: 6% 4% 6% 4%;
  display: inline-block;
}
.facebookItems .facebookItem .info {
  background-image: url('/_skins/base/images/icon_fb_user.svg');
  background-size: 40px auto;
  background-position: 12px 12px;
  background-repeat: no-repeat;
  width: 100%;
  padding: 12px 12px 12px 60px;
  display: block;
  height: 52px;
}
.facebookItems .facebookItem .info .account {
  background-image: url('/_skins/base/images/icon_fb_blue.svg');
  background-size: 12px auto;
  background-position: right 7px;
  background-repeat: no-repeat;
  padding-right: 20px;
  font-size: 16px;
  font-weight: 700;
  color: #333333;
  display: inline-block;
}
.facebookItems .facebookItem .info .date {
  background-image: url('/_skins/base/images/icon_fb_date.svg');
  background-size: 12px auto;
  background-position: right 2px;
  background-repeat: no-repeat;
  padding-right: 20px;
  font-size: 13px;
  color: #65676B;
  font-weight: 300;
  width: auto;
  display: inline-block;
  line-height: 15px;
}
.facebookItems .facebookItem .title {
  width: 100%;
  display: inline-block;
  color: #333333;
  min-height: 36px;
  font-size: 15px;
  line-height: 23px;
  z-index: 998;
  font-weight: 300;
  margin-top: 15px;
  max-height: 77px;
  padding: 0px 15px 30px 15px;
  margin-bottom: 0px;
  display: -moz-box;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
  position: relative;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease 0s;
  -moz-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  -ms-transition: all 0.5s ease 0s;
  /*p*/
}
.facebookItems .facebookItem .title .hashtag {
  color: #A20000;
  float: left;
  display: inline-block;
  font-weight: 300;
  font-size: 21px;
  padding-right: 6px;
  line-height: 13px;
  padding-top: 5px;
}
.facebookItems .facebookItem .title .hashtag:nth-of-type(1) {
  clear: both;
  display: table-column-group;
  float: none;
}
.facebookItems .facebookItem .title p {
  width: 100%;
  margin: 0px;
  min-height: 30px;
  line-height: 24px;
}
.facebookItems .facebookItem .title::after {
  content: '... mehr lesen';
  position: absolute;
  right: 15px;
  bottom: 6px;
  display: inline-block;
  color: #A7A7A7;
  font-size: 15px;
  line-height: 23px;
  z-index: 998;
  font-weight: 300;
  background-color: #FFF;
  height: 23px;
  padding-left: 145px;
  padding-right: 5px;
  background: rgba(255, 255, 255, 0.5);
  background: -moz-linear-gradient(left, rgba(255, 255, 255, 0.5) 0%, #ffffff 53%, #ffffff 100%);
  background: -webkit-gradient(left top, right top, color-stop(0%, rgba(255, 255, 255, 0.5)), color-stop(53%, #ffffff), color-stop(100%, #ffffff));
  background: -webkit-linear-gradient(left, rgba(255, 255, 255, 0.5) 0%, #ffffff 53%, #ffffff 100%);
  background: -o-linear-gradient(left, rgba(255, 255, 255, 0.5) 0%, #ffffff 53%, #ffffff 100%);
  background: -ms-linear-gradient(left, rgba(255, 255, 255, 0.5) 0%, #ffffff 53%, #ffffff 100%);
  background: linear-gradient(to right, rgba(255, 255, 255, 0.5) 0%, #ffffff 53%, #ffffff 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff', endColorstr='#ffffff', GradientType=1);
}
.facebookItems .facebookItem .autor {
  text-indent: -10000px;
  background: #ffffff none repeat scroll 0 0;
  height: 5px;
  display: block;
  position: relative;
  margin-top: -6px;
}
.facebookItems .facebookItem .txt {
  font-weight: 300;
  line-height: 19px;
  position: relative;
  text-align: left;
}
.facebookItems .facebookItem .txt.inlay {
  width: 100%;
  padding: 7px 10px 5px 10px;
}
.facebookItems .facebookItem .autor.inlay {
  padding: 5px 6% 0px 6%;
}
.facebookItems .facebookItem:hover {
  z-index: 999;
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
  /*.date*/
}
.facebookItems .facebookItem:hover .infos {
  height: 35px;
  background-color: #2b786c;
}
.facebookItems .facebookItem:hover .txt {
  background: rgba(69, 69, 69, 0) none repeat scroll 0 0;
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 100 );
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
}
.facebookItems .facebookItem:hover .date,
.facebookItems .facebookItem:hover .title {
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
}
.facebookItems .facebookItem:hover .openClose {
  bottom: -3px;
}
.facebookItems .facebookItem .linkLayer:hover {
  /*.ico_link*/
}
.facebookItems .facebookItem .linkLayer:hover .ico_link {
  display: block;
  transition: all 0.1s linear 0s;
  -webkit-transition: all 0.1s linear 0s;
  -moz-transition: all 0.1s linear 0s;
  -o-transition: all 0.1s linear 0s;
  -ms-transition: all 0.1s linear 0s;
}
.facebookItems .facebookItem .img:hover::after {
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
  background-color: rgba(88, 88, 90, 0.8);
}
.facebookItems .facebookItem .img:hover img {
  transition: all 0.4s linear 0.7s;
  -webkit-transition: all 0.4s linear 0.7s;
  -moz-transition: all 0.4s linear 0.7s;
  -o-transition: all 0.4s linear 0.7s;
  -ms-transition: all 0.4s linear 0.7s;
}
.facebookItems .facebookItem.event.startEvent {
  margin-bottom: 0px;
}
.facebookItems .event_mod3 {
  margin-right: 0px;
}
.facebookItems .data {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 10px;
  height: 45px;
  align-content: center;
  border-bottom: 1px solid #CCCCCC;
}
.facebookItems .data .likes {
  background-image: url('/_skins/base/images/icon_fb_like.svg');
  background-size: 16px auto;
  background-position: left center;
  background-repeat: no-repeat;
  padding-left: 22px;
}
.facebookItems .data .comments.noComment {
  color: #CCCCCC;
}
.facebookItems .linkMedia {
  text-align: center;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  color: #CCCCCC;
  align-content: center;
  height: 45px;
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
}
.facebookItems .linkMedia a {
  color: #CCCCCC;
  width: 100%;
  display: block;
}
.facebookItems .linkMedia:hover {
  background-color: #a20000;
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
}
.facebookItems .linkMedia:hover a {
  color: #FFF;
  cursor: pointer;
}
.facebookItems .facebookItem.show .title {
  -webkit-line-clamp: 20;
  max-height: 500px;
  padding-bottom: 30px;
  transition: all 1.5s ease 0s;
  -webkit-transition: all 1.5s ease 0s;
  -moz-transition: all 1.5s ease 0s;
  -o-transition: all 1.5s ease 0s;
  -ms-transition: all 1.5s ease 0s;
}
.facebookItems .facebookItem.show .title::after {
  content: '... weniger anzeigen';
  background: none;
  transition: all 1.5s ease 0s;
  -webkit-transition: all 1.5s ease 0s;
  -moz-transition: all 1.5s ease 0s;
  -o-transition: all 1.5s ease 0s;
  -ms-transition: all 1.5s ease 0s;
}
/*.facebookItems*/
.smIcons {
  text-align: center;
  margin-top: 10px;
  height: 42px;
  max-width: 105px;
  margin-left: auto;
  margin-right: auto;
}
.smIcon {
  width: 42px;
  height: 42px;
  float: left;
  display: block;
}
.smIcon.insta {
  background-image: url("/_skins/base/images/icon_insta_logo.svg");
  background-position: top center;
  background-repeat: no-repeat;
  background-size: 100% auto;
  margin-right: 20px;
}
.smIcon.fb {
  background-image: url("/_skins/base/images/icon_fb_logo.svg");
  background-position: top center;
  background-repeat: no-repeat;
  background-size: 100% auto;
  margin-right: 0px;
}
.fbSectors {
  width: 100%;
  float: left;
  min-height: 100px;
  margin-top: 100px;
  /*.hashtags*/
}
.fbSectors .caption {
  font-size: 40px;
  color: #000;
  line-height: 40px;
  margin-bottom: 15px;
  width: 100%;
  display: block;
  font-family: 'Noto Serif';
  letter-spacing: 0px;
  font-size: 38px;
  font-weight: 400;
  line-height: 52px;
  color: #A20000;
  font-style: normal;
}
.fbSectors .hashtags {
  text-align: center;
  font-size: 19px;
  font-weight: 200;
  margin-top: 15px;
  color: #594a37;
  line-height: 38px;
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
  float: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.fbSectors .hashtags strong {
  font: normal normal normal 23px/33px P22 Stanyan;
  letter-spacing: 0px;
  color: #A20000;
  float: left;
  text-align: center;
}
.fbSectors .hashtags span {
  margin-right: 1px;
  padding: 0px 5px 0px 5px;
  margin-bottom: 1px;
  display: inline-block;
  font-size: 21px;
  font-weight: 400;
  font-family: 'Noto Serif';
  letter-spacing: 0.10px;
  color: #A20000;
  float: left;
  text-align: center;
}
.fbSectors .hashtags span.first {
  width: 100%;
  display: block;
}
.facebookItems .grid-item,
.facebookItems .grid-sizer {
  width: 395px;
  width: calc(100% * (1/4) - 15px);
}
.fbSector {
  float: left;
  min-height: 200px;
  position: relative;
  width: 395px;
  max-width: 1700px;
  margin: 0 auto;
  float: none;
  display: table;
}
.smProfiles {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}
div#navigation {
  /* Navigation - Global*/
  position: absolute;
  right: 20px;
  bottom: 0;
  height: 67px;
  width: 100%;
  max-width: 655px;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease 0s;
  -moz-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  -ms-transition: all 0.5s ease 0s;
}
div#navigation .navbutton {
  display: block;
  padding-left: 17px;
  padding-right: 17px;
  font-size: 18px;
  color: #333333;
  font-weight: 400;
  float: left;
  letter-spacing: 0.1px;
  text-decoration: none;
  height: 67px;
  line-height: 30px;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease 0s;
  -moz-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  -ms-transition: all 0.5s ease 0s;
}
div#navigation .navbutton.navbutton_sub {
  background-image: url("/_skins/base/images/icon_subnav.svg");
  background-position: right 5px top 15px;
  background-repeat: no-repeat;
  background-size: 9px auto;
  padding-right: 25px;
}
div#navigation .navbutton:hover {
  color: #af181e;
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
}
div#navigation .navbutton.navbutton5 {
  padding-right: 0;
}
div#navigation .navbutton_active {
  color: #af181e;
}
div#navigation .justMobile.navbutton {
  display: none;
}
div#navigation .subnav {
  max-height: 0;
  overflow: hidden;
  background-color: #FFF;
  position: fixed;
  left: 0;
  top: 135px;
  z-index: -1;
  width: 100%;
  transform: translateY(-20px);
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
}
div#navigation .subnav .subnavInlay {
  width: 100%;
  max-width: 1640px;
  padding-left: 20px;
  padding-right: 20px;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease 0s;
  -moz-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  -ms-transition: all 0.5s ease 0s;
  display: flex;
  justify-content: right;
}
div#navigation .subnav .subnavInlay .navbutton {
  font-size: 17px;
  font-weight: 300;
  height: 40px;
  line-height: 39px;
}
div#navigation .subnav.show {
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
  transform: translateY(0px);
  box-shadow: 0px 3px 4px #0000001A;
  max-height: 445px;
}
/* @end */
.panelBlock.panelBlockTHX {
  min-height: 500px;
  text-align: center;
}
div.ccm_form {
  /* Form - Global*/
  /*.formInfo*/
  /*div.fieldOption.field*/
  /*div.field.Datenschutz*/
}
div.ccm_form.panel {
  max-width: 965px;
  margin: 0 auto;
}
div.ccm_form .panelCaption {
  margin-top: 0px;
  margin-bottom: 10px;
  font-size: 21px;
  font-weight: 500;
  color: #a20000;
  line-height: 24px;
}
div.ccm_form .panelSubCaption {
  margin-top: 0px;
  margin-bottom: 4px;
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
  color: #a20000;
  margin-top: 25px;
}
div.ccm_form input,
div.ccm_form textarea,
div.ccm_form select {
  font-family: 'Outfit';
}
div.ccm_form .fieldContainer {
  width: 100%;
  float: left;
  min-height: 40px;
}
div.ccm_form div.field {
  margin-bottom: 15px;
  padding: 0px;
  width: calc(50% - 20px);
  max-width: 440px;
  float: left;
  margin-right: 40px;
  position: relative;
}
div.ccm_form div.field.shortFieldRight {
  margin-right: 0;
}
div.ccm_form div.fieldDouble {
  margin-right: 0px;
  max-width: 100%;
  width: calc(100% - 0px);
}
div.ccm_form div.field.smallfieldRight {
  margin-right: 0px;
  width: calc(50% - 20px);
}
div.ccm_form div.fieldSmall {
  width: 165px;
  margin-right: 5px;
}
div.ccm_form div.fieldSmall.PLZ {
  width: 105px;
}
div.ccm_form div.fieldSmall.Ort {
  width: calc(50% - 20px - 112px);
}
div.ccm_form div.fieldSmall.fieldRight {
  margin-right: 0px;
}
div.ccm_form .formInfo {
  width: 100%;
  height: 20px;
  color: #a6a6a6;
  font-size: 11px;
  margin-bottom: 5px;
}
div.ccm_form div label {
  width: 100%;
  display: block;
  float: left;
  font-size: 17px;
  height: 35px;
  line-height: 35px;
  color: #363636;
  font-weight: 500;
  font-family: 'Noto Serif';
}
div.ccm_form div label span.required {
  display: inline;
}
div.ccm_form div label span.missing {
  color: #dc2432;
}
div.ccm_form .textinfo span.missing {
  color: #dc2432;
}
div.ccm_form .field input {
  height: 40px;
  line-height: 40px;
  display: block;
  float: left;
  border: none;
  position: relative;
  padding: 5px 15px 5px 15px;
  background-color: #fff;
  width: 100%;
  font-size: 17px;
  font-weight: 300;
  color: #363636;
  -webkit-appearance: none;
  -webkit-border-radius: 0;
  border-bottom: 4px solid #c8c8c8;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}
div.ccm_form .field input:focus {
  outline: none;
}
div.ccm_form .field .inputfield {
  min-height: 25px;
  width: 100%;
  position: relative;
  display: block;
  float: left;
}
div.ccm_form .field .inputfield::after {
  height: 4px;
  content: '';
  float: left;
  background-color: #f5f5f5;
  width: 0%;
  position: absolute;
  left: 0px;
  bottom: 0px;
  background: #7fbd4a;
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
}
div.ccm_form .field .inputfield.required::before {
  background-image: url("/_skins/base/images/ico_required.svg");
  background-position: 5px 3px;
  background-repeat: no-repeat;
  background-size: 11px auto;
  height: 19px;
  width: 19px;
  content: '';
  float: left;
  z-index: 1;
  position: absolute;
  right: 8px;
  top: 11px;
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
}
div.ccm_form .field.errorMessage .inputfield.required::before {
  background-image: url("/_skins/base/images/ico_required_red.svg");
  background-position: center;
  background-repeat: no-repeat;
  background-size: 11px auto;
  width: 25px;
  content: '';
  float: left;
  height: 100%;
  z-index: 1;
  position: absolute;
  right: 0px;
  top: 0px;
  background-color: #db2b13;
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
}
div.ccm_form .field .inputfield.required.notEmptyInput.notEmptyInputFocus::before {
  background-image: url("/_skins/base/images/ico_required.svg");
  background-position: 5px 3px;
  background-repeat: no-repeat;
  background-size: 11px auto;
}
div.ccm_form .field .inputfield.required.notEmptyInput::before {
  background-image: url("/_skins/base/images/ico_ok.svg");
  background-position: 0px 0px;
  background-repeat: no-repeat;
  background-size: 100% auto;
  height: 19px;
  width: 19px;
}
div.ccm_form .field .inputfield.notEmptyInput::after {
  width: 100%;
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
}
div.ccm_form input[type="checkbox"] {
  display: none;
}
div.ccm_form input[type="checkbox"] + label::before {
  display: block;
  content: '';
  position: absolute;
  left: 0px;
  width: 25px;
  height: 25px;
  background-color: #f5f5f5;
  z-index: 1;
  background: rgba(247, 244, 244, 0.1) none repeat scroll 0 0;
  border: 1px solid #a5abb0;
}
div.ccm_form input[type="checkbox"] + label {
  display: inline-block;
  width: 150px;
  height: 25px;
  line-height: 25px;
  vertical-align: middle;
  background: url('/_skins/base/images/ico_ok.svg');
  background-position: 0px -50px;
  background-size: 20px auto;
  background-repeat: no-repeat;
  cursor: pointer;
  margin-top: 6px;
  margin-left: 2px;
  padding-left: 30px;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}
div.ccm_form input:checked + label {
  background: url('/_skins/base/images/ico_ok.svg');
  background-position: 3px 6px;
  background-size: 20px auto;
  background-repeat: no-repeat;
}
div.ccm_form .field textarea {
  width: 100%;
  height: 150px;
  border: none;
  padding: 5px;
  resize: none;
  line-height: 28px;
  font-weight: 300;
  font-size: 17px;
  color: #2d1919;
  -webkit-appearance: none;
  -webkit-border-radius: 0;
  border: 1px solid #c8c8c8;
  background-color: #f5f5f5;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}
div.ccm_form div select {
  padding: 3px;
  margin: 0;
  border: none;
  outline: none;
  display: inline-block;
  -moz-appearance: none;
  appearance: none;
  height: 40px;
  cursor: pointer;
  width: 100%;
  font-size: 17px;
  font-weight: 300;
  background-color: #fff;
  color: #363636;
  -webkit-appearance: none;
  -webkit-border-radius: 0;
  border-bottom: 4px solid #c8c8c8;
}
div.ccm_form .fieldSelect .inputfield span {
  position: relative;
}
div.ccm_form .fieldSelect .inputfield span:after {
  content: '>';
  font-size: 22px;
  color: #747787;
  font-weight: 400;
  letter-spacing: -2px;
  -webkit-transform: rotate(90deg);
  -moz-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  transform: rotate(90deg);
  right: 40px;
  top: -3px;
  width: 27px;
  height: 27px;
  line-height: 35px;
  padding: 0px;
  position: absolute;
  pointer-events: none;
  border-top: 1px solid #dcdbdb;
  text-align: center;
}
div.ccm_form .fieldSelect .inputfield span:after:hover {
  color: #1f2745;
}
div.ccm_form .fieldSelect .inputfield:hover span:after {
  color: #1f2745;
}
div.ccm_form .field.fieldOption span:after {
  display: none;
}
div.ccm_form div.fieldOption.field input {
  width: 30px;
  border: none;
  height: 30px;
}
div.ccm_form div.fieldOption.field span label {
  font-weight: 500;
}
div.ccm_form div.fieldOption.field span {
  clear: both;
}
div.ccm_form div.Zustimmung.fieldOption {
  width: 100%;
  -webkit-box-sizing: content-box;
  -moz-box-sizing: content-box;
  box-sizing: content-box;
  margin-bottom: 10px;
}
div.ccm_form div.Zustimmung.fieldOption label {
  max-width: 430px;
  width: 100%;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}
div.ccm_form div.Zustimmung.fieldOption input[type="checkbox"] + label {
  max-width: 430px;
  width: 100%;
  width: auto;
  padding-right: 5px;
}
div.ccm_form div.Zustimmung.fieldOption span.info {
  width: auto;
  display: block;
  font-size: 12px;
  line-height: 18px;
  padding-left: 31px;
  margin-left: 0px;
  -webkit-box-sizing: content-box;
  -moz-box-sizing: content-box;
  box-sizing: content-box;
}
div.ccm_form div.Zustimmung.fieldOption span.info a {
  color: #1e2541;
}
div.ccm_form div.field.Datenschutz {
  height: 90px;
  /*input*/
}
div.ccm_form div.field.Datenschutz .inputfield label {
  margin-left: 1px;
  width: calc(100% - 35px);
  padding-left: 38px;
}
div.ccm_form div.field.Datenschutz .checkbox {
  height: 25px;
  width: 25px;
  float: left;
}
div.ccm_form div.field.Datenschutz input {
  width: auto;
  height: auto;
  border: none;
}
div.ccm_form div.field.Datenschutz .txt {
  font-size: 13px;
  width: 100%;
  display: block;
  line-height: 23px;
  margin-top: 30px;
  margin-left: 40px;
}
div.ccm_form div.field.Datenschutz .txt a {
  color: #1e2541;
}
div.ccm_form div span.info {
  width: 430px;
  display: block;
  float: left;
  color: #9C9C9C;
  clear: left;
  margin-left: 136px;
  font-style: italic;
}
div.ccm_form div span.errorMessage {
  clear: left;
  color: #E51937;
  margin-left: 136px;
}
div.ccm_form div span.error input,
div.ccm_form div.ccm_form div span.error textarea {
  border: 1px solid #E51937;
}
div.ccm_form .col1Contact {
  width: 100%;
  max-width: 100%;
  float: left;
  min-height: 100px;
  margin-right: 40px;
}
div.ccm_form .col1Contact div.field {
  margin-bottom: 15px;
  padding: 0px;
  width: calc(100% - 0px);
  float: left;
  margin-right: 0px;
}
div.ccm_form .col1Contact div.field textarea {
  max-width: 100%;
}
div.ccm_form .col2Contact {
  float: left;
  width: 100%;
  padding-right: 0px;
}
div.ccm_form .col2Contact div.field {
  margin-bottom: 15px;
  padding: 0px;
  width: calc(100% - 0px);
  float: left;
  margin-right: 0px;
  max-width: 630px;
}
div.ccm_form .col2Contact div.field textarea {
  max-width: 100%;
}
div.ccm_form .requiredFields {
  font-size: 13px;
  color: #6c6c6c;
  float: left;
  margin: 10px 50px 20px 0px;
  line-height: 21px;
}
div.ccm_form .formButton {
  margin: 5px 0;
  font-size: 19px;
  text-decoration: none;
  width: auto;
  min-height: 42px;
  line-height: 32px;
  padding: 10px 25px 10px 25px;
  background-color: #a20000;
  font-weight: 300;
  margin: 30px 0 30px 0;
  color: #FFF;
  border-radius: 7px;
  border: none;
  display: block;
  max-width: fit-content;
  transition: all 0.4s ease 0s;
  -webkit-transition: all 0.4s ease 0s;
  -moz-transition: all 0.4s ease 0s;
  -o-transition: all 0.4s ease 0s;
  -ms-transition: all 0.4s ease 0s;
}
div.ccm_form input:checked + label {
  background: url('/_skins/base/images/ico_ok.svg');
  background-position: 3px 6px;
  background-size: 16px auto;
  background-repeat: no-repeat;
}
/* @end  */
.ErrorReportGen {
  background-image: url("/_skins/base/images/icon_error.svg");
  background-repeat: no-repeat;
  background-position: 6px 4px;
  background-size: 13px auto;
  background-color: #e60000;
  color: #ffffff;
  font-size: 10px;
  position: absolute;
  bottom: -15px;
  height: 22px;
  line-height: 24px;
  letter-spacing: 0.3px;
  padding: 0px 7px 0px 26px;
  z-index: 2;
  min-width: 130px;
  left: -1px;
}
.ErrorReportGen .er_content {
  max-width: unset !important;
}
.ErrorReportGen::after {
  content: '';
  position: absolute;
  left: 5px;
  top: -10px;
  width: 0px;
  height: 0px;
  transform: rotate(360deg);
  border-style: solid;
  border-width: 0 8px 10px 8px;
  border-color: transparent transparent #e60000 transparent;
}
.field .inputfield.notEmptyInput .ErrorReportGen {
  visibility: hidden;
}
.Datenschutz .ErrorReportGen {
  top: -25px;
  bottom: auto;
}
.Datenschutz .ErrorReportGen::after {
  display: none;
}
.FileUpload.field.attachment {
  height: auto;
  padding-top: 20px;
  min-height: 230px;
  width: 100%;
  margin: 0 auto;
  background-color: transparent;
  border: none;
  max-width: 100%;
  /*#Attachment_image*/
  /*#Attachment_image*/
  /*span.inputfield*/
  /*.fileUpload*/
}
.FileUpload.field.attachment #Attachment_image,
.FileUpload.field.attachment #Attachment2_image,
.FileUpload.field.attachment #Attachment3_image,
.FileUpload.field.attachment #Attachment4_image,
.FileUpload.field.attachment #Attachment5_image {
  position: absolute;
  right: 0px;
  top: 0px;
  width: auto;
  height: 35px;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 0 );
  transition: all 0.3s linear 0s;
  -webkit-transition: all 0.3s linear 0s;
  -moz-transition: all 0.3s linear 0s;
  -o-transition: all 0.3s linear 0s;
  -ms-transition: all 0.3s linear 0s;
}
.FileUpload.field.attachment .att1.visible #Attachment_image,
.FileUpload.field.attachment .att2.visible #Attachment2_image,
.FileUpload.field.attachment .att3.visible #Attachment3_image,
.FileUpload.field.attachment .att4.visible #Attachment4_image,
.FileUpload.field.attachment .att5.visible #Attachment5_image {
  visibility: visible;
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 100 );
  transition: all 0.3s linear 0s;
  -webkit-transition: all 0.3s linear 0s;
  -moz-transition: all 0.3s linear 0s;
  -o-transition: all 0.3s linear 0s;
  -ms-transition: all 0.3s linear 0s;
}
.FileUpload.field.attachment span.inputfields {
  float: left;
  width: 100%;
  min-height: 60px;
  display: block;
  margin: 0px 0px 10px 0px;
  display: flex;
}
.FileUpload.field.attachment span.inputfields span.inputfield {
  width: 100%;
  min-height: 35px;
  margin: 0px 0px 10px 0px;
  clear: both;
  position: relative;
  display: table;
  max-width: 50%;
  width: calc(50% - 20px);
  max-width: 440px;
  float: left;
  margin-right: 40px;
  /*div.FileUpload*/
  /*.fileUpload*/
}
.FileUpload.field.attachment span.inputfields span.inputfield.att2 {
  margin-right: 0px;
}
.FileUpload.field.attachment span.inputfields span.inputfield .caption {
  width: 100%;
  display: block;
  height: 35px;
  line-height: 30px;
  font-size: 14px;
  font-weight: 600;
}
.FileUpload.field.attachment span.inputfields span.inputfield input {
  padding: 0px;
}
.FileUpload.field.attachment span.inputfields span.inputfield span {
  float: left;
  min-height: 10px;
  width: 100%;
}
.FileUpload.field.attachment span.inputfields span.inputfield label {
  font-size: 12px;
  line-height: 16px;
  width: 183px;
  margin-top: 6px;
}
.FileUpload.field.attachment span.inputfields span.inputfield div.FileUpload img {
  width: 55px;
  height: auto;
  float: left;
}
.FileUpload.field.attachment span.inputfields span.inputfield a.fileUpload {
  display: block;
  height: 85px;
  line-height: 35px;
  font-size: 14px;
  color: #595959;
  font-weight: 400;
  max-width: 460px;
  text-align: center;
  width: 100%;
  margin-top: 0px;
  float: left;
  background-image: none;
  position: relative;
  background-color: #FFF;
  border: 1px solid #595959;
  text-decoration: none;
  display: flex;
  align-items: end;
  justify-content: center;
  padding: 0px 15px;
}
.FileUpload.field.attachment span.inputfields span.inputfield a.fileUpload:hover {
  cursor: pointer;
}
.FileUpload.field.attachment .fileName {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  max-width: 210px;
  padding: 0 5px 1px 5px !important;
  border: none;
  height: 25px;
  pointer-events: none;
  visibility: hidden;
  background: transparent;
  color: #9f9f9f;
  font-size: 12px;
  text-align: center;
  transition: all 0.3s linear 0s;
  -webkit-transition: all 0.3s linear 0s;
  -moz-transition: all 0.3s linear 0s;
  -o-transition: all 0.3s linear 0s;
  -ms-transition: all 0.3s linear 0s;
}
.FileUpload.field.attachment a.fileUpload::before {
  position: absolute;
  content: '';
  top: 15px;
  left: 0px;
  right: 0;
  margin: 0 auto;
  width: 27px;
  height: 35px;
  background-image: url("/_skins/base/images/icon_doc.svg");
  background-position: center 0px;
  background-size: 27px auto;
  background-repeat: no-repeat;
}
.FileUpload.field.attachment span.inputfields span.inputfield.visible {
  min-height: 35px;
  margin: 0px 40px 40px 0px;
  transition: all 0.3s linear 0s;
  -webkit-transition: all 0.3s linear 0s;
  -moz-transition: all 0.3s linear 0s;
  -o-transition: all 0.3s linear 0s;
  -ms-transition: all 0.3s linear 0s;
  /*.fileUpload*/
  /*.fileUpload*/
  /*#Attachment_image*/
}
.FileUpload.field.attachment span.inputfields span.inputfield.visible.att2 {
  margin-right: 0;
}
.FileUpload.field.attachment span.inputfields span.inputfield.visible a.fileUpload {
  text-indent: -10000px;
  height: 65px;
  color: #fff;
  border-color: #a20000;
  padding: 0 15px;
  transition: all 0.3s linear 0s;
  -webkit-transition: all 0.3s linear 0s;
  -moz-transition: all 0.3s linear 0s;
  -o-transition: all 0.3s linear 0s;
  -ms-transition: all 0.3s linear 0s;
}
.FileUpload.field.attachment span.inputfields span.inputfield.visible a.fileUpload::before {
  position: absolute;
  content: 'Dokument bereitgestellt';
  top: 0px;
  left: 0px;
  text-indent: 0px;
  text-align: center;
  width: 100%;
  height: 35px;
  color: #595959;
  line-height: 35px;
}
.FileUpload.field.attachment span.inputfields span.inputfield.visible .fileName {
  visibility: visible;
  transition: all 0.3s linear 0s;
  -webkit-transition: all 0.3s linear 0s;
  -moz-transition: all 0.3s linear 0s;
  -o-transition: all 0.3s linear 0s;
  -ms-transition: all 0.3s linear 0s;
}
.FileUpload.field.attachment span.inputfields span.inputfield.visible #Attachment_image,
.FileUpload.field.attachment span.inputfields span.inputfield.visible #Attachment2_image,
.FileUpload.field.attachment span.inputfields span.inputfield.visible #Attachment3_image,
.FileUpload.field.attachment span.inputfields span.inputfield.visible #Attachment4_image,
.FileUpload.field.attachment span.inputfields span.inputfield.visible #Attachment5_image {
  height: 35px;
  display: none;
  transition: all 0.3s linear 0s;
  -webkit-transition: all 0.3s linear 0s;
  -moz-transition: all 0.3s linear 0s;
  -o-transition: all 0.3s linear 0s;
  -ms-transition: all 0.3s linear 0s;
}
.FileUpload.field.attachment span.inputfields span.inputfield.visible #Attachment_filename,
.FileUpload.field.attachment span.inputfields span.inputfield.visible #Attachment2_filename,
.FileUpload.field.attachment span.inputfields span.inputfield.visible #Attachment3_filename,
.FileUpload.field.attachment span.inputfields span.inputfield.visible #Attachment4_filename,
.FileUpload.field.attachment span.inputfields span.inputfield.visible #Attachment5_filename {
  position: absolute;
  left: 0px;
  right: 0;
  width: 100%;
  text-align: center;
  bottom: 0px;
  height: 35px;
  line-height: 35px;
  font-size: 14px;
  z-index: 99;
  max-width: 460px;
  margin-bottom: 0;
  color: #4a4a4a;
}
/*div.ccm_form.ccmSpecial .FileUpload.field */
div.anfrageFormContainer {
  max-width: 970px;
  padding: 0 20px;
  width: 100%;
  min-height: 500px;
  margin: 0 auto;
}
div.anfrageFormContainer h1 {
  margin-bottom: 20px;
  font-family: 'Noto Serif';
  letter-spacing: 0px;
  font-size: 27px;
  font-weight: 400;
  line-height: 37px;
  color: #A20000;
}
.anfrageContainerContact h2 {
  margin-bottom: 20px;
  font-family: 'Noto Serif';
  letter-spacing: 0px;
  font-size: 27px;
  font-weight: 400;
  line-height: 37px;
  color: #A20000;
}
.buttonForm,
.buttonAgain {
  color: #FFF;
  text-align: center;
  width: 195px;
  height: 43px;
  float: left;
  line-height: 39px;
  text-decoration: none;
  font-weight: 400;
  background-color: #333333;
  border: 1px solid #333333;
  margin: 9px 52px 0px 0px;
}
.buttonForm:hover,
.buttonAgain:hover {
  background-color: #7FBD4A;
  border: 1px solid #7FBD4A;
}
.buttonForm span span,
.buttonAgain span span {
  font-weight: 700;
}
.jobOffers .jobOffer {
  display: flex;
  flex-wrap: wrap;
  position: relative;
  min-height: 130px;
  margin: 0 0 40px auto;
}
.jobOffers .jobOffer .jobOfferInner {
  padding: 50px 0 0 0;
  width: 100%;
  display: flex;
  flex-wrap: wrap;
}
.jobOffers .jobOffer .jobOfferInner .img {
  width: 350px;
  height: auto;
  min-height: 245px;
}
.jobOffers .jobOffer .jobOfferInner .img img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}
.jobOffers .jobOffer .jobOfferInner .details {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  padding-left: 40px;
  padding-right: 15px;
  width: calc(100% - 350px);
  max-width: 1100px;
  background-color: #fff;
  padding: 15px 15px 15px 40px;
}
.jobOffers .jobOffer .jobOfferInner .title {
  width: 100%;
  max-width: 100%;
  display: flex;
  flex-wrap: wrap;
  align-content: start;
}
.jobOffers .jobOffer .jobOfferInner .title h2 {
  width: 100%;
  margin: 0px 0px 2px 0px;
  text-align: left;
  font-family: 'Noto Serif';
  letter-spacing: 0px;
  font-size: 26px;
  font-weight: 400;
  line-height: 36px;
  color: #a20000;
}
.jobOffers .jobOffer .jobOfferInner .title .intro {
  letter-spacing: 0.08px;
  font-family: 'Outfit';
  font-size: 16px;
  line-height: 26px;
  color: #333333;
  min-height: 125px;
  max-width: 950px;
}
.jobOffers .jobOffer .jobOfferInner .button {
  margin: 5px 0;
  font-size: 15px;
  text-decoration: none;
  width: auto;
  height: 42px;
  max-width: 240px;
  line-height: 42px;
  padding: 0px 25px 0px 25px;
  background-color: #333;
  font-weight: 300;
  color: #FFF;
  border-radius: 25px;
  text-transform: uppercase;
  border: none;
  display: block;
  max-width: fit-content;
  transition: all 0.4s ease 0s;
  -webkit-transition: all 0.4s ease 0s;
  -moz-transition: all 0.4s ease 0s;
  -o-transition: all 0.4s ease 0s;
  -ms-transition: all 0.4s ease 0s;
}
.jobOffers .jobOffer .jobOfferInner .button.button_apply {
  margin-left: 20px;
  background-color: #a20000;
}
.jobOffers .jobOffer .jobOfferInner .button:hover {
  background-color: #a20000;
  transition: all 0.4s ease 0s;
  -webkit-transition: all 0.4s ease 0s;
  -moz-transition: all 0.4s ease 0s;
  -o-transition: all 0.4s ease 0s;
  -ms-transition: all 0.4s ease 0s;
}
.jobOffers .jobOffer.jobOffer_last {
  border-bottom: none;
}
.JobOfferHeader .JobOfferHeaderInner {
  width: 100%;
  max-width: 800px;
  margin: 0 auto;
}
.JobOfferHeader .title h1 {
  font-size: 27px;
  width: 100%;
  margin: 0px 0px 20px 0px;
  font-family: 'Noto Serif';
  letter-spacing: 0px;
  font-weight: 400;
  line-height: 36px;
  color: #a20000;
  text-align: center;
}
.JobOfferHeader .img {
  position: relative;
  border-bottom: 1px solid #d5d5d5;
}
.JobOfferHeader .img img {
  width: 100%;
  height: auto;
  display: block;
}
.JobOfferHeader .buttonsJob {
  display: flex;
  justify-content: center;
  width: 100%;
  height: 50px;
  margin: 40px auto 40px auto;
  align-items: center;
  padding-left: 20px;
  padding-right: 20px;
}
.JobOfferHeader .buttonsJob .btn {
  margin: 5px 0;
  font-size: 15px;
  text-decoration: none;
  width: auto;
  height: 42px;
  max-width: 240px;
  line-height: 42px;
  padding: 0px 25px 0px 25px;
  background-color: #333;
  font-weight: 300;
  color: #FFF;
  border-radius: 25px;
  text-transform: uppercase;
  border: none;
  display: block;
  max-width: fit-content;
  color: #333;
  border: 1px solid #333;
  background-color: transparent;
  transition: all 0.4s ease 0s;
  -webkit-transition: all 0.4s ease 0s;
  -moz-transition: all 0.4s ease 0s;
  -o-transition: all 0.4s ease 0s;
  -ms-transition: all 0.4s ease 0s;
}
.JobOfferHeader .buttonsJob .btn.btnApp {
  margin-left: 20px;
  color: #FFF;
  background-color: #333;
  border: 1px solid #333;
}
.JobOfferHeader .buttonsJob .btn.btnJob span {
  width: 100%;
  height: 100%;
  display: block;
}
.JobOfferHeader .buttonsJob .btn.btnJob:hover {
  color: #FFF;
}
.JobOfferHeader .buttonsJob .btn.active:hover {
  cursor: default;
  background-color: transparent;
  pointer-events: none;
}
.JobOfferHeader .buttonsJob .btn:hover {
  background-color: #a20000;
  border: 1px solid #a20000;
  transition: all 0.4s ease 0s;
  -webkit-transition: all 0.4s ease 0s;
  -moz-transition: all 0.4s ease 0s;
  -o-transition: all 0.4s ease 0s;
  -ms-transition: all 0.4s ease 0s;
}
.jobOfferVO .jobOfferVOInner {
  max-width: 1300px;
  margin: 0 auto;
}
.jobOfferVO .jobOfferVOInner .offerPart {
  width: 100%;
  background-color: #fff;
  margin: 20px 0 20px 0;
  padding: 30px 20px 20px 30px;
}
.jobOfferVO .jobOfferVOInner .offerPart .offerPartInner {
  max-width: 800px;
}
.jobOfferVO .jobOfferVOInner .offerPart .offerPartInner h3 {
  margin-top: 0px;
  margin-bottom: 4px;
  font-size: 25px;
  font-weight: 400;
  line-height: 24px;
}
.jobOfferVO .jobOfferVOInner .intro {
  max-width: 800px;
  text-align: center;
  margin: 0 auto;
}
.jobOfferVO .jobOfferVOInner .imgLeiste {
  width: 100%;
  margin: 20px 0 20px 0;
}
.jobOfferVO .jobOfferVOInner .imgLeiste img {
  width: 100%;
  height: auto;
  display: block;
}
.jobOfferVO .jobOfferVOInner .formButtonJobContainer {
  margin: 5px 0;
  font-size: 19px;
  text-decoration: none;
  width: auto;
  min-height: 42px;
  line-height: 32px;
  padding: 10px 25px 10px 25px;
  background-color: #a20000;
  font-weight: 300;
  margin: 30px auto 30px auto;
  color: #FFF;
  border-radius: 17px;
  border: none;
  display: block;
  max-width: fit-content;
  transition: all 0.4s ease 0s;
  -webkit-transition: all 0.4s ease 0s;
  -moz-transition: all 0.4s ease 0s;
  -o-transition: all 0.4s ease 0s;
  -ms-transition: all 0.4s ease 0s;
}
.jobOfferVO .jobOfferVOInner .formButtonJobContainer .formButtonJobContainerInner .txt span {
  font-size: 26px;
  text-transform: uppercase;
  font-weight: 500;
  letter-spacing: 0.5px;
}
#buttonSideMenu .menu_icon {
  bottom: auto;
  display: inline-block;
  height: 4px;
  left: 38%;
  position: absolute;
  right: auto;
  top: 50%;
  -webkit-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
  width: 18px;
  transition: all 0.3s ease 0s;
  -webkit-transition: all 0.3s ease 0s;
  -moz-transition: all 0.3s ease 0s;
  -o-transition: all 0.3s ease 0s;
  -ms-transition: all 0.3s ease 0s;
}
#buttonSideMenu .menu_icon::before,
#buttonSideMenu .menu_icon::after {
  content: "";
  height: 100%;
  left: 0px;
  position: absolute;
  width: 100%;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease 0s;
  -moz-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  -ms-transition: all 0.5s ease 0s;
}
#buttonSideMenu .menu_icon::before {
  bottom: 9px;
  width: calc(100% + 10px);
}
#buttonSideMenu .menu_icon::after {
  top: 9px;
  width: calc(100% + 5px);
}
#buttonSideMenu.active .menu_icon {
  height: 4px;
}
#buttonSideMenu .menu_icon,
#buttonSideMenu .menu_icon::before,
#buttonSideMenu .menu_icon::after {
  background-color: #333;
}
#buttonSideMenu.active .menu_icon {
  background-color: transparent;
}
#buttonSideMenu::before {
  top: -10px;
  width: 100% !important;
  position: absolute;
  content: 'MENU';
  left: 0;
  right: 0;
  color: #333333;
  font-size: 10px;
  letter-spacing: 0px;
  transition: all 0.2s ease 0s;
  -webkit-transition: all 0.2s ease 0s;
  -moz-transition: all 0.2s ease 0s;
  -o-transition: all 0.2s ease 0s;
  -ms-transition: all 0.2s ease 0s;
}
#buttonSideMenu.active::before {
  content: '';
  left: -7px;
  transition: all 0.2s ease 0.5s;
  -webkit-transition: all 0.2s ease 0.5s;
  -moz-transition: all 0.2s ease 0.5s;
  -o-transition: all 0.2s ease 0.5s;
  -ms-transition: all 0.2s ease 0.5s;
}
#buttonSideMenu.active .menu_icon::before {
  bottom: 0;
  width: 100% !important;
  background-color: #fff;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
#buttonSideMenu.active .menu_icon::after {
  top: 0;
  width: 100% !important;
  background-color: #fff;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
.buttonSideMenuContainer {
  width: 40px;
  height: 40px;
  position: fixed;
  right: 20px;
  top: 48px;
  z-index: 99;
  display: none;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease 0s;
  -moz-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  -ms-transition: all 0.5s ease 0s;
}
.Bodyholder.show .buttonSideMenuContainer {
  z-index: 99999;
}
#topContainer.scroll .buttonSideMenuContainer {
  top: 11px;
}
#topContainer.scroll div#navigation .subnav {
  top: 60px;
}
#buttonSideMenu {
  display: block;
  width: 100%;
  height: 100%;
}
#buttonSideMenu:hover {
  cursor: pointer;
}
#googleMaps {
  width: 100%;
  height: calc(70vh - 50px);
  display: block;
  overflow: hidden;
  position: relative;
}
#googleMaps #main-googleMaps {
  width: 100%;
  height: 100%;
  display: block;
}
/*.googleMaps */
.clearB {
  clear: both;
}
#navigationContainer.mobile {
  display: none;
}
.kontaktdaten {
  width: 100%;
  padding: 35px 20px 30px 20px;
  background-color: #ebebec;
  -webkit-box-shadow: inset 0px 3px 6px 0px rgba(0, 0, 0, 0.1);
  -moz-box-shadow: inset 0px 3px 6px 0px rgba(0, 0, 0, 0.1);
  box-shadow: inset 0px 3px 6px 0px rgba(0, 0, 0, 0.1);
  height: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  position: relative;
}
.kontaktdaten .kontaktdatenInner {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  height: 100%;
  max-width: 930px;
}
.kontaktdaten .kontaktdatenInner h2 {
  width: 100%;
  text-align: center;
  font-family: 'Noto Serif';
  letter-spacing: 0px;
  font-size: 42px;
  font-weight: 400;
  line-height: 52px;
  color: #A20000;
  font-style: normal;
  margin: 15px 0 27px 0;
}
.kontaktdaten.contactSite {
  background-color: #fff;
  -webkit-box-shadow: inset 0px 3px 6px 0px rgba(0, 0, 0, 0);
  -moz-box-shadow: inset 0px 3px 6px 0px rgba(0, 0, 0, 0);
  box-shadow: inset 0px 3px 6px 0px rgba(0, 0, 0, 0);
  min-height: 200px;
}
.kontaktdaten.contactSite .kontaktdatenInner {
  position: absolute;
  left: 0;
  right: 0;
  margin: 0 auto;
  top: -100px;
  border: 1px solid #fff;
  background-color: #fff;
  filter: drop-shadow(10px 0px 10px rgba(12, 50, 86, 0.1));
  height: auto;
  padding: 20px;
  max-width: 970px;
}
.kontaktdaten div.part {
  width: 100%;
  margin: 0px 0 25px 0px;
  line-height: 40px;
  min-height: 40px;
  font-size: 18px;
  max-width: 33%;
  text-align: center;
}
.kontaktdaten div.part .icon {
  height: 80px;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.kontaktdaten div.part .icon img {
  width: auto;
}
.kontaktdaten div.part .caption {
  font-weight: 600;
  width: 100%;
  font-size: 19px;
  line-height: 21px;
  margin-top: 10px;
}
.kontaktdaten div.part a {
  text-decoration: none;
  height: 40px;
  color: #a20000;
  display: inline-block;
  max-width: fit-content;
  font-size: 18px;
}
.kontaktdaten div.part.tel .icon img {
  max-height: 50px;
}
.kontaktdaten div.part.tel .icon img {
  max-height: 50px;
}
.kontaktdaten div.part.online .icon img {
  max-height: 70px;
  margin-right: -10px;
}
.kontaktdaten div.part.company .address {
  line-height: 22px;
  text-align: center;
  font-size: 18px;
}
.kontaktdaten div.part.company .icon img {
  max-height: 60px;
}
.kontaktdaten div.part.email .icon img {
  max-height: 40px;
}
.kontaktdaten.generalSite .kontaktdatenInner .part.tel {
  order: 1;
}
.kontaktdaten.generalSite .kontaktdatenInner .part.online {
  order: 2;
}
.kontaktdaten.generalSite .kontaktdatenInner .part.email {
  order: 3;
}
.slideOutArea {
  background: #952a16;
  -webkit-backface-visibility: hidden;
  position: fixed;
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 100 );
  left: 0;
  top: 0;
  z-index: 1;
  height: 100%;
  width: 100%;
  transition: all 0.8s linear 0s;
  -webkit-transition: all 0.8s linear 0s;
  -moz-transition: all 0.8s linear 0s;
  -o-transition: all 0.8s linear 0s;
  -ms-transition: all 0.8s linear 0s;
}
.BodyHolder.show .slideOutArea {
  background: linear-gradient(145deg, #af181e, #af181e);
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
  filter: alpha(opacity = 100 );
  height: 100%;
  width: 100%;
  transition: all 0.2s linear 0s;
  -webkit-transition: all 0.2s linear 0s;
  -moz-transition: all 0.2s linear 0s;
  -o-transition: all 0.2s linear 0s;
  -ms-transition: all 0.2s linear 0s;
}
.BodyHolder {
  width: 100%;
  min-height: 100vh;
  height: 100%;
  float: left;
}
.BodyHolderInner {
  transition: transform 0.8s cubic-bezier(0.15, 0.2, 0.1, 1);
  transform-origin: center;
  position: relative;
  z-index: 10;
}
.BodyHolder.show .BodyHolderInner {
  -webkit-transition: transform 0.8s cubic-bezier(0.15, 0.2, 0.1, 1);
  transition: transform 0.8s cubic-bezier(0.15, 0.2, 0.1, 1);
  -webkit-transform: scale(0.9) translateX(-320px) translateZ(0) !important;
  transform: scale(0.9) translateX(-320px) translateZ(0) !important;
  height: 100%;
  max-height: calc(100vh - 90px);
  overflow: hidden;
}
.BodyHolder.show .BodyHolderInner #topContainerSpacer {
  background-color: white;
}
.shareBox {
  width: 100%;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  max-width: 160px;
  margin: 15px 5px 30px auto;
}
.shareBox span {
  width: 100%;
  display: block;
  font-weight: 300;
  text-align: center;
  height: 30px;
  line-height: 30px;
  font-size: 16px;
  color: #333;
}
.shareBox .shareBtn {
  background-position: center center;
  background-repeat: no-repeat;
  width: 35px;
  height: 35px;
  display: block;
}
.shareBox .shareBtn.fb {
  background-image: url("/_skins/base/images/share_facebook.svg");
  background-size: 12px auto;
  background-color: #3C5A9A;
}
.shareBox .shareBtn.xing {
  background-image: url("/_skins/base/images/xing_logo.svg");
  background-size: 20px auto;
  background-color: #006567;
}
.shareBox .shareBtn.linked {
  background-image: url("/_skins/base/images/share_linkedin.svg");
  background-size: 30px auto;
  background-color: #0a66c2;
}
.shareBox .shareBtn.twitter {
  background-image: url("/_skins/base/images/twitter_logo.svg");
  background-size: 22px auto;
  background-color: #1DA1F2;
}
.BodyHolder.afterHide .BodyHolderInner {
  animation: maxHeight 1.9s cubic-bezier(0.77, 0, 0.175, 1);
}
/* noTouch*/
@media (hover: none) {
  .projektGallerien .projektGallerie a.layer .layerInner {
    display: none;
  }
  .galleryDetail .button_left a,
  .galleryDetail .button_right a {
    opacity: 1;
  }
}
/* noTouch END*/
@media only screen and (max-width: 1670px) {
  .stage .slide .bild picture {
    width: 100%;
    height: 100vh;
    display: block;
  }
}
@media only screen and (max-width: 1550px) {
  .stage .slide .bild picture {
    height: calc(100vh - 0px);
    display: block;
  }
  .stage .slide .bild img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .services .servicesInner .left .title {
    font-size: 22px;
  }
  .services .servicesInner .right {
    width: 100%;
    max-width: 45vw;
  }
  .services .servicesInner .left {
    max-width: calc(45vw - 120px);
  }
}
@media only screen and (max-width: 1450px) {
  .stage .infoText .infoTextInner .infoTextLeft {
    padding-left: 35px;
    max-width: 45%;
    padding-right: 25px;
  }
  .stage .infoText .infoTextInner .infoTextLeft .title {
    font-size: 22px;
    line-height: 30px;
  }
  .stage .infoText .infoTextInner .infoTextRight {
    max-width: 55%;
  }
  .stage .infoText .infoTextInner .infoTextRight .text {
    line-height: 25px;
    padding: 0 20px;
  }
  .stage .infoText .scrollAction {
    width: 40px;
    height: 110px;
    bottom: 65px;
  }
  @keyframes solutions {
    0% {
      max-width: 0;
    }
    50% {
      max-width: 95vw;
    }
    100% {
      max-width: 87vw;
    }
  }
  .stage .infoText .scrollAction {
    right: calc(15vw - 120px);
  }
  .stage .infoText .infoTextInner.active {
    max-width: 87vw;
  }
  .stageOuter {
    height: calc((100vw / 2.12) + 0px);
  }
  .stage {
    height: calc(100vh - 0px);
  }
  .stage .infoText {
    bottom: 0px;
    height: 170px;
  }
  .stage .infoText .infoTextInner {
    height: 170px;
  }
  .stageOuter {
    height: calc((100vw / 2.12) + 755px);
  }
  .stage .infoText .scrollAction {
    bottom: 45px;
  }
  .contentElemente .contentElement .ceText .inner h2.title br {
    display: none;
  }
  .services .servicesInner .left .text {
    font-size: 15px;
  }
  .services .servicesInner .left {
    max-width: calc(45vw - 50px);
    margin-right: 50px;
    min-width: calc(50% - 50px);
  }
}
@media only screen and (max-width: 1400px) {
  .contentElemente .contentElement .ceText .inner .link {
    margin: 15px 0px 0 0;
    font-size: 14px;
    height: 37px;
    line-height: 37px;
    padding: 0px 19px 0px 19px;
    border-radius: 20px;
  }
  .contentElemente .contentElement .ceText .inner h2.title {
    margin-bottom: 10px;
    font-size: 33px;
    line-height: 42px;
  }
}
@media only screen and (max-width: 1290px) {
  .contentElemente .contentElement .ceText .inner h2.title {
    margin: 0px 0px 10px 0px;
    font-size: 26px;
    line-height: 33px;
  }
  .contentElemente .contentElement .ceText .inner h2.title p {
    margin: 0;
  }
  .contentElemente .contentElement .ceText .inner {
    padding: 0 25px;
  }
  #topContainer,
  div#top,
  div#top div#topInlay {
    height: 115px;
  }
  div#top div#topInlay a.logo {
    width: 170px;
    height: 63px;
    bottom: 10px;
  }
  div#navigation {
    height: 55px;
  }
  div#navigation div#navigation .navbutton {
    height: 55px;
  }
  .stageOuter {
    height: calc((100vw / 2.12) + 830px);
  }
  .services .servicesInner .left .title {
    font-size: 19px;
    line-height: 30px;
    min-height: 30px;
  }
  .services .servicesInner {
    padding-top: 0vw;
  }
  .containerRefs .projektGallerien .projektGallerienInner .projektGallerie.projektGallerie_withText .textInfos h2 {
    font-size: 26px;
    line-height: 36px;
  }
  .contentElementVO .inner .details {
    width: 55%;
    padding-right: 40px;
  }
  .contentElementVO .inner .ceImg {
    width: 45%;
  }
  .contentElementVO .inner .details h1.title,
  .contentElementVO h2.title {
    margin: 0px 0px 10px 0px;
    font-size: 26px;
    line-height: 33px;
  }
  .contentElementVO .inner .details h1.title p,
  .contentElementVO h2.title p {
    margin: 0;
  }
  .JobOfferHeader .title h1 {
    font-size: 26px;
    line-height: 33px;
  }
}
@media only screen and (max-width: 1200px) {
  .facebookItems .grid-item,
  .facebookItems .grid-sizer {
    width: calc(100% * (1/2) - 15px);
  }
  .facebookItems {
    padding-left: 0px;
    padding-right: 0px;
    padding-top: 20px;
    max-width: 800px;
    margin: 0 auto;
    float: none;
  }
  .facebookItems .facebookItem {
    margin: 0px 7px 30px 7px;
    border-radius: 20px;
  }
  .services .servicesInner .right {
    width: 100%;
    max-width: 48vw;
    min-width: 48vw;
  }
  .services .servicesInner .left .opener .icon {
    top: 5px;
  }
  .services .servicesInner .left {
    padding-bottom: 10px;
  }
  .services .servicesInner .left {
    max-width: calc(49vw - 50px);
    min-width: calc(49vw - 50px);
  }
  .services .servicesInner .left .title {
    font-size: 18px;
  }
  .galleryDetail .button_left,
  .galleryDetail .button_right {
    width: 17vw;
  }
  .galleryDetail .button_left a,
  .galleryDetail .button_right a {
    background-size: auto 15vh;
  }
  .galleryDetail .button_left a {
    background-position: 0 center;
  }
  .galleryDetail .button_right a {
    background-position: right 10px center;
  }
  .projektGallerien .projektGallerie .caption .copyright {
    right: 5px;
    font-size: 11px;
    bottom: 30px;
    color: #FFF;
  }
}
@media only screen and (max-width: 1124px) {
  .contentElemente .contentElement .ceText .inner h2.title {
    font-size: 26px;
    line-height: 35px;
    margin-bottom: 15px;
  }
  .contentElementVO .inner .details h1.title {
    font-size: 26px;
    line-height: 35px;
    margin-bottom: 15px;
  }
}
@media only screen and (max-width: 1024px) {
  .services .servicesInner .serviceContainer.show .left {
    border-color: transparent;
  }
  .services .servicesInner .left {
    max-width: 100%;
    min-width: 100%;
    margin-right: 0;
    padding-right: 20px;
  }
  .services .servicesInner .right {
    width: 100%;
    max-width: 100%;
    min-width: unset;
    margin: 0 auto;
    left: auto;
    bottom: auto;
    top: auto;
    position: relative;
    max-height: 0;
    overflow: hidden;
    min-height: 0;
    padding: 0;
  }
  .services .servicesInner .serviceContainer.show .right {
    max-width: 100%;
    max-height: 800px;
    border-bottom: 1px solid #333;
  }
  .services .servicesInner .serviceContainer.show .right img {
    padding: 10px 20px 20px 20px;
    max-width: calc(100% - 40px);
    margin: 0 auto;
  }
  .services .servicesInner {
    margin-bottom: 0vw;
  }
  .services .servicesInner .right {
    width: 100%;
    max-width: 800px;
    min-width: unset;
    margin: 0 auto;
    left: 0;
    bottom: 0;
    top: calc(100% + 30px);
  }
  @keyframes solutions {
    0% {
      max-width: 0;
    }
    50% {
      max-width: 100vw;
    }
    100% {
      max-width: 92vw;
    }
  }
  .stage .infoText .infoTextInner.active {
    max-width: 92vw;
  }
  .stage .infoText .scrollAction {
    right: 23px;
    bottom: 65px;
    width: 25px;
    height: 65px;
  }
  .stage .infoText .infoTextInner .infoTextLeft .title {
    font-size: 19px;
    line-height: 27px;
  }
  .stage .infoText .infoTextInner .infoTextRight .text {
    letter-spacing: 0.15px;
    font-size: 14px;
    line-height: 23px;
    padding: 0 20px 0 30px;
  }
  .contentElemente .contentElement .ceText .inner .txt {
    font-size: 15px;
  }
  .contentElemente .contentElement .ceText .inner h2.title {
    font-size: 22px;
    line-height: 32px;
  }
  .contentElemente .contentElement .ceText .inner {
    padding: 0 20px;
  }
  .TextItem div.Text {
    font-size: 15px;
    line-height: 26px;
  }
  div#footer #footerInner .leftPart {
    width: 310px;
  }
  div#footer #footerInner .leftPart .logo {
    max-width: 200px;
    margin-bottom: 20px;
  }
  div#footer #footerInner .leftPart .adress {
    font-size: 15px;
  }
  div#footer #footerInner .leftPart a {
    line-height: 35px;
    font-size: 15px;
  }
  div#footer #footerInner .leftPart .contacts a {
    line-height: 35px;
    font-size: 15px;
  }
  div#footer #footerInner .bottomPart {
    font-size: 13px;
  }
  #footerSpacer {
    min-height: 415px;
  }
  div#footer #footerInner .rightPart .info .caption {
    font: normal normal 600 19px/26px Outfit Thin;
    letter-spacing: 0.1px;
    font-family: 'Outfit';
    color: #AF181E;
    font-size: 17px;
  }
  div#footer #footerInner .rightPart {
    padding-top: 62px;
    max-width: calc(100% - 310px);
  }
  div#footer #footerInner .rightPart .info .list a {
    line-height: 35px;
    font-size: 15px;
  }
  .containerRefs .projektGallerien .projektGallerienInner .projektGallerie.projektGallerie_withText .textInfos {
    font-size: 15px;
    line-height: 26px;
  }
  .containerRefs .projektGallerien .projektGallerienInner .projektGallerie.projektGallerie_withText .textInfos h2 {
    font-size: 21px;
    line-height: 28px;
  }
  .contentElementVO .inner .details .txt,
  .contentElementVO .inner .details .langtxt {
    letter-spacing: 0.15px;
    font-size: 14px;
    line-height: 23px;
  }
  .jobOffers .jobOffer .jobOfferInner .title h2 {
    font-size: 21px;
    line-height: 28px;
  }
  .jobOffers .jobOffer .jobOfferInner .title .intro {
    font-size: 15px;
    line-height: 26px;
  }
  .jobOffers .jobOffer .jobOfferInner .button {
    font-size: 14px;
    height: 37px;
    line-height: 37px;
  }
}
@media only screen and (max-width: 969px) {
  .JobOfferHeader .title h1 {
    font-size: 21px;
    line-height: 27px;
  }
  .JobOfferHeader .buttonsJob {
    margin-bottom: 0;
  }
  .jobOfferVO .jobOfferVOInner .formButtonJobContainer .formButtonJobContainerInner .txt span {
    font-size: 21px;
  }
  div#top .topInfo .topInfoInner div {
    width: 0;
    overflow: hidden;
  }
  div#top .topInfo .topInfoInner div.manufacture {
    width: 100%;
    height: 20px;
  }
  .contactInfo.contactInfoMobile {
    display: flex;
    justify-content: right;
    position: fixed;
    right: 80px;
    top: 52px;
    z-index: 999;
    width: 80px;
    height: 30px;
    transition: all 0.5s ease 0s;
    -webkit-transition: all 0.5s ease 0s;
    -moz-transition: all 0.5s ease 0s;
    -o-transition: all 0.5s ease 0s;
    -ms-transition: all 0.5s ease 0s;
  }
  .contactInfoMobile a.tel,
  .contactInfoMobile a.mail {
    background-position: 0px center;
    background-repeat: no-repeat;
    text-decoration: none;
    height: 100%;
    display: block;
    padding-left: 20px;
    transition: all 0.2s linear 0s;
    -webkit-transition: all 0.2s linear 0s;
    -moz-transition: all 0.2s linear 0s;
    -o-transition: all 0.2s linear 0s;
    -ms-transition: all 0.2s linear 0s;
  }
  .contactInfoMobile a.tel {
    background-image: url("/_skins/base/images/icon_phone_black.svg");
    margin-right: 15px;
    text-indent: -10000px;
    width: 25px;
    background-size: 18px auto;
  }
  .contactInfoMobile a.mail {
    background-image: url("/_skins/base/images/icon_mail_black.svg");
    background-size: 25px auto;
    text-indent: -10000px;
    padding: 0;
    width: 25px;
  }
  div#topContainer,
  div#top,
  div#top div#topInlay {
    height: 95px;
  }
  div#top div#topInlay a.logo,
  div#topContainer.scroll div#top div#topInlay a.logo {
    width: 130px;
    height: 47px;
    bottom: 8px;
  }
  .BodyHolder.scroll .buttonSideMenuContainer {
    top: 15px;
    transition: all 0.5s ease 0s;
    -webkit-transition: all 0.5s ease 0s;
    -moz-transition: all 0.5s ease 0s;
    -o-transition: all 0.5s ease 0s;
    -ms-transition: all 0.5s ease 0s;
  }
  .BodyHolder.scroll .contactInfo.contactInfoMobile {
    top: 19px;
    transition: all 0.5s ease 0s;
    -webkit-transition: all 0.5s ease 0s;
    -moz-transition: all 0.5s ease 0s;
    -o-transition: all 0.5s ease 0s;
    -ms-transition: all 0.5s ease 0s;
  }
  #topContainer.scroll div#top div#topInlay a.logo {
    top: auto;
  }
  #topContainer.scroll .buttonSideMenuContainer {
    top: 4px;
    transition: all 0.2s ease 0.3s;
    -webkit-transition: all 0.2s ease 0.3s;
    -moz-transition: all 0.2s ease 0.3s;
    -o-transition: all 0.2s ease 0.3s;
    -ms-transition: all 0.2s ease 0.3s;
  }
  div#topContainer.scroll div#top div#topInlay a.logoFixed {
    bottom: auto;
    top: 5px;
  }
  #buttonSideMenu {
    display: block;
    width: 100%;
    height: 100%;
    position: relative;
    pointer-events: auto;
    transition: all 0.5s ease 0s;
    -webkit-transition: all 0.5s ease 0s;
    -moz-transition: all 0.5s ease 0s;
    -o-transition: all 0.5s ease 0s;
    -ms-transition: all 0.5s ease 0s;
  }
  #buttonSideMenu:hover {
    cursor: pointer;
  }
  #buttonSideMenu.active {
    width: 50px;
    height: 50px;
    transition: all 0.5s ease 0s;
    -webkit-transition: all 0.5s ease 0s;
    -moz-transition: all 0.5s ease 0s;
    -o-transition: all 0.5s ease 0s;
    -ms-transition: all 0.5s ease 0s;
  }
  #buttonSideMenu::after {
    position: absolute;
    top: -4px;
    width: 100%;
    content: "Menü";
    display: block;
    text-align: center;
    color: #3D4446;
    font-size: 13px;
    left: -6px;
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
    filter: alpha(opacity = 0 );
  }
  #buttonSideMenu.active::after {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
    filter: alpha(opacity = 0 );
  }
  .buttonSideMenuContainer {
    display: block;
    pointer-events: auto;
  }
  .navContainerMobile {
    pointer-events: none;
  }
  #navigationContainer.mobile div.mNavigation {
    width: 280px;
    right: -100vw;
    z-index: 98;
    margin-top: 0px;
    padding-top: 0%;
    height: 100vh;
    top: 0px;
    position: fixed;
    float: left;
    transform: translateX(520px);
    transition: all 0.7s linear 0s;
    -webkit-transition: all 0.7s linear 0s;
    -moz-transition: all 0.7s linear 0s;
    -o-transition: all 0.7s linear 0s;
    -ms-transition: all 0.7s linear 0s;
    /* div#navigation*/
    /* div#navigationInlayM*/
    /*div.navigationInlayM*/
    /*.navbuttonC */
    /*.navbutton*/
  }
  #navigationContainer.mobile div.mNavigation div#navigation {
    width: 280px;
    margin-top: 0px;
    padding-top: 80px;
    float: left;
    right: 0px;
    bottom: auto;
    top: 10vh;
    height: auto !important;
    pointer-events: none;
    transition: all 0.3s linear 0s;
    -webkit-transition: all 0.3s linear 0s;
    -moz-transition: all 0.3s linear 0s;
    -o-transition: all 0.3s linear 0s;
    -ms-transition: all 0.3s linear 0s;
  }
  #navigationContainer.mobile div.mNavigation div.navigationInlay {
    position: relative;
    display: block;
  }
  #navigationContainer.mobile div.mNavigation div#navigation::before {
    background-image: url("/_skins/base/images/logo_white.png");
    background-position: 0 0;
    background-repeat: no-repeat;
    display: block;
    overflow: hidden;
    background-size: 100% auto;
    content: '';
    height: 100px;
    position: absolute;
    left: 15px;
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
    filter: alpha(opacity = 0 );
    top: 0px;
    width: 140px;
    transition: all 0.2s ease 0.3s;
    -webkit-transition: all 0.2s ease 0.3s;
    -moz-transition: all 0.2s ease 0.3s;
    -o-transition: all 0.2s ease 0.3s;
    -ms-transition: all 0.2s ease 0.3s;
  }
  #navigationContainer.mobile div.mNavigation div.navigationInlayM::before {
    float: left;
    top: 50px;
    display: block;
    overflow: hidden;
    content: '';
    background-size: 100% auto;
    height: 100px;
    position: absolute;
    left: 35px;
    width: 175px;
    transition: all 0.2s ease 0s;
    -webkit-transition: all 0.2s ease 0s;
    -moz-transition: all 0.2s ease 0s;
    -o-transition: all 0.2s ease 0s;
    -ms-transition: all 0.2s ease 0s;
  }
  #navigationContainer.mobile div.mNavigation div.navigationInlayM {
    width: 350px;
    visibility: hidden;
    overflow: hidden;
    z-index: 9998;
    margin-top: 0px;
    padding-top: 0%;
    height: calc(100vh - 0px);
    transition: all 0.3s linear 0s;
    -webkit-transition: all 0.3s linear 0s;
    -moz-transition: all 0.3s linear 0s;
    -o-transition: all 0.3s linear 0s;
    -ms-transition: all 0.3s linear 0s;
  }
  #navigationContainer.mobile div.mNavigation div.navigationInlayM {
    width: 350px;
    visibility: visible;
    overflow: visible;
    z-index: 9999;
    margin-top: 0px;
    float: right;
    height: calc(100vh - 0px);
    padding-top: 155px;
    padding-bottom: 90px;
    position: relative;
    -webkit-overflow-scrolling: touch;
    transition: all 0.3s linear 0s;
    -webkit-transition: all 0.3s linear 0s;
    -moz-transition: all 0.3s linear 0s;
    -o-transition: all 0.3s linear 0s;
    -ms-transition: all 0.3s linear 0s;
    /*div#navigation*/
  }
  #navigationContainer.mobile div.mNavigation div.navigationInlayM div#navigation {
    width: 350px;
    display: block;
    visibility: visible;
    overflow: visible;
    height: calc(100vh - 0px);
  }
  #navigationContainer.mobile div.mNavigation .navbutton {
    display: block;
    height: 40px;
    line-height: 40px;
    font-size: 17px;
    border: none;
    width: 100%;
    color: #FFF;
    padding-left: 30px;
    padding-right: 20px;
    text-align: left;
    max-width: 100%;
    margin: 0px;
    float: none;
    pointer-events: auto;
    max-width: fit-content;
    transition: all 0.35s ease 0s;
    -webkit-transition: all 0.35s ease 0s;
    -moz-transition: all 0.35s ease 0s;
    -o-transition: all 0.35s ease 0s;
    -ms-transition: all 0.35s ease 0s;
  }
  #navigationContainer.mobile div.mNavigation .navbutton span {
    z-index: 1;
    position: relative;
    width: 100%;
    height: 100%;
    display: table;
  }
  #navigationContainer.mobile div.mNavigation .navbutton:hover {
    background-color: transparent;
    color: #fff;
  }
  #navigationContainer.mobile div.mNavigation .navbutton.navbutton_sub {
    background-image: url("/_skins/base/images/icon_subnav_white.svg");
    background-position: right 5px top 20px;
    background-repeat: no-repeat;
    background-size: 9px auto;
    padding-right: 25px;
  }
  #navigationContainer.mobile div.mNavigation div#navigation .navbutton_active span::after {
    display: none;
  }
  #navigationContainer.mobile div.mNavigation .justMobile.navbutton {
    font-size: 15px;
    height: 35px;
    line-height: 35px;
    margin-top: 10px;
  }
  #navigationContainer.mobile div.mNavigation div#navigation .subnav .subnavInlay {
    justify-content: left;
  }
  #navigationContainer.mobile div.mNavigation div#navigation .subnav {
    background-color: #AF181E;
    position: relative;
    left: 0;
    top: 0;
    box-shadow: 0px 0px 0px #0000001A;
    transform: translateY(0px);
  }
  #navigationContainer.mobile div.mNavigation div#navigation .subnav .navbutton {
    font-size: 14px;
    padding-left: 20px;
    height: auto;
    line-height: 19px;
    pointer-events: auto;
    margin-bottom: 10px;
  }
  #navigationContainer.mobile div.mNavigation div#navigation .subnav.show {
    box-shadow: 0px 0px 0px #0000001A;
  }
  #navigationContainer.mobile div.mNavigation .navbutton_active {
    border-bottom: none;
    color: #fff;
    position: relative;
  }
  #navigationContainer.mobile div.mNavigation .navbutton_active:hover {
    color: #fff;
  }
  #navigationContainer.mobile div.mNavigation .navbuttonC .navbutton_active {
    color: #fff;
  }
  #navigationContainer.mobile div.mNavigation .navbutton.navbutton_active::after {
    height: 2px;
    content: '';
    float: left;
    background-color: #f5f5f5;
    width: calc(100% - 50px);
    position: absolute;
    left: 30px;
    right: 0;
    bottom: 5px;
  }
  #navigationContainer.fixed #navigationContainerInner .navbutton {
    color: #fff;
  }
  #navigationContainer.desktop {
    display: none;
  }
  #navigationContainer.mobile {
    display: block;
    padding-top: 0;
  }
  .BodyHolder.show #navigationContainer.mobile div.mNavigation {
    visibility: visible;
    overflow: visible;
    right: 0%;
    z-index: 98;
    transform: translateX(0px);
    transition: transform 0.6s ease 0.2s;
    -webkit-transition: transform 0.6s ease 0.2s;
    -moz-transition: transform 0.6s ease 0.2s;
    -o-transition: transform 0.6s ease 0.2s;
    -ms-transition: transform 0.6s ease 0.2s;
  }
  .BodyHolder.show #navigationContainer.mobile div.mNavigation div#navigation::before {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
    filter: alpha(opacity = 100 );
    transition: all 0.4s ease 0.7s;
    -webkit-transition: all 0.4s ease 0.7s;
    -moz-transition: all 0.4s ease 0.7s;
    -o-transition: all 0.4s ease 0.7s;
    -ms-transition: all 0.4s ease 0.7s;
  }
  .BodyHolder.show .contactInfo.contactInfoMobile {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=@op)";
    filter: alpha(opacity = 0 );
  }
  .containerTeamFotos .teamFotos .teamFotosInner .teamFoto {
    max-width: calc(((100%) * 1/2) - 0px);
  }
  .BodyHolder.afterHide #navigationContainer.mobil div.mNavigation {
    /**/
    right: -200vw;
    z-index: 9999;
    transition: all 0.7s linear 0s;
    -webkit-transition: all 0.7s linear 0s;
    -moz-transition: all 0.7s linear 0s;
    -o-transition: all 0.7s linear 0s;
    -ms-transition: all 0.7s linear 0s;
  }
  .TextItem.TextItem_1 {
    margin-top: 5vw;
  }
  .stage .infoText .scrollAction {
    right: 16px;
  }
  .contentElemente .contentElement {
    margin-bottom: 5vw;
  }
  .contentElemente .contentElement .ceText .inner h2.title {
    margin: 0px 0px 15px 0px;
    font-size: 23px;
    line-height: 30px;
  }
  .contentElemente .contentElement .ceText {
    width: 100%;
    max-width: 810px;
    float: left;
    min-height: 25px;
    height: 100%;
  }
  .contentElemente .contentElement .ceText .inner {
    padding: 0 40px 0 0px;
  }
  .contentElemente .contentElement.contentEven .ceText .inner {
    padding: 0 0px 0 40px;
  }
  .contentElemente {
    margin: 8vw 0px 4vw 0px;
  }
}
@media only screen and (max-width: 900px) {
  .jobOffers .jobOffer .jobOfferInner .button {
    width: 240px;
    max-width: 100%;
    text-align: center;
  }
  .jobOffers .jobOffer .jobOfferInner .button.button_apply {
    margin-left: 0;
  }
  .jobOffers .jobOffer .jobOfferInner .title h2 {
    font-size: 21px;
    line-height: 28px;
  }
  .jobOffers .jobOffer .jobOfferInner .details {
    padding: 15px 10px 15px 25px;
  }
}
@media only screen and (max-width: 835px) {
  div#container.containerTop {
    padding-top: 105px;
  }
  .contentElementVO .inner .details {
    width: 100%;
    padding-right: 0px;
  }
  .contentElementVO .inner .ceImg {
    width: 100%;
    margin: 40px 0 0 0;
  }
  .services .servicesInner .serviceContainer.show .right img {
    padding: 5px 0px 20px 0px;
    max-width: calc(100% - 0px);
  }
  .galleryContainer {
    padding-left: 10px;
    padding-bottom: 65px;
  }
  .galleryContainer::after {
    bottom: 0px;
  }
  .projektGallerien .projektGallerie {
    max-width: calc(100vw - 45px);
  }
  .contentElemente .contentElement,
  .contentElemente .contentElement.contentEven {
    flex-wrap: wrap;
    max-width: 810px;
    margin-bottom: 8vw;
  }
  .contentElemente .contentElement .ceText .inner,
  .contentElemente .contentElement.contentEven .ceText .inner {
    padding: 0 0px 0 0px;
  }
  .contentElemente .contentElement .ceText .inner h2.title,
  .contentElemente .contentElement.contentEven .ceText .inner h2.title {
    margin: 0px auto 10px auto;
    font-size: 27px;
    line-height: 35px;
    text-align: center;
    max-width: 550px;
  }
  .contentElemente .contentElement.contentEven {
    flex-wrap: wrap-reverse;
  }
  .contentElemente .contentElement.contentEven .ceText .inner {
    padding: 0 0px 0 0px;
  }
  .contentElemente .contentElement .ceImg {
    width: 100%;
  }
  .contentElemente .contentElement .ceText {
    width: 100%;
    max-width: 810px;
    float: left;
    min-height: 25px;
    height: 100%;
    margin-bottom: 3vw;
  }
  .contentElemente .contentElement .ceText .inner .link {
    font-size: 13px;
    height: 30px;
    line-height: 30px;
    padding: 0px 25px 0px 25px;
    position: absolute;
    left: 0;
    right: 0;
    margin: 5px auto;
  }
  .jobOffers .jobOffer .jobOfferInner .button {
    width: 240px;
    max-width: 100%;
    text-align: center;
  }
  .jobOffers .jobOffer .jobOfferInner .button.button_apply {
    margin-left: 0;
  }
  .backLinkCross.backLinkCrossActive {
    top: 10px;
    right: 10px;
  }
  .galleryDetail .button_left,
  .galleryDetail .button_right {
    display: none;
  }
}
@media only screen and (max-width: 800px) {
  .stage {
    height: calc((100vw / 2.12) - 0px);
  }
  .stageOuter {
    height: calc((100vw / 2.12) + 230px);
  }
  .stage .slide .bild img {
    width: 100%;
    height: auto;
  }
  @keyframes solutions {
    0% {
      max-width: 0;
    }
    50% {
      max-width: 100vw;
    }
    100% {
      max-width: 100vw;
    }
  }
  .stage .infoText .infoTextInner.active {
    max-width: 100vw;
  }
  .stage .infoText .scrollAction {
    right: 10px;
    width: 20px;
    height: 60px;
    top: -100px;
    bottom: auto;
    margin: 0 auto;
  }
  div.scrollDown {
    bottom: 0px;
    height: 15px;
    width: 10px;
  }
  div.scrollDown .containerScroll {
    width: 10px;
    height: 10px;
  }
  div.scrollDown .arrow {
    width: 10px;
  }
  @keyframes move {
    25% {
      opacity: 1;
    }
    33% {
      opacity: 1;
      transform: translateY(10px);
    }
    67% {
      opacity: 1;
      transform: translateY(20px);
    }
    100% {
      opacity: 0;
      transform: translateY(35px) scale3d(0.5, 0.5, 0.5);
    }
  }
  .stage .infoText .infoTextInner.active {
    max-width: 100vw;
    padding-bottom: 95px;
  }
  .stage .infoText .infoTextInner {
    height: 265px;
  }
  .stage .infoText {
    bottom: -260px;
    position: absolute;
    height: 265px;
  }
  .stageOuter {
    height: calc((100vw / 2.12) + 290px);
  }
  .stage .infoText .scrollAction {
    right: 0;
    width: 20px;
    height: 70px;
    top: auto;
    bottom: 20px;
    margin: 0 auto;
    z-index: 999;
    left: 0;
  }
  .stage .infoText .infoTextInner .infoTextLeft {
    padding-top: 20px;
  }
  .stage .infoText .infoTextInner {
    align-content: center;
  }
  .stage .infoText .infoTextInner .infoTextLeft,
  .stage .infoText .infoTextInner .infoTextRight {
    padding-top: 20px;
    padding-left: 20px;
    padding-right: 20px;
    max-width: 100%;
    width: 100%;
    height: auto;
    justify-content: center;
    text-align: center;
  }
  .stage .infoText .infoTextInner .infoTextLeft {
    padding-top: 0;
  }
  .stage .infoText .infoTextInner .infoTextLeft .title {
    font-size: 17px;
    line-height: 20px;
    width: 100%;
    max-width: 100%;
  }
  .stage .infoText .infoTextInner .infoTextLeft .subtitle {
    font-size: 11px;
    line-height: 22px;
  }
  .stage .infoText .infoTextInner .infoTextRight {
    padding-top: 10px;
  }
  .stage .infoText .infoTextInner .infoTextRight .text {
    letter-spacing: 0px;
    padding: 0;
    width: 100%;
  }
  .containerRefs .projektGallerien .projektGallerienInner .projektGallerie {
    max-width: 100%;
    margin: 0 0px 45px 0px;
  }
  .containerRefs .projektGallerien .projektGallerienInner .projektGallerie.projektGallerie_withText {
    margin: 0 0 45px 0px;
  }
  .containerRefs .projektGallerien .projektGallerienInner .projektGallerie.projektGallerie_withText .projektGallerieInner {
    max-width: 100%;
  }
  .containerRefs .projektGallerien .projektGallerienInner .projektGallerie.projektGallerie_withText .textInfos h2 {
    font-size: 19px;
    line-height: 25px;
    margin-bottom: 0;
  }
  .containerRefs .projektGallerien .projektGallerienInner .projektGallerie.projektGallerie_withText .textInfos {
    max-width: 100%;
    padding: 20px 0px 30px 5px;
    max-height: unset;
  }
}
@media only screen and (max-width: 770px) {
  .jobOffers .jobOffer .jobOfferInner .img {
    width: 100%;
    height: auto;
    min-height: unset;
  }
  .jobOffers .jobOffer .jobOfferInner .details {
    width: 100%;
    padding: 15px 20px 15px 20px;
  }
  .jobOffers .jobOffer .jobOfferInner .button.button_apply {
    margin-left: auto;
  }
  div#footer {
    position: relative;
  }
  #footerSpacer {
    min-height: 585px;
  }
  div#footer #footerInner .leftPart {
    width: 100%;
  }
  div#footer #footerInner .leftPart .adress {
    text-align: center;
    padding-left: 0;
  }
  div#footer #footerInner .leftPart .logo {
    margin: 0 auto 20px auto;
  }
  div#footer #footerInner .leftPart .smIcons {
    margin: 10px auto 0px auto;
    width: fit-content;
  }
  div#footer #footerInner .rightPart {
    padding-top: 50px;
    max-width: 100%;
  }
  div#footer #footerInner .rightPart .info {
    width: 100%;
    text-align: center;
    margin-bottom: 20px;
  }
  div#footer #footerInner .rightPart .info .list a {
    line-height: 30px;
    font-size: 14px;
  }
  div#footer #footerInner .bottomPart {
    text-align: center;
    margin: 0 auto;
  }
  div#footer #footerInner .bottomPart a {
    width: 100%;
    display: block;
  }
  .kontaktdaten {
    padding: 20px 10px 5px 10px;
  }
  .kontaktdaten .kontaktdatenInner h2 {
    font-size: 27px;
    line-height: 30px;
    margin: 15px 0 15px 0;
  }
  .kontaktdaten div.part .icon {
    height: 50px;
  }
  .kontaktdaten div.part .caption {
    font-size: 17px;
    line-height: 18px;
    margin-top: 8px;
  }
  .kontaktdaten div.part a {
    height: 30px;
    font-size: 15px;
  }
  .kontaktdaten div.part.company .address {
    line-height: 18px;
    font-size: 14px;
  }
  .kontaktdaten div.part.tel .icon img {
    max-height: 35px;
  }
  .kontaktdaten div.part.online .icon img {
    max-height: 55px;
  }
  .kontaktdaten div.part.email .icon img {
    max-height: 30px;
  }
  .kontaktdaten.contactSite .kontaktdatenInner {
    padding: 20px 10px 0 10px;
  }
  .galleryDetail .copyright {
    left: 10px;
    font-size: 13px;
    color: #333;
  }
}
@media only screen and (max-width: 700px) {
  .stage .infoText .infoTextInner .infoTextLeft .title {
    max-width: 350px;
  }
  .filterArea .filter {
    display: flex;
    flex-wrap: wrap;
  }
  .filterArea .filterBox a {
    padding: 0 5px;
    font-size: 13px;
  }
  .facebookItems .grid-item,
  .facebookItems .grid-sizer {
    width: calc(100% * (1) - 0px);
  }
  .facebookItems .facebookItem {
    margin: 0px 0px 30px 0px;
    border-radius: 15px;
  }
  .facebookItems {
    max-width: 395px;
  }
  .stageOuter {
    height: calc((100vw / 1.1) + 295px);
  }
  .stage {
    height: calc((100vw / 1.1) + 0px);
    top: 30px;
  }
  .stage .infoText {
    bottom: -265px;
    height: 265px;
  }
  .stage .infoText .infoTextInner {
    height: 265px;
  }
  .stage .slide .bild img {
    width: auto;
    height: calc(100vw / 1.1);
  }
  .stage .infoText .infoTextInner .infoTextRight .text {
    font-size: 12px;
    line-height: 21px;
  }
  .stage .infoText .infoTextInner.active {
    padding-bottom: 60px;
  }
  div.ccm_form div.field {
    margin-bottom: 10px;
    width: 100%;
    max-width: 100%;
    margin-right: 0px;
  }
  div.ccm_form div label {
    font-size: 15px;
    height: 30px;
    line-height: 30px;
  }
  .FileUpload.field.attachment span.inputfields span.inputfield {
    max-width: 100%;
    width: 100%;
    float: left;
    margin-right: 0;
  }
  div.ccm_form div.field.Datenschutz .txt {
    max-width: calc(100% - 40px);
  }
  .FileUpload.field.attachment span.inputfields {
    flex-wrap: wrap;
  }
  div.ccm_form div.field.Datenschutz {
    height: auto;
  }
  div.ccm_form div.field.smallfieldRight {
    margin-right: 0px;
    width: 100%;
  }
}
@media only screen and (max-width: 600px) {
  .kontaktdaten.contactSite div.part.company {
    max-width: 100%;
  }
  .kontaktdaten.contactSite div.part {
    margin: 0px 0 10px 0px;
  }
  .jobOffers .jobOffer .jobOfferInner .button {
    margin: 5px auto;
    clear: both;
    width: 100%;
    max-width: 100%;
  }
}
@media only screen and (max-width: 560px) {
  .filterArea {
    height: 95px;
    margin-top: 4vw;
    margin-bottom: 20px;
  }
  .filterArea .filterBox a {
    max-height: 80px;
  }
  .filterArea .filterBox span.title {
    max-width: 85px;
    line-height: 13px;
    padding-top: 0;
    height: 34px;
    font-size: 11px;
    display: flex;
    align-items: end;
    padding-bottom: 3px;
  }
  .filterArea .filterBox.filterBox_Wohnen span.title,
  .filterArea .filterBox.filterBox_Arbeiten span.title {
    align-items: center;
    padding-bottom: 0;
    height: 20px;
  }
  .kontaktdaten .kontaktdatenInner {
    justify-content: space-between;
  }
  .kontaktdaten div.part .caption {
    font-size: 16px;
  }
  .kontaktdaten.generalSite .kontaktdatenInner .part.tel {
    max-width: 120px;
    order: 1;
  }
  .kontaktdaten.generalSite .kontaktdatenInner .part.online {
    max-width: 125px;
    order: 3;
  }
  .kontaktdaten.generalSite .kontaktdatenInner .part.email {
    max-width: 153px;
    order: 2;
  }
}
@media only screen and (max-width: 520px) {
  .projektGallerien .projektGallerie .caption .copyright {
    right: auto;
    bottom: 56px;
    left: 6px;
  }
  .projektGallerien .projektGallerie .caption {
    font-size: 15px;
    flex-wrap: wrap;
    letter-spacing: 0px;
    line-height: 18px;
  }
  .projektGallerien .projektGallerie .caption .title {
    width: 100%;
  }
  .projektGallerien .projektGallerie .caption .location {
    border-left: none;
    padding-left: 0;
    margin-left: 0;
    width: 100%;
  }
  .projektGallerien .projektGallerie .counter {
    height: 25px;
    font-size: 13px;
    letter-spacing: 0px;
    bottom: 55px;
    line-height: 25px;
  }
  .galleryContainer::after {
    bottom: 10px;
    height: 40px;
    width: 35px;
    left: 20px;
  }
  .services .servicesInner .left .opener {
    height: 51px;
  }
  .services .servicesInner .left .title {
    font-size: 16px;
  }
  .kontaktdaten .kontaktdatenInner {
    justify-content: space-around;
  }
  .kontaktdaten.generalSite .kontaktdatenInner .part.online {
    max-width: 100%;
  }
}
@media only screen and (max-width: 450px) {
  .projektGallerien .projektGallerie .caption .copyright {
    bottom: 46px;
  }
  .projektGallerien .projektGallerie .counter {
    bottom: 46px;
  }
  .galleryDetail #counter {
    bottom: 0;
  }
  .galleryDetail .copyright {
    bottom: -30px;
    width: 100%;
    text-align: center;
    left: 0;
  }
  .stage .infoText .infoTextInner .infoTextLeft {
    padding-top: 0px;
  }
  .stage .infoText .infoTextInner .infoTextLeft,
  .stage .infoText .infoTextInner .infoTextRight {
    padding-left: 10px;
    padding-right: 10px;
  }
  div#top .topInfo .manufacture span {
    font-size: 12px;
  }
  div#top div#topInlay {
    padding-left: 8px;
    padding-right: 8px;
  }
  .buttonSideMenuContainer {
    right: 8px;
  }
  .contactInfo.contactInfoMobile {
    right: 62px;
  }
  .contactInfo.contactInfoMobile a.tel {
    margin-right: 8px;
  }
}
@media only screen and (max-width: 370px) {
  .galleryDetail #counter {
    bottom: 0px;
  }
  .galleryDetail .copyright {
    font-size: 13px;
    color: #333;
    width: 100%;
    left: 0;
    text-align: center;
    bottom: -35px;
  }
}
@media only screen and (max-width: 390px) {
  .filterArea .filterBox_Wohnen .icon {
    min-width: 45px;
  }
  .filterArea .filterBox_Gastronomie__Hotelerie .icon {
    min-width: 40px;
  }
  .filterArea .filterBox_Arbeiten .icon {
    min-width: 35px;
  }
}
@media only screen and (max-height: 850px) {
  #topContainer,
  div#top,
  div#top div#topInlay {
    height: 115px;
  }
  div#top div#topInlay a.logo {
    width: 170px;
    height: 63px;
    bottom: 10px;
  }
  div#navigation {
    height: 55px;
  }
  div#navigation div#navigation .navbutton {
    height: 55px;
  }
}
@media only screen and (max-width: 969px) and (max-height: 850px) {
  div#topContainer,
  div#top,
  div#top div#topInlay {
    height: 95px;
  }
  div#top div#topInlay a.logo,
  div#topContainer.scroll div#top div#topInlay a.logo {
    width: 130px;
    height: 47px;
    bottom: 8px;
  }
}
