/* Grid
-------------------------------------------------------------------------------*/
/* Overflow-X prevents the horizontal scrollbar to mess up the slider resize*/
.grid-inner {
  max-width: 1180px;
  margin: 0 auto; }

.col1, .col2, .col3, .col4, .col5, .col6, .col7, .col8, .col9, .col10, .col11, .col12 {
  float: left;
  margin: 0 3% 0 0; }

.col1.last, .col2.last, .col3.last, .col4.last, .col5.last, .col6.last, .col7.last, .col8.last, .col9.last, .col10.last, .col11.last, .col12 {
  margin: 0; }

.col1 {
  width: 5.5%; }

.col2 {
  width: 14%; }

.col3 {
  width: 22.5%; }

.col4 {
  width: 31.3%; }

.col5 {
  width: 39.5%; }

.col6 {
  width: 48%; }

.col7 {
  width: 56.5%; }

.col8 {
  width: 65%; }

.col9 {
  width: 73.5%; }

.col10 {
  width: 82%; }

.col11 {
  width: 90.5%; }

.col12 {
  width: 99%;
  margin: 0; }

/* Variables
-------------------------------------------------------------------------------*/
/*$col-black: #282121;*/
/* General
-------------------------------------------------------------------------------*/
body {
  font-family: 'Roboto', sans-serif;
  color: #000000; }

h1 {
  font-size: 3em;
  margin-bottom: 100px;
  font-weight: 700; }

h2 {
  font-size: 2em;
  margin-bottom: 50px;
  font-weight: 700; }

h3 {
  font-size: 1.2em;
  line-height: 1.3em;
  margin: 0;
  font-weight: 700; }

ul li {
  margin: 0 0 1.5em 0; }

ul li:last-child {
  margin-bottom: 0; }

ul li, p {
  font-size: 1.5em; }

.frontpage-element {
  width: 100%; }

.content {
  width: 100%;
  padding: 120px 67px 120px 100px;
  overflow: hidden; }
  .content.small {
    min-height: 300px;
    padding: 40px 100px; }
    .content.small h1 {
      margin-bottom: 0; }

.spaced {
  margin: 2rem auto; }

.col-red {
  color: #e94550;
  font-weight: inherit; }

.background-black {
  background-color: #000000; }

.relative {
  position: relative; }

.align-center {
  text-align: center; }

.block {
  display: block; }

/* Slogan
-------------------------------------------------------------------------------*/
.slogan-wrapper {
  width: 100%;
  position: relative;
  height: 100vh; }
  .slogan-wrapper .slogan {
    height: auto;
    width: 50%;
    max-height: 311px;
    overflow: hidden;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%); }
    .slogan-wrapper .slogan img {
      max-width: 100%;
      display: block;
      margin: 0 auto;
      z-index: 20; }

/* Second element
-------------------------------------------------------------------------------*/
.text-border {
  border-left: 30px solid #e94550;
  padding-left: 60px; }

.text-border h1 {
  margin-top: -5px; }

#slideToggler > ul > li:hover {
  cursor: pointer; }

#slideToggler li .fake {
  width: 9px;
  height: 5px;
  background: url("../images/caret_down.png") no-repeat center;
  background-size: 9px 5px;
  vertical-align: middle;
  margin-left: 10px; }

#slideToggler li.open .fake {
  background: none; }

#slideToggler > ul > li.open::after {
  display: none; }

#slideToggler li:hover {
  color: #e94550; }

#slideToggler li.open {
  color: #e94550; }

/* Second list level */
ul li div.hidden-content {
  display: none;
  list-style: disc;
  font-size: 0.75rem;
  /*height: 100%; /* This avoids 'jumping' when toggling */
  cursor: default;
  color: #000000;
  line-height: 1.7rem; }
  ul li div.hidden-content div {
    padding: 15px 0;
    height: 100%; }
  ul li div.hidden-content ul {
    list-style-type: disc;
    margin-left: 1.5em;
    margin-bottom: 1.5em;
    margin-top: 1.5em; }

ul li ul li:hover {
  color: #000000 !important; }

/* Third element
-------------------------------------------------------------------------------*/
.slowmo-container {
  position: relative; }
  .slowmo-container #logo-with-subheading {
    width: 45%;
    margin-top: 20%; }
  .slowmo-container .content {
    margin-left: 10%;
    width: 38%;
    padding: 0;
    position: absolute;
    top: 0;
    font-size: 1.6vw;
    line-height: 2.6vw; }
  .slowmo-container .subtitle-logo {
    margin-top: 5px;
    margin-bottom: 7%;
    line-height: 1.9em;
    font-size: 0.7em; }
    .slowmo-container .subtitle-logo h3 {
      font-weight: 500; }
  .slowmo-container p {
    hyphens: auto;
    line-height: 1.5em;
    margin-bottom: 115px;
    font-size: 1.0em; }

.slowmo-video {
  width: 100%;
  height: auto;
  /*Otherwise we would have a small white margin at the bottom*/
  display: block; }

/* Forth element
-------------------------------------------------------------------------------*/
#content-quote {
  position: relative; }

.quote-container {
  position: relative;
  display: inline-block;
  margin: 0 auto;
  margin-bottom: 170px;
  margin-top: 170px; }

.quote {
  padding: 0 100px;
  font-size: 3.158em;
  margin-bottom: 0;
  color: #000; }

.quote-container:before {
  content: "\201e";
  font-family: Arial, sans-serif;
  font-size: 9em;
  position: absolute;
  bottom: -21px;
  font-weight: 700;
  color: #000;
  left: 0; }

.quote-container:after {
  content: "\201c";
  font-family: Arial, sans-serif;
  font-size: 9em;
  position: absolute;
  right: 0;
  top: -45px;
  font-weight: 700;
  color: #000; }

.button-container {
  position: absolute;
  bottom: 48px;
  width: 35%;
  border-bottom: 31px solid #e94550;
  padding-bottom: 16px; }

.buttons {
  float: right;
  padding-top: 65%; }

.button {
  /* todo Color */
  border: 1px solid rgba(206, 208, 209, 0.3);
  border-radius: 1px;
  box-shadow: 0 -1px 1px rgba(229, 230, 230, 0.3);
  /* todo */
  background-color: #ffffff;
  /*background-color: rgba(43, 64, 93, 0.3);*/
  display: block;
  cursor: pointer;
  margin: 16px 0;
  padding: 0 28px 0 20px;
  height: 70px;
  position: relative;
  /* Needed for center the icons insde the button */ }

.button:hover {
  border: 1px solid rgba(206, 208, 209, 0.7);
  border-radius: 1px;
  box-shadow: 0 -1px 1px rgba(229, 230, 230, 0.7);
  /* todo */
  background-color: rgba(206, 208, 209, 0.7); }

.button img {
  /* Center icons ion button */
  position: absolute;
  top: 50%;
  transform: translateY(-50%); }

.button a {
  margin-left: 40px;
  font-size: 1.5em;
  line-height: 2.9em;
  text-decoration: none;
  color: #000000; }

#icon-call {
  /* This icon is bigger than the mail icon. Add padding to align them correct */
  margin-left: 5px; }

#line-red {
  height: 31px;
  width: 47%;
  background-color: #e94550;
  position: absolute;
  left: 0;
  bottom: -66px; }

/* Footer
-------------------------------------------------------------------------------*/
.footer {
  width: 100%;
  color: white;
  text-align: center;
  padding: 14px 15px;
  font-size: 0.9em;
  line-height: 1.6em; }
  .footer span.dot {
    margin: 0 10px; }
  .footer br.break1, .footer br.break2 {
    display: none; }
  .footer a {
    display: inline;
    text-decoration: none;
    color: white; }
    .footer a:hover {
      color: #e94550; }

.footer-impressum {
  width: 75%;
  padding: 5.0rem 0 4.0rem; }
  .footer-impressum h3 {
    margin-bottom: 10px;
    color: #c5c5c5; }
  .footer-impressum p {
    color: #c0c0c0;
    font-size: 0.9rem; }

.button-label-desktop {
  display: inline; }

.button-label-mobile {
  display: none; }

/* Mr. Uno
-------------------------------------------------------------------------------*/
.mr-uno {
  pointer-events: none;
  position: fixed;
  min-height: 280px;
  right: 0;
  bottom: 0;
  opacity: 0;
  background-color: #ffffff;
  padding: 24px 0 0 24px;
  font-family: 'Indie Flower', cursive;
  width: 705px;
  height: auto;
  font-size: 0.8em;
  background-image: url(/assets/images/outline.svg);
  background-repeat: no-repeat;
  background-size: 110%;
  -webkit-transition: all 0.5s ease-in-out;
  -moz-transition: all 0.5s ease-in-out;
  -o-transition: all 0.5s ease-in-out;
  -ms-transition: all 0.5s ease-in-out;
  transition: all 0.5s ease-in-out; }
  .mr-uno .text {
    width: 63%;
    float: left;
    margin-top: 24px; }
    .mr-uno .text p {
      margin-bottom: 24px; }
  .mr-uno .animation {
    /*width: 100%;*/
    /*width: 288px;
    height: 288px;
    width: 45%;*/
    width: 37%;
    float: left;
    position: relative;
    /*position: absolute;
    right: 0;
    bottom: 0;*/ }
  .mr-uno .stage {
    -webkit-transform: scale(0.52) !important;
    -moz-transform: scale(0.52) !important;
    -ms-transform: scale(0.52) !important;
    -o-transform: scale(0.52) !important;
    transform: scale(0.52) !important; }
  .mr-uno .close {
    pointer-events: auto;
    position: absolute;
    top: 12px;
    right: 12px; }
    .mr-uno .close img {
      width: 20px; }

/* Privacy
-------------------------------------------------------------------------------*/
.privacy-statement {
  font-size: 17px;
  float: none;
  width: 82%;
  margin: 24px auto; }
  .privacy-statement h2 {
    font-size: 2.4em;
    margin-bottom: 32px; }
  .privacy-statement h3 {
    font-size: 1.4em;
    margin-bottom: 24px; }
  .privacy-statement h4 {
    font-weight: bold; }
  .privacy-statement ul, .privacy-statement li, .privacy-statement p {
    font-size: 1em !important; }
  .privacy-statement li, .privacy-statement p {
    line-height: 1.6em;
    margin-bottom: 1em; }

/* Responsive
-------------------------------------------------------------------------------*/
@media screen and (max-width: 1180px) {
  .footer {
    font-size: 0.8em; } }
@media screen and (max-width: 920px) {
  .quote-container {
    display: block; }

  .quote {
    padding: 0 14%;
    font-size: 5.6vw;
    margin: 30% 0; }

  .quote-container:before, .quote-container:after {
    font-size: 16vw;
    line-height: 1em; }

  .quote-container {
    margin: 0; }

  .quote-container:before {
    left: 7%;
    bottom: -10%; }

  .quote-container:after {
    right: 7%;
    top: -30%; }

  .footer span.break1 {
    display: none; }
  .footer br.break1 {
    display: block; }

  .button-container {
    width: 42%; }

  .button {
    height: 44px; }
    .button a {
      font-size: 1em;
      height: 35px; }

  .button-label-desktop {
    display: none; }

  .button-label-mobile {
    display: inline; }

  .mr-uno {
    width: 550px;
    height: auto; }
    .mr-uno .text {
      width: 55%; }
    .mr-uno .animation {
      width: 45%; }

  .stage {
    -webkit-transform: scale(0.48) !important;
    -moz-transform: scale(0.48) !important;
    -ms-transform: scale(0.48) !important;
    -o-transform: scale(0.48) !important;
    transform: scale(0.48) !important; } }
@media screen and (max-width: 816px) {
  .slogan-wrapper .slogan {
    width: 72%; }

  .slowmo-container .content {
    width: 60%;
    font-size: 3vw;
    line-height: 4.5vw; }

  .content {
    padding: 95px 8%; }

  .text-border {
    padding-left: 8%; }

  .text-border h1 {
    font-size: 2.2em;
    margin-bottom: 60px; }

  ul li, p {
    font-size: 1.3em; } }
@media screen and (max-width: 580px) {
  .button-container {
    width: 64%;
    padding-bottom: 8px;
    right: 0;
    border-bottom: 23px solid #e94550; }
    .button-container .buttons {
      margin-right: 8px; }
    .button-container .button {
      margin-bottom: 8px; }

  .footer {
    font-size: 1em; }
    .footer span.dot {
      display: none; }
    .footer br.break2 {
      display: block; }

  .mr-uno {
    width: 101%; }
    .mr-uno .text {
      margin-top: 8px;
      width: 55%; }
    .mr-uno .animation {
      width: 45%; }
    .mr-uno .stage {
      -webkit-transform: scale(0.4) !important;
      -moz-transform: scale(0.4) !important;
      -ms-transform: scale(0.4) !important;
      -o-transform: scale(0.4) !important;
      transform: scale(0.4) !important; } }
@media screen and (max-width: 500px) {
  .text-border {
    border-left: 20px solid #e94550; }
    .text-border h1 {
      font-size: 2em; }
      .text-border h1 br {
        display: none; }

  ul li, p {
    font-size: 1em; } }
@media screen and (max-width: 400px) {
  .mr-uno .stage {
    -webkit-transform: scale(0.34) !important;
    -moz-transform: scale(0.34) !important;
    -ms-transform: scale(0.34) !important;
    -o-transform: scale(0.34) !important;
    transform: scale(0.34) !important; } }

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