:root {
  --off-white: #fffdfc;
  --khaki: #545124;
  --button-bg-hover: #e0dfcd;
  --transparent: transparent;
  --button-bg: #eeedd9;
  --secondary: #ced1c7;
  --white: white;
  --black: black;
}

.w-layout-vflex {
  flex-direction: column;
  align-items: flex-start;
  display: flex;
}

.w-layout-blockcontainer {
  max-width: 940px;
  margin-left: auto;
  margin-right: auto;
  display: block;
}

@media screen and (max-width: 991px) {
  .w-layout-blockcontainer {
    max-width: 728px;
  }
}

@media screen and (max-width: 767px) {
  .w-layout-blockcontainer {
    max-width: none;
  }
}

body {
  background-color: var(--off-white);
  color: var(--khaki);
  font-family: Font, sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
}

h1 {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 2.5rem;
  font-weight: 400;
  line-height: 120%;
}

h2 {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 120%;
}

p {
  margin-bottom: 10px;
  font-size: 1.25rem;
  line-height: 155%;
}

label {
  margin-bottom: 4px;
  font-size: 1rem;
  font-weight: 400;
  line-height: 100%;
  display: block;
}

.navlink {
  color: var(--khaki);
  border-bottom: 1px solid #54512400;
  justify-content: center;
  align-items: center;
  height: 42px;
  padding: 16px 0 11px;
  font-size: 1rem;
  line-height: 100%;
  text-decoration: none;
  transition: all .2s;
  display: flex;
}

.navlink:hover {
  opacity: .5;
}

.navlink.w--current {
  border-bottom: 1px solid var(--khaki);
  color: var(--khaki);
}

.navbar {
  z-index: 1000;
  background-color: #fff;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  height: 130px;
  padding-top: 10px;
  padding-left: 50px;
  padding-right: 50px;
  display: flex;
  position: fixed;
  inset: 0% 0% auto;
}

.container {
  width: 100%;
  max-width: 100%;
}

.container.detail {
  justify-content: space-between;
  display: flex;
}

.logotype {
  font-size: 1.6rem;
  line-height: 120%;
}

.brand {
  grid-column-gap: 4px;
  grid-row-gap: 4px;
  color: var(--khaki);
  flex-flow: column;
  flex: 1;
  justify-content: center;
  align-items: flex-start;
  display: flex;
}

.brand.w--current {
  padding-left: 0;
}

.nav-menu {
  flex: 1;
}

.nav-menu.detail {
  flex: 0 auto;
}

.hero-image {
  justify-content: center;
  align-items: flex-end;
  width: 100%;
  height: 100vh;
  padding: 50px;
  display: flex;
  position: relative;
  overflow: hidden;
}

.image {
  z-index: 0;
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.img-overlay {
  z-index: 100;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.teaser-section {
  justify-content: center;
  align-items: center;
  margin-top: 120px;
  display: flex;
  position: relative;
}

.full-width-container {
  width: 100%;
  max-width: 1500px;
  display: flex;
}

.image-wrapper {
  width: 50%;
  padding-bottom: 120px;
  padding-left: 120px;
  padding-right: 120px;
}

.image-wrapper.bottom {
  justify-content: center;
  align-items: flex-end;
  padding-bottom: 190px;
  display: flex;
}

.image-wrapper.bottom.left {
  justify-content: center;
  align-items: flex-end;
}

.image-wrapper.bottom.left.long {
  padding-bottom: 50px;
}

.image-small {
  width: 100%;
}

.group {
  grid-column-gap: 1.3rem;
  grid-row-gap: 1.3rem;
  flex-flow: column;
  align-items: flex-start;
  width: 345px;
  display: flex;
}

.teaser-txt {
  color: var(--khaki);
  font-size: 1rem;
  line-height: 142%;
}

.teaser-txt.footer-txt {
  margin-bottom: 0;
  line-height: 160%;
}

.teaser-txt.imprint {
  margin-bottom: 0;
  font-size: 12px;
  line-height: 160%;
}

.button {
  border: 1px solid var(--button-bg);
  color: var(--khaki);
  background-color: #eeedd9;
  border-radius: 30px;
  justify-content: center;
  align-items: center;
  height: 42px;
  padding-top: 2px;
  padding-left: 28px;
  padding-right: 28px;
  text-decoration: none;
  transition: all .2s;
  display: flex;
}

.button:hover {
  opacity: .8;
}

.base-text {
  margin-bottom: 0;
  font-size: 1rem;
  line-height: 100%;
}

.page-wrap {
  width: 100%;
  overflow: hidden;
}

.footer {
  flex-flow: column;
  width: 100%;
  margin-top: 12rem;
  padding: 50px;
  display: flex;
}

.footer-logo-wrapper {
  margin-bottom: 1.7rem;
}

.footer-address-wrapper {
  grid-column-gap: 1.6rem;
  grid-row-gap: 1.6rem;
  margin-bottom: 1.1rem;
  display: flex;
}

.disclaimer {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  justify-content: flex-start;
  align-items: center;
  margin-top: 4rem;
  display: flex;
}

.footer-block {
  min-width: 210px;
}

.footer-link-block {
  text-decoration: none;
  display: inline-flex;
  position: relative;
  overflow: hidden;
}

.underline {
  background-color: var(--khaki);
  width: 100%;
  height: 1px;
  margin-bottom: 2px;
  position: absolute;
  inset: auto 0% 0%;
}

.text-link {
  border-bottom: 1px solid var(--khaki);
  color: var(--khaki);
  text-decoration: none;
}

.divider {
  background-color: var(--secondary);
  width: 1px;
  height: 12px;
}

.footer-txt-block {
  text-decoration: none;
  display: inline-flex;
  position: relative;
  overflow: hidden;
}

.detail-content {
  justify-content: center;
  align-items: flex-start;
  margin-top: 23rem;
  display: flex;
}

.content {
  grid-column-gap: 6rem;
  grid-row-gap: 6rem;
  flex-flow: column;
  width: 100%;
  max-width: 720px;
  display: flex;
}

.content.no-space {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
}

.bright {
  opacity: .5;
}

.title-block {
  margin-bottom: 1rem;
}

.description-block {
  grid-column-gap: 2.3rem;
  grid-row-gap: 2.3rem;
  flex-flow: row;
}

.price-table {
  min-width: 190px;
  padding-top: 4px;
}

.small {
  margin-bottom: 0;
  font-size: 1rem;
}

.wrapper {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
}

.wrapper.no-space {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
}

.table {
  flex-flow: column;
  width: 100%;
  display: flex;
}

.row {
  border-bottom: 1px solid var(--secondary);
  padding-top: 1rem;
  padding-bottom: .7rem;
  display: flex;
}

.celll {
  flex: 1;
}

.celll.left {
  flex: 0 auto;
  width: 120px;
}

.celll.time {
  flex: none;
  justify-content: flex-end;
  width: 70px;
  margin-right: 15px;
  display: flex;
}

.form-element {
  flex: 1;
  align-items: stretch;
  width: 100%;
}

.form-element.bottom {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  margin-top: 2rem;
}

.text-field {
  border-style: none none solid;
  border-width: 1px;
  border-color: black black var(--secondary);
  background-color: var(--off-white);
  color: var(--khaki);
  height: 60px;
  padding: 5px 13px 0;
  font-size: 1.25rem;
  transition: all .2s;
}

.text-field:hover {
  border-bottom-color: var(--khaki);
}

.text-field:focus {
  border-bottom-color: var(--khaki);
  background-color: var(--button-bg);
  color: var(--khaki);
}

.text-field:focus-visible {
  border-bottom-color: var(--khaki);
}

.text-field[data-wf-focus-visible] {
  border-bottom-color: var(--khaki);
}

.form-block {
  width: 100%;
}

.form-group {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  flex-flow: row;
}

.form {
  grid-column-gap: 1.6rem;
  grid-row-gap: 1.6rem;
  flex-flow: column;
  display: flex;
}

.submit-button {
  border: 1px solid var(--button-bg);
  background-color: var(--button-bg);
  color: var(--khaki);
  border-radius: 32px;
  height: 62px;
  padding-top: 13px;
  font-size: 1.25rem;
  transition: all .2s;
}

.submit-button:hover {
  border-color: var(--secondary);
}

.mood-imf-wrapper {
  width: 60%;
}

.footer-image {
  flex-flow: column;
  width: 100%;
  margin-top: 120px;
  padding: 50px;
  display: flex;
}

.history-back-old {
  margin-top: 1rem;
  text-decoration: none;
  display: inline-flex;
  position: relative;
  overflow: hidden;
}

.flex-block {
  grid-column-gap: 1.5rem;
  grid-row-gap: 1.5rem;
  flex-flow: row;
}

.cell-group {
  flex-flow: row;
}

.success-message {
  background-color: var(--button-bg);
  text-align: left;
  border-radius: 8px;
  padding: 48px 50px 36px;
}

.error-message {
  text-align: left;
  background-color: #eeded9;
  border-radius: 8px;
  margin-top: 34px;
  padding: 48px 50px 36px;
}

.error-txt {
  color: #542424;
}

.cleverhistory {
  border: 1px solid var(--button-bg);
  color: var(--khaki);
  background-color: #eeedd9;
  border-radius: 30px;
  justify-content: center;
  align-items: center;
  height: 42px;
  padding-top: 2px;
  padding-left: 28px;
  padding-right: 28px;
  text-decoration: none;
  transition: all .2s;
  display: flex;
}

.cleverhistory:hover {
  opacity: .8;
}

.spacer {
  width: 100%;
  height: .5rem;
}

.spacer.large {
  height: 4.5rem;
}

.border {
  background-color: var(--off-white);
  width: 100%;
  height: 50px;
  position: fixed;
  inset: auto 0% 0%;
}

.utility-page-wrap {
  justify-content: center;
  align-items: center;
  width: 100vw;
  max-width: 100%;
  height: 100vh;
  max-height: 100%;
  display: flex;
}

.utility-page-content {
  text-align: center;
  flex-direction: column;
  width: 260px;
  display: flex;
}

@media screen and (max-width: 991px) {
  h1 {
    font-size: 2.3rem;
  }

  p {
    font-size: 1.2rem;
  }

  .navlink {
    justify-content: flex-start;
    align-items: center;
    height: auto;
    margin-left: 0;
    margin-right: 0;
    padding-top: 15px;
    padding-bottom: 3px;
    font-size: 1.4rem;
  }

  .navlink.w--current {
    border-bottom-color: var(--khaki);
  }

  .navbar {
    height: auto;
    padding-top: 30px;
    padding-bottom: 18px;
  }

  .navbar.detail {
    background-color: var(--off-white);
  }

  .logotype {
    font-size: 1.4rem;
  }

  .nav-menu {
    background-color: var(--button-bg-hover);
    flex-flow: column;
    justify-content: flex-start;
    align-items: flex-start;
    width: 350px;
    height: 100vh;
    padding: 130px 60px 60px;
  }

  .nav-menu.detail {
    background-color: var(--transparent);
    box-shadow: none;
    width: auto;
    height: auto;
    padding: 0;
  }

  .image {
    aspect-ratio: 4 / 5;
    object-fit: cover;
  }

  .teaser-section {
    margin-top: 0;
    padding-top: 120px;
  }

  .full-width-container {
    flex-flow: column;
  }

  .image-wrapper {
    width: 100%;
    padding-bottom: 0;
    padding-left: 120px;
    padding-right: 120px;
  }

  .image-wrapper.bottom {
    order: -1;
    padding-bottom: 120px;
  }

  .image-wrapper.bottom.left.long {
    padding-bottom: 120px;
  }

  .group {
    width: 410px;
  }

  .button:hover {
    border-color: var(--button-bg);
  }

  .button.anmelden {
    border-color: var(--khaki);
    background-color: var(--transparent);
    margin-top: 30px;
  }

  .footer {
    margin-top: 100px;
  }

  .footer-address-wrapper, .disclaimer {
    flex-flow: wrap;
  }

  .underline.small {
    display: none;
  }

  .detail-content {
    padding-left: 120px;
    padding-right: 120px;
  }

  .content {
    grid-column-gap: 5rem;
    grid-row-gap: 5rem;
  }

  .description-block {
    grid-column-gap: .3rem;
    grid-row-gap: .3rem;
    flex-flow: column-reverse;
  }

  .description-block.info {
    flex-flow: column;
  }

  .row {
    flex-flow: wrap;
  }

  .mood-imf-wrapper {
    width: 100%;
  }

  .footer-image {
    padding: 0 120px;
  }

  .menu-button {
    z-index: 2000;
    background-color: var(--off-white);
    border-radius: 50%;
    justify-content: center;
    align-items: center;
    width: 58px;
    height: 58px;
    margin-top: -10px;
    margin-right: -17px;
    padding: 0;
    display: flex;
    overflow: hidden;
  }

  .menu-button.w--open {
    background-color: var(--off-white);
  }

  .flex-block {
    grid-column-gap: 0rem;
    grid-row-gap: 0rem;
    flex-flow: column;
    justify-content: flex-start;
    align-items: flex-start;
  }

  .cleverhistory:hover {
    border-color: var(--button-bg);
  }

  .lottie-animation {
    z-index: 100;
    justify-content: center;
    align-items: center;
    width: 58px;
    height: 58px;
    display: flex;
    position: absolute;
    transform: scale(1.2);
  }

  .close-action {
    z-index: 300;
    display: none;
    position: absolute;
    inset: 0%;
  }
}

@media screen and (max-width: 767px) {
  h1 {
    font-size: 2rem;
  }

  h2 {
    font-size: 1.4rem;
  }

  p {
    font-size: 1.1rem;
  }

  .navlink {
    font-size: 1.3rem;
  }

  .navbar {
    height: auto;
    padding: 25px 40px 17px;
  }

  .navbar.detail {
    padding-top: 25px;
    padding-bottom: 17px;
  }

  .logotype {
    font-size: 1.3rem;
  }

  .brand {
    padding-left: 0;
  }

  .nav-menu {
    width: 300px;
    padding: 90px 50px 50px;
  }

  .nav-menu.detail {
    width: auto;
  }

  .hero-image {
    padding-left: 0;
    padding-right: 0;
  }

  .teaser-section {
    padding-top: 60px;
  }

  .image-wrapper {
    padding-left: 40px;
    padding-right: 40px;
  }

  .image-wrapper.bottom, .image-wrapper.bottom.left, .image-wrapper.bottom.left.long {
    padding-bottom: 60px;
  }

  .group {
    width: 100%;
  }

  .teaser-txt {
    margin-bottom: 0;
  }

  .footer {
    padding: 40px;
  }

  .disclaimer {
    margin-top: 3rem;
  }

  .detail-content {
    margin-top: 16rem;
    padding-left: 40px;
    padding-right: 40px;
  }

  .title-block {
    margin-bottom: .4rem;
  }

  .small {
    font-size: .9rem;
  }

  .row {
    flex-flow: column;
  }

  .row.first {
    padding-top: 0;
  }

  .celll.left {
    width: 110px;
  }

  .celll.time {
    justify-content: flex-start;
    margin-right: 0;
  }

  .form-element.spacer {
    display: none;
  }

  .form-group {
    flex-flow: column;
  }

  .footer-image {
    margin-top: 40px;
    padding-left: 40px;
    padding-right: 40px;
  }

  .menu-button {
    width: 54px;
    height: 54px;
    margin-top: -6px;
    margin-right: -16px;
  }

  .cell-group {
    justify-content: flex-start;
  }

  .lottie-animation {
    width: 54px;
    height: 54px;
  }

  .spacer {
    height: 1rem;
  }

  .spacer.large {
    height: 3.5rem;
  }
}

@media screen and (max-width: 479px) {
  h1 {
    font-size: 1.8rem;
  }

  p {
    font-size: 1.05rem;
  }

  .navlink {
    font-size: 1.1rem;
  }

  .navbar {
    padding: 17px 30px 11px;
  }

  .navbar.detail {
    padding-top: 17px;
    padding-bottom: 11px;
    padding-right: 18px;
  }

  .logotype {
    font-size: 1.1rem;
  }

  .brand {
    margin-right: 10px;
    padding-top: 2px;
  }

  .nav-menu {
    width: 250px;
    padding: 71px 40px 40px;
  }

  .nav-menu.detail {
    margin-top: -1px;
  }

  .hero-image {
    padding-left: 0;
    padding-right: 0;
  }

  .image {
    aspect-ratio: 4 / 6;
  }

  .teaser-section {
    margin-top: 1px;
    padding-top: 40px;
  }

  .image-wrapper {
    padding-left: 0;
    padding-right: 0;
  }

  .image-wrapper.bottom {
    padding-bottom: 50px;
    padding-left: 30px;
    padding-right: 30px;
  }

  .image-wrapper.bottom.left, .image-wrapper.bottom.left.long {
    padding-bottom: 50px;
  }

  .group {
    grid-column-gap: 1.4rem;
    grid-row-gap: 1.4rem;
    width: 100%;
  }

  .button {
    padding-left: 26px;
    padding-right: 26px;
  }

  .footer {
    margin-top: 0;
    padding: 30px;
  }

  .disclaimer {
    flex-flow: column;
    align-items: flex-start;
    margin-top: 2rem;
  }

  .divider {
    display: none;
  }

  .detail-content {
    margin-top: 14rem;
    margin-bottom: 2rem;
    padding-left: 30px;
    padding-right: 30px;
  }

  .content {
    grid-column-gap: 3rem;
    grid-row-gap: 3rem;
  }

  .title-block {
    margin-bottom: .4rem;
  }

  .description-block {
    grid-column-gap: .4rem;
    grid-row-gap: .4rem;
  }

  .celll.left {
    flex: none;
  }

  .footer-image {
    margin-top: -1px;
    padding-left: 0;
    padding-right: 0;
  }

  .menu-button {
    width: 50px;
    height: 50px;
    margin-top: -6px;
    margin-right: -20px;
  }

  .cleverhistory {
    padding-left: 26px;
    padding-right: 26px;
  }

  .lottie-animation {
    width: 50px;
    height: 50px;
  }

  .spacer {
    height: .7rem;
  }
}


@font-face {
  font-family: 'Font';
  src: url('../fonts/font.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}