/*!******************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js!./node_modules/postcss-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./src/scss/app.scss ***!
  \******************************************************************************************************************************************************/
/* Code functions */
/* Core variables */
/**
 * Variables
*/
/* Typography */
/* Breakpoints */
/* Paths */
/* Grid setup */
/* Colour palette */
:root {
  --black: #000;
  --white: #fff;
  --gray: #D1D3CA;
  --coral: #FF5959;
  --ocean: #002FA7;
  --moss: #B3FF60;
  --soft-black: #171717;
  --off-white: #F3F2EF;
  --shade-gray: #4C4C49;
  --ember: #510F1B;
  --midnight: #12121A;
  --forest: #0D241E;
  --black90: #111;
  --black85: #2a2a2a;
  --black80: #363636;
  --black70: #484848;
  --black60: #666;
  --black50: #888;
  --black40: #999;
  --black30: #B3B3B3;
  --black20: #ccc;
  --black15: #E6E6E6;
  --black10: #ececec;
  --black07: #EDEDED;
  --black05: #f2f2f2;
}

/* Components */
/* CSS Reset */
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  border: none;
  font: inherit;
  font-size: 100%;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
}

html {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

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

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section,
summary,
main {
  display: block;
}

audio,
canvas,
video {
  display: inline-block;
}

body {
  margin: 0;
}

ul {
  list-style-type: none;
}

a {
  background: transparent;
  text-decoration: none;
}

button,
input {
  line-height: normal;
}

input[type=search] {
  -webkit-appearance: textfield;
}

input[type=search]::-webkit-search-decoration,
input[type=search]::-webkit-search-cancel-button {
  -webkit-appearance: none;
}

button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

textarea {
  overflow: auto;
  vertical-align: top;
}

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

textarea:focus,
input:focus {
  outline: 0;
}

input {
  margin: 0;
  padding: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

/* CSS print */
/**
 * Print Stylesheet
*/
@media print {
  @page {
    margin: 1cm;
  }
  body {
    background: var(--white);
    color: var(--black);
  }
  a {
    page-break-inside: avoid;
  }
  blockquote {
    page-break-inside: avoid;
  }
  table,
  pre {
    page-break-inside: avoid;
  }
  ul, ol, dl {
    page-break-before: avoid;
  }
}
/* Fonts */
/**
 * Fonts
*/
@font-face {
  font-family: "Soehne";
  src: url(../fonts/soehne-leicht.7e18f0.woff2) format("woff2");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Soehne";
  src: url(../fonts/soehne-leicht-kursiv.484b91.woff2) format("woff2");
  font-weight: 300;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "Soehne";
  src: url(../fonts/soehne-buch.9d0b20.woff2) format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Soehne";
  src: url(../fonts/soehne-halbfett.a33f3f.woff2) format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "ValtechNeue";
  src: url(../fonts/FFF-ValtechNeue-Light.60b3ee.woff2) format("woff2"), url(../fonts/FFF-ValtechNeue-Light.af6cb0.woff) format("woff");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "ValtechNeue";
  src: url(../fonts/FFF-ValtechNeue-Book.5307a7.woff2) format("woff2"), url(../fonts/FFF-ValtechNeue-Book.f59a8d.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
/* Mixins, helpers and functions */
/**
 * Helper mixins
*/
/* Topography */
/* Vendor */
/* Base */
body {
  background-color: var(--off-white);
  color: var(--black);
  font-family: "ValtechNeue", sans-serif;
  font-weight: 300;
  color: var(--black);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  min-height: 100vh;
}
body ::-moz-selection {
  background: var(--ocean);
  color: var(--white);
  text-shadow: none;
}
body ::selection {
  background: var(--ocean);
  color: var(--white);
  text-shadow: none;
}
body main {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}

/* Common */
.main-container-layout {
  width: 100%;
  padding-right: 1.5rem;
  padding-left: 1.5rem;
}
@media all and (min-width: 120rem) {
  .main-container-layout {
    width: 84vw;
    margin-right: auto;
    margin-left: auto;
  }
}

.title-h2 {
  color: var(--black);
  font-family: "ValtechNeue", sans-serif;
  font-weight: 300;
  color: var(--black);
  font-size: 3rem;
  line-height: 120%;
  margin-bottom: 2rem;
}
@media all and (max-width: 58.749rem) {
  .title-h2 {
    margin-bottom: 1rem;
    margin-left: -0.5rem;
    font-size: 1.75rem;
    line-height: 150%;
  }
}

/* Components */
.navigation {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 4.75rem;
}
@media all and (max-width: 58.749rem) {
  .navigation {
    border-bottom: 0.0625rem solid var(--gray);
    margin-bottom: 0.6875rem;
    height: 4rem;
  }
}
.navigation_qr-code {
  width: 4rem;
  height: 4rem;
}
.navigation_qr-code img {
  width: 4rem;
  height: 4rem;
}
.navigation_logo {
  width: px2ren(158.457);
  height: 2.25rem;
  position: relative;
}
@media all and (max-width: 58.749rem) {
  .navigation_logo {
    width: px2ren(134.457);
    height: 2rem;
  }
}

.footer {
  background-color: var(--forest);
  height: 9.625rem;
  position: relative;
}
@media all and (max-width: 58.749rem) {
  .footer {
    height: 7rem;
  }
}
.footer .main-container-layout {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 100%;
}
@media all and (max-width: 58.749rem) {
  .footer .main-container-layout {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
.footer_id {
  color: var(--moss);
  font-size: 1.25rem;
  font-weight: 300;
  line-height: 290%;
}
@media all and (max-width: 58.749rem) {
  .footer_id {
    font-size: 1.25rem;
    line-height: normal;
  }
}
.footer_logo {
  width: px2ren(158.457);
  height: 2.25rem;
}
@media all and (max-width: 58.749rem) {
  .footer_logo {
    width: px2ren(134.457);
    height: 2rem;
  }
}
.footer_qr-code {
  width: 6.625rem;
  height: 6.625rem;
}
@media all and (max-width: 58.749rem) {
  .footer_qr-code {
    position: absolute;
    width: 4rem;
    height: 4rem;
    right: 1.5rem;
  }
}
.footer_qr-code img {
  width: 6.625rem;
  height: 6.625rem;
}
@media all and (max-width: 58.749rem) {
  .footer_qr-code img {
    width: 4rem;
    height: 4rem;
  }
}

.offerings {
  margin-bottom: 5rem;
}
@media all and (max-width: 58.749rem) {
  .offerings {
    margin-bottom: 2.5rem;
  }
}
.offerings .offerings-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  -webkit-column-gap: 3.0625rem;
     -moz-column-gap: 3.0625rem;
          column-gap: 3.0625rem;
  row-gap: 5.6875rem;
}
@media all and (max-width: 63.999rem) {
  .offerings .offerings-grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media all and (max-width: 58.749rem) {
  .offerings .offerings-grid {
    grid-template-columns: 1fr;
    row-gap: 2rem;
  }
}
.offerings_item {
  width: 100%;
  border-top: 0.0625rem solid var(--gray);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-top: 1.6875rem;
}
@media all and (max-width: 58.749rem) {
  .offerings_item {
    padding-top: 0rem;
    border-top: none;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
}
.offerings_item-icon {
  width: 6.875rem;
}
@media all and (max-width: 58.749rem) {
  .offerings_item-icon {
    width: auto;
    margin-bottom: 0.5rem;
  }
}
.offerings_item-icon span {
  margin-left: 0.5rem;
  display: block;
  width: 4rem;
  height: 4rem;
}
@media all and (max-width: 58.749rem) {
  .offerings_item-icon span {
    margin-left: 0;
    width: 5rem;
    height: 5rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
.offerings_item-text-block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.offerings_item-title {
  font-family: "ValtechNeue", sans-serif;
  font-weight: 300;
  color: var(--black);
  font-size: 1.5rem;
  line-height: normal;
  margin-bottom: 0.5rem;
}
@media all and (max-width: 58.749rem) {
  .offerings_item-title {
    font-size: 1.375rem;
    margin-bottom: 0.25rem;
  }
}
.offerings_item-link {
  font-family: "Soehne", sans-serif;
  font-weight: 300;
  color: var(--black);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  color: var(--ocean);
  font-size: 1rem;
  line-height: 120%;
}
.offerings_item-link::after {
  -webkit-transition: -webkit-transform 0.3s ease-in-out;
  transition: -webkit-transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
  -webkit-transform-origin: left center;
          transform-origin: left center;
  content: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyOSIgaGVpZ2h0PSI4IiB2aWV3Qm94PSIwIDAgMjkgOCIgZmlsbD0ibm9uZSI+CiAgPHBhdGggZmlsbC1ydWxlPSJldmVub2RkIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik0yNS44MzUzIDAuNjM5MjExTDI4Ljg2MDggMy42NjM5MkMyOS4wNDY0IDMuODQ5NTMgMjkuMDQ2NCA0LjE1MDQ3IDI4Ljg2MDggNC4zMzYwOEwyNS44MzUzIDcuMzYwNzlDMjUuNjQ5NiA3LjU0NjQxIDI1LjM0ODYgNy41NDY0MSAyNS4xNjI5IDcuMzYwNzlDMjQuOTc3MyA3LjE3NTE4IDI0Ljk3NzMgNi44NzQyNSAyNS4xNjI5IDYuNjg4NjRMMjcuMzc2OCA0LjQ3NTI5TC0zLjQ3NTMxZS0wNyA0LjQ3NTI5TC0yLjY0NDI5ZS0wNyAzLjUyNDcxTDI3LjM3NjggMy41MjQ3MUwyNS4xNjI5IDEuMzExMzdDMjQuOTc3MyAxLjEyNTc2IDI0Ljk3NzMgMC44MjQ4MjIgMjUuMTYyOSAwLjYzOTIxMUMyNS4zNDg2IDAuNDUzNTk5IDI1LjY0OTYgMC40NTM1OTkgMjUuODM1MyAwLjYzOTIxMVoiIGZpbGw9IiMwMDJGQTciLz4KPC9zdmc+);
  width: 1.90625rem;
  height: 0.46rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-left: 1rem;
  margin-top: -0.25rem;
}

.masthead {
  margin-bottom: 2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media all and (max-width: 58.749rem) {
  .masthead {
    margin-bottom: 2.5rem;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
  }
}
.masthead_content {
  width: calc(50% - 3.5625rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media all and (max-width: 58.749rem) {
  .masthead_content {
    width: calc(75% - 2.3125rem);
  }
}
.masthead_title {
  font-family: "ValtechNeue", sans-serif;
  font-weight: 300;
  color: var(--black);
  font-size: 5.5rem;
  line-height: 110%;
  letter-spacing: -0.88px;
  margin-bottom: 2rem;
}
@media all and (max-width: 58.749rem) {
  .masthead_title {
    font-size: 2rem;
    letter-spacing: normal;
    margin-bottom: 0.5rem;
  }
}
.masthead_subtitle {
  font-family: "Soehne", sans-serif;
  font-weight: 300;
  color: var(--black);
  font-size: 1.25rem;
  line-height: 140%;
  margin-bottom: 0;
}
@media all and (max-width: 58.749rem) {
  .masthead_subtitle {
    font-size: 1rem;
    line-height: 120%;
  }
}
.masthead_media {
  width: calc(50% - 3.5625rem);
}
@media all and (max-width: 58.749rem) {
  .masthead_media {
    width: calc(25% - 0.8125rem);
    margin-right: -1.5rem;
  }
}
.masthead_media img {
  width: 100%;
  height: calc(63vw - 2.52rem);
  -o-object-fit: cover;
     object-fit: cover;
  max-height: 54.5rem;
}
@media all and (max-width: 58.749rem) {
  .masthead_media img {
    height: 21.75rem;
    max-height: 21.75rem;
  }
}
.masthead a {
  text-decoration: none;
}

.partners {
  margin-bottom: 5rem;
}
@media all and (max-width: 58.749rem) {
  .partners {
    margin-bottom: 0.5rem;
  }
}
.partners-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  -webkit-column-gap: 4.375rem;
     -moz-column-gap: 4.375rem;
          column-gap: 4.375rem;
  row-gap: 2rem;
}
@media all and (max-width: 58.749rem) {
  .partners-grid {
    grid-template-columns: repeat(2, 1fr);
    -webkit-column-gap: 0;
       -moz-column-gap: 0;
            column-gap: 0;
    row-gap: 0;
  }
}
.partners-grid .partners-item {
  height: 12.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media all and (max-width: 58.749rem) {
  .partners-grid .partners-item {
    height: 5rem;
  }
}
.partners-grid .partners-item picture {
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.partners-grid .partners-item img {
  max-width: initial;
}

/* Browser specific styles */
/**
 * Dirty hacks, yes internet explorer, we are looking at you
*/
.exp-eva-icon {
  width: 3.6875rem;
  height: 3.5625rem;
}
@media all and (max-width: 58.749rem) {
  .exp-eva-icon {
    width: 5rem;
    height: 5rem;
  }
}

.ent-tra-icon {
  width: 3rem;
  height: 3.5625rem;
}
@media all and (max-width: 58.749rem) {
  .ent-tra-icon {
    width: 5rem;
    height: 5rem;
  }
}

.ent-tra-icon {
  width: 4rem;
  height: 4rem;
}
@media all and (max-width: 58.749rem) {
  .ent-tra-icon {
    width: 5rem;
    height: 5rem;
  }
}
