:root {
  --font-std: 'Inter', sans-serif;
  --Himmelblau: #E4FCFF;
  --Anthrazit: #353F42;
  --Hellblau: #93F2FF;
  --Weiss: #fff; }

.container {
  max-width: 1640px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 16px;
  padding-right: 16px;
  width: 100%; }
  @media (min-width: 1024px) {
    .container {
      padding-inline: 40px; } }
  @media (min-width: 1200px) {
    .container {
      padding-inline: 140px; } }

/* inter-regular - latin_latin-ext */
@font-face {
  font-display: swap;
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/inter-v13-latin_latin-ext-regular.woff2") format("woff2"); }

/* inter-600 - latin_latin-ext */
@font-face {
  font-display: swap;
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  src: url("../fonts/inter-v13-latin_latin-ext-600.woff2") format("woff2"); }

/* inter-700 - latin_latin-ext */
@font-face {
  font-display: swap;
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  src: url("../fonts/inter-v13-latin_latin-ext-700.woff2") format("woff2"); }

html {
  height: auto;
  box-sizing: border-box;
  font-size: 62.5%; }

*, *:before, *:after {
  box-sizing: inherit; }

body {
  position: relative;
  color: var(--Anthrazit);
  font-family: var(--font-std);
  font-size: 1.6rem;
  -webkit-font-smoothing: antialiased;
  text-underline-offset: 6px; }

a {
  color: inherit;
  text-decoration-thickness: 2px; }
  a:hover {
    text-decoration: none; }

a:focus {
  color: inherit;
  outline: none; }

a:hover {
  color: inherit;
  outline: none; }

img {
  max-width: 100%;
  height: auto; }

table {
  border: 0; }

.clear {
  clear: both; }

.block {
  display: block; }

.pr0, .small-pr0 {
  padding-right: 0px; }

.pl0, .small-pl0 {
  padding-left: 0px; }

.pt0, .small-pt0 {
  padding-top: 0px; }

.pb0, .small-pb0 {
  padding-bottom: 0px; }

.mr0, .small-mr0 {
  margin-right: 0px; }

.ml0, .small-ml0 {
  margin-left: 0px; }

.mt0, .small-mt0 {
  margin-top: 0px; }

.mb0, .small-mb0 {
  margin-bottom: 0px; }

.pr5, .small-pr5 {
  padding-right: 5px; }

.pl5, .small-pl5 {
  padding-left: 5px; }

.pt5, .small-pt5 {
  padding-top: 5px; }

.pb5, .small-pb5 {
  padding-bottom: 5px; }

.mr5, .small-mr5 {
  margin-right: 5px; }

.ml5, .small-ml5 {
  margin-left: 5px; }

.mt5, .small-mt5 {
  margin-top: 5px; }

.mb5, .small-mb5 {
  margin-bottom: 5px; }

.pr10, .small-pr10 {
  padding-right: 10px; }

.pl10, .small-pl10 {
  padding-left: 10px; }

.pt10, .small-pt10 {
  padding-top: 10px; }

.pb10, .small-pb10 {
  padding-bottom: 10px; }

.mr10, .small-mr10 {
  margin-right: 10px; }

.ml10, .small-ml10 {
  margin-left: 10px; }

.mt10, .small-mt10 {
  margin-top: 10px; }

.mb10, .small-mb10 {
  margin-bottom: 10px; }

.pr15, .small-pr15 {
  padding-right: 15px; }

.pl15, .small-pl15 {
  padding-left: 15px; }

.pt15, .small-pt15 {
  padding-top: 15px; }

.pb15, .small-pb15 {
  padding-bottom: 15px; }

.mr15, .small-mr15 {
  margin-right: 15px; }

.ml15, .small-ml15 {
  margin-left: 15px; }

.mt15, .small-mt15 {
  margin-top: 15px; }

.mb15, .small-mb15 {
  margin-bottom: 15px; }

.pr20, .small-pr20 {
  padding-right: 20px; }

.pl20, .small-pl20 {
  padding-left: 20px; }

.pt20, .small-pt20 {
  padding-top: 20px; }

.pb20, .small-pb20 {
  padding-bottom: 20px; }

.mr20, .small-mr20 {
  margin-right: 20px; }

.ml20, .small-ml20 {
  margin-left: 20px; }

.mt20, .small-mt20 {
  margin-top: 20px; }

.mb20, .small-mb20 {
  margin-bottom: 20px; }

.pr25, .small-pr25 {
  padding-right: 25px; }

.pl25, .small-pl25 {
  padding-left: 25px; }

.pt25, .small-pt25 {
  padding-top: 25px; }

.pb25, .small-pb25 {
  padding-bottom: 25px; }

.mr25, .small-mr25 {
  margin-right: 25px; }

.ml25, .small-ml25 {
  margin-left: 25px; }

.mt25, .small-mt25 {
  margin-top: 25px; }

.mb25, .small-mb25 {
  margin-bottom: 25px; }

.pr30, .small-pr30 {
  padding-right: 30px; }

.pl30, .small-pl30 {
  padding-left: 30px; }

.pt30, .small-pt30 {
  padding-top: 30px; }

.pb30, .small-pb30 {
  padding-bottom: 30px; }

.mr30, .small-mr30 {
  margin-right: 30px; }

.ml30, .small-ml30 {
  margin-left: 30px; }

.mt30, .small-mt30 {
  margin-top: 30px; }

.mb30, .small-mb30 {
  margin-bottom: 30px; }

.pr35, .small-pr35 {
  padding-right: 35px; }

.pl35, .small-pl35 {
  padding-left: 35px; }

.pt35, .small-pt35 {
  padding-top: 35px; }

.pb35, .small-pb35 {
  padding-bottom: 35px; }

.mr35, .small-mr35 {
  margin-right: 35px; }

.ml35, .small-ml35 {
  margin-left: 35px; }

.mt35, .small-mt35 {
  margin-top: 35px; }

.mb35, .small-mb35 {
  margin-bottom: 35px; }

.pr40, .small-pr40 {
  padding-right: 40px; }

.pl40, .small-pl40 {
  padding-left: 40px; }

.pt40, .small-pt40 {
  padding-top: 40px; }

.pb40, .small-pb40 {
  padding-bottom: 40px; }

.mr40, .small-mr40 {
  margin-right: 40px; }

.ml40, .small-ml40 {
  margin-left: 40px; }

.mt40, .small-mt40 {
  margin-top: 40px; }

.mb40, .small-mb40 {
  margin-bottom: 40px; }

.pr45, .small-pr45 {
  padding-right: 45px; }

.pl45, .small-pl45 {
  padding-left: 45px; }

.pt45, .small-pt45 {
  padding-top: 45px; }

.pb45, .small-pb45 {
  padding-bottom: 45px; }

.mr45, .small-mr45 {
  margin-right: 45px; }

.ml45, .small-ml45 {
  margin-left: 45px; }

.mt45, .small-mt45 {
  margin-top: 45px; }

.mb45, .small-mb45 {
  margin-bottom: 45px; }

.pr50, .small-pr50 {
  padding-right: 50px; }

.pl50, .small-pl50 {
  padding-left: 50px; }

.pt50, .small-pt50 {
  padding-top: 50px; }

.pb50, .small-pb50 {
  padding-bottom: 50px; }

.mr50, .small-mr50 {
  margin-right: 50px; }

.ml50, .small-ml50 {
  margin-left: 50px; }

.mt50, .small-mt50 {
  margin-top: 50px; }

.mb50, .small-mb50 {
  margin-bottom: 50px; }

.pr55, .small-pr55 {
  padding-right: 55px; }

.pl55, .small-pl55 {
  padding-left: 55px; }

.pt55, .small-pt55 {
  padding-top: 55px; }

.pb55, .small-pb55 {
  padding-bottom: 55px; }

.mr55, .small-mr55 {
  margin-right: 55px; }

.ml55, .small-ml55 {
  margin-left: 55px; }

.mt55, .small-mt55 {
  margin-top: 55px; }

.mb55, .small-mb55 {
  margin-bottom: 55px; }

.pr60, .small-pr60 {
  padding-right: 60px; }

.pl60, .small-pl60 {
  padding-left: 60px; }

.pt60, .small-pt60 {
  padding-top: 60px; }

.pb60, .small-pb60 {
  padding-bottom: 60px; }

.mr60, .small-mr60 {
  margin-right: 60px; }

.ml60, .small-ml60 {
  margin-left: 60px; }

.mt60, .small-mt60 {
  margin-top: 60px; }

.mb60, .small-mb60 {
  margin-bottom: 60px; }

.pr65, .small-pr65 {
  padding-right: 65px; }

.pl65, .small-pl65 {
  padding-left: 65px; }

.pt65, .small-pt65 {
  padding-top: 65px; }

.pb65, .small-pb65 {
  padding-bottom: 65px; }

.mr65, .small-mr65 {
  margin-right: 65px; }

.ml65, .small-ml65 {
  margin-left: 65px; }

.mt65, .small-mt65 {
  margin-top: 65px; }

.mb65, .small-mb65 {
  margin-bottom: 65px; }

.pr70, .small-pr70 {
  padding-right: 70px; }

.pl70, .small-pl70 {
  padding-left: 70px; }

.pt70, .small-pt70 {
  padding-top: 70px; }

.pb70, .small-pb70 {
  padding-bottom: 70px; }

.mr70, .small-mr70 {
  margin-right: 70px; }

.ml70, .small-ml70 {
  margin-left: 70px; }

.mt70, .small-mt70 {
  margin-top: 70px; }

.mb70, .small-mb70 {
  margin-bottom: 70px; }

.pr75, .small-pr75 {
  padding-right: 75px; }

.pl75, .small-pl75 {
  padding-left: 75px; }

.pt75, .small-pt75 {
  padding-top: 75px; }

.pb75, .small-pb75 {
  padding-bottom: 75px; }

.mr75, .small-mr75 {
  margin-right: 75px; }

.ml75, .small-ml75 {
  margin-left: 75px; }

.mt75, .small-mt75 {
  margin-top: 75px; }

.mb75, .small-mb75 {
  margin-bottom: 75px; }

.pr80, .small-pr80 {
  padding-right: 80px; }

.pl80, .small-pl80 {
  padding-left: 80px; }

.pt80, .small-pt80 {
  padding-top: 80px; }

.pb80, .small-pb80 {
  padding-bottom: 80px; }

.mr80, .small-mr80 {
  margin-right: 80px; }

.ml80, .small-ml80 {
  margin-left: 80px; }

.mt80, .small-mt80 {
  margin-top: 80px; }

.mb80, .small-mb80 {
  margin-bottom: 80px; }

.pr85, .small-pr85 {
  padding-right: 85px; }

.pl85, .small-pl85 {
  padding-left: 85px; }

.pt85, .small-pt85 {
  padding-top: 85px; }

.pb85, .small-pb85 {
  padding-bottom: 85px; }

.mr85, .small-mr85 {
  margin-right: 85px; }

.ml85, .small-ml85 {
  margin-left: 85px; }

.mt85, .small-mt85 {
  margin-top: 85px; }

.mb85, .small-mb85 {
  margin-bottom: 85px; }

.pr90, .small-pr90 {
  padding-right: 90px; }

.pl90, .small-pl90 {
  padding-left: 90px; }

.pt90, .small-pt90 {
  padding-top: 90px; }

.pb90, .small-pb90 {
  padding-bottom: 90px; }

.mr90, .small-mr90 {
  margin-right: 90px; }

.ml90, .small-ml90 {
  margin-left: 90px; }

.mt90, .small-mt90 {
  margin-top: 90px; }

.mb90, .small-mb90 {
  margin-bottom: 90px; }

.pr95, .small-pr95 {
  padding-right: 95px; }

.pl95, .small-pl95 {
  padding-left: 95px; }

.pt95, .small-pt95 {
  padding-top: 95px; }

.pb95, .small-pb95 {
  padding-bottom: 95px; }

.mr95, .small-mr95 {
  margin-right: 95px; }

.ml95, .small-ml95 {
  margin-left: 95px; }

.mt95, .small-mt95 {
  margin-top: 95px; }

.mb95, .small-mb95 {
  margin-bottom: 95px; }

.pr100, .small-pr100 {
  padding-right: 100px; }

.pl100, .small-pl100 {
  padding-left: 100px; }

.pt100, .small-pt100 {
  padding-top: 100px; }

.pb100, .small-pb100 {
  padding-bottom: 100px; }

.mr100, .small-mr100 {
  margin-right: 100px; }

.ml100, .small-ml100 {
  margin-left: 100px; }

.mt100, .small-mt100 {
  margin-top: 100px; }

.mb100, .small-mb100 {
  margin-bottom: 100px; }

@media all and (min-width: 643px) {
  .medium-pr0 {
    padding-right: 0px; }
  .medium-pl0 {
    padding-left: 0px; }
  .medium-pt0 {
    padding-top: 0px; }
  .medium-pb0 {
    padding-bottom: 0px; }
  .medium-mr0 {
    margin-right: 0px; }
  .medium-ml0 {
    margin-left: 0px; }
  .medium-mt0 {
    margin-top: 0px; }
  .medium-mb0 {
    margin-bottom: 0px; }
  .medium-pr5 {
    padding-right: 5px; }
  .medium-pl5 {
    padding-left: 5px; }
  .medium-pt5 {
    padding-top: 5px; }
  .medium-pb5 {
    padding-bottom: 5px; }
  .medium-mr5 {
    margin-right: 5px; }
  .medium-ml5 {
    margin-left: 5px; }
  .medium-mt5 {
    margin-top: 5px; }
  .medium-mb5 {
    margin-bottom: 5px; }
  .medium-pr10 {
    padding-right: 10px; }
  .medium-pl10 {
    padding-left: 10px; }
  .medium-pt10 {
    padding-top: 10px; }
  .medium-pb10 {
    padding-bottom: 10px; }
  .medium-mr10 {
    margin-right: 10px; }
  .medium-ml10 {
    margin-left: 10px; }
  .medium-mt10 {
    margin-top: 10px; }
  .medium-mb10 {
    margin-bottom: 10px; }
  .medium-pr15 {
    padding-right: 15px; }
  .medium-pl15 {
    padding-left: 15px; }
  .medium-pt15 {
    padding-top: 15px; }
  .medium-pb15 {
    padding-bottom: 15px; }
  .medium-mr15 {
    margin-right: 15px; }
  .medium-ml15 {
    margin-left: 15px; }
  .medium-mt15 {
    margin-top: 15px; }
  .medium-mb15 {
    margin-bottom: 15px; }
  .medium-pr20 {
    padding-right: 20px; }
  .medium-pl20 {
    padding-left: 20px; }
  .medium-pt20 {
    padding-top: 20px; }
  .medium-pb20 {
    padding-bottom: 20px; }
  .medium-mr20 {
    margin-right: 20px; }
  .medium-ml20 {
    margin-left: 20px; }
  .medium-mt20 {
    margin-top: 20px; }
  .medium-mb20 {
    margin-bottom: 20px; }
  .medium-pr25 {
    padding-right: 25px; }
  .medium-pl25 {
    padding-left: 25px; }
  .medium-pt25 {
    padding-top: 25px; }
  .medium-pb25 {
    padding-bottom: 25px; }
  .medium-mr25 {
    margin-right: 25px; }
  .medium-ml25 {
    margin-left: 25px; }
  .medium-mt25 {
    margin-top: 25px; }
  .medium-mb25 {
    margin-bottom: 25px; }
  .medium-pr30 {
    padding-right: 30px; }
  .medium-pl30 {
    padding-left: 30px; }
  .medium-pt30 {
    padding-top: 30px; }
  .medium-pb30 {
    padding-bottom: 30px; }
  .medium-mr30 {
    margin-right: 30px; }
  .medium-ml30 {
    margin-left: 30px; }
  .medium-mt30 {
    margin-top: 30px; }
  .medium-mb30 {
    margin-bottom: 30px; }
  .medium-pr35 {
    padding-right: 35px; }
  .medium-pl35 {
    padding-left: 35px; }
  .medium-pt35 {
    padding-top: 35px; }
  .medium-pb35 {
    padding-bottom: 35px; }
  .medium-mr35 {
    margin-right: 35px; }
  .medium-ml35 {
    margin-left: 35px; }
  .medium-mt35 {
    margin-top: 35px; }
  .medium-mb35 {
    margin-bottom: 35px; }
  .medium-pr40 {
    padding-right: 40px; }
  .medium-pl40 {
    padding-left: 40px; }
  .medium-pt40 {
    padding-top: 40px; }
  .medium-pb40 {
    padding-bottom: 40px; }
  .medium-mr40 {
    margin-right: 40px; }
  .medium-ml40 {
    margin-left: 40px; }
  .medium-mt40 {
    margin-top: 40px; }
  .medium-mb40 {
    margin-bottom: 40px; }
  .medium-pr45 {
    padding-right: 45px; }
  .medium-pl45 {
    padding-left: 45px; }
  .medium-pt45 {
    padding-top: 45px; }
  .medium-pb45 {
    padding-bottom: 45px; }
  .medium-mr45 {
    margin-right: 45px; }
  .medium-ml45 {
    margin-left: 45px; }
  .medium-mt45 {
    margin-top: 45px; }
  .medium-mb45 {
    margin-bottom: 45px; }
  .medium-pr50 {
    padding-right: 50px; }
  .medium-pl50 {
    padding-left: 50px; }
  .medium-pt50 {
    padding-top: 50px; }
  .medium-pb50 {
    padding-bottom: 50px; }
  .medium-mr50 {
    margin-right: 50px; }
  .medium-ml50 {
    margin-left: 50px; }
  .medium-mt50 {
    margin-top: 50px; }
  .medium-mb50 {
    margin-bottom: 50px; }
  .medium-pr55 {
    padding-right: 55px; }
  .medium-pl55 {
    padding-left: 55px; }
  .medium-pt55 {
    padding-top: 55px; }
  .medium-pb55 {
    padding-bottom: 55px; }
  .medium-mr55 {
    margin-right: 55px; }
  .medium-ml55 {
    margin-left: 55px; }
  .medium-mt55 {
    margin-top: 55px; }
  .medium-mb55 {
    margin-bottom: 55px; }
  .medium-pr60 {
    padding-right: 60px; }
  .medium-pl60 {
    padding-left: 60px; }
  .medium-pt60 {
    padding-top: 60px; }
  .medium-pb60 {
    padding-bottom: 60px; }
  .medium-mr60 {
    margin-right: 60px; }
  .medium-ml60 {
    margin-left: 60px; }
  .medium-mt60 {
    margin-top: 60px; }
  .medium-mb60 {
    margin-bottom: 60px; }
  .medium-pr65 {
    padding-right: 65px; }
  .medium-pl65 {
    padding-left: 65px; }
  .medium-pt65 {
    padding-top: 65px; }
  .medium-pb65 {
    padding-bottom: 65px; }
  .medium-mr65 {
    margin-right: 65px; }
  .medium-ml65 {
    margin-left: 65px; }
  .medium-mt65 {
    margin-top: 65px; }
  .medium-mb65 {
    margin-bottom: 65px; }
  .medium-pr70 {
    padding-right: 70px; }
  .medium-pl70 {
    padding-left: 70px; }
  .medium-pt70 {
    padding-top: 70px; }
  .medium-pb70 {
    padding-bottom: 70px; }
  .medium-mr70 {
    margin-right: 70px; }
  .medium-ml70 {
    margin-left: 70px; }
  .medium-mt70 {
    margin-top: 70px; }
  .medium-mb70 {
    margin-bottom: 70px; }
  .medium-pr75 {
    padding-right: 75px; }
  .medium-pl75 {
    padding-left: 75px; }
  .medium-pt75 {
    padding-top: 75px; }
  .medium-pb75 {
    padding-bottom: 75px; }
  .medium-mr75 {
    margin-right: 75px; }
  .medium-ml75 {
    margin-left: 75px; }
  .medium-mt75 {
    margin-top: 75px; }
  .medium-mb75 {
    margin-bottom: 75px; }
  .medium-pr80 {
    padding-right: 80px; }
  .medium-pl80 {
    padding-left: 80px; }
  .medium-pt80 {
    padding-top: 80px; }
  .medium-pb80 {
    padding-bottom: 80px; }
  .medium-mr80 {
    margin-right: 80px; }
  .medium-ml80 {
    margin-left: 80px; }
  .medium-mt80 {
    margin-top: 80px; }
  .medium-mb80 {
    margin-bottom: 80px; }
  .medium-pr85 {
    padding-right: 85px; }
  .medium-pl85 {
    padding-left: 85px; }
  .medium-pt85 {
    padding-top: 85px; }
  .medium-pb85 {
    padding-bottom: 85px; }
  .medium-mr85 {
    margin-right: 85px; }
  .medium-ml85 {
    margin-left: 85px; }
  .medium-mt85 {
    margin-top: 85px; }
  .medium-mb85 {
    margin-bottom: 85px; }
  .medium-pr90 {
    padding-right: 90px; }
  .medium-pl90 {
    padding-left: 90px; }
  .medium-pt90 {
    padding-top: 90px; }
  .medium-pb90 {
    padding-bottom: 90px; }
  .medium-mr90 {
    margin-right: 90px; }
  .medium-ml90 {
    margin-left: 90px; }
  .medium-mt90 {
    margin-top: 90px; }
  .medium-mb90 {
    margin-bottom: 90px; }
  .medium-pr95 {
    padding-right: 95px; }
  .medium-pl95 {
    padding-left: 95px; }
  .medium-pt95 {
    padding-top: 95px; }
  .medium-pb95 {
    padding-bottom: 95px; }
  .medium-mr95 {
    margin-right: 95px; }
  .medium-ml95 {
    margin-left: 95px; }
  .medium-mt95 {
    margin-top: 95px; }
  .medium-mb95 {
    margin-bottom: 95px; }
  .medium-pr100 {
    padding-right: 100px; }
  .medium-pl100 {
    padding-left: 100px; }
  .medium-pt100 {
    padding-top: 100px; }
  .medium-pb100 {
    padding-bottom: 100px; }
  .medium-mr100 {
    margin-right: 100px; }
  .medium-ml100 {
    margin-left: 100px; }
  .medium-mt100 {
    margin-top: 100px; }
  .medium-mb100 {
    margin-bottom: 100px; } }

@media all and (min-width: 1025px) {
  .large-pr0 {
    padding-right: 0px; }
  .large-pl0 {
    padding-left: 0px; }
  .large-pt0 {
    padding-top: 0px; }
  .large-pb0 {
    padding-bottom: 0px; }
  .large-mr0 {
    margin-right: 0px; }
  .large-ml0 {
    margin-left: 0px; }
  .large-mt0 {
    margin-top: 0px; }
  .large-mb0 {
    margin-bottom: 0px; }
  .large-pr5 {
    padding-right: 5px; }
  .large-pl5 {
    padding-left: 5px; }
  .large-pt5 {
    padding-top: 5px; }
  .large-pb5 {
    padding-bottom: 5px; }
  .large-mr5 {
    margin-right: 5px; }
  .large-ml5 {
    margin-left: 5px; }
  .large-mt5 {
    margin-top: 5px; }
  .large-mb5 {
    margin-bottom: 5px; }
  .large-pr10 {
    padding-right: 10px; }
  .large-pl10 {
    padding-left: 10px; }
  .large-pt10 {
    padding-top: 10px; }
  .large-pb10 {
    padding-bottom: 10px; }
  .large-mr10 {
    margin-right: 10px; }
  .large-ml10 {
    margin-left: 10px; }
  .large-mt10 {
    margin-top: 10px; }
  .large-mb10 {
    margin-bottom: 10px; }
  .large-pr15 {
    padding-right: 15px; }
  .large-pl15 {
    padding-left: 15px; }
  .large-pt15 {
    padding-top: 15px; }
  .large-pb15 {
    padding-bottom: 15px; }
  .large-mr15 {
    margin-right: 15px; }
  .large-ml15 {
    margin-left: 15px; }
  .large-mt15 {
    margin-top: 15px; }
  .large-mb15 {
    margin-bottom: 15px; }
  .large-pr20 {
    padding-right: 20px; }
  .large-pl20 {
    padding-left: 20px; }
  .large-pt20 {
    padding-top: 20px; }
  .large-pb20 {
    padding-bottom: 20px; }
  .large-mr20 {
    margin-right: 20px; }
  .large-ml20 {
    margin-left: 20px; }
  .large-mt20 {
    margin-top: 20px; }
  .large-mb20 {
    margin-bottom: 20px; }
  .large-pr25 {
    padding-right: 25px; }
  .large-pl25 {
    padding-left: 25px; }
  .large-pt25 {
    padding-top: 25px; }
  .large-pb25 {
    padding-bottom: 25px; }
  .large-mr25 {
    margin-right: 25px; }
  .large-ml25 {
    margin-left: 25px; }
  .large-mt25 {
    margin-top: 25px; }
  .large-mb25 {
    margin-bottom: 25px; }
  .large-pr30 {
    padding-right: 30px; }
  .large-pl30 {
    padding-left: 30px; }
  .large-pt30 {
    padding-top: 30px; }
  .large-pb30 {
    padding-bottom: 30px; }
  .large-mr30 {
    margin-right: 30px; }
  .large-ml30 {
    margin-left: 30px; }
  .large-mt30 {
    margin-top: 30px; }
  .large-mb30 {
    margin-bottom: 30px; }
  .large-pr35 {
    padding-right: 35px; }
  .large-pl35 {
    padding-left: 35px; }
  .large-pt35 {
    padding-top: 35px; }
  .large-pb35 {
    padding-bottom: 35px; }
  .large-mr35 {
    margin-right: 35px; }
  .large-ml35 {
    margin-left: 35px; }
  .large-mt35 {
    margin-top: 35px; }
  .large-mb35 {
    margin-bottom: 35px; }
  .large-pr40 {
    padding-right: 40px; }
  .large-pl40 {
    padding-left: 40px; }
  .large-pt40 {
    padding-top: 40px; }
  .large-pb40 {
    padding-bottom: 40px; }
  .large-mr40 {
    margin-right: 40px; }
  .large-ml40 {
    margin-left: 40px; }
  .large-mt40 {
    margin-top: 40px; }
  .large-mb40 {
    margin-bottom: 40px; }
  .large-pr45 {
    padding-right: 45px; }
  .large-pl45 {
    padding-left: 45px; }
  .large-pt45 {
    padding-top: 45px; }
  .large-pb45 {
    padding-bottom: 45px; }
  .large-mr45 {
    margin-right: 45px; }
  .large-ml45 {
    margin-left: 45px; }
  .large-mt45 {
    margin-top: 45px; }
  .large-mb45 {
    margin-bottom: 45px; }
  .large-pr50 {
    padding-right: 50px; }
  .large-pl50 {
    padding-left: 50px; }
  .large-pt50 {
    padding-top: 50px; }
  .large-pb50 {
    padding-bottom: 50px; }
  .large-mr50 {
    margin-right: 50px; }
  .large-ml50 {
    margin-left: 50px; }
  .large-mt50 {
    margin-top: 50px; }
  .large-mb50 {
    margin-bottom: 50px; }
  .large-pr55 {
    padding-right: 55px; }
  .large-pl55 {
    padding-left: 55px; }
  .large-pt55 {
    padding-top: 55px; }
  .large-pb55 {
    padding-bottom: 55px; }
  .large-mr55 {
    margin-right: 55px; }
  .large-ml55 {
    margin-left: 55px; }
  .large-mt55 {
    margin-top: 55px; }
  .large-mb55 {
    margin-bottom: 55px; }
  .large-pr60 {
    padding-right: 60px; }
  .large-pl60 {
    padding-left: 60px; }
  .large-pt60 {
    padding-top: 60px; }
  .large-pb60 {
    padding-bottom: 60px; }
  .large-mr60 {
    margin-right: 60px; }
  .large-ml60 {
    margin-left: 60px; }
  .large-mt60 {
    margin-top: 60px; }
  .large-mb60 {
    margin-bottom: 60px; }
  .large-pr65 {
    padding-right: 65px; }
  .large-pl65 {
    padding-left: 65px; }
  .large-pt65 {
    padding-top: 65px; }
  .large-pb65 {
    padding-bottom: 65px; }
  .large-mr65 {
    margin-right: 65px; }
  .large-ml65 {
    margin-left: 65px; }
  .large-mt65 {
    margin-top: 65px; }
  .large-mb65 {
    margin-bottom: 65px; }
  .large-pr70 {
    padding-right: 70px; }
  .large-pl70 {
    padding-left: 70px; }
  .large-pt70 {
    padding-top: 70px; }
  .large-pb70 {
    padding-bottom: 70px; }
  .large-mr70 {
    margin-right: 70px; }
  .large-ml70 {
    margin-left: 70px; }
  .large-mt70 {
    margin-top: 70px; }
  .large-mb70 {
    margin-bottom: 70px; }
  .large-pr75 {
    padding-right: 75px; }
  .large-pl75 {
    padding-left: 75px; }
  .large-pt75 {
    padding-top: 75px; }
  .large-pb75 {
    padding-bottom: 75px; }
  .large-mr75 {
    margin-right: 75px; }
  .large-ml75 {
    margin-left: 75px; }
  .large-mt75 {
    margin-top: 75px; }
  .large-mb75 {
    margin-bottom: 75px; }
  .large-pr80 {
    padding-right: 80px; }
  .large-pl80 {
    padding-left: 80px; }
  .large-pt80 {
    padding-top: 80px; }
  .large-pb80 {
    padding-bottom: 80px; }
  .large-mr80 {
    margin-right: 80px; }
  .large-ml80 {
    margin-left: 80px; }
  .large-mt80 {
    margin-top: 80px; }
  .large-mb80 {
    margin-bottom: 80px; }
  .large-pr85 {
    padding-right: 85px; }
  .large-pl85 {
    padding-left: 85px; }
  .large-pt85 {
    padding-top: 85px; }
  .large-pb85 {
    padding-bottom: 85px; }
  .large-mr85 {
    margin-right: 85px; }
  .large-ml85 {
    margin-left: 85px; }
  .large-mt85 {
    margin-top: 85px; }
  .large-mb85 {
    margin-bottom: 85px; }
  .large-pr90 {
    padding-right: 90px; }
  .large-pl90 {
    padding-left: 90px; }
  .large-pt90 {
    padding-top: 90px; }
  .large-pb90 {
    padding-bottom: 90px; }
  .large-mr90 {
    margin-right: 90px; }
  .large-ml90 {
    margin-left: 90px; }
  .large-mt90 {
    margin-top: 90px; }
  .large-mb90 {
    margin-bottom: 90px; }
  .large-pr95 {
    padding-right: 95px; }
  .large-pl95 {
    padding-left: 95px; }
  .large-pt95 {
    padding-top: 95px; }
  .large-pb95 {
    padding-bottom: 95px; }
  .large-mr95 {
    margin-right: 95px; }
  .large-ml95 {
    margin-left: 95px; }
  .large-mt95 {
    margin-top: 95px; }
  .large-mb95 {
    margin-bottom: 95px; }
  .large-pr100 {
    padding-right: 100px; }
  .large-pl100 {
    padding-left: 100px; }
  .large-pt100 {
    padding-top: 100px; }
  .large-pb100 {
    padding-bottom: 100px; }
  .large-mr100 {
    margin-right: 100px; }
  .large-ml100 {
    margin-left: 100px; }
  .large-mt100 {
    margin-top: 100px; }
  .large-mb100 {
    margin-bottom: 100px; } }

img.alignright {
  float: right;
  margin: 0 0 1em 1em; }

img.alignleft {
  float: left;
  margin: 0 1em 1em 0; }

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

.alignright {
  float: right; }

.alignleft {
  float: left; }

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

.zindex5 {
  position: relative;
  z-index: 5; }

.fright {
  float: right; }

.fleft {
  float: left !important; }

.clear {
  clear: both; }

.relative {
  position: relative; }

.underline {
  text-decoration: underline; }

.w50p {
  width: 50%; }

.lh80 {
  line-height: 80%; }

.lh90 {
  line-height: 90%; }

.lh100 {
  line-height: 100%; }

.lh110 {
  line-height: 110%; }

.lh120 {
  line-height: 120%; }

.lh130 {
  line-height: 130%; }

.lh140 {
  line-height: 140%; }

.lh150 {
  line-height: 150%; }

.fs10 {
  font-size: 0.625em; }

.fs11 {
  font-size: 0.688em; }

.fs12 {
  font-size: 0.750em; }

.fs13 {
  font-size: 0.813em; }

.fs14 {
  font-size: 0.875em; }

.fs15 {
  font-size: 0.938em; }

.fs16 {
  font-size: 1em; }

.fs17 {
  font-size: 1.063em; }

.fs18 {
  font-size: 1.125em; }

.fs19 {
  font-size: 1.118em; }

.fs20 {
  font-size: 1.250em; }

.overflow {
  overflow: hidden; }

.inline {
  display: inline-block; }

.black {
  color: #000 !important; }

.light {
  font-weight: 300; }

.bold {
  font-weight: 700; }

.dnone {
  display: none; }

.dblock {
  display: block; }

.uppercase {
  text-transform: uppercase; }

.photo-block {
  display: block; }

.separator {
  padding-block: 50px;
  background: var(--Anthrazit);
  color: var(--Weiss);
  text-align: center;
  font-size: 2.4rem;
  line-height: 120%; }
  @media (min-width: 1024px) {
    .separator {
      font-size: 3.5rem; } }

button {
  background: transparent;
  border: 0; }

.full-photo {
  max-height: 100dvh;
  overflow: hidden; }
  .full-photo img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    display: block; }

.btn, .nav a {
  display: inline-block;
  text-align: center;
  border: 0;
  transition: background .2s, color .2s, border .2s;
  line-height: 108%;
  letter-spacing: 0.9px;
  text-transform: uppercase;
  font-size: 1.1rem;
  padding: 8px 12px;
  border-radius: 6px;
  text-decoration: none; }
  @media (min-width: 1024px) {
    .btn, .nav a {
      font-size: 1.8rem;
      padding: 10px 16px;
      border-radius: 10px; } }
  .btn--100 {
    display: block;
    width: 100%; }
  .btn.white, .nav a.white {
    background: var(--Weiss);
    color: var(--Anthrazit);
    border: 1.5px solid var(--Weiss); }
    .btn.white:hover, .nav a.white:hover {
      background: var(--Anthrazit);
      color: var(--Weiss); }
  .btn.dark, .nav a.dark, .nav .current-menu-item a, .nav .current-menu-item.contact a {
    background: var(--Anthrazit);
    color: var(--Weiss);
    border: 1.5px solid var(--Anthrazit); }
    .btn.dark:hover, .nav a.dark:hover, .nav .current-menu-item a:hover {
      background: var(--Weiss);
      color: var(--Anthrazit); }
  .btn.dark-border, .nav a {
    background: transparent;
    color: var(--Anthrazit);
    border: 1.5px solid var(--Anthrazit); }
    .btn.dark-border:hover, .nav a:hover {
      background: var(--Anthrazit);
      color: var(--Weiss); }
  .btn.blue, .nav a.blue, .nav .contact a {
    background: var(--Hellblau);
    color: var(--Anthrazit);
    border: 1.5px solid var(--Hellblau); }
    .btn.blue:hover, .nav a.blue:hover, .nav .contact a:hover {
      background: var(--Anthrazit);
      border: 1.5px solid var(--Anthrazit);
      color: var(--Weiss); }

.buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 30px; }

.contact-wrapper {
  padding-top: 100px;
  padding-bottom: 80px; }
  @media (min-width: 370px) {
    .contact-wrapper {
      padding-top: 120px; } }
  @media (min-width: 1024px) {
    .contact-wrapper {
      padding-top: 140px;
      padding-bottom: 120px; } }
  @media (min-width: 1024px) and (min-height: 880px) {
    .contact-wrapper {
      padding-top: 200px;
      padding-bottom: 160px; } }
  @media (min-width: 1024px) {
    .contact-wrapper__inner {
      display: flex;
      justify-content: space-between;
      gap: 20px; } }
  @media (min-width: 1024px) {
    .contact-wrapper .contact-title {
      margin-bottom: 50px !important; } }

.contact-row {
  display: flex;
  flex-wrap: wrap;
  gap: 11px; }

.cw-info {
  max-width: 678px;
  width: 100%;
  display: flex;
  flex-direction: column; }
  @media (max-width: 1023px) {
    .cw-info {
      margin-bottom: 50px;
      gap: 50px; } }
  @media (min-width: 1024px) {
    .cw-info {
      justify-content: space-between;
      padding-bottom: 65px; } }
  @media (min-width: 1024px) {
    .cw-info__bottom .btn, .cw-info__bottom .nav a, .nav .cw-info__bottom a {
      margin-top: 15px; } }

.form {
  max-width: 678px;
  width: 100%; }

.error-404 {
  padding-block: 100px;
  min-height: 100vh;
  background: url(../images/background/hp-1.svg) no-repeat left top 180px;
  background-size: 100vw auto; }
  @media (min-width: 1024px) {
    .error-404 {
      padding-block: 200px;
      display: flex;
      justify-content: center;
      align-items: center; } }
  .error-404 h1 {
    margin-bottom: 25px; }
  .error-404 h2 {
    margin-bottom: 50px; }
    @media (min-width: 1024px) {
      .error-404 h2 {
        margin-bottom: 70px; } }

.feedback-bar {
  padding-block: 50px;
  background: var(--Anthrazit);
  color: var(--Weiss);
  font-size: 1.9rem;
  line-height: 120%;
  position: relative;
  z-index: 10; }
  @media (min-width: 360px) {
    .feedback-bar {
      padding-inline: 60px; } }
  @media (min-width: 1024px) {
    .feedback-bar {
      padding-block: 100px;
      font-size: 2.8rem; } }
  @media (min-width: 1440px) {
    .feedback-bar {
      font-size: 3.5rem; } }

.footer-contact {
  background: var(--Hellblau);
  position: relative;
  z-index: 10; }
  @media (min-width: 1024px) {
    .footer-contact {
      display: flex;
      font-size: 1.8rem;
      line-height: 140%; } }
  @media (min-width: 1024px) {
    .footer-contact.reversed .map {
      order: 2; }
    .footer-contact.reversed .footer-contact__info {
      order: 1; } }
  .footer-contact .map {
    position: relative; }
    @media (min-width: 1024px) {
      .footer-contact .map {
        width: 50%;
        max-height: 580px; }
        .footer-contact .map img {
          width: 100%;
          height: 100%;
          -o-object-fit: cover;
             object-fit: cover;
          display: block; } }
    .footer-contact .map__copyright {
      position: absolute;
      bottom: 0;
      right: 0;
      font-size: 1rem;
      padding: 0 7px;
      background: rgba(255, 255, 255, 0.3); }
  @media (max-width: 1023px) {
    .footer-contact__info {
      display: flex;
      justify-content: center;
      padding-block: 70px; } }
  @media (min-width: 1024px) {
    .footer-contact__info {
      padding: 130px 0 130px 126px;
      flex: 1 1 0; } }
  .footer-contact__info-inner {
    display: flex; }
    @media (max-width: 600px) {
      .footer-contact__info-inner {
        flex-direction: column;
        gap: 40px; } }
    @media (min-width: 601px) and (max-width: 1023px) {
      .footer-contact__info-inner {
        width: 100%;
        justify-content: space-evenly; } }
    @media (min-width: 1024px) {
      .footer-contact__info-inner {
        justify-content: space-between;
        max-width: 600px;
        padding-right: 45px; } }
  .footer-contact .opening-hours {
    display: flex;
    flex-direction: column;
    gap: 6px; }
    @media (min-width: 1024px) {
      .footer-contact .opening-hours {
        gap: 15px; } }
  .footer-contact .contact__inner {
    display: flex;
    flex-direction: column;
    gap: 10px; }
    .footer-contact .contact__inner a {
      text-underline-offset: 3px;
      text-decoration-thickness: 1px; }
  .footer-contact address {
    font-style: normal;
    line-height: 140%;
    margin-bottom: 10px; }

footer.footer {
  padding-top: 30px;
  position: relative;
  z-index: 10; }

.legal {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 20px;
  margin-bottom: 17px;
  padding-inline: 16px;
  font-size: 1rem;
  gap: 20px; }
  @media (min-width: 1024px) {
    .legal {
      padding: 0px 40px 0 40px;
      justify-content: flex-end;
      font-size: 1.2rem; } }
  .legal__left {
    display: flex;
    gap: 20px; }
    .legal__left a {
      text-decoration: none; }
    @media (max-width: 1023px) {
      .legal__left {
        display: flex;
        flex-direction: column;
        gap: 5px; } }

.form {
  width: 100%;
  position: relative; }
  @media (min-width: 1024px) {
    .form .fields-row {
      display: flex;
      gap: 20px; } }
  @media (min-width: 1024px) {
    .form .fields-row .field {
      flex: 1 1 0; } }
  .form .required {
    font-size: 1.2rem;
    margin-top: -5px;
    margin-bottom: 20px; }

.field {
  width: 100%;
  margin-bottom: 15px;
  display: block; }
  .field__label {
    margin-bottom: 5px; }
  .field .wpcf7-not-valid-tip {
    font-size: 1.4rem;
    margin-top: 5px; }

.input, .textarea {
  width: 100%;
  border: 0;
  background: var(--Himmelblau);
  border-radius: 5px; }

.input {
  height: 35px; }

.textarea {
  height: 150px; }

.checkbox-wrapper {
  position: relative !important;
  display: block;
  cursor: pointer;
  line-height: 135%;
  z-index: 5;
  margin-bottom: 25px; }
  @media (min-width: 1024px) {
    .checkbox-wrapper {
      margin-bottom: 50px; } }
  .checkbox-wrapper .wpcf7-list-item {
    margin-left: 0; }
  .checkbox-wrapper input[type="checkbox"], .checkbox-wrapper input[type="radio"] {
    opacity: 0;
    position: absolute;
    left: 0; }
  .checkbox-wrapper input[type="checkbox"] + span, .checkbox-wrapper input[type="radio"] + span {
    position: relative;
    display: inline-block;
    font-size: 1.8rem;
    cursor: pointer;
    padding-left: 30px;
    line-height: 130%;
    z-index: 5; }
    .checkbox-wrapper input[type="checkbox"] + span a, .checkbox-wrapper input[type="radio"] + span a {
      text-decoration: underline; }
      .checkbox-wrapper input[type="checkbox"] + span a:hover, .checkbox-wrapper input[type="radio"] + span a:hover {
        text-decoration: none; }
    .checkbox-wrapper input[type="checkbox"] + span::before, .checkbox-wrapper input[type="radio"] + span::before {
      content: "";
      display: block;
      width: 18px;
      height: 18px;
      border: 1.5px solid var(--Anthrazit);
      position: absolute;
      left: 0;
      top: 3px; }
    .checkbox-wrapper input[type="checkbox"] + span::after, .checkbox-wrapper input[type="radio"] + span::after {
      content: "";
      display: block;
      width: 10px;
      height: 10px;
      position: absolute;
      left: 4px;
      top: 7px;
      opacity: 0;
      transition: opacity .3s;
      background: var(--Anthrazit); }
  .checkbox-wrapper input[type="checkbox"]:checked + span::after, .checkbox-wrapper input[type="radio"]:checked + span::after {
    opacity: 1; }

.wpcf7 form .wpcf7-response-output {
  margin: 25px 0 0 0; }
  @media (min-width: 1024px) {
    .wpcf7 form .wpcf7-response-output {
      position: absolute;
      top: 100%;
      left: 0;
      right: 0; } }

.header, .footer {
  padding: 20px 16px 0 16px;
  display: flex;
  justify-content: space-between;
  align-items: center; }
  @media (min-width: 1024px) {
    .header, .footer {
      padding: 20px 40px 0 40px; } }
  @media (min-width: 1400px) {
    .header, .footer {
      padding: 40px 40px 0 40px; } }
  .header__logo, .footer__logo {
    max-width: 50%; }
  @media (max-width: 1023px) {
    .header .nav, .footer .nav {
      display: none; } }
  .header .mobile-nav-opener, .footer .mobile-nav-opener {
    padding-top: 8px;
    padding-bottom: 6px;
    margin-top: 2px; }
    @media (min-width: 1024px) {
      .header .mobile-nav-opener, .footer .mobile-nav-opener {
        display: none; } }

.header {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 99; }

.hp-bg-1 {
  position: relative;
  overflow: hidden; }
  .hp-bg-1::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 100dvh;
    background-size: cover;
    background: no-repeat; }
    @media (max-width: 1023px) {
      .hp-bg-1::before {
        background-image: url(../images/intro-mobile.jpg);
        background-position: right -60px top 50px;
        background-size: auto 100%; } }
    @media (min-width: 1024px) {
      .hp-bg-1::before {
        background-image: url(../images/intro.jpg);
        background-position: center right; } }
  .hp-bg-1::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0; }
    @media (max-width: 1023px) {
      .hp-bg-1::after {
        background: url(../images/background/hp-mobile-1.svg) no-repeat left -40dvw top calc(100dvh - 300px); } }
    @media (min-width: 380px) and (max-width: 1023px) {
      .hp-bg-1::after {
        background-size: 270dvw auto; } }
    @media (min-width: 1024px) {
      .hp-bg-1::after {
        background: url(../images/background/hp-1.svg) no-repeat left top 180px;
        background-size: 100vw auto; } }

@media (min-width: 1024px) {
  .hp-bg-2 {
    background: url(../images/background/hp-2.svg) no-repeat top -40px right -300px;
    background-size: calc(100vw + 300px) auto; } }

@media (max-width: 1023px) {
  .hp-mobile-bg-2 {
    background: url(../images/background/hp-mobile-2.svg) no-repeat top -80px left -100px; } }

@media (min-width: 380px) and (max-width: 1023px) {
  .hp-mobile-bg-2 {
    background-size: 270dvw auto; } }

@media (max-width: 1023px) {
  .hp-mobile-bg-3 {
    background: url(../images/background/hp-mobile-3.svg) no-repeat top 100px left -300px;
    background-size: auto 100%; } }

.badge {
  background: var(--Himmelblau);
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  gap: 20px;
  transform: rotate(-15deg);
  position: absolute;
  bottom: 170px;
  right: 10px;
  width: 200px;
  height: 200px; }
  @media (min-width: 1024px) {
    .badge {
      width: 350px;
      height: 350px;
      gap: 30px;
      bottom: 40px;
      right: 40px; } }
  .badge__text {
    line-height: 100%;
    font-size: 2.4rem;
    font-weight: 600; }
    @media (min-width: 1024px) {
      .badge__text {
        font-size: 4.6rem; } }
  .badge__cta {
    line-height: 108%;
    letter-spacing: 0.8px;
    text-transform: uppercase;
    text-decoration: none;
    border: 1px solid var(--Anthrazit);
    border-radius: 10px;
    padding: 14px 19px;
    transition: color 0.2s, background 0.2s; }
    @media (max-width: 1023px) {
      .badge__cta {
        font-size: 1.2rem; } }
    .badge__cta:hover {
      background: var(--Anthrazit);
      color: var(--Himmelblau); }

.hp-philosophy {
  padding-top: 75px; }
  @media (min-width: 1024px) {
    .hp-philosophy {
      padding-top: 150px; } }
  @media (min-width: 1450px) {
    .hp-philosophy {
      padding-top: 300px; } }

.hp-numbers {
  padding-top: 80px;
  padding-bottom: 100px; }
  @media (min-width: 1024px) {
    .hp-numbers {
      padding-block: 150px; } }
  @media (min-width: 1450px) {
    .hp-numbers {
      padding-top: 265px;
      padding-bottom: 200px; } }
  .hp-numbers__inner {
    display: flex; }
    @media (max-width: 1023px) {
      .hp-numbers__inner {
        flex-direction: column;
        gap: 80px; } }
    @media (min-width: 1024px) {
      .hp-numbers__inner {
        gap: 40px; } }
    @media (min-width: 1440px) {
      .hp-numbers__inner {
        gap: 130px; } }

@media (min-width: 1024px) {
  .hp-number-item {
    align-items: center;
    gap: 30px;
    margin-bottom: 0; } }

.hp-number-item__number {
  -webkit-text-stroke-width: 2px;
  -webkit-text-stroke-color: var(--Anthrazit);
  color: transparent;
  font-size: 15rem;
  line-height: 100%; }
  @media (max-width: 1023px) {
    .hp-number-item__number {
      margin-bottom: 20px; } }
  @media (min-width: 1024px) {
    .hp-number-item__number {
      -webkit-text-stroke-width: 4px;
      font-size: 20rem; } }
  @media (min-width: 1500px) {
    .hp-number-item__number {
      font-size: 30rem; } }

.hp-number-item__title {
  margin-bottom: 20px; }

@media (min-width: 1024px) {
  .hp-number-item__text {
    font-size: 2rem;
    line-height: 130%; } }

@media (max-width: 1023px) {
  .hp-team {
    padding-top: 50px;
    padding-bottom: 100px; } }

@media (min-width: 1024px) {
  .hp-team {
    padding-top: 100px;
    padding-bottom: 200px; } }

@media (max-width: 1023px) {
  .hp-services {
    padding-top: 100px; } }

@media (min-width: 1024px) {
  .hp-services {
    padding-top: 267px; } }

@media (min-width: 1024px) {
  .image-text {
    display: flex;
    gap: 70px; } }

@media (min-width: 1440px) {
  .image-text {
    gap: 140px; } }

.image-text__image img {
  display: block; }

@media (max-width: 780px) {
  .image-text__image {
    margin-left: -16px;
    margin-right: -16px;
    margin-bottom: 50px; } }

@media (min-width: 1024px) {
  .image-text__image {
    width: 49%; } }

.image-text__content {
  flex: 1 1 0;
  max-width: 678px; }

.info-bar {
  background: var(--Hellblau);
  position: absolute;
  left: 0;
  right: 0;
  z-index: 9;
  display: flex;
  justify-content: space-between; }
  .info-bar.fixed {
    position: fixed;
    top: 0; }
  @media (max-width: 1023px) {
    .info-bar {
      padding: 16px 10px;
      font-size: 1.1rem;
      top: calc(100dvh - 46px); } }
  @media (min-width: 1024px) {
    .info-bar {
      padding: 24px 30px;
      top: calc(100dvh - 68px); } }
  .info-bar a {
    text-underline-offset: 3px;
    text-decoration-thickness: 1px; }
  .info-bar__opening {
    display: flex;
    gap: 20px; }
    @media (max-width: 1023px) {
      .info-bar__opening {
        width: 100%; } }
  @media (max-width: 1023px) {
    .info-bar__opening-msg {
      display: none; } }
  .info-bar__hours {
    display: flex;
    gap: 10px; }
    @media (max-width: 1023px) {
      .info-bar__hours {
        width: 100%;
        justify-content: center; } }
    @media (min-width: 360px) {
      .info-bar__hours {
        gap: 15px; } }
    @media (min-width: 1024px) {
      .info-bar__hours {
        gap: 20px; } }
  @media (max-width: 1023px) {
    .info-bar__contact {
      display: none; } }
  @media (min-width: 1024px) {
    .info-bar__contact {
      display: flex;
      gap: 20px;
      text-transform: uppercase; } }
  .info-bar__contact .e-mail {
    letter-spacing: 0.8px; }

.intro {
  min-height: 100vh;
  padding-top: 200px;
  padding-bottom: 50px;
  display: flex;
  position: relative;
  z-index: 5; }
  @media (max-width: 1023px) {
    .intro {
      align-items: flex-end; } }
  @media (min-width: 1024px) {
    .intro {
      min-height: calc(100vh - 68px);
      align-items: center; } }
  @media (max-width: 1023px) {
    .intro--hp {
      padding-bottom: 30px; } }
  .intro--services {
    padding-top: 120px;
    padding-bottom: 80px; }

.mobile-overlay {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 99;
  background: var(--Himmelblau);
  display: flex;
  align-items: center;
  justify-content: center;
  transform: translateY(-100%);
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s, transform .3s; }
  .nav-opened .mobile-overlay {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0); }
  .mobile-overlay .mobile-nav-closer {
    position: absolute;
    top: 33px;
    right: 19px;
    border-radius: 6px;
    border: 0.9px solid var(--Anthrazit);
    width: 33px;
    height: 25px;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center; }

.nav {
  list-style-type: none;
  margin: 0;
  padding: 0;
  display: flex; }
  @media (max-width: 1023px) {
    .nav {
      flex-direction: column;
      gap: 16px;
      justify-content: center;
      align-items: center; } }
  @media (min-width: 1024px) {
    .nav {
      font-size: 1.8rem;
      gap: 11px; } }
  .nav li {
    margin: 0;
    padding: 0; }
  .nav a {
    text-decoration: none;
    background: transparent; }
    @media (max-width: 1023px) {
      .nav a {
        font-size: 1.4rem; } }
  @media (max-width: 1023px) {
    .nav .contact a {
      margin-top: 20px; } }

.nav-legal {
  list-style-type: none;
  margin: 0;
  padding: 0;
  display: flex;
  text-underline-offset: 3px; }
  @media (max-width: 1023px) {
    .nav-legal {
      flex-direction: column;
      text-align: right;
      gap: 5px; } }
  @media (min-width: 1024px) {
    .nav-legal {
      gap: 20px; } }
  .nav-legal a {
    text-decoration-thickness: 1px; }

@media (max-width: 1023px) {
  .oberdorf-bg-1 {
    background: url(../images/background/oberdorf.svg) no-repeat top 100px right 0px;
    background-size: cover; } }

@media (min-width: 1024px) {
  .oberdorf-bg-1 {
    background: url(../images/background/oberdorf.svg) no-repeat top 100px right -50px;
    background-size: cover; } }

.oberdorf-contact {
  background: var(--Hellblau);
  padding-block: 70px; }
  @media (min-width: 1024px) {
    .oberdorf-contact {
      padding-block: 130px; } }
  @media (min-width: 1024px) {
    .oberdorf-contact .inner {
      display: flex;
      gap: 120px;
      align-items: flex-start; } }
  .oberdorf-contact .map {
    position: relative; }
    @media (max-width: 1023px) {
      .oberdorf-contact .map {
        margin-bottom: 30px; } }
    @media (min-width: 1024px) {
      .oberdorf-contact .map {
        width: 50%;
        max-height: 790px; }
        .oberdorf-contact .map img {
          width: 100%;
          height: 100%;
          -o-object-fit: cover;
             object-fit: cover;
          display: block; } }
    .oberdorf-contact .map__copyright {
      position: absolute;
      bottom: 0;
      right: 0;
      font-size: 1rem;
      padding: 2px 7px;
      background: rgba(255, 255, 255, 0.3); }
  .oberdorf-contact .opening-hours {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-top: 10px; }
    @media (min-width: 1024px) {
      .oberdorf-contact .opening-hours {
        gap: 15px;
        margin-top: 50px; } }
  .oberdorf-contact .contact-details {
    font-size: 2rem; }
    @media (min-width: 480px) {
      .oberdorf-contact .contact-details {
        font-size: 2.4rem; } }
    @media (min-width: 1204px) {
      .oberdorf-contact .contact-details {
        font-size: 3rem;
        margin-bottom: 20px; } }
    @media (min-width: 1500px) {
      .oberdorf-contact .contact-details {
        font-size: 3.5rem; } }
    .oberdorf-contact .contact-details__inner {
      display: flex;
      flex-direction: column;
      gap: 5px; }
      .oberdorf-contact .contact-details__inner a {
        text-underline-offset: 3px;
        text-decoration-thickness: 1px; }
  .oberdorf-contact address {
    font-style: normal;
    line-height: 140%;
    margin-bottom: 10px; }
    @media (min-width: 1024px) {
      .oberdorf-contact address {
        margin-bottom: 50px; } }

@media (max-width: 1023px) {
  .philosophy-bg-1 {
    background: url(../images/background/philosophy-mobile-1.svg) no-repeat top -200px right -500px;
    background-size: cover; } }

@media (min-width: 1024px) {
  .philosophy-bg-1 {
    background: url(../images/background/philosophy-1.svg) no-repeat top right -300px;
    background-size: cover; } }

.practice {
  padding-block: 100px;
  overflow: hidden; }
  @media (min-width: 1024px) {
    .practice {
      padding-block: 200px; } }
  .practice .header-2, .practice .text h2, .text .practice h2 {
    max-width: 605px; }

.practice-info {
  max-width: 678px; }
  @media (min-width: 1024px) {
    .practice-info {
      width: 60%; } }

.gallery {
  position: relative;
  margin-top: 30px;
  margin-bottom: 20px; }
  @media (min-width: 1024px) {
    .gallery {
      margin-top: 100px;
      padding-bottom: 100px; } }
  .gallery img {
    display: block;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover; }
  @media (max-width: 1023px) {
    .gallery .image--1 {
      aspect-ratio: 789 / 527;
      width: 48%;
      margin-left: auto;
      position: relative;
      z-index: 4;
      border: 5px solid #fff; }
    .gallery .image--2 {
      aspect-ratio: 1025 / 882;
      width: 60%;
      margin-top: -80px;
      position: relative;
      z-index: 5; }
    .gallery .image--3 {
      aspect-ratio: 1 / 1;
      width: 40%;
      position: absolute;
      bottom: -30px;
      right: 0;
      border: 5px solid #fff; }
      .gallery .image--3 img {
        -o-object-position: top center;
           object-position: top center; } }
  @media (min-width: 1024px) {
    .gallery .image--1 {
      aspect-ratio: 789 / 527;
      width: 45%;
      position: absolute;
      right: -20px;
      bottom: 100%;
      transform: translateY(200px); }
    .gallery .image--2 {
      aspect-ratio: 1025 / 682;
      width: 62%; }
    .gallery .image--3 {
      aspect-ratio: 440 / 660;
      width: 30%;
      position: absolute;
      left: calc(62% + 25px);
      top: 225px; } }

.services {
  display: flex;
  box-shadow: 0px 0px 80px 0px #e4fcff;
  gap: 5px;
  flex: 1 1 0;
  flex-wrap: wrap;
  background: rgba(229, 252, 255, 0.3);
  margin-top: 30px; }
  @media (min-width: 1024px) {
    .services {
      gap: 10px; } }
  @media (min-width: 1400px) {
    .services {
      margin-top: 60px; } }

.service {
  padding: 4px 6px;
  font-size: 1.4rem;
  border-radius: 5px;
  background: var(--Weiss); }
  @media (min-width: 1024px) {
    .service {
      font-size: 1.8rem;
      padding: 8px 12px; } }
  @media (min-width: 1400px) {
    .service {
      font-size: 3.5rem; } }
  @media (max-height: 799px) and (min-width: 1024px) {
    .service {
      font-size: 2.5rem; } }

.service-bg-1 {
  overflow: hidden;
  background: url(../images/background/services-1.svg) no-repeat left -200px center; }

.service-infos {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: 5px;
  padding-block: 75px; }
  @media (min-width: 480px) {
    .service-infos {
      grid-template-columns: repeat(2, minmax(0, 1fr)); } }
  @media (min-width: 1024px) {
    .service-infos {
      grid-template-columns: repeat(4, minmax(0, 1fr));
      grid-gap: 10px;
      padding-block: 150px; } }

.service-info {
  background: var(--Anthrazit);
  padding: 15px;
  border-radius: 10px;
  color: var(--Weiss);
  line-height: 130%; }
  .service-info em {
    color: var(--Hellblau);
    font-style: normal;
    font-weight: 600; }
  @media (min-width: 1024px) {
    .service-info {
      padding: 30px;
      border-radius: 20px;
      font-size: 2rem; }
      .service-info em {
        font-size: 1.8rem; } }

.service-numbers {
  background: var(--Anthrazit);
  padding-top: 80px;
  padding-bottom: 100px;
  color: var(--Weiss); }
  @media (min-width: 1024px) {
    .service-numbers {
      padding-block: 115px; } }
  .service-numbers__inner {
    display: flex; }
    @media (max-width: 1023px) {
      .service-numbers__inner {
        flex-direction: column;
        gap: 80px; } }

@media (min-width: 1024px) {
  .number-item {
    width: 50%;
    padding-right: 40px;
    display: flex;
    align-items: center;
    gap: 30px;
    margin-bottom: 0; } }

@media (min-width: 1440px) {
  .number-item {
    padding-right: 120px; } }

.number-item__number {
  -webkit-text-stroke-width: 2px;
  -webkit-text-stroke-color: var(--Hellblau);
  color: transparent;
  font-size: 15rem;
  line-height: 100%; }
  @media (max-width: 1023px) {
    .number-item__number {
      margin-bottom: 20px; } }
  @media (min-width: 1024px) {
    .number-item__number {
      -webkit-text-stroke-width: 4px;
      font-size: 30rem; } }

.number-item__title {
  margin-bottom: 20px; }

@media (min-width: 1024px) {
  .number-item__text {
    font-size: 2rem;
    line-height: 130%; } }

.certificate {
  padding-block: 75px;
  background: var(--Himmelblau); }
  @media (min-width: 1024px) {
    .certificate {
      padding-block: 150px; } }

@media (min-width: 1024px) {
  .cert-wrapper {
    width: 56%;
    min-width: 750px; } }

.certs {
  display: flex;
  gap: 10px;
  flex-wrap: wrap; }
  @media (min-width: 1024px) {
    .certs {
      gap: 70px;
      margin-top: 40px; } }

.cert-image {
  max-width: calc(33% - 20px);
  display: block; }
  @media (min-width: 1024px) {
    .cert-image {
      max-width: calc(33% - 80px); } }

.sustainability {
  padding-block: 75px; }
  @media (min-width: 1024px) {
    .sustainability {
      padding-block: 150px; } }

/**
 * Swiper 11.1.4
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * https://swiperjs.com
 *
 * Copyright 2014-2024 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: May 30, 2024
 */
@font-face {
  font-family: swiper-icons;
  src: url("data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA");
  font-weight: 400;
  font-style: normal; }

:root {
  --swiper-theme-color: #007aff
; }

:host {
  position: relative;
  display: block;
  margin-left: auto;
  margin-right: auto;
  z-index: 1; }

.swiper {
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  z-index: 1;
  display: block; }

.swiper-vertical > .swiper-wrapper {
  flex-direction: column; }

.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
  box-sizing: content-box; }

.swiper-android .swiper-slide, .swiper-ios .swiper-slide, .swiper-wrapper {
  transform: translate3d(0px, 0, 0); }

.swiper-horizontal {
  touch-action: pan-y; }

.swiper-vertical {
  touch-action: pan-x; }

.swiper-slide {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  transition-property: transform;
  display: block; }

.swiper-slide-invisible-blank {
  visibility: hidden; }

.swiper-autoheight, .swiper-autoheight .swiper-slide {
  height: auto; }

.swiper-autoheight .swiper-wrapper {
  align-items: flex-start;
  transition-property: transform, height; }

.swiper-backface-hidden .swiper-slide {
  transform: translateZ(0);
  backface-visibility: hidden; }

.swiper-3d.swiper-css-mode .swiper-wrapper {
  perspective: 1200px; }

.swiper-3d .swiper-wrapper {
  transform-style: preserve-3d; }

.swiper-3d {
  perspective: 1200px; }

.swiper-3d .swiper-cube-shadow, .swiper-3d .swiper-slide {
  transform-style: preserve-3d; }

.swiper-css-mode > .swiper-wrapper {
  overflow: auto;
  scrollbar-width: none;
  -ms-overflow-style: none; }

.swiper-css-mode > .swiper-wrapper::-webkit-scrollbar {
  display: none; }

.swiper-css-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: start start; }

.swiper-css-mode.swiper-horizontal > .swiper-wrapper {
  scroll-snap-type: x mandatory; }

.swiper-css-mode.swiper-vertical > .swiper-wrapper {
  scroll-snap-type: y mandatory; }

.swiper-css-mode.swiper-free-mode > .swiper-wrapper {
  scroll-snap-type: none; }

.swiper-css-mode.swiper-free-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: none; }

.swiper-css-mode.swiper-centered > .swiper-wrapper::before {
  content: '';
  flex-shrink: 0;
  order: 9999; }

.swiper-css-mode.swiper-centered > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: center center;
  scroll-snap-stop: always; }

.swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child {
  margin-inline-start: var(--swiper-centered-offset-before); }

.swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper::before {
  height: 100%;
  min-height: 1px;
  width: var(--swiper-centered-offset-after); }

.swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child {
  margin-block-start: var(--swiper-centered-offset-before); }

.swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper::before {
  width: 100%;
  min-width: 1px;
  height: var(--swiper-centered-offset-after); }

.swiper-3d .swiper-slide-shadow, .swiper-3d .swiper-slide-shadow-bottom, .swiper-3d .swiper-slide-shadow-left, .swiper-3d .swiper-slide-shadow-right, .swiper-3d .swiper-slide-shadow-top {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 10; }

.swiper-3d .swiper-slide-shadow {
  background: rgba(0, 0, 0, 0.15); }

.swiper-3d .swiper-slide-shadow-left {
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0)); }

.swiper-3d .swiper-slide-shadow-right {
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0)); }

.swiper-3d .swiper-slide-shadow-top {
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0)); }

.swiper-3d .swiper-slide-shadow-bottom {
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0)); }

.swiper-lazy-preloader {
  width: 42px;
  height: 42px;
  position: absolute;
  left: 50%;
  top: 50%;
  margin-left: -21px;
  margin-top: -21px;
  z-index: 10;
  transform-origin: 50%;
  box-sizing: border-box;
  border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
  border-radius: 50%;
  border-top-color: transparent; }

.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader, .swiper:not(.swiper-watch-progress) .swiper-lazy-preloader {
  animation: swiper-preloader-spin 1s infinite linear; }

.swiper-lazy-preloader-white {
  --swiper-preloader-color: #fff
; }

.swiper-lazy-preloader-black {
  --swiper-preloader-color: #000
; }

@keyframes swiper-preloader-spin {
  0% {
    transform: rotate(0deg); }
  100% {
    transform: rotate(360deg); } }

.swiper-virtual .swiper-slide {
  -webkit-backface-visibility: hidden;
  transform: translateZ(0); }

.swiper-virtual.swiper-css-mode .swiper-wrapper::after {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none; }

.swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper::after {
  height: 1px;
  width: var(--swiper-virtual-size); }

.swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper::after {
  width: 1px;
  height: var(--swiper-virtual-size); }

:root {
  --swiper-navigation-size: 44px
; }

.swiper-button-next, .swiper-button-prev {
  position: absolute;
  top: var(--swiper-navigation-top-offset, 50%);
  width: calc(var(--swiper-navigation-size) / 44 * 27);
  height: var(--swiper-navigation-size);
  margin-top: calc(0px - (var(--swiper-navigation-size) / 2));
  z-index: 10;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--swiper-navigation-color, var(--swiper-theme-color)); }

.swiper-button-next.swiper-button-disabled, .swiper-button-prev.swiper-button-disabled {
  opacity: .35;
  cursor: auto;
  pointer-events: none; }

.swiper-button-next.swiper-button-hidden, .swiper-button-prev.swiper-button-hidden {
  opacity: 0;
  cursor: auto;
  pointer-events: none; }

.swiper-navigation-disabled .swiper-button-next, .swiper-navigation-disabled .swiper-button-prev {
  display: none !important; }

.swiper-button-next svg, .swiper-button-prev svg {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  transform-origin: center; }

.swiper-rtl .swiper-button-next svg, .swiper-rtl .swiper-button-prev svg {
  transform: rotate(180deg); }

.swiper-button-prev, .swiper-rtl .swiper-button-next {
  left: var(--swiper-navigation-sides-offset, 10px);
  right: auto; }

.swiper-button-next, .swiper-rtl .swiper-button-prev {
  right: var(--swiper-navigation-sides-offset, 10px);
  left: auto; }

.swiper-button-lock {
  display: none; }

.swiper-button-next:after, .swiper-button-prev:after {
  font-family: swiper-icons;
  font-size: var(--swiper-navigation-size);
  text-transform: none !important;
  letter-spacing: 0;
  font-variant: initial;
  line-height: 1; }

.swiper-button-prev:after, .swiper-rtl .swiper-button-next:after {
  content: 'prev'; }

.swiper-button-next, .swiper-rtl .swiper-button-prev {
  right: var(--swiper-navigation-sides-offset, 10px);
  left: auto; }

.swiper-button-next:after, .swiper-rtl .swiper-button-prev:after {
  content: 'next'; }

.swiper-pagination {
  position: absolute;
  text-align: center;
  transition: .3s opacity;
  transform: translate3d(0, 0, 0);
  z-index: 10; }

.swiper-pagination.swiper-pagination-hidden {
  opacity: 0; }

.swiper-pagination-disabled > .swiper-pagination, .swiper-pagination.swiper-pagination-disabled {
  display: none !important; }

.swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
  bottom: var(--swiper-pagination-bottom, 8px);
  top: var(--swiper-pagination-top, auto);
  left: 0;
  width: 100%; }

.swiper-pagination-bullets-dynamic {
  overflow: hidden;
  font-size: 0; }

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transform: scale(0.33);
  position: relative; }

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
  transform: scale(1); }

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
  transform: scale(1); }

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
  transform: scale(0.66); }

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
  transform: scale(0.33); }

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
  transform: scale(0.66); }

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
  transform: scale(0.33); }

.swiper-pagination-bullet {
  width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
  height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
  display: inline-block;
  border-radius: var(--swiper-pagination-bullet-border-radius, 50%);
  background: var(--swiper-pagination-bullet-inactive-color, #000);
  opacity: var(--swiper-pagination-bullet-inactive-opacity, 0.2); }

button.swiper-pagination-bullet {
  border: none;
  margin: 0;
  padding: 0;
  box-shadow: none;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none; }

.swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer; }

.swiper-pagination-bullet:only-child {
  display: none !important; }

.swiper-pagination-bullet-active {
  opacity: var(--swiper-pagination-bullet-opacity, 1);
  background: var(--swiper-pagination-color, var(--swiper-theme-color)); }

.swiper-pagination-vertical.swiper-pagination-bullets, .swiper-vertical > .swiper-pagination-bullets {
  right: var(--swiper-pagination-right, 8px);
  left: var(--swiper-pagination-left, auto);
  top: 50%;
  transform: translate3d(0px, -50%, 0); }

.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet, .swiper-vertical > .swiper-pagination-bullets .swiper-pagination-bullet {
  margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0;
  display: block; }

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic, .swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  top: 50%;
  transform: translateY(-50%);
  width: 8px; }

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet, .swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  display: inline-block;
  transition: .2s transform, .2s top; }

.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px); }

.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic, .swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap; }

.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: .2s transform, .2s left; }

.swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: .2s transform, .2s right; }

.swiper-pagination-fraction {
  color: var(--swiper-pagination-fraction-color, inherit); }

.swiper-pagination-progressbar {
  background: var(--swiper-pagination-progressbar-bg-color, rgba(0, 0, 0, 0.25));
  position: absolute; }

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  transform: scale(0);
  transform-origin: left top; }

.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  transform-origin: right top; }

.swiper-horizontal > .swiper-pagination-progressbar, .swiper-pagination-progressbar.swiper-pagination-horizontal, .swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite, .swiper-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
  width: 100%;
  height: var(--swiper-pagination-progressbar-size, 4px);
  left: 0;
  top: 0; }

.swiper-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite, .swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite, .swiper-pagination-progressbar.swiper-pagination-vertical, .swiper-vertical > .swiper-pagination-progressbar {
  width: var(--swiper-pagination-progressbar-size, 4px);
  height: 100%;
  left: 0;
  top: 0; }

.swiper-pagination-lock {
  display: none; }

.swiper-scrollbar {
  border-radius: var(--swiper-scrollbar-border-radius, 10px);
  position: relative;
  touch-action: none;
  background: var(--swiper-scrollbar-bg-color, rgba(0, 0, 0, 0.1)); }

.swiper-scrollbar-disabled > .swiper-scrollbar, .swiper-scrollbar.swiper-scrollbar-disabled {
  display: none !important; }

.swiper-horizontal > .swiper-scrollbar, .swiper-scrollbar.swiper-scrollbar-horizontal {
  position: absolute;
  left: var(--swiper-scrollbar-sides-offset, 1%);
  bottom: var(--swiper-scrollbar-bottom, 4px);
  top: var(--swiper-scrollbar-top, auto);
  z-index: 50;
  height: var(--swiper-scrollbar-size, 4px);
  width: calc(100% - 2 * var(--swiper-scrollbar-sides-offset, 1%)); }

.swiper-scrollbar.swiper-scrollbar-vertical, .swiper-vertical > .swiper-scrollbar {
  position: absolute;
  left: var(--swiper-scrollbar-left, auto);
  right: var(--swiper-scrollbar-right, 4px);
  top: var(--swiper-scrollbar-sides-offset, 1%);
  z-index: 50;
  width: var(--swiper-scrollbar-size, 4px);
  height: calc(100% - 2 * var(--swiper-scrollbar-sides-offset, 1%)); }

.swiper-scrollbar-drag {
  height: 100%;
  width: 100%;
  position: relative;
  background: var(--swiper-scrollbar-drag-bg-color, rgba(0, 0, 0, 0.5));
  border-radius: var(--swiper-scrollbar-border-radius, 10px);
  left: 0;
  top: 0; }

.swiper-scrollbar-cursor-drag {
  cursor: move; }

.swiper-scrollbar-lock {
  display: none; }

.swiper-zoom-container {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center; }

.swiper-zoom-container > canvas, .swiper-zoom-container > img, .swiper-zoom-container > svg {
  max-width: 100%;
  max-height: 100%;
  -o-object-fit: contain;
     object-fit: contain; }

.swiper-slide-zoomed {
  cursor: move;
  touch-action: none; }

.swiper .swiper-notification {
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none;
  opacity: 0;
  z-index: -1000; }

.swiper-free-mode > .swiper-wrapper {
  transition-timing-function: ease-out;
  margin: 0 auto; }

.swiper-grid > .swiper-wrapper {
  flex-wrap: wrap; }

.swiper-grid-column > .swiper-wrapper {
  flex-wrap: wrap;
  flex-direction: column; }

.swiper-fade.swiper-free-mode .swiper-slide {
  transition-timing-function: ease-out; }

.swiper-fade .swiper-slide {
  pointer-events: none;
  transition-property: opacity; }

.swiper-fade .swiper-slide .swiper-slide {
  pointer-events: none; }

.swiper-fade .swiper-slide-active {
  pointer-events: auto; }

.swiper-fade .swiper-slide-active .swiper-slide-active {
  pointer-events: auto; }

.swiper-cube {
  overflow: visible; }

.swiper-cube .swiper-slide {
  pointer-events: none;
  backface-visibility: hidden;
  z-index: 1;
  visibility: hidden;
  transform-origin: 0 0;
  width: 100%;
  height: 100%; }

.swiper-cube .swiper-slide .swiper-slide {
  pointer-events: none; }

.swiper-cube.swiper-rtl .swiper-slide {
  transform-origin: 100% 0; }

.swiper-cube .swiper-slide-active, .swiper-cube .swiper-slide-active .swiper-slide-active {
  pointer-events: auto; }

.swiper-cube .swiper-slide-active, .swiper-cube .swiper-slide-next, .swiper-cube .swiper-slide-prev {
  pointer-events: auto;
  visibility: visible; }

.swiper-cube .swiper-cube-shadow {
  position: absolute;
  left: 0;
  bottom: 0px;
  width: 100%;
  height: 100%;
  opacity: .6;
  z-index: 0; }

.swiper-cube .swiper-cube-shadow:before {
  content: '';
  background: #000;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  filter: blur(50px); }

.swiper-cube .swiper-slide-next + .swiper-slide {
  pointer-events: auto;
  visibility: visible; }

.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-bottom, .swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-left, .swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-right, .swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-top {
  z-index: 0;
  backface-visibility: hidden; }

.swiper-flip {
  overflow: visible; }

.swiper-flip .swiper-slide {
  pointer-events: none;
  backface-visibility: hidden;
  z-index: 1; }

.swiper-flip .swiper-slide .swiper-slide {
  pointer-events: none; }

.swiper-flip .swiper-slide-active, .swiper-flip .swiper-slide-active .swiper-slide-active {
  pointer-events: auto; }

.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-bottom, .swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-left, .swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-right, .swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-top {
  z-index: 0;
  backface-visibility: hidden; }

.swiper-creative .swiper-slide {
  backface-visibility: hidden;
  overflow: hidden;
  transition-property: transform, opacity, height; }

.swiper-cards {
  overflow: visible; }

.swiper-cards .swiper-slide {
  transform-origin: center bottom;
  backface-visibility: hidden;
  overflow: hidden; }

@media (max-width: 1023px) {
  .team-bg-1 {
    background: url(../images/background/team-mobile-1.svg) no-repeat bottom -300px right -800px;
    background-size: cover; } }

@media (min-width: 1024px) {
  .team-bg-1 {
    background: url(../images/background/team-1.svg) no-repeat bottom -1100px right -800px; } }

.team {
  padding-block: 100px; }
  @media (min-width: 1024px) {
    .team {
      padding-block: 200px; } }

.team-list {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: 20px; }
  @media (min-width: 640px) {
    .team-list {
      grid-template-columns: repeat(2, minmax(0, 1fr)); } }
  @media (min-width: 1024px) {
    .team-list {
      grid-gap: 40px; } }
  @media (min-width: 1200px) {
    .team-list {
      grid-gap: 50px; } }
  @media (min-width: 1600px) {
    .team-list {
      grid-gap: 80px; } }

.person {
  background: var(--Himmelblau); }
  .person__photos {
    display: flex; }
  .person__photo {
    aspect-ratio: 1 / 1;
    overflow: hidden;
    flex: 1 1 0;
    width: 50%; }
    .person__photo img {
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
         object-fit: cover; }
  .person__info {
    padding: 15px; }
    @media (min-width: 1024px) {
      .person__info {
        padding: 30px 20px;
        max-width: 75%; } }
  .person__role {
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    margin-bottom: 15px; }
  .person__name {
    font-size: 2rem;
    font-weight: 600;
    line-height: 130%;
    margin-bottom: 10px; }
  .person__description {
    font-size: 1.5rem;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden; }

.testimonials {
  padding-block: 125px;
  position: relative; }
  .testimonials .swiper {
    margin-left: 120px;
    margin-right: 120px; }
  @media (min-width: 1024px) {
    .testimonials {
      padding-block: 150px; } }
  @media (min-width: 1024px) {
    .testimonials--hp {
      padding-top: 300px;
      padding-bottom: 300px; } }
  @media (max-width: 1023px) {
    .testimonials .swiper {
      padding-bottom: 100px; } }
  .testimonials .prev-slide, .testimonials .next-slide {
    position: absolute;
    z-index: 5; }
    @media (min-width: 1024px) {
      .testimonials .prev-slide, .testimonials .next-slide {
        top: 50%;
        transform: translateY(-80%);
        width: 58px; } }
    @media (max-width: 1023px) {
      .testimonials .prev-slide, .testimonials .next-slide {
        bottom: 0;
        width: 30px; } }
  @media (max-width: 1023px) {
    .testimonials .prev-slide {
      left: calc(50% - 40px); } }
  @media (min-width: 1024px) {
    .testimonials .prev-slide {
      left: 140px; } }
  @media (max-width: 1023px) {
    .testimonials .next-slide {
      right: calc(50% - 40px); } }
  @media (min-width: 1024px) {
    .testimonials .next-slide {
      right: 140px; } }
  .testimonials.dark, .nav .current-menu-item a.testimonials {
    background: var(--Anthrazit);
    color: var(--Weiss); }

.testimonial-slide {
  max-width: 1140px;
  margin-inline: auto; }
  @media (max-width: 1023px) {
    .testimonial-slide .header-3, .testimonial-slide .contact-wrapper h2, .contact-wrapper .testimonial-slide h2, .testimonial-slide .image-text h2, .image-text .testimonial-slide h2, .testimonial-slide .text h3, .text .testimonial-slide h3 {
      margin-bottom: 20px; } }
  @media (min-width: 1024px) {
    .testimonial-slide .header-3, .testimonial-slide .contact-wrapper h2, .contact-wrapper .testimonial-slide h2, .testimonial-slide .image-text h2, .image-text .testimonial-slide h2, .testimonial-slide .text h3, .text .testimonial-slide h3 {
      margin-bottom: 30px; } }

.header-1, .text h1 {
  font-size: 4.5rem;
  line-height: 100%;
  font-weight: 400;
  margin-top: 0; }
  @media (min-width: 1024px) {
    .header-1, .text h1 {
      font-size: 10rem; } }
  @media (min-width: 1500px) {
    .header-1, .text h1 {
      font-size: 15rem; } }
  @media (max-height: 799px) and (min-width: 1024px) {
    .header-1, .text h1 {
      font-size: 10rem; } }
  @media (max-height: 600px) and (min-width: 1024px) {
    .header-1, .text h1 {
      font-size: 8rem; } }

.header-2, .text h2 {
  font-size: 2.4rem;
  line-height: 110%;
  font-weight: 400;
  margin-top: 0; }
  @media (min-width: 480px) {
    .header-2, .text h2 {
      font-size: 3rem; } }
  @media (min-width: 1024px) {
    .header-2, .text h2 {
      font-size: 6rem; } }
  @media (min-width: 1500px) {
    .header-2, .text h2 {
      font-size: 7.5rem; } }
  @media (max-height: 799px) and (min-width: 1024px) {
    .header-2, .text h2 {
      font-size: 5rem; } }
  @media (max-height: 600px) and (min-width: 1024px) {
    .header-2, .text h2 {
      font-size: 4.5rem; } }
  @media (max-height: 550px) and (min-width: 1024px) {
    .header-2, .text h2 {
      font-size: 3.5rem; } }

.header-3, .contact-wrapper h2, .image-text h2, .text h3 {
  font-size: 2rem;
  line-height: 120%;
  font-weight: 600;
  margin-top: 0;
  margin-bottom: 10px; }
  .header-3.no-bold, .contact-wrapper h2.no-bold, .image-text h2.no-bold, .text h3.no-bold {
    font-weight: 400; }
  @media (min-width: 480px) {
    .header-3, .contact-wrapper h2, .image-text h2, .text h3 {
      font-size: 2.4rem; } }
  @media (min-width: 1204px) {
    .header-3, .contact-wrapper h2, .image-text h2, .text h3 {
      font-size: 3rem;
      margin-bottom: 20px; } }
  @media (min-width: 1500px) {
    .header-3, .contact-wrapper h2, .image-text h2, .text h3 {
      font-size: 3.5rem; } }

.label {
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  line-height: 108%;
  margin-bottom: 20px; }
  @media (min-width: 1024px) {
    .label {
      font-size: 1.5rem;
      letter-spacing: 0.75px;
      margin-bottom: 30px; } }

.text p, .text ul, .text ol {
  line-height: 130%; }
  @media (min-width: 1024px) {
    .text p, .text ul, .text ol {
      font-size: 2rem; } }
  .text p strong, .text ul strong, .text ol strong {
    font-size: 1.4rem;
    font-weight: 600; }
    @media (min-width: 1024px) {
      .text p strong, .text ul strong, .text ol strong {
        font-size: 1.8rem; } }

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

@media (max-width: 1023px) {
  .text-block h2, .text-block h3 {
    font-size: 2rem; } }

@media (min-width: 1024px) {
  .text-block h2, .text-block h3 {
    font-size: 2.4rem; } }

.text-block p, .text-block ul, .text-block ol {
  line-height: 130%; }
  @media (min-width: 1024px) {
    .text-block p, .text-block ul, .text-block ol {
      font-size: 2rem; } }
  .text-block p strong, .text-block ul strong, .text-block ol strong {
    font-weight: 600; }

.values {
  padding-block: 100px;
  display: flex;
  flex-direction: column;
  gap: 50px; }
  @media (min-width: 1024px) {
    .values {
      padding-block: 200px;
      gap: 150px; } }

@media (min-width: 1024px) {
  .value {
    display: flex;
    align-items: center;
    gap: 70px; }
    .value:nth-child(odd) .value__image {
      order: 2; }
    .value:nth-child(odd) .value__content {
      order: 1; } }

@media (min-width: 1440px) {
  .value {
    gap: 100px; } }

@media (min-width: 1540px) {
  .value {
    gap: 140px; } }

.value__image img {
  display: block; }

@media (max-width: 780px) {
  .value__image {
    margin-left: -16px;
    margin-right: -16px;
    margin-bottom: 50px; } }

@media (min-width: 1024px) {
  .value__image {
    width: 49%; } }

.value__content {
  flex: 1 1 0;
  max-width: 678px; }
  @media (min-width: 480px) {
    .value__content {
      display: flex;
      gap: 20px; } }
  @media (min-width: 1024px) {
    .value__content {
      gap: 60px; } }

.value__number {
  -webkit-text-stroke-width: 2px;
  -webkit-text-stroke-color: var(--Anthrazit);
  color: transparent;
  font-size: 15rem;
  line-height: 100%; }
  @media (min-width: 1024px) {
    .value__number {
      font-size: 30rem; } }

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