@charset "UTF-8";
body > section, body > footer {
  opacity: 0;
  transition: all 0.5s ease;
}

body > .show ~ section, body.show > header ~ section, body > .show ~ footer, body.show > header ~ footer {
  opacity: 1;
}

@font-face {
  font-family: "Nunito";
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/nunito-v12-latin-regular.eot");
  src: local("Nunito Regular"), local("Nunito-Regular"), url("../fonts/nunito-v12-latin-regular.eot?#iefix") format("embedded-opentype"), url("../fonts/nunito-v12-latin-regular.woff2") format("woff2"), url("../fonts/nunito-v12-latin-regular.woff") format("woff"), url("../fonts/nunito-v12-latin-regular.ttf") format("truetype"), url("../fonts/nunito-v12-latin-regular.svg#Nunito") format("svg");
}
@font-face {
  font-family: "Nunito";
  font-style: normal;
  font-weight: 700;
  src: url("../fonts/nunito-v12-latin-700.eot");
  src: local("Nunito Bold"), local("Nunito-Bold"), url("../fonts/nunito-v12-latin-700.eot?#iefix") format("embedded-opentype"), url("../fonts/nunito-v12-latin-700.woff2") format("woff2"), url("../fonts/nunito-v12-latin-700.woff") format("woff"), url("../fonts/nunito-v12-latin-700.ttf") format("truetype"), url("../fonts/nunito-v12-latin-700.svg#Nunito") format("svg");
}
html, body {
  font-size: 16px;
}

* {
  font-family: "Nunito", sans-serif;
  font-weight: normal;
  font-size: 1rem;
  box-sizing: border-box;
}

h1, h2 {
  font-size: 15vw;
  line-height: 105%;
  color: white;
  padding: 1.5vw;
}

h3 {
  font-size: 120%;
}

h3, h4, b, strong {
  font-weight: 700;
}

a {
  color: #570F17;
}

sup {
  font-size: 0.633em;
}

button {
  background: #023B57;
  padding: 0.5vw 0.85vw;
  color: white;
  box-shadow: 0 0 1.25rem rgba(0, 0, 0, 0.4);
  transition: all 0.33s ease;
  border: 0;
  border-radius: 0;
  cursor: pointer;
}
button:focus {
  opacity: 0.8;
  outline: none;
}
button:hover {
  background: #1c77a3;
}

::-moz-selection {
  background: #023B57;
  color: #fff;
}

::selection {
  background: #023B57;
  color: #fff;
}

body {
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
  min-height: 100vh;
  background-color: #B5152B;
  background: url(../img/bg/bg.svg);
  background-size: 200% auto;
  background-repeat: repeat-y;
  background-position: 0 12.66vw;
  overflow-x: hidden;
}

header {
  display: inline-block;
  width: 100%;
  padding: 1.5vw 3vw;
  background: white;
  height: 12.66vw;
  position: relative;
  z-index: 9999;
}
header #logo {
  display: inline-block;
  height: 100%;
  width: auto;
  font-size: 0 !important;
  min-width: 12.5rem;
}
header #logo img {
  height: 100%;
}
header #menutoggle {
  right: calc(6.33vw - 1rem);
  height: 2rem;
  width: 2rem;
  top: calc(6.33vw - 1rem);
  position: fixed;
  z-index: 95;
  cursor: pointer;
}
header #menutoggle span, header #menutoggle span:after, header #menutoggle span:before {
  content: "";
  display: inline-block;
  width: 2.25rem;
  height: 0.1875rem;
  background: rgb(0, 0, 0);
  border-radius: 0.3125rem;
  position: absolute;
  top: 1rem;
  opacity: 1;
  transition: all 0.5s ease;
}
header #menutoggle span:after {
  top: 0.8125rem;
}
header #menutoggle span:before {
  top: -0.8125rem;
}
header #menutoggle.open span {
  background: rgba(0, 0, 0, 0);
}
header #menutoggle.open span:after {
  top: 0rem;
  transform: rotate(-45deg);
}
header #menutoggle.open span:before {
  top: 0rem;
  transform: rotate(45deg);
}
header nav {
  background: white;
  position: fixed;
  z-index: 90;
  top: 0;
  right: -67%;
  padding-top: 11.16vw;
  min-height: 100vh;
  width: 66.66666%;
  transition: all 0.5s ease;
  box-shadow: 0 0 1.25rem rgba(0, 0, 0, 0.15);
}
header nav a {
  text-decoration: none;
  color: black;
  font-size: 110%;
  padding: 3vw;
  display: inline-block;
}
header nav a.selected {
  font-weight: 700;
  pointer-events: none;
}
header .open + nav {
  right: 0;
}

section {
  position: relative;
  overflow: hidden;
  box-sizing: inherit;
}
section > div {
  display: flex;
  width: 100%;
  align-items: center;
}
section .headline {
  position: relative;
  z-index: 29;
}
section .headline h1, section .headline h2 {
  width: 100%;
  align-self: center;
  text-align: center;
  margin: 0;
  transition: all 0.5s ease;
}
section .text {
  position: relative;
  z-index: 50;
  color: #570F17;
}
section .text > div {
  position: relative;
  background: white;
  padding: 3vw;
  width: 66.66666%;
  margin: 3vw 0;
  display: inline-block;
}
section .text > div img {
  width: 50%;
}
section .text > div button {
  opacity: 0;
  position: absolute;
  bottom: calc(-1vw - 1.375rem);
  right: -1.3vw;
  left: auto;
  border: 0;
  border-radius: 0;
  cursor: pointer;
}
section .text > div button.left {
  right: auto;
  left: -1.3vw;
}
section .text > div:hover button {
  opacity: 1;
}
section .text > div .left, section .text > div .right {
  float: left;
  width: 50%;
  padding-right: 1.5vw;
}
section .text.t_1-6 {
  width: 33.333%;
}
section .text.t_1-6 > div {
  width: 100%;
}
section .text.t_3-6 {
  width: 100%;
}
section .text.t_3-6 > div {
  width: 100%;
}
section .image {
  position: absolute;
  z-index: 1;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 50%;
}
section .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: relative;
}
section .image.through img:first-child {
  mix-blend-mode: multiply;
  z-index: 2;
}
section .image.through .pattern {
  position: absolute;
  z-index: 1;
  width: 200%;
  height: auto;
}
section .image.i_left {
  bottom: auto;
  top: 0;
}
section .team {
  height: 100%;
  display: block;
}
section .team > div {
  width: 33.33333%;
  height: 33.33333%;
  float: left;
  position: static;
  margin: 0;
  padding: 0;
  position: relative;
}
section .team > div img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  transition: all 0.5s ease;
  filter: grayscale(1);
  left: 0;
  top: 0;
}
section .team > div .info {
  display: none;
  position: absolute;
  width: 100%;
  min-height: 50%;
  bottom: 0;
  left: 0;
  z-index: 10;
  padding: 1.5vw;
  transition: all 0.5s ease;
  color: black;
  background: white;
}
section .team > div .info button {
  bottom: -0.65vw;
}
section .team > div:hover img {
  width: 300%;
  height: 200%;
  position: absolute;
  pointer-events: none;
  left: 0%;
  top: -150%;
  z-index: 9;
}
section .team > div:hover .info {
  display: inline-block;
}
section .team > div:nth-child(3n+2):hover img {
  left: -100%;
}
section .team > div:nth-child(3n):hover img {
  left: auto;
  right: 0;
}
section .team > div button {
  position: relative;
  right: 0;
}

form {
  background: white;
  display: inline-block;
  width: 100%;
  padding: 3vw;
  padding: calc(3vw - 0.3125rem) 3vw 3vw 3vw;
}
form input, form textarea {
  border-radius: none;
  border: 0.0625rem solid #570F17;
  padding: 0.0625rem;
}
form textarea, form button, form input {
  width: 100%;
}
form textarea {
  resize: vertical;
}
form label {
  display: none;
}
form label:first-child {
  margin-top: -10%;
}
form button {
  margin-top: 0.3125rem;
}
form > p {
  width: calc(50% - 1.5vw);
  float: left;
  margin: 0.3125rem 0 0 0;
  margin-right: 3vw;
  position: relative;
}
form > p:nth-child(2n+2) {
  margin-right: 0;
}

#pattern {
  position: fixed;
  z-index: 30;
  pointer-events: none;
  top: -0.425vw;
  width: 100%;
  height: 100%;
  background-image: -webkit-gradient(linear, left bottom, left top, color-stop(1.55%, #ffffff), color-stop(1.55%, transparent), color-stop(50%, transparent), color-stop(50%, #ffffff), color-stop(51.55%, #ffffff), color-stop(51.55%, transparent), to(transparent));
  background-image: linear-gradient(0deg, #ffffff 1.55%, transparent 1.55%, transparent 50%, #ffffff 50%, #ffffff 51.55%, transparent 51.55%, transparent 100%);
  background-size: 2.75rem 2.75rem;
  opacity: 0.25;
  display: none;
}

footer {
  position: relative;
}
footer section {
  margin-bottom: 66.66666%;
  /* :after{
       content: "";
       position: absolute;
       bottom: 0;
       left: 0;
       width: 100%;
       height: 0.0625rem;
       background: black;
   }*/
}
footer section .text > div {
  width: 100%;
  color: #570F17;
  line-height: 200%;
}
footer section .image {
  bottom: 0.0625rem;
}
footer nav {
  position: absolute;
  z-index: 7777;
  top: 100%;
  width: 100%;
  min-height: 16.66666%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
footer nav > div {
  width: 100%;
  display: inline-block;
}
footer nav a {
  color: white;
  text-decoration: none;
  width: 100%;
  text-align: center;
  padding: 3%;
  float: left;
}
footer#mapfooter nav {
  top: 125%;
}
footer .to-top {
  position: fixed;
  z-index: 99999;
  width: 3rem;
  height: 3rem;
  bottom: calc(8.3333vw - 1.5rem);
  right: calc(8.3333vw - 1.5rem);
  pointer-events: none;
  opacity: 0;
  transition: all 1s ease;
  font-size: 0;
  padding: 0;
}
footer .to-top.show {
  opacity: 1;
  pointer-events: all;
}
footer .to-top:after {
  content: "";
  display: inline-block;
  width: 1.25rem;
  height: 1.25rem;
  -webkit-transform: rotate(45deg);
  transform: rotate(-45deg);
  border: 0.0625rem solid white;
  border-width: 0.0625rem 0.0625rem 0 0;
  position: relative;
  left: 0;
  top: 0.4375rem;
}

#map {
  position: absolute;
  width: 66.66666%;
  min-height: calc(100vw - 1.0625rem);
  right: 0;
  top: 0;
  display: inline-block;
}

@media all and (min-width: 30rem) {
  form {
    width: 66.66666%;
    margin-left: 33.33333%;
  }
  form input, form textarea {
    padding: 0.5rem;
  }
  form input::placeholder, form textarea::placeholder {
    color: white;
  }
  form textarea {
    resize: vertical;
    min-height: 8vw;
  }
  form button {
    margin-top: 1.5vw;
  }
  form label {
    display: initial;
  }
  form > p {
    margin-top: 1.5vw;
  }
  footer section .text > div {
    width: 66.66666%;
  }
}
@media all and (min-width: 68.75rem) {
  header #menutoggle {
    display: none;
  }
  header nav {
    position: relative;
    float: right;
    padding-top: 0;
    min-height: inherit;
    width: auto;
    box-shadow: none;
    right: 0;
  }
  header nav a {
    padding: 3.5vw 3vw;
    position: relative;
  }
  header nav a:after {
    content: "";
    position: absolute;
    width: 1.25rem;
    height: 0.3125rem;
    background: #570F17;
    top: 3vw;
    left: 3vw;
    opacity: 0;
    transition: all 0.33s ease;
  }
  header nav a:hover:after {
    opacity: 1;
  }
  header nav a.selected {
    font-weight: 400;
  }
  header nav a.selected:after {
    opacity: 1;
    width: calc(100% - 6vw);
    background: black;
    transition: all 1s ease;
  }
  header nav a.selected:hover:after {
    width: 2.5rem;
    background: #570F17;
  }
  header nav div {
    float: left;
  }
}
@media all and (min-width: 75rem) {
  * {
    font-size: 1.5rem;
  }
  h1, h2 {
    font-size: 7.4vw;
    padding: 1.5vw;
  }
  header {
    height: 6.33vw;
    top: 0.0625rem;
  }
  header #menutoggle {
    top: calc(3.1666vw - 1rem);
    right: 3vw;
  }
  header nav a {
    padding: 0.5vw 3vw;
  }
  body {
    background-size: 100% auto;
    background-position: 0 6.33vw;
    margin-top: -0.0625rem;
  }
  section {
    width: 100%;
  }
  section > div {
    width: 50%;
    height: 100%;
    float: left;
  }
  section .image {
    left: calc(50% - 0.0625rem);
    bottom: 0;
    width: calc(50% + 0.0625rem);
    height: 100%;
  }
  section .image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  section .image.through .pattern {
    width: 100%;
    height: 100%;
  }
  section .headline.h_top {
    background: url(../img/bg/bg.svg);
    background-size: 100% auto;
    background-position: 0 0;
  }
  section .headline.h_top h1, section .headline.h_top h2 {
    padding: 0;
  }
  section .headline.h_top.offset_1 {
    margin-left: 16.66666%;
  }
  section .headline.h_top.offset_2 {
    margin-left: 33.33333%;
  }
  section .headline.h_top.offset_3 {
    margin-left: 50%;
  }
  section .headline.h_top.offset_4 {
    margin-left: 66.66666%;
  }
  section .headline.h_2x1, section .headline .h_3x1, section .headline .h_4x1, section .headline .h_5x1, section .headline .h_6x1 {
    height: 33.33333%;
  }
  section .headline.h_2x2, section .headline .h_3x2 {
    height: 66.66666%;
  }
  section .headline.h_2x1 {
    width: 33.33333%;
    background-size: 300% auto;
  }
  section .headline.h_3x1 {
    width: 50%;
    background-size: 200% auto;
  }
  section .headline.h_4x1 {
    width: 66.66666%;
    background-size: 150% auto;
  }
  section .headline.h_5x1 {
    width: 83.3333%;
    background-size: 120% auto;
  }
  section .headline.h_6x1 {
    width: 100%;
    background-size: 100% auto;
  }
  section .text {
    max-height: 66.666%;
  }
  section .text > div button {
    bottom: -1.3vw;
  }
  section .text.t_1-6 {
    width: 16.666%;
  }
  section .text.t_3-6 {
    width: 50%;
  }
  section.switched_layout > div {
    float: right;
  }
  section.h_2-6 .headline {
    width: 33.33333%;
  }
  section.h_4-6 .headline {
    width: 66.66666%;
  }
  section.h_4-6 .text {
    width: 33.33333%;
  }
  section.h_4-6 .text > div {
    width: 100%;
  }
  section .image.i_full {
    width: 100%;
    left: 0;
    height: 100% !important;
  }
  section .image.i_left {
    left: 0;
    width: calc(50% - 0rem);
  }
  section .team {
    position: absolute;
    max-height: inherit;
    width: 100%;
  }
  section .team > div {
    width: 16.66666%;
    /*&:hover, &:nth-child(3n):hover{ 
        img{
            width: 200%;
            height: 200%;
            top: auto;
            bottom: 0;
            left:0;
            right: auto;
        }
        .info{
            width: 100%;
            height: 100%;
            top: auto;
            bottom: 0;
            left:0;
            right: auto;
        }
    }*/
  }
  section .team > div.offset_1r {
    margin-right: 16.66666%;
  }
  section .team > div.offset_2r {
    margin-right: 33.33333%;
  }
  section .team > div.offset_3r {
    margin-right: 50%;
  }
  section .team > div.offset_4r {
    margin-right: 66.66666%;
  }
  section .team > div.offset_5r {
    margin-right: 83.33333%;
  }
  section .team > div.offset_1l {
    margin-left: 16.66666%;
  }
  section .team > div.offset_2l {
    margin-left: 33.33333%;
  }
  section .team > div.offset_3l {
    margin-left: 50%;
  }
  section .team > div.offset_4l {
    margin-left: 66.66666%;
  }
  section .team > div.offset_5l {
    margin-left: 83.33333%;
  }
  section .team > div:hover img {
    left: 0 !important;
  }
  footer section {
    margin-bottom: 0;
  }
  footer section .text > div {
    width: 100%;
  }
  footer nav {
    bottom: 0;
    width: 100%;
    top: auto;
    height: auto;
    display: inline-block;
  }
  footer nav a {
    display: inline-block;
    width: 16.66666%;
    text-align: center;
  }
  footer#mapfooter nav {
    top: auto;
  }
  footer#mapfooter nav a {
    color: #023B57;
  }
  form {
    width: 50%;
    margin-left: 0;
    padding: calc(3vw - 0.9375rem) 3vw 3vw 3vw;
  }
  form button {
    margin-top: 1.5vw;
  }
  form label {
    font-size: 75%;
  }
  form > p {
    margin-top: 0;
  }
  #map {
    min-height: 42vw;
  }
  .team-section, .team-section + footer {
    width: 100%;
    float: left;
  }
}
@media all and (min-width: 87.5rem) {
  form {
    width: 33.33333%;
    margin-left: 16.66666%;
  }
  form > p {
    margin-top: 0.75vw;
  }
}
@media all and (min-width: 100rem) {
  footer section .text > div {
    width: 66.66666%;
  }
}
@media screen and (-ms-high-contrast: active), screen and (-ms-high-contrast: none) {
  body {
    background: none;
  }
  body * {
    display: none;
  }
  body:before {
    content: "Sie benutzen einen veralteten Browser. Wenn Sie diese Seite ohne Einschränkungen geniessen möchten empfehlen wir Ihnen einen modernen Browser zu nutzen.";
    text-align: center;
    font-size: 6vw;
    padding: 10vh 10vw;
    display: inline-block;
  }
}

/*# sourceMappingURL=style.css.map */
