@charset "UTF-8";
/*
///########################################################################
///########################################################################
///
///------------------------ designed - created - hosted | by HeiCom Systems
///
///########################################################################
///########################################################################
*/
/*
///########################################################################
///------------------- 01 Allgemein
///########################################################################
*/
/* ---------------------------------------------------------- open-sans */
/* open-sans-300 - latin */
@font-face {
  font-display: swap;
  /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 300;
  src: url("/wp-content/themes/heicom-systems/fonts/open-sans-v34-latin-300.woff2") format("woff2"), url("/wp-content/themes/heicom-systems/fonts/open-sans-v34-latin-300.woff") format("woff");
  /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}
/* open-sans-regular - latin */
@font-face {
  font-display: swap;
  /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 400;
  src: url("/wp-content/themes/heicom-systems/fonts/open-sans-v34-latin-regular.woff2") format("woff2"), url("/wp-content/themes/heicom-systems/fonts/open-sans-v34-latin-regular.woff") format("woff");
  /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}
/* open-sans-700 - latin */
@font-face {
  font-display: swap;
  /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 700;
  src: url("/wp-content/themes/heicom-systems/fonts/open-sans-v34-latin-700.woff2") format("woff2"), url("/wp-content/themes/heicom-systems/fonts/open-sans-v34-latin-700.woff") format("woff");
  /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}
/* ---------------------------------------------------------- Satoshi */
@font-face {
  font-family: "Satoshi";
  font-weight: 300;
  font-display: swap;
  font-style: normal;
  src: url("/wp-content/themes/heicom-systems/fonts/Satoshi-Light.woff2") format("woff2"), url("/wp-content/themes/heicom-systems/fonts/Satoshi-Light.woff") format("woff");
}
@font-face {
  font-family: "Satoshi";
  font-weight: 400;
  font-display: swap;
  font-style: normal;
  src: url("/wp-content/themes/heicom-systems/fonts/Satoshi-Regular.woff2") format("woff2"), url("/wp-content/themes/heicom-systems/fonts/Satoshi-Regular.woff") format("woff");
}
@font-face {
  font-family: "Satoshi";
  font-weight: 700;
  font-display: swap;
  font-style: normal;
  src: url("/wp-content/themes/heicom-systems/fonts/Satoshi-Bold.woff2") format("woff2"), url("/wp-content/themes/heicom-systems/fonts/Satoshi-Bold.woff") format("woff");
}
@font-face {
  font-family: "Satoshi";
  font-weight: 900;
  font-display: swap;
  font-style: normal;
  src: url("/wp-content/themes/heicom-systems/fonts/Satoshi-Black.woff2") format("woff2"), url("/wp-content/themes/heicom-systems/fonts/Satoshi-Black.woff") format("woff");
}
.box--xl {
  max-width: 1200px;
}
.box--l {
  max-width: 1000px;
}
.box--m {
  max-width: 800px;
}
.box--s {
  max-width: 600px;
}
.box--xs {
  max-width: 400px;
}
@keyframes fade-in-left--key {
  from {
    opacity: 0;
    transform: translate3d(-100px, 0, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}
@keyframes fade-in-bottom--key {
  from {
    opacity: 0;
    transform: translate3d(0, 100px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}
@keyframes fade-in-top--key {
  from {
    opacity: 0;
    transform: translate3d(0, -100px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}
@keyframes fade-in--key {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes zoom-out--key {
  0% {
    transform: scale(1.1);
  }
  100% {
    transform: scale(1);
  }
}
.text--white {
  color: #fff;
}
.text--white.heading, .text--white.text {
  color: #fff;
}
.center {
  text-align: center;
}
.hyphens h1, .hyphens h2, .hyphens h3, .hyphens h4, .hyphens p, .hyphens a, .hyphens li, .hyphens span {
  hyphens: auto;
}
[class*="spaltentext"] {
  column-gap: 2rem;
  margin-top: 1rem;
}
.spaltentext--2 {
  column-count: 2;
  column-width: 500px;
}
.no-select {
  -webkit-user-select: none;
  /* Safari */
  -ms-user-select: none;
  /* IE 10 and IE 11 */
  user-select: none;
  /* Standard syntax */
}
[class*="_ctr"] {
  padding: 10rem 3rem;
}
[class*="_ctr"].min {
  padding: 3rem;
}
[class*="_ctr"].min--top {
  padding-top: 3rem;
}
[class*="_ctr"].min--bottom {
  padding-bottom: 3rem;
}
[class*="_ctr"].zero {
  padding: 0;
}
.fixed_ctr {
  width: 100%;
  max-width: 1800px;
}
.full_ctr {
  width: 100%;
}
@media (max-width: 1920px) {
  .fixed_ctr {
    max-width: 1550px;
  }
}
@media (max-width: 1600px) {
  .fixed_ctr {
    max-width: 1300px;
  }
}
@media (max-width: 1366px) {
  .fixed_ctr {
    max-width: 1024px;
  }
  [class*="_ctr"] {
    padding: 8rem 3rem;
  }
}
@media (max-width: 1024px) {
  .fixed_ctr {
    max-width: 100%;
  }
  [class*="_ctr"] {
    padding: 6rem 3rem;
  }
}
@media (max-width: 768px) {
  [class*="_ctr"] {
    padding: 4rem 2rem;
  }
  [class*="_ctr"].min {
    padding: 2rem;
  }
  [class*="_ctr"].min--top {
    padding-top: 2rem;
  }
  [class*="_ctr"].min--bottom {
    padding-bottom: 2rem;
  }
}
@media (max-width: 500px) {
  [class*="_ctr"] {
    padding: 3rem 1.5rem;
  }
  [class*="_ctr"].min {
    padding: 1.5rem;
  }
  [class*="_ctr"].min--top {
    padding-top: 1.5rem;
  }
  [class*="_ctr"].min--bottom {
    padding-bottom: 1.5rem;
  }
}
.justify-start {
  justify-content: flex-start;
}
.justify-end {
  justify-content: flex-end;
}
.justify-center {
  justify-content: center;
}
.justify-between {
  justify-content: space-between;
}
.justify-around {
  justify-content: space-around;
}
.justify-evenly {
  justify-content: space-evenly;
}
.justify-items-start {
  justify-items: start;
}
.justify-items-end {
  justify-items: end;
}
.justify-items-center {
  justify-items: center;
}
.justify-items-stretch {
  justify-items: stretch;
}
.justify-self-auto {
  justify-self: auto;
}
.justify-self-start {
  justify-self: start;
}
.justify-self-end {
  justify-self: end;
}
.justify-self-center {
  justify-self: center;
}
.justify-self-stretch {
  justify-self: stretch;
}
.content-center {
  align-content: center;
}
.content-start {
  align-content: flex-start;
}
.content-end {
  align-content: flex-end;
}
.content-between {
  align-content: space-between;
}
.content-around {
  align-content: space-around;
}
.content-evenly {
  align-content: space-evenly;
}
.content-baseline {
  align-content: baseline;
}
.items-start {
  align-items: flex-start;
}
.items-end {
  align-items: flex-end;
}
.items-center {
  align-items: center;
}
.items-baseline {
  align-items: baseline;
}
.items-stretch {
  align-items: stretch;
}
.self-auto {
  align-self: auto;
}
.self-start {
  align-self: flex-start;
}
.self-end {
  align-self: flex-end;
}
.self-center {
  align-self: center;
}
.self-stretch {
  align-self: stretch;
}
.self-baseline {
  align-self: baseline;
}
.place-content-center {
  place-content: center;
}
.place-content-start {
  place-content: start;
}
.place-content-end {
  place-content: end;
}
.place-content-between {
  place-content: space-between;
}
.place-content-around {
  place-content: space-around;
}
.place-content-evenly {
  place-content: space-evenly;
}
.place-content-baseline {
  place-content: baseline;
}
.place-content-stretch {
  place-content: stretch;
}
.place-items-start {
  place-items: start;
}
.place-items-end {
  place-items: end;
}
.place-items-center {
  place-items: center;
}
.place-items-baseline {
  place-items: baseline;
}
.place-items-stretch {
  place-items: stretch;
}
.place-self-auto {
  place-self: auto;
}
.place-self-start {
  place-self: start;
}
.place-self-end {
  place-self: end;
}
.place-self-center {
  place-self: center;
}
.place-self-stretch {
  place-self: stretch;
}
.mdl {
  margin: 1.25rem 0;
}
.mdl--s {
  margin: 1rem 0;
}
.mdl--l {
  margin: 1.5rem 0;
}
.mdl--zero {
  margin: 0;
}
.m-xxs {
  margin: 1rem;
}
.m-xs {
  margin: 2rem;
}
.m-s {
  margin: 3rem;
}
.m-m {
  margin: 4rem;
}
.m-l {
  margin: 5rem;
}
.m-xl {
  margin: 6rem;
}
.m-xxl {
  margin: 7rem;
}
.mx-xxs {
  margin: 0 1rem;
}
.mx-xs {
  margin: 0 2rem;
}
.mx-s {
  margin: 0 3rem;
}
.mx-m {
  margin: 0 4rem;
}
.mx-l {
  margin: 0 5rem;
}
.mx-xl {
  margin: 0 6rem;
}
.mx-xxl {
  margin: 0 7rem;
}
.my-xxs {
  margin: 1rem 0;
}
.my-xs {
  margin: 2rem 0;
}
.my-s {
  margin: 3rem 0;
}
.my-m {
  margin: 4rem 0;
}
.my-l {
  margin: 5rem 0;
}
.my-xl {
  margin: 6rem 0;
}
.my-xxl {
  margin: 7rem 0;
}
.ml-zero {
  margin-left: 0;
}
.ml-xxs {
  margin-left: 1rem;
}
.ml-xs {
  margin-left: 2rem;
}
.ml-s {
  margin-left: 3rem;
}
.ml-m {
  margin-left: 4rem;
}
.ml-l {
  margin-left: 5rem;
}
.ml-xl {
  margin-left: 6rem;
}
.ml-xxl {
  margin-left: 7rem;
}
.mr-zero {
  margin-right: 0;
}
.mr-xxs {
  margin-right: 1rem;
}
.mr-xs {
  margin-right: 2rem;
}
.mr-s {
  margin-right: 3rem;
}
.mr-m {
  margin-right: 4rem;
}
.mr-l {
  margin-right: 5rem;
}
.mr-xl {
  margin-right: 6rem;
}
.mr-xxl {
  margin-right: 7rem;
}
.mt-zero {
  margin-top: 0;
}
.mt-xxs {
  margin-top: 1rem;
}
.mt-xs {
  margin-top: 2rem;
}
.mt-s {
  margin-top: 3rem;
}
.mt-m {
  margin-top: 4rem;
}
.mt-l {
  margin-top: 5rem;
}
.mt-xl {
  margin-top: 6rem;
}
.mt-xxl {
  margin-top: 7rem;
}
.mb-zero {
  margin-bottom: 0;
}
.mb-xxs {
  margin-bottom: 1rem;
}
.mb-xs {
  margin-bottom: 2rem;
}
.mb-s {
  margin-bottom: 3rem;
}
.mb-m {
  margin-bottom: 4rem;
}
.mb-l {
  margin-bottom: 5rem;
}
.mb-xl {
  margin-bottom: 6rem;
}
.mb-xxl {
  margin-bottom: 7rem;
}
.p-xxs {
  padding: 1rem;
}
.p-xs {
  padding: 2rem;
}
.p-s {
  padding: 3rem;
}
.p-m {
  padding: 4rem;
}
.p-l {
  padding: 5rem;
}
.p-xl {
  padding: 6rem;
}
.p-xxl {
  padding: 7rem;
}
.px-xxs {
  padding: 0 1rem;
}
.px-xs {
  padding: 0 2rem;
}
.px-s {
  padding: 0 3rem;
}
.px-m {
  padding: 0 4rem;
}
.px-l {
  padding: 0 5rem;
}
.px-xl {
  padding: 0 6rem;
}
.px-xxl {
  padding: 0 7rem;
}
.py-xxs {
  padding: 1rem 0;
}
.py-xs {
  padding: 2rem 0;
}
.py-s {
  padding: 3rem 0;
}
.py-m {
  padding: 4rem 0;
}
.py-l {
  padding: 5rem 0;
}
.py-xl {
  padding: 6rem 0;
}
.py-xxl {
  padding: 7rem 0;
}
.pl-zero {
  padding-left: 0;
}
.pl-xxs {
  padding-left: 1rem;
}
.pl-xs {
  padding-left: 2rem;
}
.pl-s {
  padding-left: 3rem;
}
.pl-m {
  padding-left: 4rem;
}
.pl-l {
  padding-left: 5rem;
}
.pl-xl {
  padding-left: 6rem;
}
.pl-xxl {
  padding-left: 7rem;
}
.pr-zero {
  padding-right: 0;
}
.pr-xxs {
  padding-right: 1rem;
}
.pr-xs {
  padding-right: 2rem;
}
.pr-s {
  padding-right: 3rem;
}
.pr-m {
  padding-right: 4rem;
}
.pr-l {
  padding-right: 5rem;
}
.pr-xl {
  padding-right: 6rem;
}
.pr-xxl {
  padding-right: 7rem;
}
.pt-zero {
  padding-top: 0;
}
.pt-xxs {
  padding-top: 1rem;
}
.pt-xs {
  padding-top: 2rem;
}
.pt-s {
  padding-top: 3rem;
}
.pt-m {
  padding-top: 4rem;
}
.pt-l {
  padding-top: 5rem;
}
.pt-xl {
  padding-top: 6rem;
}
.pt-xxl {
  padding-top: 7rem;
}
.pb-zero {
  padding-bottom: 0;
}
.pb-xxs {
  padding-bottom: 1rem;
}
.pb-xs {
  padding-bottom: 2rem;
}
.pb-s {
  padding-bottom: 3rem;
}
.pb-m {
  padding-bottom: 4rem;
}
.pb-l {
  padding-bottom: 5rem;
}
.pb-xl {
  padding-bottom: 6rem;
}
.pb-xxl {
  padding-bottom: 7rem;
}
@media (max-width: 768px) {
  .mdl {
    margin: 1rem 0;
  }
  .mdl--s {
    margin: 0.75rem 0;
  }
  .mdl--l {
    margin: 1.25rem 0;
  }
  .m-xxs {
    margin: 0.5rem;
  }
  .m-xs {
    margin: 1rem;
  }
  .m-s {
    margin: 1.5rem;
  }
  .m-m {
    margin: 2rem;
  }
  .m-l {
    margin: 2.5rem;
  }
  .m-xl {
    margin: 3rem;
  }
  .m-xxl {
    margin: 3.5rem;
  }
  .mx-xxs {
    margin: 0 0.5rem;
  }
  .mx-xs {
    margin: 0 1rem;
  }
  .mx-s {
    margin: 0 1.5rem;
  }
  .mx-m {
    margin: 0 2rem;
  }
  .mx-l {
    margin: 0 2.5rem;
  }
  .mx-xl {
    margin: 0 3rem;
  }
  .mx-xxl {
    margin: 0 3.5rem;
  }
  .my-xxs {
    margin: 0.5rem 0;
  }
  .my-xs {
    margin: 1rem 0;
  }
  .my-s {
    margin: 1.5rem 0;
  }
  .my-m {
    margin: 2rem 0;
  }
  .my-l {
    margin: 2.5rem 0;
  }
  .my-xl {
    margin: 3rem 0;
  }
  .my-xxl {
    margin: 3.5rem 0;
  }
  .ml-zero {
    margin-left: 0;
  }
  .ml-xxs {
    margin-left: 0.5rem;
  }
  .ml-xs {
    margin-left: 1rem;
  }
  .ml-s {
    margin-left: 1.5rem;
  }
  .ml-m {
    margin-left: 2rem;
  }
  .ml-l {
    margin-left: 2.5rem;
  }
  .ml-xl {
    margin-left: 3rem;
  }
  .ml-xxl {
    margin-left: 3.5rem;
  }
  .mr-zero {
    margin-right: 0;
  }
  .mr-xxs {
    margin-right: 0.5rem;
  }
  .mr-xs {
    margin-right: 1rem;
  }
  .mr-s {
    margin-right: 1.5rem;
  }
  .mr-m {
    margin-right: 2rem;
  }
  .mr-l {
    margin-right: 2.5rem;
  }
  .mr-xl {
    margin-right: 3rem;
  }
  .mr-xxl {
    margin-right: 3.5rem;
  }
  .mt-zero {
    margin-top: 0;
  }
  .mt-xxs {
    margin-top: 0.5rem;
  }
  .mt-xs {
    margin-top: 1rem;
  }
  .mt-s {
    margin-top: 1.5rem;
  }
  .mt-m {
    margin-top: 2rem;
  }
  .mt-l {
    margin-top: 2.5rem;
  }
  .mt-xl {
    margin-top: 3rem;
  }
  .mt-xxl {
    margin-top: 3.5rem;
  }
  .mb-zero {
    margin-bottom: 0;
  }
  .mb-xxs {
    margin-bottom: 0.5rem;
  }
  .mb-xs {
    margin-bottom: 1rem;
  }
  .mb-s {
    margin-bottom: 1.5rem;
  }
  .mb-m {
    margin-bottom: 2rem;
  }
  .mb-l {
    margin-bottom: 2.5rem;
  }
  .mb-xl {
    margin-bottom: 3rem;
  }
  .mb-xxl {
    margin-bottom: 3.5rem;
  }
  .p-xxs {
    padding: 0.5rem;
  }
  .p-xs {
    padding: 1rem;
  }
  .p-s {
    padding: 1.5rem;
  }
  .p-m {
    padding: 2rem;
  }
  .p-l {
    padding: 2.5rem;
  }
  .p-xl {
    padding: 3rem;
  }
  .p-xxl {
    padding: 3.5rem;
  }
  .px-xxs {
    padding: 0 0.5rem;
  }
  .px-xs {
    padding: 0 1rem;
  }
  .px-s {
    padding: 0 1.5rem;
  }
  .px-m {
    padding: 0 2rem;
  }
  .px-l {
    padding: 0 2.5rem;
  }
  .px-xl {
    padding: 0 3rem;
  }
  .px-xxl {
    padding: 0 3.5rem;
  }
  .py-xxs {
    padding: 0.5rem 0;
  }
  .py-xs {
    padding: 1rem 0;
  }
  .py-s {
    padding: 1.5rem 0;
  }
  .py-m {
    padding: 2rem 0;
  }
  .py-l {
    padding: 2.5rem 0;
  }
  .py-xl {
    padding: 3rem 0;
  }
  .py-xxl {
    padding: 3.5rem 0;
  }
  .pl-zero {
    padding-left: 0;
  }
  .pl-xxs {
    padding-left: 0.5rem;
  }
  .pl-xs {
    padding-left: 1rem;
  }
  .pl-s {
    padding-left: 1.5rem;
  }
  .pl-m {
    padding-left: 2rem;
  }
  .pl-l {
    padding-left: 2.5rem;
  }
  .pl-xl {
    padding-left: 3rem;
  }
  .pl-xxl {
    padding-left: 3.5rem;
  }
  .pr-zero {
    padding-right: 0;
  }
  .pr-xxs {
    padding-right: 0.5rem;
  }
  .pr-xs {
    padding-right: 1rem;
  }
  .pr-s {
    padding-right: 1.5rem;
  }
  .pr-m {
    padding-right: 2rem;
  }
  .pr-l {
    padding-right: 2.5rem;
  }
  .pr-xl {
    padding-right: 3rem;
  }
  .pr-xxl {
    padding-right: 3.5rem;
  }
  .pt-zero {
    padding-top: 0;
  }
  .pt-xxs {
    padding-top: 0.5rem;
  }
  .pt-xs {
    padding-top: 1rem;
  }
  .pt-s {
    padding-top: 1.5rem;
  }
  .pt-m {
    padding-top: 2rem;
  }
  .pt-l {
    padding-top: 2.5rem;
  }
  .pt-xl {
    padding-top: 3rem;
  }
  .pt-xxl {
    padding-top: 3.5rem;
  }
  .pb-zero {
    padding-bottom: 0;
  }
  .pb-xxs {
    padding-bottom: 0.5rem;
  }
  .pb-xs {
    padding-bottom: 1rem;
  }
  .pb-s {
    padding-bottom: 1.5rem;
  }
  .pb-m {
    padding-bottom: 2rem;
  }
  .pb-l {
    padding-bottom: 2.5rem;
  }
  .pb-xl {
    padding-bottom: 3rem;
  }
  .pb-xxl {
    padding-bottom: 3.5rem;
  }
}
@media (max-width: 500px) {
  .mdl {
    margin: 0.75rem 0;
  }
  .mdl--s {
    margin: 0.5rem 0;
  }
  .mdl--l {
    margin: 1rem 0;
  }
}
.col_wrapper.grid.gap--zero, .cards_wrapper.grid.gap--zero, .wrapper.grid.gap--zero {
  gap: 0 0;
}
.col_wrapper.grid.gap--s, .cards_wrapper.grid.gap--s, .wrapper.grid.gap--s {
  gap: 1rem 1rem;
}
.col_wrapper.grid.gap--l, .cards_wrapper.grid.gap--l, .wrapper.grid.gap--l {
  gap: 3rem 3rem;
}
.col_wrapper.grid.gap--xl, .cards_wrapper.grid.gap--xl, .wrapper.grid.gap--xl {
  gap: 4rem 4rem;
}
.col_wrapper.grid.gap--2xl, .cards_wrapper.grid.gap--2xl, .wrapper.grid.gap--2xl {
  gap: 6rem 6rem;
}
.col_wrapper.grid.gap--3xl, .cards_wrapper.grid.gap--3xl, .wrapper.grid.gap--3xl {
  gap: 8rem 8rem;
}
.col_wrapper.grid.gap--4xl, .cards_wrapper.grid.gap--4xl, .wrapper.grid.gap--4xl {
  gap: 10rem 10rem;
}
.col_wrapper.grid.gap--5xl, .cards_wrapper.grid.gap--5xl, .wrapper.grid.gap--5xl {
  gap: 12rem 12rem;
}
.col_wrapper.grid, .wrapper.grid {
  gap: 2rem 6rem;
}
.cards_wrapper.grid {
  gap: 2rem 2rem;
}
.grid {
  display: grid;
}
.grid--2fr {
  grid-template-columns: 1fr 1fr;
}
.grid--3fr {
  grid-template-columns: 1fr 1fr 1fr;
}
.grid--4fr {
  grid-template-columns: 1fr 1fr 1fr 1fr;
}
.grid--5fr {
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
}
.grid--21fr {
  grid-template-columns: 2fr 1fr;
}
.grid--12fr {
  grid-template-columns: 1fr 2fr;
}
.grid--32fr {
  grid-template-columns: 3fr 2fr;
}
.grid--23fr {
  grid-template-columns: 2fr 3fr;
}
.grid--auto {
  grid-template-columns: repeat(auto-fit, minmax(min(300px, 100%), 1fr));
}
.cards_wrapper.grid {
  align-items: stretch;
}
.cards_wrapper.grid .card.mdl {
  margin: 0;
}
@media (max-width: 1366px) {
  .grid {
    display: grid;
  }
  .grid--2fr, .grid--3fr, .grid--4fr, .grid--5fr, .grid--21fr, .grid--12fr, .grid--32fr, .grid--23fr {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 1024px) {
  .grid {
    display: grid;
  }
  .grid--2fr, .grid--3fr, .grid--4fr, .grid--5fr, .grid--21fr, .grid--12fr, .grid--32fr, .grid--23fr {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 768px) {
  .col_wrapper.grid.gap--s, .cards_wrapper.grid.gap--s, .wrapper.grid.gap--s {
    gap: 0.75rem 0.75rem;
  }
  .col_wrapper.grid.gap--l, .cards_wrapper.grid.gap--l, .wrapper.grid.gap--l {
    gap: 2rem 2rem;
  }
  .col_wrapper.grid.gap--xl, .cards_wrapper.grid.gap--xl, .wrapper.grid.gap--xl {
    gap: 3rem 3rem;
  }
  .col_wrapper.grid.gap--2xl, .cards_wrapper.grid.gap--2xl, .wrapper.grid.gap--2xl {
    gap: 4rem 4rem;
  }
  .col_wrapper.grid.gap--3xl, .cards_wrapper.grid.gap--3xl, .wrapper.grid.gap--3xl {
    gap: 5rem 5rem;
  }
  .col_wrapper.grid.gap--4xl, .cards_wrapper.grid.gap--4xl, .wrapper.grid.gap--4xl {
    gap: 6rem 6rem;
  }
  .col_wrapper.grid.gap--5xl, .cards_wrapper.grid.gap--5xl, .wrapper.grid.gap--5xl {
    gap: 7rem 7rem;
  }
  .col_wrapper.grid, .wrapper.grid {
    gap: 1rem 4rem;
  }
  .cards_wrapper.grid {
    gap: 1rem 1rem;
  }
}
@media (max-width: 500px) {
  .col_wrapper.grid.gap--s, .cards_wrapper.grid.gap--s, .wrapper.grid.gap--s {
    gap: 0.5rem 0.5rem;
  }
  .col_wrapper.grid.gap--l, .cards_wrapper.grid.gap--l, .wrapper.grid.gap--l {
    gap: 1.5rem 1.5rem;
  }
  .col_wrapper.grid.gap--xl, .cards_wrapper.grid.gap--xl, .wrapper.grid.gap--xl {
    gap: 2.5rem 2.5rem;
  }
  .col_wrapper.grid.gap--2xl, .cards_wrapper.grid.gap--2xl, .wrapper.grid.gap--2xl {
    gap: 3.5rem 3.5rem;
  }
  .col_wrapper.grid.gap--3xl, .cards_wrapper.grid.gap--3xl, .wrapper.grid.gap--3xl {
    gap: 4.5rem 4.5rem;
  }
  .col_wrapper.grid.gap--4xl, .cards_wrapper.grid.gap--4xl, .wrapper.grid.gap--4xl {
    gap: 4.5rem 4.5rem;
  }
  .col_wrapper.grid.gap--5xl, .cards_wrapper.grid.gap--5xl, .wrapper.grid.gap--5xl {
    gap: 4.5rem 4.5rem;
  }
  .col_wrapper.grid, .wrapper.grid {
    gap: 1rem 3.5rem;
  }
  .cards_wrapper.grid {
    gap: 1rem 1rem;
  }
}
:root {
  --fluid-text-xs: clamp(0.79rem, -0.169vw + 0.843rem, 0.64rem);
  --fluid-text-s: clamp(0.889rem, -0.1vw + 0.92rem, 0.8rem);
  --fluid-text-m: clamp(1rem, 0vw + 1rem, 1rem);
  --fluid-text-l: clamp(1.125rem, 0.141vw + 1.081rem, 1.25rem);
  --fluid-heading-xs: clamp(1.266rem, 0.335vw + 1.161rem, 1.563rem);
  --fluid-heading-s: clamp(1.424rem, 0.596vw + 1.237rem, 1.953rem);
  --fluid-heading-m: clamp(1.602rem, 0.946vw + 1.306rem, 2.441rem);
  --fluid-heading-l: clamp(1.802rem, 1.408vw + 1.362rem, 3.052rem);
  --fluid-heading-xl: clamp(2.027rem, 2.014vw + 1.398rem, 3.815rem);
  --fluid-heading-2xl: clamp(2.281rem, 2.803vw + 1.405rem, 4.768rem);
  --fluid-heading-3xl: clamp(2.566rem, 3.825vw + 1.37rem, 5.96rem);
  --fluid-heading-4xl: clamp(2.887rem, 5.143vw + 1.279rem, 7.451rem);
}
html {
  font-size: 100% !important;
}
body {
  font-size: 1rem;
  font-size: var(--fluid-text-m);
  line-height: 1.5;
}
h1 {
  font-size: var(--fluid-heading-l);
}
h2 {
  font-size: var(--fluid-heading-m);
}
h3 {
  font-size: var(--fluid-heading-s);
}
h4 {
  font-size: var(--fluid-heading-xs);
}
h5 {
  font-size: var(--fluid-text-l);
}
h6 {
  font-size: var(--fluid-text-m);
}
.heading {
  line-height: 1.2;
  font-size: var(--fluid-heading-m);
}
.heading--4xl {
  font-size: var(--fluid-heading-4xl);
}
.heading--3xl {
  font-size: var(--fluid-heading-3xl);
}
.heading--2xl {
  font-size: var(--fluid-heading-2xl);
}
.heading--xl {
  font-size: var(--fluid-heading-xl);
}
.heading--l {
  font-size: var(--fluid-heading-l);
}
.heading--m {
  font-size: var(--fluid-heading-m);
}
.heading--s {
  font-size: var(--fluid-heading-s);
}
.heading--xs {
  font-size: var(--fluid-heading-xs);
}
.text {
  font-size: 1rem;
  font-size: var(--fluid-text-m);
  line-height: 1.5;
}
.text--l {
  font-size: var(--fluid-text-l);
}
.text--s {
  font-size: var(--fluid-text-s);
}
.text--xs {
  font-size: var(--fluid-text-xs);
}
[class*="heading_wrapper"] {
  margin-bottom: 2rem;
}
.heading_wrapper--section {
  margin-bottom: 4rem;
}
.heading_wrapper--cover, .heading_wrapper--zero {
  margin-bottom: 0;
}
.heading, .card__heading {
  font-family: "Satoshi", "Open Sans", Arial, sans-serif;
  font-weight: 700;
  font-style: normal;
  color: #c19c60;
}
.heading--hero {
  font-size: var(--fluid-heading-4xl);
  color: #fff;
  max-width: 1200px;
}
.heading--hero--small {
  font-size: var(--fluid-heading-3xl);
}
.heading--cover {
  font-size: var(--fluid-heading-2xl);
  color: #fff;
}
.heading--section {
  font-size: var(--fluid-heading-xl);
}
.heading--content {
  font-size: var(--fluid-heading-xs);
}
.heading--thin {
  font-weight: 300;
}
[class*="heading--before"] {
  color: #c19c60;
  font-weight: 700;
  font-size: var(--fluid-text-m);
  max-width: 600px;
  margin-bottom: 2rem;
}
.heading--before::after {
  content: "";
  height: 3px;
  width: 3rem;
  background: #808080;
  display: block;
  position: relative;
  top: 1rem;
}
.heading--before--hero, .heading--before--cover {
  font-size: var(--fluid-text-l);
  color: #ffda9e;
}
[class*="heading--after"] {
  font-weight: 300;
  font-size: var(--fluid-heading-xs);
  max-width: 600px;
  margin-top: -1rem;
  color: #222222;
}
.heading--after--hero, .heading--after--cover {
  font-size: var(--fluid-heading-s);
  color: #8A8A8A;
}
body, .hcs {
  font-family: "Satoshi", "Open Sans", Arial, sans-serif;
  font-weight: 400;
  font-style: normal;
  color: #222222;
}
.text a {
  font-weight: 700;
  text-decoration: underline;
}
.text a:hover {
  opacity: 0.7;
}
.text blockquote {
  font-size: var(--fluid-text-l);
  margin-bottom: 3rem;
  border-color: #c19c60;
}
.rich-text td, .tabelle td {
  padding: 0.3rem 2rem;
  padding-left: 0;
}
.section .rich-text h1, .section .rich-text h2, .section .rich-text h3, .section .rich-text h4, .section .rich-text h5, .section .rich-text h6, .flexible_row .rich-text h1, .flexible_row .rich-text h2, .flexible_row .rich-text h3, .flexible_row .rich-text h4, .flexible_row .rich-text h5, .flexible_row .rich-text h6, .text .rich-text h1, .text .rich-text h2, .text .rich-text h3, .text .rich-text h4, .text .rich-text h5, .text .rich-text h6 {
  font-size: var(--fluid-text-l);
  margin-top: 1rem;
  display: block;
  margin-bottom: 1rem;
  font-family: "Satoshi", "Open Sans", Arial, sans-serif;
  font-weight: 700;
  font-style: normal;
  color: #222222;
}
.section .rich-text hr, .flexible_row .rich-text hr, .text .rich-text hr {
  margin: 2rem 0;
}
.text > ul, .text > ol, .card__text > ul, .card__text > ol {
  margin: 1rem 0;
  padding-inline-start: 1rem;
}
.text li, .card__text li {
  line-height: 1.2;
  padding: 0;
  margin: 0.5rem 0;
  padding-left: 0.5rem;
}
.text ol li, .card__text ol li {
  padding-left: 0.5rem;
}
.text ol li::before, .card__text ol li::before {
  content: none;
}
.text ol li::marker, .card__text ol li::marker {
  font-weight: bold;
}
.text--liste ul, .card__text--liste ul {
  list-style: none;
}
.text--liste li, .card__text--liste li {
  padding-left: 0;
  margin-left: 0;
}
.text--liste li::before, .card__text--liste li::before {
  content: "•";
  color: #222222;
  font-weight: bold;
  display: inline-block;
  width: 1.1rem;
  margin-left: -1.1rem;
}
.text--iconliste > ul, .card__text--iconliste > ul {
  list-style: none;
  padding-inline-start: 0;
  margin: 0;
}
.text--iconliste > ul > li::before, .card__text--iconliste > ul > li::before {
  content: "";
  padding-left: 1.9rem;
  background: url(/wp-content/uploads/bullet-points.svg) no-repeat left center;
  background-size: 1.3em;
  width: 1.9rem;
}
.ausstattungsliste .liste__item {
  margin-bottom: 1rem;
}
.ausstattungsliste .liste__item .icon {
  opacity: 0.5;
  filter: grayscale(1);
}
.ausstattungsliste .liste__item .content {
  margin-left: 1rem;
  font-size: var(--fluid-text-m);
  font-weight: 700;
}
.section--rot .text--liste::before, .section--rot .card__text--liste::before {
  color: #fff;
}
.section--rot .text--iconliste li, .section--rot .card__text--iconliste li {
  filter: brightness(100);
}
.section--rot .text--checkliste li, .section--rot .card__text--checkliste li {
  filter: brightness(100);
}
/*
///########################################################################
///------------------- 02 sections
///########################################################################
*/
body {
  background: #000;
}
.hero_row {
  position: relative;
  min-height: 100vh;
  min-height: 100svh;
}
.hero_row .background_wrapper {
  overflow: hidden;
}
.hero_row .background_wrapper, .hero_row .background__image, .hero_row .background__image::after, .hero_row .background__gradient, .hero_row .background__raster {
  content: "";
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
}
.hero_row .background__image {
  background-size: cover;
  background-position: bottom right;
  background-repeat: no-repeat;
  animation: zoom-out--key 10s ease-in-out infinite alternate both;
  z-index: 1;
}
.hero_row .background__image::after {
  display: none;
  z-index: 2;
}
@supports (mix-blend-mode: hue) {
  .hero_row .background__image::after {
    display: none;
    background-color: #c19c60;
    mix-blend-mode: hue;
    z-index: 2;
  }
}
.hero_row .background__gradient {
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.85) 15%, rgba(0, 0, 0, 0) 75%);
  z-index: 4;
}
.hero_row .background__raster {
  background-size: cover;
  background-color: transparent;
  background-repeat: no-repeat;
  background-position: bottom left;
  background-image: url(/wp-content/uploads/balu_freigestellt.png);
  z-index: 5;
}
.hero_row .content_wrapper {
  position: relative;
  z-index: 10;
}
.hero_row .content_wrapper .text {
  max-width: 600px;
  color: #fff;
}
@media (orientation: portrait) {
  .hero_row {
    min-height: 75vh;
    min-height: 75svh;
  }
}
.hero_row--subpage, .hero_row--post {
  min-height: 65vh;
  min-height: 65svh;
}
@media (orientation: portrait) {
  .hero_row--subpage, .hero_row--post {
    min-height: 50vh;
    min-height: 50svh;
  }
}
.section {
  background-color: #fff;
  align-items: center;
  display: flex;
  flex-direction: column;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}
.section [class*="_ctr"] {
  align-items: flex-start;
  display: flex;
  flex-direction: column;
  margin-left: auto;
  margin-right: auto;
}
.section--dark, .col--dark {
  background-color: #222222;
}
.section--white, .col--white {
  background-color: #fff;
}
.section--grau, .col--grau {
  background-color: #F3F3F3;
}
.section--color, .col--color {
  background-color: #8f6a2e;
}
.section--gold, .col--gold {
  background: linear-gradient(to bottom right, #ffda9e 0%, #BB8E47 65%, #f3ce92 100%) !important;
}
.section--texture, .col--texture {
  background-color: #ffda9e;
  background-size: 10px;
}
.section--color, .section--dark, .col--color, .col--dark {
  color: #fff;
}
.section--color .heading, .section--color .text, .section--dark .heading, .section--dark .text, .col--color .heading, .col--color .text, .col--dark .heading, .col--dark .text {
  color: #fff;
}
.section--color .text strong, .section--dark .text strong, .col--color .text strong, .col--dark .text strong {
  color: #fff;
}
.section--gold .heading, .section--gold .text, .col--gold .heading, .col--gold .text {
  color: #222222;
}
.watermark--left, .watermark--right {
  background-image: url(/wp-content/uploads/pfoten_bg_grafik_hell-02.svg);
  background-repeat: no-repeat;
  background-size: 65vw auto;
}
.watermark--left.section--dark, .watermark--right.section--dark {
  background-image: url(/wp-content/uploads/icon_watermark_dunkel.svg);
}
.watermark--left {
  background-position: bottom -3vh left -3vw;
}
.watermark--right {
  background-position: bottom -10vh right -10vw;
}
.brxe-divider {
  margin: 3rem auto;
}
.divider {
  box-shadow: 0 1.5rem 1.5rem -0.5rem #000000;
}
.divider--top, .divider--bottom {
  position: relative;
}
.divider--top::before, .divider--bottom::after {
  width: 101%;
  height: 15%;
  content: "";
  left: -1px;
  right: 0;
  display: block;
  position: absolute;
  z-index: 5;
  background-repeat: no-repeat;
  background-size: 101% auto;
  pointer-events: none;
}
.divider--top::before {
  top: 0;
}
.divider--bottom::after {
  bottom: -1px;
  transform: rotate(180deg);
}
.section--50vh {
  min-height: 50vh;
  min-height: 50svh;
}
.section--75vh {
  min-height: 75vh;
  min-height: 75svh;
}
.section--100vh {
  min-height: 100vh;
  min-height: 100svh;
}
.cover_row {
  height: 50vh;
  position: relative;
  z-index: 1;
}
.cover_row::after {
  content: "";
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.85) 15%, rgba(0, 0, 0, 0) 75%);
  z-index: -1;
}
.flexible_row .col_wrapper, .section .col_wrapper {
  margin-bottom: 3rem;
}
.flexible_row .col_wrapper:last-child, .section .col_wrapper:last-child {
  margin-bottom: 0;
}
.flexible_row > div > .col_wrapper:not(:first-of-type) > .col > div:not(:first-of-type) > .heading--section, .flexible_row > div > .col_wrapper > .col > div:not(:first-of-type) > .heading--section {
  margin-top: 7rem;
}
.flexible_row > div > .col_wrapper:not(:first-of-type) > .col > div:not(:first-of-type) > .heading--content, .flexible_row > div > .col_wrapper > .col > div:not(:first-of-type) > .heading--content {
  margin-top: 4rem;
}
.kontakt_row .form_wrapper, .flexible_row .form_wrapper, .formular_row .form_wrapper {
  padding: 3rem;
  background: #fff;
  box-shadow: rgba(17, 17, 26, 0.2) 0rem 0rem 1rem -0.1rem;
  border-radius: 0.75rem;
  width: 100%;
}
@media (max-width: 768px) {
  .kontakt_row .form_wrapper, .flexible_row .form_wrapper, .formular_row .form_wrapper {
    padding: 2rem;
  }
}
@media (max-width: 500px) {
  .kontakt_row .form_wrapper, .flexible_row .form_wrapper, .formular_row .form_wrapper {
    padding: 1rem;
  }
}
/*
///########################################################################
///------------------- 03 Template / Theme
///########################################################################
*/
#brx-header, .hcs_header--js {
  position: fixed;
  top: 0;
  z-index: 1000;
}
.header__topbar {
  background: #c19c60;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  height: 2.5rem;
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
}
.header__topbar [class*="mdl"] {
  margin: 0;
}
.header__main {
  transition: all 0.3s ease;
  background: transparent;
}
.header__main[class*="_ctr"] {
  transition: all 0.3s ease;
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
}
.header__main [class*="mdl"] {
  margin: 0;
}
.scrolled .header__topbar {
  height: 0;
  padding: 0;
  overflow: hidden;
}
.scrolled .header__main {
  background: #ffda9e;
  box-shadow: 0 -0.5rem 1.9rem -0.1rem #222222;
  border-bottom: 0 solid #F3F3F3;
}
.scrolled .header__main[class*="_ctr"] {
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
}
.scrolled .header__main .logo_col {
  filter: brightness(1);
}
.scrolled .header__main .logo svg {
  transform: scale(0.8);
}
.scrolled .header__main .logo:hover svg {
  transform: scale(0.75);
}
.header__main .col {
  animation: header-stagger--key 0.6s cubic-bezier(0.39, 0.575, 0.565, 1) both;
  transform-origin: left;
}
.header__main .col:nth-child(1) {
  animation-delay: 0.4s;
}
.header__main .col:nth-child(2) {
  animation-delay: 0.5s;
}
.header__main .col:nth-child(3) {
  animation-delay: 0.6s;
}
.header__main .col:nth-child(4) {
  animation-delay: 0.7s;
}
.header__main .col:nth-child(5) {
  animation-delay: 0.8s;
}
.header__main .col:nth-child(6) {
  animation-delay: 0.9s;
}
@keyframes header-stagger--key {
  0% {
    transform: translateY(-50%);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}
@media (max-width: 1024px) {
  .header__topbar {
    display: none;
  }
}
.footer__content {
  background-color: #222;
}
.footer__content [class*="_ctr"] {
  padding-top: 3rem;
  padding-bottom: 3rem;
}
.footer__imprint {
  background-color: #c19c60;
}
.footer__imprint [class*="_ctr"] {
  padding-top: 0.4rem;
  padding-bottom: 0.4rem;
}
.footer__content .col_wrapper {
  justify-content: center;
  gap: 3rem;
}
.footer__content .col_wrapper .col {
  width: auto;
  min-width: 200px;
}
.footer__content .col_wrapper .col:first-child {
  flex-grow: 1;
}
.footer {
  color: #D9D9D9;
}
.footer__content .heading {
  color: #c19c60;
  font-size: var(--fluid-text-m);
  text-transform: uppercase;
  font-weight: 700;
}
.footer__content .col, .footer__content .text {
  font-size: var(--fluid-text-s);
}
.footer__imprint .text {
  font-size: var(--fluid-text-xs);
}
.footer__imprint .text a:hover {
  color: #ffda9e;
}
.footer__info-text {
  max-width: 400px;
}
.footer__social-icons i::before {
  font-size: 1.5rem;
  margin-right: 1rem;
}
.footer__social-icons i:hover {
  color: #ffda9e;
}
.footer__nav .bricks-nav-menu li {
  margin: 0;
}
.footer__nav a {
  margin-bottom: 0.3rem;
}
.footer__nav a:hover {
  color: #ffda9e;
}
.footer__kontakt-box {
  gap: 0.4rem;
}
.footer__kontakt-box li svg {
  width: 1.2rem;
  fill: #ffda9e;
}
.footer__kontakt-box li a > span {
  display: block;
}
.footer__kontakt-box li:hover span {
  text-decoration: underline;
}
.footer__zeiten-box table {
  border-collapse: collapse;
}
.footer__zeiten-box tr {
  display: table-row;
}
.footer__zeiten-box tr:last-child td {
  border-bottom: none;
}
.footer__zeiten-box tr:first-child td {
  padding-top: 0;
}
.footer__zeiten-box td {
  padding: 0.7rem 2.5rem;
  padding-left: 0;
  border-bottom: 1px solid #D9D9D9;
}
.footer__zeiten-box td:last-child td {
  border-bottom: none;
}
.footer__zeiten-box td:last-child {
  padding-right: 0;
}
.pum.pum-theme-heicom-popup-theme-2-0 .pum-container {
  padding: 3rem;
  border-radius: 1rem;
}
.pum.pum-theme-heicom-popup-theme-2-0 .pum-container .pum-title {
  margin-bottom: 3rem;
  color: #c19c60;
  font-size: 2rem;
  text-transform: uppercase;
  letter-spacing: 2px;
}
.pum.pum-theme-heicom-popup-theme-2-0 .pum-container .pum-content {
  margin-bottom: 3rem;
}
.pum.pum-theme-heicom-popup-theme-2-0 .pum-container .pum-content.popmake-content:focus-visible {
  outline: -webkit-focus-ring-color auto 0 !important;
}
.pum.pum-theme-heicom-popup-theme-2-0 .pum-container .pum-content + .pum-close {
  position: absolute;
  height: auto;
  width: 100%;
  left: auto;
  right: 0px;
  bottom: 0px;
  top: auto;
  text-align: center;
  padding: 1rem;
  font-weight: 700;
  font-size: 0.9rem;
  border-top: 1px solid #ddd;
  border-bottom-left-radius: 1rem;
  border-bottom-right-radius: 1rem;
  background-color: #c19c60;
  transition: all 0.2s ease-in-out;
  color: #fff;
}
.pum.pum-theme-heicom-popup-theme-2-0 .pum-container .pum-content + .pum-close:hover, .pum.pum-theme-heicom-popup-theme-2-0 .pum-container .pum-content + .pum-close:focus {
  background-color: #ddd;
  color: #333;
}
.pum-content.popmake-content:focus-visible, .pum-content *:focus, .pum-overlay .pum-content {
  outline: none !important;
}
@media not all and (min-resolution: 0.001dpcm) {
  @supports (-webkit-appearance:none) {
    .pum-overlay .pum-content {
      outline: none !important;
    }
  }
}
@media (max-width: 500px) {
  .pum.pum-theme-heicom-popup-theme-2-0 .pum-container {
    padding: 2rem;
  }
  .pum.pum-theme-heicom-popup-theme-2-0 .pum-container .pum-title {
    font-size: 1.7rem;
    letter-spacing: 1px;
  }
}
.hcs .form .frm_forms .frm_fields_container label, .hcs .form .frm_forms .frm_fields_container input, .hcs .form .frm_forms .frm_fields_container .frm_inline_box, .hcs .form .frm_forms .frm_fields_container textarea {
  font-family: "Satoshi", "Open Sans", Arial, sans-serif !important;
}
.hcs .form .frm_style_formidable-style.with_frm_style label.frm_primary_label {
  font-size: var(--fluid-text-xs);
  font-weight: 400;
  color: #222222;
  opacity: 1;
}
.hcs .form .frm_form_fields .form-field input[type="text"], .hcs .form .frm_form_fields .form-field input[type="tel"], .hcs .form .frm_form_fields .form-field input[type="email"], .hcs .form .frm_form_fields .form-field input[type="number"], .hcs .form .frm_form_fields .form-field textarea, .hcs .form .frm_form_fields .form-field select {
  border-width: 0;
  border-bottom-color: #fff;
  border-bottom-width: 0;
  background: #EFEFEF;
  border-radius: 0.25rem;
  box-shadow: none;
  padding: 1rem 1rem;
  font-size: var(--fluid-text-m);
  color: #222222;
  height: auto;
}
.hcs .form .frm_form_fields .form-field input[type="text"]:active, .hcs .form .frm_form_fields .form-field input[type="text"]:focus, .hcs .form .frm_form_fields .form-field input[type="tel"]:active, .hcs .form .frm_form_fields .form-field input[type="tel"]:focus, .hcs .form .frm_form_fields .form-field input[type="email"]:active, .hcs .form .frm_form_fields .form-field input[type="email"]:focus, .hcs .form .frm_form_fields .form-field input[type="number"]:active, .hcs .form .frm_form_fields .form-field input[type="number"]:focus, .hcs .form .frm_form_fields .form-field textarea:active, .hcs .form .frm_form_fields .form-field textarea:focus, .hcs .form .frm_form_fields .form-field select:active, .hcs .form .frm_form_fields .form-field select:focus {
  border-width: 0;
  border-bottom-color: #fff;
  border-bottom-width: 0;
  background: #dbdbdb;
  border-radius: 0.25rem;
  box-shadow: none;
  padding: 1rem 1rem;
  font-size: var(--fluid-text-m);
  color: #222222;
  outline: none;
  height: auto;
}
.hcs .form .frm_form_fields .form-field input[type="text"]::-webkit-input-placeholder, .hcs .form .frm_form_fields .form-field input[type="tel"]::-webkit-input-placeholder, .hcs .form .frm_form_fields .form-field input[type="email"]::-webkit-input-placeholder, .hcs .form .frm_form_fields .form-field input[type="number"]::-webkit-input-placeholder, .hcs .form .frm_form_fields .form-field textarea::-webkit-input-placeholder, .hcs .form .frm_form_fields .form-field select::-webkit-input-placeholder {
  color: #222222;
  opacity: 0.4;
}
.hcs .form .frm_form_fields .form-field select {
  height: auto;
}
.hcs .form .frm_forms label[for=field_gf6zy-0], .hcs .form .frm_forms label[for=field_tmf4-0] {
  font-size: var(--fluid-text-xs);
  color: #222222;
}
.hcs .form .frm_forms label[for=field_gf6zy-0] a, .hcs .form .frm_forms label[for=field_tmf4-0] a {
  font-size: var(--fluid-text-xs);
  color: #222222;
  text-decoration: underline;
}
input:-webkit-autofill, input:-webkit-autofill:hover, input:-webkit-autofill:focus textarea:-webkit-autofill, textarea:-webkit-autofill:hover textarea:-webkit-autofill:focus, select:-webkit-autofill, select:-webkit-autofill:hover, select:-webkit-autofill:focus {
  -webkit-box-shadow: 0 0 0px 1000px #EFEFEF inset !important;
  -webkit-text-fill-color: #222222;
}
.hcs .form .frm_forms .frm_message {
  background: #fff;
  border: none;
}
.hcs .form .frm_forms .frm_message h4 {
  font-size: var(--fluid-heading-xs);
  margin-bottom: 1rem;
}
.hcs .form .frm_forms .frm_message p {
  color: #222222;
  font-size: var(--fluid-text-m);
}
#wp-auth-check-wrap.hidden {
  display: none;
}
/* Flat Style Button */
.frm_checkbox, .frm_radio:not(.frm_image_option) {
  margin-left: 0px;
  margin-bottom: 15px !important;
}
.frm_checkbox label, .frm_radio:not(.frm_image_option) label {
  height: auto;
  position: relative;
  padding: 0 0 0 35px !important;
  /* Texteinzug 10px */
  text-indent: 0 !important;
  margin-bottom: 0;
  cursor: pointer;
  vertical-align: bottom;
}
.frm_checkbox input[type=checkbox], .frm_checkbox input[type=radio], .frm_radio:not(.frm_image_option) input[type=checkbox], .frm_radio:not(.frm_image_option) input[type=radio] {
  position: absolute !important;
  margin-left: -9999px;
  visibility: hidden;
}
.frm_checkbox label input[type=checkbox], .frm_checkbox label input[type=radio], .frm_radio:not(.frm_image_option) label input[type=checkbox], .frm_radio:not(.frm_image_option) label input[type=radio] {
  position: absolute;
  opacity: 0;
  cursor: pointer;
  height: 0;
  width: 0;
}
.frm_checkbox span, .frm_radio:not(.frm_image_option) span {
  position: absolute;
  top: 0;
  left: 0;
  height: 25px;
  width: 25px;
  background-color: #eee;
}
.frm_checkbox label:hover input[type=checkbox] ~ span, .frm_checkbox label input[type=radio]:checked ~ span, .frm_radio:not(.frm_image_option) label:hover input[type=checkbox] ~ span, .frm_radio:not(.frm_image_option) label input[type=radio]:checked ~ span {
  background-color: #ccc;
}
.frm_checkbox label input[type=checkbox]:checked ~ span, .frm_checkbox label input[type=radio]:checked ~ span, .frm_radio:not(.frm_image_option) label input[type=checkbox]:checked ~ span, .frm_radio:not(.frm_image_option) label input[type=radio]:checked ~ span {
  background-color: #ffda9e;
}
.frm_checkbox span:after, .frm_radio:not(.frm_image_option) span:after {
  content: "";
  position: absolute;
  display: none;
}
.frm_checkbox label input[type=checkbox]:checked ~ span:after, .frm_checkbox label input[type=radio]:checked ~ span:after, .frm_radio:not(.frm_image_option) label input[type=checkbox]:checked ~ span:after, .frm_radio:not(.frm_image_option) label input[type=radio]:checked ~ span:after {
  display: block;
}
.frm_checkbox label span:after, .frm_radio:not(.frm_image_option) label span:after {
  left: 9px;
  top: 5px;
  width: 5px;
  height: 10px;
  border: solid white;
  border-width: 0 3px 3px 0;
  transform: rotate(45deg);
}
.sfrm_radio.frm_image_option span {
  position: relative;
  width: 100%;
  height: auto;
  background: transparent;
}
input[type="radio"] + .frm_image_option_container, input[type="checkbox"] + .frm_image_option_container {
  filter: grayscale(1);
}
input[type="radio"]:checked + .frm_image_option_container, input[type="checkbox"]:checked + .frm_image_option_container {
  filter: grayscale(0);
}
@media (max-width: 1366px) {
  .with_frm_style input[type=text], .with_frm_style input[type=password], .with_frm_style input[type=email], .with_frm_style input[type=number], .with_frm_style input[type=url], .with_frm_style input[type=tel], .with_frm_style input[type=phone], .with_frm_style input[type=search], .with_frm_style select, .with_frm_style textarea, .frm_form_fields_style, .with_frm_style .frm_scroll_box .frm_opt_container, .frm_form_fields_active_style, .frm_form_fields_error_style, .with_frm_style .frm-card-element.StripeElement, .with_frm_style .chosen-container-multi .chosen-choices, .with_frm_style .chosen-container-single .chosen-single {
    font-size: 1rem !important;
  }
}
.splashscreen--row {
  height: 100%;
  width: 100%;
  z-index: 9999999;
  position: fixed;
  background: #222222;
  display: flex;
  justify-content: center;
  align-content: center;
  align-items: center;
  animation: splashscreen-fade;
  animation-duration: 0.5s;
  animation-delay: 1.25s;
  animation-fill-mode: forwards;
  animation-timing-function: ease-in;
}
.splashscreen--row img {
  max-width: 85vw;
}
@keyframes splashscreen-fade {
  0% {
    opacity: 1;
  }
  90% {
    opacity: 0;
  }
  100% {
    opacity: 0;
    visibility: hidden;
  }
}
.wp_row .post-navigation .label {
  font-weight: 300;
  text-transform: none;
  font-size: var(--fluid-text-s);
}
.wp_row .post-navigation .title {
  font-weight: 700;
  text-transform: none;
  font-size: var(--fluid-text-m);
}
@media (max-width: 1024px) {
  .wp_row {
    display: none;
  }
}
/*
///########################################################################
///------------------- 04 UI/UX
///########################################################################
*/
.header__topbar[class*="_ctr"] {
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
}
.header__topbar .kontakt-box, .header__topbar .social-box {
  gap: 2rem 2rem;
}
.header__topbar .kontakt-box li a, .header__topbar .kontakt-box li span, .header__topbar .social-box li a, .header__topbar .social-box li span {
  color: #fff;
  font-size: var(--fluid-text-xs);
  font-weight: 400;
  height: 0.9rem;
}
.header__topbar .kontakt-box li svg, .header__topbar .social-box li svg {
  width: 0.9rem;
  height: 0.9rem;
  fill: #fff;
}
.header__topbar .kontakt-box li:hover span, .header__topbar .social-box li:hover span {
  text-decoration: underline;
}
.header__main .burger_col {
  display: none;
}
.header__main .logo_col {
  display: flex;
  filter: brightness(100);
}
.header__main .logo_col svg {
  transition: all 0.3s ease;
  height: 40px;
  width: auto;
  max-width: 40vw;
  max-height: 7vh;
}
.header__main .logo_col:hover svg {
  transform: scale(0.95);
}
.header__main .nav_col {
  flex-grow: 1;
  display: flex;
  justify-content: center;
  flex-direction: row;
}
.header__main .button_col .button {
  display: block;
}
@media (max-width: 1366px) {
  .header__main .burger_col {
    display: flex;
  }
  .header__main .logo_col {
    flex-grow: 1;
    justify-content: center;
  }
  .header__main .nav_col {
    display: none;
  }
}
@media (max-width: 768px) {
  .header__main .logo_col {
    justify-content: flex-end;
  }
  .header__main .button_col {
    display: none;
  }
}
.header__off-canvas {
  width: 500px;
  transform: translateX(-500px);
  transition: transform 0.6s cubic-bezier(0.32, 0, 0.67, 0);
  position: fixed;
  background: #fff;
  z-index: 1020;
  left: 0;
  top: 0;
  height: 100vh;
  overflow: hidden;
  scrollbar-width: none;
  /* Firefox */
  -ms-overflow-style: none;
  /* Internet Explorer 10+ */
  -webkit-overflow-scrolling: touch;
}
.header__off-canvas::-webkit-scrollbar {
  display: none;
}
.hcs_header--js.open .header__off-canvas {
  transform: translateX(0);
  transition: transform 0.6s cubic-bezier(0.33, 1, 0.68, 1);
}
.header__off-canvas .wrapper {
  height: 100vh;
  height: 100svh;
  max-height: 100vh;
  max-height: 100svh;
  overflow-y: scroll;
  background: #fff;
  padding: 2rem;
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  scrollbar-width: none;
  /* Firefox */
  -ms-overflow-style: none;
  /* Internet Explorer 10+ */
  -webkit-overflow-scrolling: touch;
  position: relative;
}
.header__off-canvas .wrapper::-webkit-scrollbar {
  display: none;
}
.header__off-canvas .burger {
  display: flex;
  justify-content: flex-end;
  position: absolute;
  top: 0;
  right: 0;
}
.header__off-canvas .logo {
  margin-top: 5vh;
  margin-bottom: 5rem;
}
.header__off-canvas .logo svg {
  max-width: 200px;
}
.header__off-canvas .nav {
  margin-bottom: 3rem;
  display: flex;
  flex-grow: 1;
  align-items: flex-start;
}
@media (max-width: 500px) {
  .hcs .header-mobile--row {
    width: 100%;
    max-width: 100vw;
    transform: translateX(-100%);
  }
}
.header__overlay, .modal__overlay {
  position: fixed;
  z-index: 1010;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  opacity: 0;
  transition: opacity 0.6s ease 0.05s, transform 0s ease 0.6s;
  transform: translateX(-100vw);
  background-color: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(15px);
}
.hcs_header--js.open .header__overlay, .modal__overlay.open {
  opacity: 1;
  transform: translateX(0);
  transition: opacity 0.6s ease;
}
.header__main .nav li a {
  transition: all 0.1s ease-out;
  color: #fff;
  border-bottom: 0px solid transparent;
  line-height: 1.5;
  margin: 0 1rem;
  font-weight: 400;
  font-size: var(--fluid-text-m);
  padding: 0;
}
.header__main .nav li a:hover, .header__main .nav li a:active, .header__main .nav li a:focus {
  border-color: #fff;
}
.header__main .nav li.current-menu-item a {
  border-bottom: 0px solid #ffda9e;
}
.header__main .nav .sub-menu {
  background: #fff;
  padding-top: 2rem;
  padding-bottom: 0.5rem;
  border-radius: 0.75rem;
  width: 300px;
  white-space: normal;
  border-left: 2px solid #c19c60;
  border-bottom: 2px solid #c19c60;
}
.header__main .nav .sub-menu li a {
  font-weight: 400;
  margin: 1rem 2rem;
  color: #222222;
}
.header__main .nav .sub-menu li a:hover, .header__main .nav .sub-menu li a:active, .header__main .nav .sub-menu li a:focus {
  border-color: #fff;
  color: #c19c60;
}
.scrolled .header__main .nav li a {
  color: #222222;
}
.header__off-canvas .nav li {
  white-space: normal;
}
.header__off-canvas .nav li a, .header__off-canvas .nav li .sub-menu a {
  transition: all 0.1s ease;
  font-size: var(--fluid-text-l);
  line-height: 1.2;
  font-weight: 400;
  color: #222222;
  margin: 0.4rem 0;
  display: flex;
}
.header__off-canvas .nav li a:hover, .header__off-canvas .nav li a:active, .header__off-canvas .nav li a:focus, .header__off-canvas .nav li .sub-menu a:hover, .header__off-canvas .nav li .sub-menu a:active, .header__off-canvas .nav li .sub-menu a:focus {
  opacity: 0.5;
}
.header__off-canvas .nav li .sub-menu a {
  font-size: var(--fluid-text-m);
  border-left: 2px solid #c19c60;
  margin: 0.7rem 0;
  opacity: 0.8;
}
.header__off-canvas .nav li .sub-menu li:first-of-type {
  margin-top: 1rem;
}
.header__off-canvas .nav li .sub-menu li:last-of-type {
  margin-bottom: 1rem;
}
.header__off-canvas .nav li.current-menu-item a {
  font-weight: 700;
}
.header__off-canvas .nav--accordion ul.sub-menu {
  opacity: 1;
  visibility: visible;
  background: none;
  display: none;
  overflow: hidden;
  max-height: 0;
}
.header__off-canvas .nav--accordion ul.sub-menu.open {
  opacity: 1;
  display: contents;
  max-height: 100%;
}
.header__off-canvas .nav li {
  opacity: 0;
  transition: all 1.5s cubic-bezier(0.22, 1, 0.36, 1);
  transition-property: transform, opacity;
  transform: translateX(-300px) translateZ(0);
}
.hcs_header--js.open .header__off-canvas .nav li {
  opacity: 1;
  transform: translateX(0) translateZ(0);
}
.hcs_header--js.open .header__off-canvas .nav li:nth-child(1) {
  transition-delay: 0.1s;
}
.hcs_header--js.open .header__off-canvas .nav li:nth-child(2) {
  transition-delay: 0.15s;
}
.hcs_header--js.open .header__off-canvas .nav li:nth-child(3) {
  transition-delay: 0.2s;
}
.hcs_header--js.open .header__off-canvas .nav li:nth-child(4) {
  transition-delay: 0.25s;
}
.hcs_header--js.open .header__off-canvas .nav li:nth-child(5) {
  transition-delay: 0.3s;
}
.hcs_header--js.open .header__off-canvas .nav li:nth-child(6) {
  transition-delay: 0.35s;
}
.hcs_header--js.open .header__off-canvas .nav li:nth-child(7) {
  transition-delay: 0.4s;
}
.hcs_header--js.open .header__off-canvas .nav li:nth-child(8) {
  transition-delay: 0.45s;
}
.hcs_header--js.open .header__off-canvas .nav li:nth-child(9) {
  transition-delay: 0.5s;
}
.hcs_header--js.open .header__off-canvas .nav li:nth-child(10) {
  transition-delay: 0.55s;
}
.hcs_header--js.open .header__off-canvas .nav li:nth-child(11) {
  transition-delay: 0.6s;
}
.hcs_header--js.open .header__off-canvas .nav li:nth-child(12) {
  transition-delay: 0.65s;
}
.hcs_header--js.open .header__off-canvas .nav li:nth-child(13) {
  transition-delay: 0.7s;
}
.hcs_header--js.open .header__off-canvas .nav li:nth-child(14) {
  transition-delay: 0.75s;
}
.hcs_header--js.open .header__off-canvas .nav li:nth-child(15) {
  transition-delay: 0.8s;
}
.hcs_header--js.open .header__off-canvas .nav li:nth-child(16) {
  transition-delay: 0.85s;
}
.burger__btn {
  cursor: pointer;
  pointer-events: auto;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  align-content: flex-start;
  width: auto;
  height: auto;
  z-index: 130;
  margin-left: 0;
  padding: 0.5rem;
  padding-right: 1rem;
  padding-left: 0rem;
  background: none;
  border: none;
  transition: all 0.2s ease-in-out;
}
.burger__btn:active, .burger__btn:focus {
  top: 0;
}
.burger__btn .bar1, .burger__btn .bar2, .burger__btn .bar3 {
  width: 2rem;
  height: 0;
  margin: 0.3rem 0;
  border-radius: 50px;
  background: #fff;
  border: 1px solid #fff;
  transition: all 0.2s ease-in-out;
}
.burger__btn .burger__text {
  color: #fff;
  font-family: "Satoshi", "Open Sans", Arial, sans-serif;
  font-weight: 600;
  font-size: 0.9rem;
  margin-left: 0.5rem;
  transition: all 0.2s ease-in-out;
}
.burger__btn:hover .bar1, .burger__btn:hover .bar3, .burger__btn:active .bar1, .burger__btn:active .bar3, .burger__btn:focus .bar1, .burger__btn:focus .bar3 {
  transform: translateX(-0.3rem);
}
.burger__btn:hover .bar2, .burger__btn:active .bar2, .burger__btn:focus .bar2 {
  transform: translateX(0.3rem);
}
.scrolled .burger__btn .bar1, .scrolled .burger__btn .bar2, .scrolled .burger__btn .bar3 {
  background: #222222;
  border: 1px solid #222222;
}
.scrolled .burger__btn .burger__text {
  color: #222222;
}
.burger__btn--close {
  background: #4a4a49;
  padding: 1.5rem 0.6rem;
  padding-right: 0.65rem;
}
.burger__btn--close .bar1, .burger__btn--close .bar2, .burger__btn--close .bar3 {
  background: #fff;
  border: 1px solid #fff;
  margin: 0;
}
.burger__btn--close .burger__text {
  color: #fff;
  display: none;
}
.burger__btn--close .bar1, .burger__btn--close:hover .bar1 {
  transform: rotate(-45deg) translateY(1px);
}
.burger__btn--close .bar2, .burger__btn--close:hover .bar2 {
  opacity: 0;
  display: none;
}
.burger__btn--close .bar3, .burger__btn--close:hover .bar3 {
  transform: rotate(45deg) translateY(-1px);
}
.burger__btn--close:hover, .burger__btn--close:active, .burger__btn--close:focus {
  background: #c19c60;
}
.burger__btn--close:hover .bar1, .burger__btn--close:hover .bar2, .burger__btn--close:hover .bar3, .burger__btn--close:active .bar1, .burger__btn--close:active .bar2, .burger__btn--close:active .bar3, .burger__btn--close:focus .bar1, .burger__btn--close:focus .bar2, .burger__btn--close:focus .bar3 {
  background: #fff;
  border: 1px solid #fff;
}
.burger__btn--close:hover .burger__text, .burger__btn--close:active .burger__text, .burger__btn--close:focus .burger__text {
  color: #fff;
}
/*
///########################################################################
///------------------- 05 Elemente
///########################################################################
*/
.grid .card {
  max-width: 100%;
}
.card {
  box-shadow: rgba(17, 17, 26, 0.2) 0rem 0rem 1rem -0.1rem;
  background: #fff;
  border-radius: 0.75rem;
  overflow: hidden;
  min-width: 300px;
  max-width: 500px;
  display: flex;
  align-items: flex-start;
}
.card .inner_wrapper {
  padding: 0.5rem 2.5rem;
}
.card > div:first-child .inner_wrapper {
  padding-top: 1.5rem;
}
.card > div:last-child .inner_wrapper {
  padding-bottom: 1.5rem;
}
.card__image {
  max-height: 40vh;
  object-fit: cover;
}
.card__icon, .card__icon::before {
  width: 2rem;
  height: 2rem;
  font-size: 2rem;
  color: #c19c60;
  fill: #c19c60;
  display: block;
}
.card .heading-wrapper > .card__heading:first-child {
  margin-bottom: 3rem;
}
.card__heading {
  font-size: var(--fluid-heading-xs);
  line-height: 1.2;
  font-weight: 700;
  margin-bottom: 0.5rem;
}
.card__heading--small {
  font-size: var(--fluid-text-m);
  font-family: "Satoshi", "Open Sans", Arial, sans-serif;
}
.card__zusatz {
  font-size: var(--fluid-text-xs);
  font-weight: 400;
}
.card__name {
  font-size: var(--fluid-heading-xs);
  margin-bottom: 0.2rem;
}
.card__job-position {
  font-size: var(--fluid-text-s);
  font-weight: 400;
}
.card__text {
  font-size: var(--fluid-text-s);
  line-height: 1.3;
}
.card__text--small {
  font-size: var(--fluid-text-xs);
}
.card__link {
  color: #222222;
  font-weight: 700;
  text-decoration: underline;
  font-size: var(--fluid-text-s);
  transition: all 0.3s ease;
}
.card__link:hover {
  color: #c19c60;
}
.card__link--disabled {
  -webkit-user-select: none;
  /* Safari */
  -ms-user-select: none;
  /* IE 10 and IE 11 */
  user-select: none;
  /* Standard syntax */
}
.card--dark {
  background: #333;
}
.card--dark .card__heading {
  color: #fff;
}
.card--dark .card__text {
  color: #fff;
}
.card--centered .card__heading, .card--centered .card__heading--small, .card--centered .card__zusatz, .card--centered .card__text {
  text-align: center;
  width: 100%;
}
.card--centered .inner_wrapper {
  align-items: center;
}
.card--large .card__icon {
  width: 4rem;
}
.card--large .card__heading {
  font-size: var(--fluid-heading-s);
}
.card--large .card__text {
  font-size: var(--fluid-text-m);
}
@media (max-width: 768px) {
  .card .inner_wrapper {
    padding: 0.5rem 2rem;
  }
}
@media (max-width: 500px) {
  .card .inner_wrapper {
    padding: 0.5rem 1.5rem;
  }
}
.image-card .card__heading {
  margin-bottom: 0.5rem;
  margin-top: 0.5rem;
}
.image-card .card__link {
  margin-top: 1rem;
}
.review-card .image_wrapper {
  gap: 2rem 2rem;
  margin-bottom: 2rem;
}
.review-card .image_wrapper img {
  border-radius: 1rem;
  max-width: 30%;
}
.review-card .card__job {
  margin-top: 1rem;
  font-size: var(--fluid-text-s);
  font-weight: 700;
  color: #c19c60;
}
.review-card .card__job-link {
  font-size: var(--fluid-text-xs);
  text-decoration: underline;
}
.team-card {
  padding: 0;
}
.team-card .background-image_wrapper {
  height: 500px;
  max-height: 60vh;
}
.team-card .inner_wrapper {
  padding: 2rem;
}
.team-card .icon-box {
  gap: 0 0;
}
.slider {
  overflow: hidden;
}
.slider .splide__arrows button svg {
  fill: #fff;
  transform: scale(0.7);
}
.slider .splide__pagination .splide__pagination__page {
  background-color: #4a4a49;
}
.slider .splide__pagination .splide__pagination__page.is-active {
  background-color: #ffda9e;
}
.image-slider {
  border-radius: 0.5rem;
}
.image-slider__slide.splide__slide {
  justify-content: flex-end;
  align-items: flex-start;
}
.image-slider__inner_wrapper {
  margin: 2rem;
  padding: 1rem;
  border-radius: 0.5rem;
  background: rgba(0, 0, 0, 0.5);
}
.image-slider__inner-heading {
  color: #fff;
  font-size: var(--fluid-heading-xs);
}
.image-slider__inner-zusatz {
  color: #fff;
  font-size: var(--fluid-text-m);
}
.image, .image img {
  border-radius: 0.5rem;
  overflow: hidden;
}
.image--no-radius, .image img--no-radius {
  border-radius: 0;
}
.image--heading {
  margin-bottom: 0.5rem;
  font-size: var(--fluid-text-l);
}
.image--caption, .image .bricks-image-caption {
  margin-top: 0.5rem;
  font-style: italic;
  font-size: var(--fluid-text-xs);
  pointer-events: none;
  background: none;
  color: #222222;
}
.hcs .button, .hcs .frm_style_formidable-style.with_frm_style .frm_submit button {
  background-clip: border-box;
  display: inline-block;
  position: relative;
  overflow: hidden;
  text-decoration: none;
  pointer-events: auto;
  cursor: pointer;
  z-index: 1;
  transition: all 0.4s cubic-bezier(0.65, 0, 0.35, 1);
  line-height: 1.5;
  font-weight: 400;
  font-size: var(--fluid-text-s);
  padding: 0.6rem 1.6rem;
  border: 0 solid #c19c60;
  border-radius: 5rem;
  color: #fff;
  border-color: #c19c60;
  background: #4a4a49;
  max-width: 350px;
}
.hcs .button::before, .hcs .frm_style_formidable-style.with_frm_style .frm_submit button::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: "";
  transform: translate3d(0, 0, 0);
  transition: all 0.4s cubic-bezier(0.65, 0, 0.35, 1);
  z-index: -1;
  background: #c19c60;
}
.hcs .button:hover::before, .hcs .button:focus::before, .hcs .button:active::before, .hcs .frm_style_formidable-style.with_frm_style .frm_submit button:hover::before, .hcs .frm_style_formidable-style.with_frm_style .frm_submit button:focus::before, .hcs .frm_style_formidable-style.with_frm_style .frm_submit button:active::before {
  transform: translate3d(0, -105%, 0);
}
.hcs .button.button--small, .hcs .frm_style_formidable-style.with_frm_style .frm_submit button.button--small {
  font-size: var(--fluid-text-s);
  padding: 0.2rem 1.2rem;
}
.hcs .button--white {
  color: #222222;
}
.hcs .button--white::before {
  background: #fff;
}
.hcs .button--white:hover, .hcs .button--white:focus, .hcs .button--white:active {
  color: #fff;
}
.hcs .hcs .frm_style_formidable-style.with_frm_style .frm_submit button::before {
  z-index: -1;
}
.hcs .button--header {
  padding: 0.2rem 1.2rem;
}
.modal--mdl {
  display: none;
  left: 50%;
  top: 50%;
  transform: translate3d(-50%, -50%, 0);
  position: fixed;
  opacity: 1;
  transition: all 0.6s cubic-bezier(0.65, 0, 0.35, 1);
  z-index: 1100;
  position: fixed;
  height: 80vh;
  overflow: hidden;
  height: 80vh;
  height: 80svh;
  max-height: 80vh;
  max-height: 80svh;
  overflow-y: scroll;
  background: #fff;
  padding: 2.5rem;
  width: 100%;
  max-width: 1200px;
}
.modal--mdl.open {
  display: block;
}
.icon-list {
  gap: 1rem 2rem;
}
.icon-list a {
  color: #ffda9e;
}
.icon-list a:hover {
  color: #c19c60;
}
.icon-list i, .icon-list i::before {
  font-size: var(--fluid-text-l);
}
.icon-list span {
  font-size: var(--fluid-text-l);
}
.icon-list--small i, .icon-list--small i::before {
  font-size: var(--fluid-text-m);
}
.icon-list--small span {
  font-size: var(--fluid-text-m);
}
.icon-box {
  gap: 1rem 2rem;
}
.icon-box li i, .icon-box li i::before, .icon-box li svg {
  font-size: 1.5rem;
  fill: #c19c60;
  color: #c19c60;
  width: 1.5rem;
  text-align: center;
}
.icon-box li a > span {
  color: #222222;
  font-size: var(--fluid-text-m);
  font-weight: 400;
  margin-left: 1.5rem;
}
.icon-box li:hover span {
  text-decoration: underline;
}
.icon-box--white li i, .icon-box--white li i::before, .icon-box--white li svg, .icon-box--white li span {
  color: #fff;
  fill: #fff;
}
.icon-box--kontakt li a > span {
  display: block;
}
.icon-box--team li i, .icon-box--team li i::before, .icon-box--team li svg {
  font-size: 1rem;
  width: 1rem;
}
.tabs__link-wrapper {
  margin-bottom: 2rem;
}
.tabs__link {
  transition: all 0.2s ease-in-out;
  background: #F3F3F3;
  padding: 0.6rem 1.6rem;
  margin-right: 0.5rem;
  border: 0 solid #222222;
  border-radius: 0.5rem;
}
.tabs__link:hover {
  transform: scale(0.9);
}
.tabs__link.brx-open {
  background: #c19c60;
  border-color: #c19c60;
}
.tabs__link.brx-open .tabs__linktext {
  color: #fff;
}
.tabs__link .tabs__linktext {
  transition: all 0.2s ease-in-out;
  font-weight: 700;
  font-size: var(--fluid-text-s);
}
.tabs__pane {
  animation: fade-in--key 1s ease-in;
}
.accordion__item {
  background: #F3F3F3;
  border-radius: 0.75rem;
  margin-bottom: 1rem;
}
.accordion__heading {
  padding: 1.5rem;
}
.accordion__heading .heading {
  font-size: var(--fluid-text-m);
  color: #222222;
}
.accordion__text {
  border-top: 1px solid #222222;
  padding: 1.5rem !important;
}
.accordion__text .text {
  color: #222222;
}
.section--grau .accordion__item {
  background: #fff;
}
.section--rot .accordion__text .text {
  color: #222222;
}
.section--rot .accordion__text .text strong {
  color: #c19c60;
}
.galerie_wrapper .happyfiles-gallery > ul.crop {
  display: flex;
  flex-wrap: wrap;
}
.galerie_wrapper .happyfiles-gallery > ul.crop li {
  flex-grow: 1;
  position: relative;
  filter: grayscale(0) brightness(1.1);
  transition: all 0.3s ease;
  border-radius: 0.75rem;
  overflow: hidden;
}
.galerie_wrapper .happyfiles-gallery > ul.crop li:hover {
  filter: grayscale(0) brightness(1);
  opacity: 1;
}
.image-galerie .image {
  border-radius: 0.5rem;
  transition: all 0.3s ease;
}
.image-galerie .image:hover {
  filter: grayscale(1);
}
.cta-box {
  background: #F3F3F3;
  padding: 1rem 2.5rem;
  border-radius: 0.5rem;
  justify-items: center;
}
.cta-box .text p {
  font-size: var(--fluid-text-l);
  text-align: center;
  color: #222222;
}
.counter__icon {
  fill: #222222;
  color: #222222;
  margin-top: 1rem;
  margin-bottom: 2rem;
  width: 3rem;
  height: auto;
}
.counter__content {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.counter .prefix, .counter .suffix {
  font-weight: 700;
  text-align: center;
}
.counter .count {
  font-size: var(--fluid-heading-xl);
  font-weight: 700;
  color: #c19c60;
  line-height: 1.3;
}
.timeline_wrapper .text-card:nth-child(even) {
  transform: translateY(10rem);
}
.timeline_wrapper .card__number {
  padding: 0.5rem 1rem;
  color: #c19c60;
  font-size: var(--fluid-heading-xs);
  border-radius: 0.5rem;
  margin-bottom: 3rem;
  border: 1px solid #4a4a49;
}
.timeline_wrapper .card__heading {
  font-size: var(--fluid-text-l);
  margin-bottom: 1rem;
}
@media (max-width: 1024px) {
  .timeline_wrapper .text-card:nth-child(even) {
    transform: translateY(0);
  }
}
/*
///########################################################################
///------------------- 06 Unterseiten
///########################################################################
*/
/*
///########################################################################
///------------------- 07 Sonstiges
///########################################################################
*/
.logged-in .header__wrapper {
  margin-top: 2rem;
}
body.bricks-is-frontend :focus {
  outline: 0 dotted currentcolor;
}
button:focus-visible {
  outline: -webkit-focus-ring-color auto 0 !important;
}
.hero_row [class*="mdl"], .hero_row--subpage [class*="mdl"] {
  animation: fade-hero--key 1.5s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}
.hero_row [class*="mdl"]:nth-child(1), .hero_row--subpage [class*="mdl"]:nth-child(1) {
  animation-delay: 0.1s;
}
.hero_row [class*="mdl"]:nth-child(2), .hero_row--subpage [class*="mdl"]:nth-child(2) {
  animation-delay: 0.4s;
}
.hero_row [class*="mdl"]:nth-child(3), .hero_row--subpage [class*="mdl"]:nth-child(3) {
  animation-delay: 0.7s;
}
.hero_row [class*="mdl"]:nth-child(4), .hero_row--subpage [class*="mdl"]:nth-child(4) {
  animation-delay: 1s;
}
.hero_row [class*="mdl"]:nth-child(5), .hero_row--subpage [class*="mdl"]:nth-child(5) {
  animation-delay: 1.3s;
}
.hero_row [class*="mdl"]:nth-child(6), .hero_row--subpage [class*="mdl"]:nth-child(6) {
  animation-delay: 1.6s;
}
@keyframes fade-hero--key {
  from {
    opacity: 0;
    transform: translate3d(0, 50px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}
html.js .stagger--auto[data-aos="hcs-aos"] [class*="mdl"] {
  opacity: 0;
}
html.js .stagger--auto[data-aos="hcs-aos"].aos-animate [class*="mdl"] {
  animation: stagger--auto--key 1.5s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}
html.js .stagger--auto.aos-animate [class*="mdl"]:nth-child(1) {
  animation-delay: 0.1s;
}
html.js .stagger--auto.aos-animate [class*="mdl"]:nth-child(2) {
  animation-delay: 0.3s;
}
html.js .stagger--auto.aos-animate [class*="mdl"]:nth-child(3) {
  animation-delay: 0.5s;
}
html.js .stagger--auto.aos-animate [class*="mdl"]:nth-child(4) {
  animation-delay: 0.7s;
}
html.js .stagger--auto.aos-animate [class*="mdl"]:nth-child(5) {
  animation-delay: 0.9s;
}
html.js .stagger--auto.aos-animate [class*="mdl"]:nth-child(6) {
  animation-delay: 1.1s;
}
html.js .stagger--auto.aos-animate [class*="mdl"]:nth-child(7) {
  animation-delay: 1.3s;
}
html.js .stagger--auto.aos-animate [class*="mdl"]:nth-child(8) {
  animation-delay: 1.5s;
}
html.js .stagger--auto.aos-animate [class*="mdl"]:nth-child(9) {
  animation-delay: 1.7s;
}
html.js .stagger--auto.aos-animate [class*="mdl"]:nth-child(10) {
  animation-delay: 1.9s;
}
html.js .stagger--auto.aos-animate [class*="mdl"]:nth-child(11) {
  animation-delay: 2.1s;
}
@keyframes stagger--auto--key {
  0% {
    transform: translate3d(0, 100%, 0);
    opacity: 0;
  }
  100% {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
body[data-aos-easing="ease-hcs"] [data-aos], [data-aos][data-aos][data-aos-easing="ease-hcs"] {
  transition-timing-function: cubic-bezier(0.23, 1, 0.32, 1);
}
.touch-start, .schnell-nav--row .touch-start, .fl-icon.touch-start {
  animation: pulsate-bck 0.3s cubic-bezier(0.445, 0.05, 0.55, 0.95) both;
}
@keyframes pulsate-bck {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(0.8);
  }
  100% {
    transform: scale(1);
  }
}
.brandmal_row {
  background: #eee5dc;
}
.brandmal_row .heading {
  font-weight: 700;
  color: #fff;
  text-align: center;
  background: #004942;
  padding: 1rem 2rem;
  border-radius: 0.5rem;
  font-size: var(--fluid-heading-xs);
}
.brandmal_row .logo {
  margin-top: 2rem;
  margin-bottom: 5rem;
}
.brandmal_row .logo img {
  width: 600px;
  max-width: 50vw;
  transition: all 0.3s ease;
}
.brandmal_row .logo img:hover, .brandmal_row .logo img:focus {
  transform: scale(0.9);
}
.brandmal_row .erecht-logo {
  width: 200px;
}
.noscript-style {
  padding: 2em;
  max-width: 100vw;
  text-align: center;
  color: #333;
  font-weight: 700;
  border: solid;
  border-color: #333;
  border-width: 0;
  background: #ffc800;
  position: fixed;
  width: 100%;
  left: 0;
  bottom: 0;
  z-index: 9999999;
  box-sizing: border-box;
}
.erecht_row h1, .erecht_row h2, .erecht_row h3, .erecht_row h4, .erecht_row h5, .erecht_row h6 {
  margin-bottom: 0.5rem;
  margin-top: 3rem;
}
.erecht_row h1:first-of-type, .erecht_row h2:first-of-type {
  margin-top: 0;
}
.hcs.bildernachweis--row .fl-photo-caption {
  overflow: visible;
  text-overflow: unset;
  white-space: normal;
  font-size: 0.8rem;
}
.hcs.bildernachweis--row .fl-photo-caption a {
  font-size: 0.8rem;
}
#BorlabsCookieBox.BorlabsCookie ._brlbs-box-wrap {
  max-width: 550px;
  width: 85vw !important;
}
#BorlabsCookieBox.BorlabsCookie ._brlbs-box-wrap ._brlbs-box .container {
  scrollbar-width: thin;
}
#BorlabsCookieBox.BorlabsCookie ._brlbs-box-wrap ._brlbs-box .container::-webkit-scrollbar {
  width: 0px;
}
#CookieBoxTextHeadline {
  font-weight: 700;
  margin-top: 0.5rem;
}
.BorlabsCookie ._brlbs-content-blocker ._brlbs-caption, .BorlabsCookie ._brlbs-content-blocker ._brlbs-caption p {
  color: #fff !important;
}
@media (max-width: 768px) {
  #BorlabsCookieBox.BorlabsCookie ._brlbs-box-wrap p {
    font-size: 0.9em;
  }
  #CookiePrefDescription, #CookieBoxTextDescription {
    max-height: 25vh;
    box-shadow: inset 0 -10px 10px -10px gray;
    scrollbar-width: thin;
  }
}
.hcs .bildernachweis--mdl .bildernachweis--wrapper {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}
.hcs .bildernachweis--mdl .bildernachweis--wrapper .image-container {
  margin: 1rem;
  display: flex;
  flex-direction: column;
  background: #fff;
  border-right: 1px solid #ccc;
  padding: 0.5rem;
  min-width: 250px;
}
.hcs .bildernachweis--mdl .bildernachweis--wrapper .image-container img.image {
  width: 150px;
  height: 150px;
  object-fit: contain;
  object-position: center center;
  margin-bottom: 1rem;
}
.hcs .bildernachweis--mdl .bildernachweis--wrapper .image-container .urheber, .hcs .bildernachweis--mdl .bildernachweis--wrapper .image-container .quelle, .hcs .bildernachweis--mdl .bildernachweis--wrapper .image-container a {
  font-size: 0.8rem;
  margin-top: 2px;
}
.hcs .bildernachweis--mdl .bildernachweis--wrapper .image-container .urheber a, .hcs .bildernachweis--mdl .bildernachweis--wrapper .image-container .quelle a, .hcs .bildernachweis--mdl .bildernachweis--wrapper .image-container a a {
  text-decoration: underline;
}
#brx-content.post-password-required {
  height: 100vh;
  min-height: 100vh;
}
#brx-content.post-password-required .post-password-form {
  margin-top: 40vh;
}
/*
///########################################################################
///------------------- 08 Plugins
///########################################################################
*/
html.lenis {
  height: auto;
}
.lenis.lenis-smooth {
  scroll-behavior: auto;
}
.lenis.lenis-smooth [data-lenis-prevent] {
  overscroll-behavior: contain;
}
.lenis.lenis-stopped {
  overflow: hidden;
}
.lenis.lenis-scrolling iframe {
  pointer-events: none;
}
