html, body {
  margin: 0;
  padding: 0;
  overflow: hidden; }

.clearfix {
  clear: both; }

.centered {
  text-align: center; }

.centered-img {
  margin-left: auto;
  margin-right: auto;
  display: block; }

#mainPage {
  position: absolute;
  height: 100%;
  width: 100%;
  overflow: hidden;
  transition: -webkit-filter 400ms, filter 400ms;
  -webkit-filter: grayscale(0%);
          filter: grayscale(0%); }
  #mainPage.off {
    -webkit-filter: grayscale(100%);
            filter: grayscale(100%); }
  #mainPage .section {
    height: 100%;
    width: 100%;
    position: absolute;
    background: #fff;
    box-shadow: -3px 0 10px 0 rgba(0, 0, 0, 0.3);
    -ms-background-size: cover;
    background-size: cover;
    background-position: top center;
    overflow-x: hidden;
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
    -webkit-transition: 500ms;
    transition: 500ms; }
    #mainPage .section .section-title {
      width: 40px;
      height: 100%;
      color: white;
      cursor: pointer;
      -webkit-user-select: none;
      -ms-box-sizing: border-box;
      -o-box-sizing: border-box;
      box-sizing: border-box;
      padding-left: 3px;
      box-shadow: -5px 0 10px 0 rgba(0, 0, 0, 0.2);
      position: fixed;
      z-index: 100; }
      #mainPage .section .section-title h2 {
        font-family: 'Playfair Display SC', serif;
        font-size: 20px;
        margin: 0;
        padding: 0;
        position: absolute;
        margin-top: 40px;
        width: 200px;
        -webkit-transform: rotate(-90deg) translateX(-50px);
        -ms-transform: rotate(-90deg) translateX(-50px);
        transform: rotate(-90deg) translateX(-50px);
        -webkit-transform-origin: 0 0;
        -ms-transform-origin: 0 0;
        transform-origin: 0 0; }
    #mainPage .section .sectionBody {
      width: 40%;
      height: 100%;
      position: absolute;
      top: 0;
      left: 0;
      z-index: 50;
      -webkit-overflow-scrolling: touch;
      left: 7%;
      padding-top: 40px;
      padding-bottom: 40px;
      font-size: 14px; }
      #mainPage .section .sectionBody .content {
        width: 100%;
        font-family: 'Playfair Display';
        line-height: 180%;
        padding: 30px;
        background-color: rgba(255, 255, 250, 0.9);
        box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.4); }
        #mainPage .section .sectionBody .content h3 {
          border-bottom: 3px solid rgba(147, 184, 211, 0.9);
          margin-left: -10px;
          margin-right: -10px;
          padding-left: 10px;
          font-size: 30px;
          line-height: initial;
          font-weight: 100;
          margin-top: 0;
          color: #353535; }
        #mainPage .section .sectionBody .content .textlink {
          text-decoration: underline;
          font-size: inherit;
          display: inline-block;
          margin-top: 20px;
          font-weight: bold;
          color: #4b89b5; }
          #mainPage .section .sectionBody .content .textlink:hover {
            opacity: 0.8; }
  #mainPage #section1 {
    left: 0;
    top: 0;
    z-index: 1;
    width: 100%;
    background-image: url("../img/hero.jpg"); }
    #mainPage #section1.rt43 {
      background-position: calc(50% + 20%) center; }
    #mainPage #section1 .section-title {
      background-color: white;
      color: #343434;
      box-shadow: 5px 0 10px 0 rgba(0, 0, 0, 0.2); }
    #mainPage #section1 .sectionBody {
      width: 40%;
      height: initial;
      left: 7%;
      padding-top: 10%;
      max-width: 600px; }
      #mainPage #section1 .sectionBody .content {
        width: 100%;
        font-family: 'Playfair Display';
        line-height: 180%;
        padding: 30px;
        background-color: rgba(255, 255, 250, 0.8);
        box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.4);
        box-sizing: border-box; }
        #mainPage #section1 .sectionBody .content p.bold {
          font-weight: bold; }
        #mainPage #section1 .sectionBody .content p:first-child {
          margin-top: 0; }
    #mainPage #section1 .hero {
      width: 100%;
      height: 100%; }
      #mainPage #section1 .hero .logo {
        width: 100%;
        width: calc(100% + 40px);
        background: url("../img/logo.png");
        -ms-background-size: cover;
        background-size: cover;
        background-position: 0 0;
        position: initial;
        margin-bottom: 40px;
        margin-left: -20px;
        margin-right: -20px; }
        #mainPage #section1 .hero .logo:after {
          content: '';
          display: block;
          padding-top: 16.04%; }
        @media screen and (max-width: 1120px) {
          #mainPage #section1 .hero .logo {
            margin-left: 0px;
            margin-right: 0px;
            width: 100%; } }
      #mainPage #section1 .hero .navigation {
        position: absolute;
        left: 7%;
        top: 40%;
        border-radius: 5px;
        border: 1px solid #b4b4b4;
        background: #4b89b5; }
        #mainPage #section1 .hero .navigation ul {
          padding: 0;
          margin: 0; }
          #mainPage #section1 .hero .navigation ul li {
            float: left;
            list-style: none;
            font-family: 'Playfair Display SC', serif;
            padding: 10px 20px;
            border-right: 1px solid rgba(0, 0, 0, 0.1);
            color: #343434;
            /* FF3.6+ */
            background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, white), color-stop(100%, gainsboro));
            /* Chrome,Safari4+ */
            background: -webkit-linear-gradient(top, white 0%, gainsboro 100%);
            /* Chrome10+,Safari5.1+ */
            /* Opera 11.10+ */
            /* IE10+ */
            background: linear-gradient(to bottom, white 0%, gainsboro 100%);
            /* W3C */
            -webkit-transition: opacity 500ms;
            transition: opacity 500ms; }
            #mainPage #section1 .hero .navigation ul li:first-child {
              margin-left: 0;
              border-radius: 4px 0 0 3px; }
            #mainPage #section1 .hero .navigation ul li:last-child {
              border: none;
              border-radius: 0 3px 3px 0; }
            #mainPage #section1 .hero .navigation ul li:hover {
              opacity: 0.8;
              cursor: pointer; }
  #mainPage #section2 {
    right: 80px;
    top: 0;
    z-index: 2;
    background-image: url("../img/bg-section-mandate.jpg"); }
    #mainPage #section2 .section-title {
      padding-top: 34px;
      /* FF3.6+ */
      background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, rgba(147, 184, 211, 0.9)), color-stop(100%, rgba(147, 184, 211, 0.4)));
      /* Chrome,Safari4+ */
      background: -webkit-linear-gradient(top, rgba(147, 184, 211, 0.9) 0%, rgba(147, 184, 211, 0.4) 100%);
      /* Chrome10+,Safari5.1+ */
      /* Opera 11.10+ */
      /* IE10+ */
      background: linear-gradient(to bottom, rgba(147, 184, 211, 0.9) 0%, rgba(147, 184, 211, 0.4) 100%);
      /* W3C */ }
    #mainPage #section2.active {
      right: -40px; }
    #mainPage #section2 .sectionBody {
      width: 80%;
      height: initial;
      left: 7%;
      padding-top: 30px;
      max-width: 1000px;
      padding-bottom: 50px; }
      #mainPage #section2 .sectionBody .content {
        width: 100%;
        font-family: 'Playfair Display';
        line-height: 180%;
        padding: 30px;
        background-color: rgba(255, 255, 250, 0.8);
        box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.4); }
        #mainPage #section2 .sectionBody .content h3 {
          border-bottom: 3px solid rgba(147, 184, 211, 0.9);
          margin-left: -10px;
          margin-right: -10px;
          padding-left: 10px;
          font-size: 30px;
          line-height: initial;
          font-weight: 100;
          margin-top: 30px;
          color: #353535; }
          #mainPage #section2 .sectionBody .content h3:first-child {
            margin-top: 0; }
        #mainPage #section2 .sectionBody .content .mandate tr:nth-child(2n) {
          background-color: rgba(255, 255, 255, 0.7); }
        #mainPage #section2 .sectionBody .content .mandate td {
          padding: 10px; }
          #mainPage #section2 .sectionBody .content .mandate td:first-child {
            padding-left: 20px; }
          #mainPage #section2 .sectionBody .content .mandate td:last-child {
            padding-right: 20px; }
          #mainPage #section2 .sectionBody .content .mandate td .sublist {
            margin: 0;
            padding: 0;
            white-space: nowrap; }
            #mainPage #section2 .sectionBody .content .mandate td .sublist li {
              line-height: 110%;
              font-size: 90%;
              list-style-position: inside;
              list-style-type: none;
              color: #646464; }
            #mainPage #section2 .sectionBody .content .mandate td .sublist li:before {
              content: "- ";
              font-weight: bold;
              color: rgba(147, 184, 211, 0.9);
              /* or whatever color you prefer */ }
        #mainPage #section2 .sectionBody .content .mandate .logo {
          width: 100px; }
        #mainPage #section2 .sectionBody .content .mandate .ort {
          display: block;
          font-size: 90%;
          line-height: 110%;
          font-style: italic;
          color: #646464; }
  #mainPage #section3 {
    right: 40px;
    top: 0;
    z-index: 3;
    background-image: url("../img/bg-section-proffessur.jpg"); }
    #mainPage #section3 .section-title {
      padding-top: 81px;
      /* FF3.6+ */
      background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, rgba(111, 161, 196, 0.9)), color-stop(100%, rgba(111, 161, 196, 0.4)));
      /* Chrome,Safari4+ */
      background: -webkit-linear-gradient(top, rgba(111, 161, 196, 0.9) 0%, rgba(111, 161, 196, 0.4) 100%);
      /* Chrome10+,Safari5.1+ */
      /* Opera 11.10+ */
      /* IE10+ */
      background: linear-gradient(to bottom, rgba(111, 161, 196, 0.9) 0%, rgba(111, 161, 196, 0.4) 100%);
      /* W3C */ }
    #mainPage #section3 .sectionBody {
      width: 40%;
      height: initial;
      left: 7%;
      padding-top: 30px;
      max-width: 600px;
      padding-bottom: 50px; }
      #mainPage #section3 .sectionBody .content h3 {
        border-bottom: 3px solid rgba(111, 161, 196, 0.9); }
  #mainPage #section4 {
    right: 0;
    top: 0;
    z-index: 4;
    background-image: url("../img/bg-section-consulting.jpg"); }
    #mainPage #section4 .section-title {
      padding-top: 66px;
      /* FF3.6+ */
      background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, rgba(75, 137, 181, 0.9)), color-stop(100%, rgba(75, 137, 181, 0.4)));
      /* Chrome,Safari4+ */
      background: -webkit-linear-gradient(top, rgba(75, 137, 181, 0.9) 0%, rgba(75, 137, 181, 0.4) 100%);
      /* Chrome10+,Safari5.1+ */
      /* Opera 11.10+ */
      /* IE10+ */
      background: linear-gradient(to bottom, rgba(75, 137, 181, 0.9) 0%, rgba(75, 137, 181, 0.4) 100%);
      /* W3C */ }
    #mainPage #section4 .sectionBody .content h3 {
      border-bottom: 3px solid rgba(75, 137, 181, 0.9); }

.footer {
  position: absolute;
  bottom: 0;
  width: 100%;
  box-sizing: border-box;
  z-index: 10;
  padding: 5px;
  text-align: center;
  background-color: rgba(250, 250, 250, 0.8);
  color: #646464; }
  .footer:after {
    content: "";
    clear: both;
    display: block; }
  .footer .linklist {
    margin: 0;
    padding: 0;
    float: right; }
    .footer .linklist li {
      float: left;
      list-style: none;
      margin-right: 40px;
      cursor: pointer; }
    .footer .linklist:after {
      content: "";
      clear: both;
      display: block; }

.overlay {
  opacity: 0;
  position: fixed;
  background-color: rgba(0, 0, 0, 0.7);
  z-index: -1;
  -webkit-transition: opacity 400ms;
  transition: opacity 400ms;
  padding-bottom: 100px;
  overflow: auto; }
  .overlay.on {
    z-index: 999;
    opacity: 1;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0; }
  .overlay .info-layer {
    position: relative;
    margin-top: 100px;
    opacity: 0;
    left: -400px;
    -webkit-transition: opacity 400ms;
    transition: opacity 400ms;
    padding: 30px;
    box-sizing: border-box; }
    .overlay .info-layer.on {
      left: 0;
      right: 0;
      margin-left: auto;
      margin-right: auto;
      width: 600px;
      background-color: #FFFFFF;
      z-index: 1000;
      opacity: 1; }
    .overlay .info-layer h3 {
      font-family: 'Playfair Display';
      border-bottom: 3px solid rgba(147, 184, 211, 0.9);
      margin-left: -10px;
      margin-right: -10px;
      padding-left: 10px;
      font-size: 30px;
      line-height: initial;
      font-weight: 100;
      margin-top: 0;
      color: #353535; }
    .overlay .info-layer .close {
      width: 30px;
      height: 30px;
      border: 2px solid white;
      background-color: black;
      border-radius: 50%;
      position: absolute;
      top: -15px;
      right: -15px;
      box-shadow: 0 0 20px 0 rgba(0, 0, 0, 0.7);
      -webkit-transform: rotate(45deg);
          -ms-transform: rotate(45deg);
              transform: rotate(45deg);
      cursor: pointer; }
      .overlay .info-layer .close span {
        position: absolute;
        display: block;
        color: white;
        font-size: 40px;
        line-height: 100%;
        top: -8px;
        left: 3.5px; }
    .overlay .info-layer .contact {
      display: none; }
      .overlay .info-layer .contact.on {
        display: block; }
      .overlay .info-layer .contact label {
        font-family: 'Playfair Display';
        font-size: 16px;
        margin-top: 30px;
        margin-bottom: 5px;
        display: block; }
      .overlay .info-layer .contact input {
        display: block;
        width: 100%;
        padding: 10px 10px;
        border-radius: 3px;
        border: 1px solid rgba(150, 150, 150, 0.8);
        box-sizing: border-box;
        font-size: 14px; }
      .overlay .info-layer .contact textarea {
        display: block;
        width: 100%;
        height: 150px;
        padding: 10px 10px;
        border-radius: 3px;
        border: 1px solid rgba(150, 150, 150, 0.8);
        box-sizing: border-box;
        font-size: 14px; }
      .overlay .info-layer .contact .btn {
        border-radius: 4px;
        border: none;
        font-family: Arial;
        color: #ffffff;
        font-size: 20px;
        background: #93b8d3;
        padding: 10px 40px 10px 40px;
        text-decoration: none;
        font-family: 'Playfair Display';
        cursor: pointer;
        margin-top: 30px;
        float: right; }
      .overlay .info-layer .contact .btn:hover {
        background: #82a3ba;
        text-decoration: none; }
    .overlay .info-layer .imprint {
      display: none; }
      .overlay .info-layer .imprint.on {
        display: block; }

.mgt {
  margin-top: 20px; }

.mgb {
  margin-bottom: 20px; }

.message {
  position: fixed;
  top: 50px;
  width: 600px;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  padding: 20px 40px;
  border-radius: 5px;
  border-style: solid;
  border-width: 1px;
  box-shadow: 0 5px 10px 0 rgba(0, 0, 0, 0.7);
  z-index: 1200; }
  .message.success {
    color: #3c763d;
    background-color: #dff0d8;
    border-color: #d6e9c6; }
  .message.error {
    color: #a94442;
    background-color: #f2dede;
    border-color: #ebccd1; }

ul.no-icon li {
  list-style: none; }

.textlink {
  text-decoration: underline;
  font-size: inherit;
  display: inline-block;
  font-weight: bold;
  color: #4b89b5; }
  .textlink:hover {
    opacity: 0.8; }

@media screen and (max-width: 767px) {
  .hidden-md {
    display: none; } }
